(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o> 6]; var primitive = (tag & 0x20) === 0; // Multi-octet tag - load if ((tag & 0x1f) === 0x1f) { var oct = tag; tag = 0; while ((oct & 0x80) === 0x80) { oct = buf.readUInt8(fail); if (buf.isError(oct)) return oct; tag <<= 7; tag |= oct & 0x7f; } } else { tag &= 0x1f; } var tagStr = der.tag[tag]; return { cls: cls, primitive: primitive, tag: tag, tagStr: tagStr }; } function derDecodeLen(buf, primitive, fail) { var len = buf.readUInt8(fail); if (buf.isError(len)) return len; // Indefinite form if (!primitive && len === 0x80) return null; // Definite form if ((len & 0x80) === 0) { // Short form return len; } // Long form var num = len & 0x7f; if (num >= 4) return buf.error('length octect is too long'); len = 0; for (var i = 0; i < num; i++) { len <<= 8; var j = buf.readUInt8(fail); if (buf.isError(j)) return j; len |= j; } return len; } },{"../../asn1":1,"inherits":167}],10:[function(require,module,exports){ var decoders = exports; decoders.der = require('./der'); decoders.pem = require('./pem'); },{"./der":9,"./pem":11}],11:[function(require,module,exports){ var inherits = require('inherits'); var Buffer = require('buffer').Buffer; var asn1 = require('../../asn1'); var DERDecoder = require('./der'); function PEMDecoder(entity) { DERDecoder.call(this, entity); this.enc = 'pem'; }; inherits(PEMDecoder, DERDecoder); module.exports = PEMDecoder; PEMDecoder.prototype.decode = function decode(data, options) { var lines = data.toString().split(/[\r\n]+/g); var label = options.label.toUpperCase(); var re = /^-----(BEGIN|END) ([^-]+)-----$/; var start = -1; var end = -1; for (var i = 0; i < lines.length; i++) { var match = lines[i].match(re); if (match === null) continue; if (match[2] !== label) continue; if (start === -1) { if (match[1] !== 'BEGIN') break; start = i; } else { if (match[1] !== 'END') break; end = i; break; } } if (start === -1 || end === -1) throw new Error('PEM section not found for: ' + label); var base64 = lines.slice(start + 1, end).join(''); // Remove excessive symbols base64.replace(/[^a-z0-9\+\/=]+/gi, ''); var input = new Buffer(base64, 'base64'); return DERDecoder.prototype.decode.call(this, input, options); }; },{"../../asn1":1,"./der":9,"buffer":61,"inherits":167}],12:[function(require,module,exports){ var inherits = require('inherits'); var Buffer = require('buffer').Buffer; var asn1 = require('../../asn1'); var base = asn1.base; var bignum = asn1.bignum; // Import DER constants var der = asn1.constants.der; function DEREncoder(entity) { this.enc = 'der'; this.name = entity.name; this.entity = entity; // Construct base tree this.tree = new DERNode(); this.tree._init(entity.body); }; module.exports = DEREncoder; DEREncoder.prototype.encode = function encode(data, reporter) { return this.tree._encode(data, reporter).join(); }; // Tree methods function DERNode(parent) { base.Node.call(this, 'der', parent); } inherits(DERNode, base.Node); DERNode.prototype._encodeComposite = function encodeComposite(tag, primitive, cls, content) { var encodedTag = encodeTag(tag, primitive, cls, this.reporter); // Short form if (content.length < 0x80) { var header = new Buffer(2); header[0] = encodedTag; header[1] = content.length; return this._createEncoderBuffer([ header, content ]); } // Long form // Count octets required to store length var lenOctets = 1; for (var i = content.length; i >= 0x100; i >>= 8) lenOctets++; var header = new Buffer(1 + 1 + lenOctets); header[0] = encodedTag; header[1] = 0x80 | lenOctets; for (var i = 1 + lenOctets, j = content.length; j > 0; i--, j >>= 8) header[i] = j & 0xff; return this._createEncoderBuffer([ header, content ]); }; DERNode.prototype._encodeStr = function encodeStr(str, tag) { if (tag === 'bitstr') { return this._createEncoderBuffer([ str.unused | 0, str.data ]); } else if (tag === 'bmpstr') { var buf = new Buffer(str.length * 2); for (var i = 0; i < str.length; i++) { buf.writeUInt16BE(str.charCodeAt(i), i * 2); } return this._createEncoderBuffer(buf); } else if (tag === 'numstr') { if (!this._isNumstr(str)) { return this.reporter.error('Encoding of string type: numstr supports ' + 'only digits and space'); } return this._createEncoderBuffer(str); } else if (tag === 'printstr') { if (!this._isPrintstr(str)) { return this.reporter.error('Encoding of string type: printstr supports ' + 'only latin upper and lower case letters, ' + 'digits, space, apostrophe, left and rigth ' + 'parenthesis, plus sign, comma, hyphen, ' + 'dot, slash, colon, equal sign, ' + 'question mark'); } return this._createEncoderBuffer(str); } else if (/str$/.test(tag)) { return this._createEncoderBuffer(str); } else { return this.reporter.error('Encoding of string type: ' + tag + ' unsupported'); } }; DERNode.prototype._encodeObjid = function encodeObjid(id, values, relative) { if (typeof id === 'string') { if (!values) return this.reporter.error('string objid given, but no values map found'); if (!values.hasOwnProperty(id)) return this.reporter.error('objid not found in values map'); id = values[id].split(/[\s\.]+/g); for (var i = 0; i < id.length; i++) id[i] |= 0; } else if (Array.isArray(id)) { id = id.slice(); for (var i = 0; i < id.length; i++) id[i] |= 0; } if (!Array.isArray(id)) { return this.reporter.error('objid() should be either array or string, ' + 'got: ' + JSON.stringify(id)); } if (!relative) { if (id[1] >= 40) return this.reporter.error('Second objid identifier OOB'); id.splice(0, 2, id[0] * 40 + id[1]); } // Count number of octets var size = 0; for (var i = 0; i < id.length; i++) { var ident = id[i]; for (size++; ident >= 0x80; ident >>= 7) size++; } var objid = new Buffer(size); var offset = objid.length - 1; for (var i = id.length - 1; i >= 0; i--) { var ident = id[i]; objid[offset--] = ident & 0x7f; while ((ident >>= 7) > 0) objid[offset--] = 0x80 | (ident & 0x7f); } return this._createEncoderBuffer(objid); }; function two(num) { if (num < 10) return '0' + num; else return num; } DERNode.prototype._encodeTime = function encodeTime(time, tag) { var str; var date = new Date(time); if (tag === 'gentime') { str = [ two(date.getFullYear()), two(date.getUTCMonth() + 1), two(date.getUTCDate()), two(date.getUTCHours()), two(date.getUTCMinutes()), two(date.getUTCSeconds()), 'Z' ].join(''); } else if (tag === 'utctime') { str = [ two(date.getFullYear() % 100), two(date.getUTCMonth() + 1), two(date.getUTCDate()), two(date.getUTCHours()), two(date.getUTCMinutes()), two(date.getUTCSeconds()), 'Z' ].join(''); } else { this.reporter.error('Encoding ' + tag + ' time is not supported yet'); } return this._encodeStr(str, 'octstr'); }; DERNode.prototype._encodeNull = function encodeNull() { return this._createEncoderBuffer(''); }; DERNode.prototype._encodeInt = function encodeInt(num, values) { if (typeof num === 'string') { if (!values) return this.reporter.error('String int or enum given, but no values map'); if (!values.hasOwnProperty(num)) { return this.reporter.error('Values map doesn\'t contain: ' + JSON.stringify(num)); } num = values[num]; } // Bignum, assume big endian if (typeof num !== 'number' && !Buffer.isBuffer(num)) { var numArray = num.toArray(); if (!num.sign && numArray[0] & 0x80) { numArray.unshift(0); } num = new Buffer(numArray); } if (Buffer.isBuffer(num)) { var size = num.length; if (num.length === 0) size++; var out = new Buffer(size); num.copy(out); if (num.length === 0) out[0] = 0 return this._createEncoderBuffer(out); } if (num < 0x80) return this._createEncoderBuffer(num); if (num < 0x100) return this._createEncoderBuffer([0, num]); var size = 1; for (var i = num; i >= 0x100; i >>= 8) size++; var out = new Array(size); for (var i = out.length - 1; i >= 0; i--) { out[i] = num & 0xff; num >>= 8; } if(out[0] & 0x80) { out.unshift(0); } return this._createEncoderBuffer(new Buffer(out)); }; DERNode.prototype._encodeBool = function encodeBool(value) { return this._createEncoderBuffer(value ? 0xff : 0); }; DERNode.prototype._use = function use(entity, obj) { if (typeof entity === 'function') entity = entity(obj); return entity._getEncoder('der').tree; }; DERNode.prototype._skipDefault = function skipDefault(dataBuffer, reporter, parent) { var state = this._baseState; var i; if (state['default'] === null) return false; var data = dataBuffer.join(); if (state.defaultBuffer === undefined) state.defaultBuffer = this._encodeValue(state['default'], reporter, parent).join(); if (data.length !== state.defaultBuffer.length) return false; for (i=0; i < data.length; i++) if (data[i] !== state.defaultBuffer[i]) return false; return true; }; // Utility methods function encodeTag(tag, primitive, cls, reporter) { var res; if (tag === 'seqof') tag = 'seq'; else if (tag === 'setof') tag = 'set'; if (der.tagByName.hasOwnProperty(tag)) res = der.tagByName[tag]; else if (typeof tag === 'number' && (tag | 0) === tag) res = tag; else return reporter.error('Unknown tag: ' + tag); if (res >= 0x1f) return reporter.error('Multi-octet tag encoding unsupported'); if (!primitive) res |= 0x20; res |= (der.tagClassByName[cls || 'universal'] << 6); return res; } },{"../../asn1":1,"buffer":61,"inherits":167}],13:[function(require,module,exports){ var encoders = exports; encoders.der = require('./der'); encoders.pem = require('./pem'); },{"./der":12,"./pem":14}],14:[function(require,module,exports){ var inherits = require('inherits'); var Buffer = require('buffer').Buffer; var asn1 = require('../../asn1'); var DEREncoder = require('./der'); function PEMEncoder(entity) { DEREncoder.call(this, entity); this.enc = 'pem'; }; inherits(PEMEncoder, DEREncoder); module.exports = PEMEncoder; PEMEncoder.prototype.encode = function encode(data, options) { var buf = DEREncoder.prototype.encode.call(this, data); var p = buf.toString('base64'); var out = [ '-----BEGIN ' + options.label + '-----' ]; for (var i = 0; i < p.length; i += 64) out.push(p.slice(i, i + 64)); out.push('-----END ' + options.label + '-----'); return out.join('\n'); }; },{"../../asn1":1,"./der":12,"buffer":61,"inherits":167}],15:[function(require,module,exports){ // http://wiki.commonjs.org/wiki/Unit_Testing/1.0 // // THIS IS NOT TESTED NOR LIKELY TO WORK OUTSIDE V8! // // Originally from narwhal.js (http://narwhaljs.org) // Copyright (c) 2009 Thomas Robinson <280north.com> // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the 'Software'), to // deal in the Software without restriction, including without limitation the // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or // sell copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN // ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. // when used in node, this will actually load the util module we depend on // versus loading the builtin util module as happens otherwise // this is a bug in node module loading as far as I am concerned var util = require('util/'); var pSlice = Array.prototype.slice; var hasOwn = Object.prototype.hasOwnProperty; // 1. The assert module provides functions that throw // AssertionError's when particular conditions are not met. The // assert module must conform to the following interface. var assert = module.exports = ok; // 2. The AssertionError is defined in assert. // new assert.AssertionError({ message: message, // actual: actual, // expected: expected }) assert.AssertionError = function AssertionError(options) { this.name = 'AssertionError'; this.actual = options.actual; this.expected = options.expected; this.operator = options.operator; if (options.message) { this.message = options.message; this.generatedMessage = false; } else { this.message = getMessage(this); this.generatedMessage = true; } var stackStartFunction = options.stackStartFunction || fail; if (Error.captureStackTrace) { Error.captureStackTrace(this, stackStartFunction); } else { // non v8 browsers so we can have a stacktrace var err = new Error(); if (err.stack) { var out = err.stack; // try to strip useless frames var fn_name = stackStartFunction.name; var idx = out.indexOf('\n' + fn_name); if (idx >= 0) { // once we have located the function frame // we need to strip out everything before it (and its line) var next_line = out.indexOf('\n', idx + 1); out = out.substring(next_line + 1); } this.stack = out; } } }; // assert.AssertionError instanceof Error util.inherits(assert.AssertionError, Error); function replacer(key, value) { if (util.isUndefined(value)) { return '' + value; } if (util.isNumber(value) && !isFinite(value)) { return value.toString(); } if (util.isFunction(value) || util.isRegExp(value)) { return value.toString(); } return value; } function truncate(s, n) { if (util.isString(s)) { return s.length < n ? s : s.slice(0, n); } else { return s; } } function getMessage(self) { return truncate(JSON.stringify(self.actual, replacer), 128) + ' ' + self.operator + ' ' + truncate(JSON.stringify(self.expected, replacer), 128); } // At present only the three keys mentioned above are used and // understood by the spec. Implementations or sub modules can pass // other keys to the AssertionError's constructor - they will be // ignored. // 3. All of the following functions must throw an AssertionError // when a corresponding condition is not met, with a message that // may be undefined if not provided. All assertion methods provide // both the actual and expected values to the assertion error for // display purposes. function fail(actual, expected, message, operator, stackStartFunction) { throw new assert.AssertionError({ message: message, actual: actual, expected: expected, operator: operator, stackStartFunction: stackStartFunction }); } // EXTENSION! allows for well behaved errors defined elsewhere. assert.fail = fail; // 4. Pure assertion tests whether a value is truthy, as determined // by !!guard. // assert.ok(guard, message_opt); // This statement is equivalent to assert.equal(true, !!guard, // message_opt);. To test strictly for the value true, use // assert.strictEqual(true, guard, message_opt);. function ok(value, message) { if (!value) fail(value, true, message, '==', assert.ok); } assert.ok = ok; // 5. The equality assertion tests shallow, coercive equality with // ==. // assert.equal(actual, expected, message_opt); assert.equal = function equal(actual, expected, message) { if (actual != expected) fail(actual, expected, message, '==', assert.equal); }; // 6. The non-equality assertion tests for whether two objects are not equal // with != assert.notEqual(actual, expected, message_opt); assert.notEqual = function notEqual(actual, expected, message) { if (actual == expected) { fail(actual, expected, message, '!=', assert.notEqual); } }; // 7. The equivalence assertion tests a deep equality relation. // assert.deepEqual(actual, expected, message_opt); assert.deepEqual = function deepEqual(actual, expected, message) { if (!_deepEqual(actual, expected)) { fail(actual, expected, message, 'deepEqual', assert.deepEqual); } }; function _deepEqual(actual, expected) { // 7.1. All identical values are equivalent, as determined by ===. if (actual === expected) { return true; } else if (util.isBuffer(actual) && util.isBuffer(expected)) { if (actual.length != expected.length) return false; for (var i = 0; i < actual.length; i++) { if (actual[i] !== expected[i]) return false; } return true; // 7.2. If the expected value is a Date object, the actual value is // equivalent if it is also a Date object that refers to the same time. } else if (util.isDate(actual) && util.isDate(expected)) { return actual.getTime() === expected.getTime(); // 7.3 If the expected value is a RegExp object, the actual value is // equivalent if it is also a RegExp object with the same source and // properties (`global`, `multiline`, `lastIndex`, `ignoreCase`). } else if (util.isRegExp(actual) && util.isRegExp(expected)) { return actual.source === expected.source && actual.global === expected.global && actual.multiline === expected.multiline && actual.lastIndex === expected.lastIndex && actual.ignoreCase === expected.ignoreCase; // 7.4. Other pairs that do not both pass typeof value == 'object', // equivalence is determined by ==. } else if (!util.isObject(actual) && !util.isObject(expected)) { return actual == expected; // 7.5 For all other Object pairs, including Array objects, equivalence is // determined by having the same number of owned properties (as verified // with Object.prototype.hasOwnProperty.call), the same set of keys // (although not necessarily the same order), equivalent values for every // corresponding key, and an identical 'prototype' property. Note: this // accounts for both named and indexed properties on Arrays. } else { return objEquiv(actual, expected); } } function isArguments(object) { return Object.prototype.toString.call(object) == '[object Arguments]'; } function objEquiv(a, b) { if (util.isNullOrUndefined(a) || util.isNullOrUndefined(b)) return false; // an identical 'prototype' property. if (a.prototype !== b.prototype) return false; // if one is a primitive, the other must be same if (util.isPrimitive(a) || util.isPrimitive(b)) { return a === b; } var aIsArgs = isArguments(a), bIsArgs = isArguments(b); if ((aIsArgs && !bIsArgs) || (!aIsArgs && bIsArgs)) return false; if (aIsArgs) { a = pSlice.call(a); b = pSlice.call(b); return _deepEqual(a, b); } var ka = objectKeys(a), kb = objectKeys(b), key, i; // having the same number of owned properties (keys incorporates // hasOwnProperty) if (ka.length != kb.length) return false; //the same set of keys (although not necessarily the same order), ka.sort(); kb.sort(); //~~~cheap key test for (i = ka.length - 1; i >= 0; i--) { if (ka[i] != kb[i]) return false; } //equivalent values for every corresponding key, and //~~~possibly expensive deep test for (i = ka.length - 1; i >= 0; i--) { key = ka[i]; if (!_deepEqual(a[key], b[key])) return false; } return true; } // 8. The non-equivalence assertion tests for any deep inequality. // assert.notDeepEqual(actual, expected, message_opt); assert.notDeepEqual = function notDeepEqual(actual, expected, message) { if (_deepEqual(actual, expected)) { fail(actual, expected, message, 'notDeepEqual', assert.notDeepEqual); } }; // 9. The strict equality assertion tests strict equality, as determined by ===. // assert.strictEqual(actual, expected, message_opt); assert.strictEqual = function strictEqual(actual, expected, message) { if (actual !== expected) { fail(actual, expected, message, '===', assert.strictEqual); } }; // 10. The strict non-equality assertion tests for strict inequality, as // determined by !==. assert.notStrictEqual(actual, expected, message_opt); assert.notStrictEqual = function notStrictEqual(actual, expected, message) { if (actual === expected) { fail(actual, expected, message, '!==', assert.notStrictEqual); } }; function expectedException(actual, expected) { if (!actual || !expected) { return false; } if (Object.prototype.toString.call(expected) == '[object RegExp]') { return expected.test(actual); } else if (actual instanceof expected) { return true; } else if (expected.call({}, actual) === true) { return true; } return false; } function _throws(shouldThrow, block, expected, message) { var actual; if (util.isString(expected)) { message = expected; expected = null; } try { block(); } catch (e) { actual = e; } message = (expected && expected.name ? ' (' + expected.name + ').' : '.') + (message ? ' ' + message : '.'); if (shouldThrow && !actual) { fail(actual, expected, 'Missing expected exception' + message); } if (!shouldThrow && expectedException(actual, expected)) { fail(actual, expected, 'Got unwanted exception' + message); } if ((shouldThrow && actual && expected && !expectedException(actual, expected)) || (!shouldThrow && actual)) { throw actual; } } // 11. Expected to throw an error: // assert.throws(block, Error_opt, message_opt); assert.throws = function(block, /*optional*/error, /*optional*/message) { _throws.apply(this, [true].concat(pSlice.call(arguments))); }; // EXTENSION! This is annoying to write outside this module. assert.doesNotThrow = function(block, /*optional*/message) { _throws.apply(this, [false].concat(pSlice.call(arguments))); }; assert.ifError = function(err) { if (err) {throw err;}}; var objectKeys = Object.keys || function (obj) { var keys = []; for (var key in obj) { if (hasOwn.call(obj, key)) keys.push(key); } return keys; }; },{"util/":636}],16:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015 Titus Wormer * @license MIT * @module attach-ware * @fileoverview Middleware with configuration. * @example * var ware = require('attach-ware')(require('ware')); * * var middleware = ware() * .use(function (context, options) { * if (!options.condition) return; * * return function (req, res, next) { * res.x = 'hello'; * next(); * }; * }, { * 'condition': true * }) * .use(function (context, options) { * if (!options.condition) return; * * return function (req, res, next) { * res.y = 'world'; * next(); * }; * }, { * 'condition': false * }); * * middleware.run({}, {}, function (err, req, res) { * res.x; // "hello" * res.y; // undefined * }); */ 'use strict'; /* eslint-env commonjs */ var slice = [].slice; var unherit = require('unherit'); /** * Clone `Ware` without affecting the super-class and * turn it into configurable middleware. * * @param {Function} Ware - Ware-like constructor. * @return {Function} AttachWare - Configurable middleware. */ function patch(Ware) { /* * Methods. */ var useFn = Ware.prototype.use; /** * @constructor * @class {AttachWare} */ var AttachWare = unherit(Ware); AttachWare.prototype.foo = true; /** * Attach configurable middleware. * * @memberof {AttachWare} * @this {AttachWare} * @param {Function} attach - Attacher. * @return {AttachWare} - `this`. */ function use(attach) { var self = this; var params = slice.call(arguments, 1); var index; var length; var fn; /* * Accept other `AttachWare`. */ if (attach instanceof AttachWare) { if (attach.attachers) { return self.use(attach.attachers); } return self; } /* * Accept normal ware. */ if (attach instanceof Ware) { self.fns = self.fns.concat(attach.fns); return self; } /* * Multiple attachers. */ if ('length' in attach && typeof attach !== 'function') { index = -1; length = attach.length; while (++index < length) { self.use.apply(self, [attach[index]].concat(params)); } return self; } /* * Single attacher. */ fn = attach.apply(null, [self.context || self].concat(params)); /* * Store the attacher to not break `new Ware(otherWare)` * functionality. */ if (!self.attachers) { self.attachers = []; } self.attachers.push(attach); /* * Pass `fn` to the original `Ware#use()`. */ if (fn) { useFn.call(self, fn); } return self; } AttachWare.prototype.use = use; return function (fn) { return new AttachWare(fn); }; } module.exports = patch; },{"unherit":629}],17:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015 Titus Wormer. All rights reserved. * @module bail * @fileoverview Throw a given error. */ 'use strict'; /** * Throw a given error. * * @example * bail(); * * @example * bail(new Error('failure')); * // Error: failure * // at repl:1:6 * // at REPLServer.defaultEval (repl.js:154:27) * // ... * * @param {Error?} [err] - Optional error. * @throws {Error} - `err`, when given. */ function bail(err) { if (err) { throw err; } } /* * Expose. */ module.exports = bail; },{}],18:[function(require,module,exports){ module.exports = balanced; function balanced(a, b, str) { var r = range(a, b, str); return r && { start: r[0], end: r[1], pre: str.slice(0, r[0]), body: str.slice(r[0] + a.length, r[1]), post: str.slice(r[1] + b.length) }; } balanced.range = range; function range(a, b, str) { var begs, beg, left, right, result; var ai = str.indexOf(a); var bi = str.indexOf(b, ai + 1); var i = ai; if (ai >= 0 && bi > 0) { begs = []; left = str.length; while (i < str.length && i >= 0 && ! result) { if (i == ai) { begs.push(i); ai = str.indexOf(a, i + 1); } else if (begs.length == 1) { result = [ begs.pop(), bi ]; } else { beg = begs.pop(); if (beg < left) { left = beg; right = bi; } bi = str.indexOf(b, i + 1); } i = ai < bi && ai >= 0 ? ai : bi; } if (begs.length) { result = [ left, right ]; } } return result; } },{}],19:[function(require,module,exports){ var bash_codes = exports.bash_codes = { "BLACK" : { "text" : "\033[0;30m", "underline": "\033[4;30m", "background": "\033[40m", "bold":"\033[1;30m", "hi_text":"\033[0;90m", "hi_bold" : "\033[1;90m", "hi_background" : "\033[0;100m" }, "RED" : { "text" : "\033[0;31m", "bold":"\033[1;31m", "underline": "\033[4;31m", "background": "\033[41m", "hi_text":"\033[0;91m", "hi_bold" : "\033[1;91m", "hi_background" : "\033[0;101m" }, "GREEN" : { "text" : "\033[0;32m", "bold":"\033[1;32m", "underline": "\033[4;32m", "background": "\033[42m", "hi_text":"\033[0;92m", "hi_bold" : "\033[1;92m", "hi_background" : "\033[0;102m" }, "YELLOW" : { "text" : "\033[0;33m", "bold":"\033[1;33m", "underline": "\033[4;33m", "background": "\033[43m", "hi_text":"\033[0;93m", "hi_bold" : "\033[1;93m", "hi_background" : "\033[0;103m" }, "BLUE" : { "text" : "\033[0;34m", "bold":"\033[1;34m", "underline": "\033[4;34m", "background": "\033[44m", "hi_text":"\033[0;94m", "hi_bold" : "\033[1;94m", "hi_background" : "\033[0;104m" }, "PURPLE" : { "text" : "\033[0;35m", "bold":"\033[1;35m", "underline": "\033[4;35m", "background": "\033[45m", "hi_text":"\033[0;95m", "hi_bold" : "\033[1;95m", "hi_background" : "\033[0;105m" }, "CYAN" : { "text" : "\033[0;36m", "bold":"\033[1;36m", "underline": "\033[4;36m", "background": "\033[46m", "hi_text":"\033[0;96m", "hi_bold" : "\033[1;96m", "hi_background" : "\033[0;106m" }, "WHITE" : { "text" : "\033[0;37m", "bold":"\033[1;37m", "underline": "\033[4;37m", "background": "\033[47m", "hi_text":"\033[0;97m", "hi_bold" : "\033[1;97m", "hi_background" : "\033[0;107m" } }; exports.colors = { BLACK: "BLACK", RED: "RED", GREEN: "GREEN", YELLOW: "YELLOW", BLUE: "BLUE", PURPLE: "PURPLE", CYAN: "CYAN", WHITE: "WHITE" }; var styles = exports.styles = { bold: "bold", underline: "underline", background: "background", hi_text: "hi_text", hi_bold: "hi_bold", hi_background: "hi_background" }; var REMOVE_COLOR = exports.REMOVE_COLOR = "\033[0m"; // various logical inconsistencies in the code below - renderColor and wrap seem like they should be combined, but I'm letting wrap basically stand on its own // in case anyone wants access to explicitly handle background or underline stuff. I feel like those are a bit more special-casey, and generally speakign // users are going to want to quickly turn a word or phrase into a single color without worrying about background or underline. So the .colorName methods // are just syntactic sugar. exports.wrap = function(str, color, style) { var c = bash_codes[color.toUpperCase()]; var s = styles[style] || "text"; return render(c[s], str); }; exports.black = function(str, hi) { return renderColor(str, bash_codes.BLACK, hi); }; exports.red = function(str, hi) { return renderColor(str, bash_codes.RED, hi); }; exports.green = function(str, hi) { return renderColor(str, bash_codes.GREEN, hi); }; exports.yellow = function(str, hi) { return renderColor(str, bash_codes.YELLOW, hi); }; exports.blue = function(str, hi) { return renderColor(str, bash_codes.BLUE, hi); }; exports.purple = function(str, hi) { return renderColor(str, bash_codes.PURPLE, hi); }; exports.cyan = function(str, hi) { return renderColor(str, bash_codes.CYAN, hi); }; exports.white = function(str, hi) { return renderColor(str, bash_codes.WHITE, hi); }; function renderColor(str, color, hi) { return render(hi ? color.hi_text : color.text, str); } function render(code, str) { return code + str + REMOVE_COLOR; } },{}],20:[function(require,module,exports){ module.exports = function(haystack, needle, comparator, low, high) { var mid, cmp; if(low === undefined) low = 0; else { low = low|0; if(low < 0 || low >= haystack.length) throw new RangeError("invalid lower bound"); } if(high === undefined) high = haystack.length - 1; else { high = high|0; if(high < low || high >= haystack.length) throw new RangeError("invalid upper bound"); } while(low <= high) { /* Note that "(low + high) >>> 1" may overflow, and results in a typecast * to double (which gives the wrong results). */ mid = low + (high - low >> 1); cmp = +comparator(haystack[mid], needle); /* Too low. */ if(cmp < 0.0) low = mid + 1; /* Too high. */ else if(cmp > 0.0) high = mid - 1; /* Key found. */ else return mid; } /* Key not found. */ return ~low; } },{}],21:[function(require,module,exports){ (function (process,__filename){ /** * Module dependencies. */ var fs = require('fs') , path = require('path') , join = path.join , dirname = path.dirname , exists = fs.existsSync || path.existsSync , defaults = { arrow: process.env.NODE_BINDINGS_ARROW || ' → ' , compiled: process.env.NODE_BINDINGS_COMPILED_DIR || 'compiled' , platform: process.platform , arch: process.arch , version: process.versions.node , bindings: 'bindings.node' , try: [ // node-gyp's linked version in the "build" dir [ 'module_root', 'build', 'bindings' ] // node-waf and gyp_addon (a.k.a node-gyp) , [ 'module_root', 'build', 'Debug', 'bindings' ] , [ 'module_root', 'build', 'Release', 'bindings' ] // Debug files, for development (legacy behavior, remove for node v0.9) , [ 'module_root', 'out', 'Debug', 'bindings' ] , [ 'module_root', 'Debug', 'bindings' ] // Release files, but manually compiled (legacy behavior, remove for node v0.9) , [ 'module_root', 'out', 'Release', 'bindings' ] , [ 'module_root', 'Release', 'bindings' ] // Legacy from node-waf, node <= 0.4.x , [ 'module_root', 'build', 'default', 'bindings' ] // Production "Release" buildtype binary (meh...) , [ 'module_root', 'compiled', 'version', 'platform', 'arch', 'bindings' ] ] } /** * The main `bindings()` function loads the compiled bindings for a given module. * It uses V8's Error API to determine the parent filename that this function is * being invoked from, which is then used to find the root directory. */ function bindings (opts) { // Argument surgery if (typeof opts == 'string') { opts = { bindings: opts } } else if (!opts) { opts = {} } opts.__proto__ = defaults // Get the module root if (!opts.module_root) { opts.module_root = exports.getRoot(exports.getFileName()) } // Ensure the given bindings name ends with .node if (path.extname(opts.bindings) != '.node') { opts.bindings += '.node' } var tries = [] , i = 0 , l = opts.try.length , n , b , err for (; i this.length) srcEnd = this.length if (srcStart >= this.length) return dst || new Buffer(0) if (srcEnd <= 0) return dst || new Buffer(0) var copy = !!dst , off = this._offset(srcStart) , len = srcEnd - srcStart , bytes = len , bufoff = (copy && dstStart) || 0 , start = off[1] , l , i // copy/slice everything if (srcStart === 0 && srcEnd == this.length) { if (!copy) // slice, just return a full concat return Buffer.concat(this._bufs) // copy, need to copy individual buffers for (i = 0; i < this._bufs.length; i++) { this._bufs[i].copy(dst, bufoff) bufoff += this._bufs[i].length } return dst } // easy, cheap case where it's a subset of one of the buffers if (bytes <= this._bufs[off[0]].length - start) { return copy ? this._bufs[off[0]].copy(dst, dstStart, start, start + bytes) : this._bufs[off[0]].slice(start, start + bytes) } if (!copy) // a slice, we need something to copy in to dst = new Buffer(len) for (i = off[0]; i < this._bufs.length; i++) { l = this._bufs[i].length - start if (bytes > l) { this._bufs[i].copy(dst, bufoff, start) } else { this._bufs[i].copy(dst, bufoff, start, start + bytes) break } bufoff += l bytes -= l if (start) start = 0 } return dst } BufferList.prototype.toString = function toString (encoding, start, end) { return this.slice(start, end).toString(encoding) } BufferList.prototype.consume = function consume (bytes) { while (this._bufs.length) { if (bytes >= this._bufs[0].length) { bytes -= this._bufs[0].length this.length -= this._bufs[0].length this._bufs.shift() } else { this._bufs[0] = this._bufs[0].slice(bytes) this.length -= bytes break } } return this } BufferList.prototype.duplicate = function duplicate () { var i = 0 , copy = new BufferList() for (; i < this._bufs.length; i++) copy.append(this._bufs[i]) return copy } BufferList.prototype.destroy = function destroy () { this._bufs.length = 0 this.length = 0 this.push(null) } ;(function () { var methods = { 'readDoubleBE' : 8 , 'readDoubleLE' : 8 , 'readFloatBE' : 4 , 'readFloatLE' : 4 , 'readInt32BE' : 4 , 'readInt32LE' : 4 , 'readUInt32BE' : 4 , 'readUInt32LE' : 4 , 'readInt16BE' : 2 , 'readInt16LE' : 2 , 'readUInt16BE' : 2 , 'readUInt16LE' : 2 , 'readInt8' : 1 , 'readUInt8' : 1 } for (var m in methods) { (function (m) { BufferList.prototype[m] = function (offset) { return this.slice(offset, offset + methods[m])[m](0) } }(m)) } }()) module.exports = BufferList }).call(this,require("buffer").Buffer) },{"buffer":61,"readable-stream/duplex":24,"util":636}],23:[function(require,module,exports){ var toString = {}.toString; module.exports = Array.isArray || function (arr) { return toString.call(arr) == '[object Array]'; }; },{}],24:[function(require,module,exports){ module.exports = require("./lib/_stream_duplex.js") },{"./lib/_stream_duplex.js":25}],25:[function(require,module,exports){ // a duplex stream is just a stream that is both readable and writable. // Since JS doesn't have multiple prototypal inheritance, this class // prototypally inherits from Readable, and then parasitically from // Writable. 'use strict'; /**/ var objectKeys = Object.keys || function (obj) { var keys = []; for (var key in obj) { keys.push(key); }return keys; }; /**/ module.exports = Duplex; /**/ var processNextTick = require('process-nextick-args'); /**/ /**/ var util = require('core-util-is'); util.inherits = require('inherits'); /**/ var Readable = require('./_stream_readable'); var Writable = require('./_stream_writable'); util.inherits(Duplex, Readable); var keys = objectKeys(Writable.prototype); for (var v = 0; v < keys.length; v++) { var method = keys[v]; if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method]; } function Duplex(options) { if (!(this instanceof Duplex)) return new Duplex(options); Readable.call(this, options); Writable.call(this, options); if (options && options.readable === false) this.readable = false; if (options && options.writable === false) this.writable = false; this.allowHalfOpen = true; if (options && options.allowHalfOpen === false) this.allowHalfOpen = false; this.once('end', onend); } // the no-half-open enforcer function onend() { // if we allow half-open state, or if the writable side ended, // then we're ok. if (this.allowHalfOpen || this._writableState.ended) return; // no more data can be written. // But allow more writes to happen in this tick. processNextTick(onEndNT, this); } function onEndNT(self) { self.end(); } function forEach(xs, f) { for (var i = 0, l = xs.length; i < l; i++) { f(xs[i], i); } } },{"./_stream_readable":26,"./_stream_writable":27,"core-util-is":104,"inherits":167,"process-nextick-args":294}],26:[function(require,module,exports){ (function (process){ 'use strict'; module.exports = Readable; /**/ var processNextTick = require('process-nextick-args'); /**/ /**/ var isArray = require('isarray'); /**/ /**/ var Buffer = require('buffer').Buffer; /**/ Readable.ReadableState = ReadableState; var EE = require('events'); /**/ var EElistenerCount = function (emitter, type) { return emitter.listeners(type).length; }; /**/ /**/ var Stream; (function () { try { Stream = require('st' + 'ream'); } catch (_) {} finally { if (!Stream) Stream = require('events').EventEmitter; } })(); /**/ var Buffer = require('buffer').Buffer; /**/ var util = require('core-util-is'); util.inherits = require('inherits'); /**/ /**/ var debugUtil = require('util'); var debug = undefined; if (debugUtil && debugUtil.debuglog) { debug = debugUtil.debuglog('stream'); } else { debug = function () {}; } /**/ var StringDecoder; util.inherits(Readable, Stream); var Duplex; function ReadableState(options, stream) { Duplex = Duplex || require('./_stream_duplex'); options = options || {}; // object stream flag. Used to make read(n) ignore n and to // make all the buffer merging and length checks go away this.objectMode = !!options.objectMode; if (stream instanceof Duplex) this.objectMode = this.objectMode || !!options.readableObjectMode; // the point at which it stops calling _read() to fill the buffer // Note: 0 is a valid value, means "don't call _read preemptively ever" var hwm = options.highWaterMark; var defaultHwm = this.objectMode ? 16 : 16 * 1024; this.highWaterMark = hwm || hwm === 0 ? hwm : defaultHwm; // cast to ints. this.highWaterMark = ~ ~this.highWaterMark; this.buffer = []; this.length = 0; this.pipes = null; this.pipesCount = 0; this.flowing = null; this.ended = false; this.endEmitted = false; this.reading = false; // a flag to be able to tell if the onwrite cb is called immediately, // or on a later tick. We set this to true at first, because any // actions that shouldn't happen until "later" should generally also // not happen before the first write call. this.sync = true; // whenever we return null, then we set a flag to say // that we're awaiting a 'readable' event emission. this.needReadable = false; this.emittedReadable = false; this.readableListening = false; this.resumeScheduled = false; // Crypto is kind of old and crusty. Historically, its default string // encoding is 'binary' so we have to make this configurable. // Everything else in the universe uses 'utf8', though. this.defaultEncoding = options.defaultEncoding || 'utf8'; // when piping, we only care about 'readable' events that happen // after read()ing all the bytes and not getting any pushback. this.ranOut = false; // the number of writers that are awaiting a drain event in .pipe()s this.awaitDrain = 0; // if true, a maybeReadMore has been scheduled this.readingMore = false; this.decoder = null; this.encoding = null; if (options.encoding) { if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder; this.decoder = new StringDecoder(options.encoding); this.encoding = options.encoding; } } var Duplex; function Readable(options) { Duplex = Duplex || require('./_stream_duplex'); if (!(this instanceof Readable)) return new Readable(options); this._readableState = new ReadableState(options, this); // legacy this.readable = true; if (options && typeof options.read === 'function') this._read = options.read; Stream.call(this); } // Manually shove something into the read() buffer. // This returns true if the highWaterMark has not been hit yet, // similar to how Writable.write() returns true if you should // write() some more. Readable.prototype.push = function (chunk, encoding) { var state = this._readableState; if (!state.objectMode && typeof chunk === 'string') { encoding = encoding || state.defaultEncoding; if (encoding !== state.encoding) { chunk = new Buffer(chunk, encoding); encoding = ''; } } return readableAddChunk(this, state, chunk, encoding, false); }; // Unshift should *always* be something directly out of read() Readable.prototype.unshift = function (chunk) { var state = this._readableState; return readableAddChunk(this, state, chunk, '', true); }; Readable.prototype.isPaused = function () { return this._readableState.flowing === false; }; function readableAddChunk(stream, state, chunk, encoding, addToFront) { var er = chunkInvalid(state, chunk); if (er) { stream.emit('error', er); } else if (chunk === null) { state.reading = false; onEofChunk(stream, state); } else if (state.objectMode || chunk && chunk.length > 0) { if (state.ended && !addToFront) { var e = new Error('stream.push() after EOF'); stream.emit('error', e); } else if (state.endEmitted && addToFront) { var e = new Error('stream.unshift() after end event'); stream.emit('error', e); } else { var skipAdd; if (state.decoder && !addToFront && !encoding) { chunk = state.decoder.write(chunk); skipAdd = !state.objectMode && chunk.length === 0; } if (!addToFront) state.reading = false; // Don't add to the buffer if we've decoded to an empty string chunk and // we're not in object mode if (!skipAdd) { // if we want the data now, just emit it. if (state.flowing && state.length === 0 && !state.sync) { stream.emit('data', chunk); stream.read(0); } else { // update the buffer info. state.length += state.objectMode ? 1 : chunk.length; if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk); if (state.needReadable) emitReadable(stream); } } maybeReadMore(stream, state); } } else if (!addToFront) { state.reading = false; } return needMoreData(state); } // if it's past the high water mark, we can push in some more. // Also, if we have no data yet, we can stand some // more bytes. This is to work around cases where hwm=0, // such as the repl. Also, if the push() triggered a // readable event, and the user called read(largeNumber) such that // needReadable was set, then we ought to push more, so that another // 'readable' event will be triggered. function needMoreData(state) { return !state.ended && (state.needReadable || state.length < state.highWaterMark || state.length === 0); } // backwards compatibility. Readable.prototype.setEncoding = function (enc) { if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder; this._readableState.decoder = new StringDecoder(enc); this._readableState.encoding = enc; return this; }; // Don't raise the hwm > 8MB var MAX_HWM = 0x800000; function computeNewHighWaterMark(n) { if (n >= MAX_HWM) { n = MAX_HWM; } else { // Get the next highest power of 2 n--; n |= n >>> 1; n |= n >>> 2; n |= n >>> 4; n |= n >>> 8; n |= n >>> 16; n++; } return n; } function howMuchToRead(n, state) { if (state.length === 0 && state.ended) return 0; if (state.objectMode) return n === 0 ? 0 : 1; if (n === null || isNaN(n)) { // only flow one buffer at a time if (state.flowing && state.buffer.length) return state.buffer[0].length;else return state.length; } if (n <= 0) return 0; // If we're asking for more than the target buffer level, // then raise the water mark. Bump up to the next highest // power of 2, to prevent increasing it excessively in tiny // amounts. if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n); // don't have that much. return null, unless we've ended. if (n > state.length) { if (!state.ended) { state.needReadable = true; return 0; } else { return state.length; } } return n; } // you can override either this method, or the async _read(n) below. Readable.prototype.read = function (n) { debug('read', n); var state = this._readableState; var nOrig = n; if (typeof n !== 'number' || n > 0) state.emittedReadable = false; // if we're doing read(0) to trigger a readable event, but we // already have a bunch of data in the buffer, then just trigger // the 'readable' event and move on. if (n === 0 && state.needReadable && (state.length >= state.highWaterMark || state.ended)) { debug('read: emitReadable', state.length, state.ended); if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this); return null; } n = howMuchToRead(n, state); // if we've ended, and we're now clear, then finish it up. if (n === 0 && state.ended) { if (state.length === 0) endReadable(this); return null; } // All the actual chunk generation logic needs to be // *below* the call to _read. The reason is that in certain // synthetic stream cases, such as passthrough streams, _read // may be a completely synchronous operation which may change // the state of the read buffer, providing enough data when // before there was *not* enough. // // So, the steps are: // 1. Figure out what the state of things will be after we do // a read from the buffer. // // 2. If that resulting state will trigger a _read, then call _read. // Note that this may be asynchronous, or synchronous. Yes, it is // deeply ugly to write APIs this way, but that still doesn't mean // that the Readable class should behave improperly, as streams are // designed to be sync/async agnostic. // Take note if the _read call is sync or async (ie, if the read call // has returned yet), so that we know whether or not it's safe to emit // 'readable' etc. // // 3. Actually pull the requested chunks out of the buffer and return. // if we need a readable event, then we need to do some reading. var doRead = state.needReadable; debug('need readable', doRead); // if we currently have less than the highWaterMark, then also read some if (state.length === 0 || state.length - n < state.highWaterMark) { doRead = true; debug('length less than watermark', doRead); } // however, if we've ended, then there's no point, and if we're already // reading, then it's unnecessary. if (state.ended || state.reading) { doRead = false; debug('reading or ended', doRead); } if (doRead) { debug('do read'); state.reading = true; state.sync = true; // if the length is currently zero, then we *need* a readable event. if (state.length === 0) state.needReadable = true; // call internal read method this._read(state.highWaterMark); state.sync = false; } // If _read pushed data synchronously, then `reading` will be false, // and we need to re-evaluate how much data we can return to the user. if (doRead && !state.reading) n = howMuchToRead(nOrig, state); var ret; if (n > 0) ret = fromList(n, state);else ret = null; if (ret === null) { state.needReadable = true; n = 0; } state.length -= n; // If we have nothing in the buffer, then we want to know // as soon as we *do* get something into the buffer. if (state.length === 0 && !state.ended) state.needReadable = true; // If we tried to read() past the EOF, then emit end on the next tick. if (nOrig !== n && state.ended && state.length === 0) endReadable(this); if (ret !== null) this.emit('data', ret); return ret; }; function chunkInvalid(state, chunk) { var er = null; if (!Buffer.isBuffer(chunk) && typeof chunk !== 'string' && chunk !== null && chunk !== undefined && !state.objectMode) { er = new TypeError('Invalid non-string/buffer chunk'); } return er; } function onEofChunk(stream, state) { if (state.ended) return; if (state.decoder) { var chunk = state.decoder.end(); if (chunk && chunk.length) { state.buffer.push(chunk); state.length += state.objectMode ? 1 : chunk.length; } } state.ended = true; // emit 'readable' now to make sure it gets picked up. emitReadable(stream); } // Don't emit readable right away in sync mode, because this can trigger // another read() call => stack overflow. This way, it might trigger // a nextTick recursion warning, but that's not so bad. function emitReadable(stream) { var state = stream._readableState; state.needReadable = false; if (!state.emittedReadable) { debug('emitReadable', state.flowing); state.emittedReadable = true; if (state.sync) processNextTick(emitReadable_, stream);else emitReadable_(stream); } } function emitReadable_(stream) { debug('emit readable'); stream.emit('readable'); flow(stream); } // at this point, the user has presumably seen the 'readable' event, // and called read() to consume some data. that may have triggered // in turn another _read(n) call, in which case reading = true if // it's in progress. // However, if we're not ended, or reading, and the length < hwm, // then go ahead and try to read some more preemptively. function maybeReadMore(stream, state) { if (!state.readingMore) { state.readingMore = true; processNextTick(maybeReadMore_, stream, state); } } function maybeReadMore_(stream, state) { var len = state.length; while (!state.reading && !state.flowing && !state.ended && state.length < state.highWaterMark) { debug('maybeReadMore read 0'); stream.read(0); if (len === state.length) // didn't get any data, stop spinning. break;else len = state.length; } state.readingMore = false; } // abstract method. to be overridden in specific implementation classes. // call cb(er, data) where data is <= n in length. // for virtual (non-string, non-buffer) streams, "length" is somewhat // arbitrary, and perhaps not very meaningful. Readable.prototype._read = function (n) { this.emit('error', new Error('not implemented')); }; Readable.prototype.pipe = function (dest, pipeOpts) { var src = this; var state = this._readableState; switch (state.pipesCount) { case 0: state.pipes = dest; break; case 1: state.pipes = [state.pipes, dest]; break; default: state.pipes.push(dest); break; } state.pipesCount += 1; debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts); var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr; var endFn = doEnd ? onend : cleanup; if (state.endEmitted) processNextTick(endFn);else src.once('end', endFn); dest.on('unpipe', onunpipe); function onunpipe(readable) { debug('onunpipe'); if (readable === src) { cleanup(); } } function onend() { debug('onend'); dest.end(); } // when the dest drains, it reduces the awaitDrain counter // on the source. This would be more elegant with a .once() // handler in flow(), but adding and removing repeatedly is // too slow. var ondrain = pipeOnDrain(src); dest.on('drain', ondrain); var cleanedUp = false; function cleanup() { debug('cleanup'); // cleanup event handlers once the pipe is broken dest.removeListener('close', onclose); dest.removeListener('finish', onfinish); dest.removeListener('drain', ondrain); dest.removeListener('error', onerror); dest.removeListener('unpipe', onunpipe); src.removeListener('end', onend); src.removeListener('end', cleanup); src.removeListener('data', ondata); cleanedUp = true; // if the reader is waiting for a drain event from this // specific writer, then it would cause it to never start // flowing again. // So, if this is awaiting a drain, then we just call it now. // If we don't know, then assume that we are waiting for one. if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain(); } src.on('data', ondata); function ondata(chunk) { debug('ondata'); var ret = dest.write(chunk); if (false === ret) { // If the user unpiped during `dest.write()`, it is possible // to get stuck in a permanently paused state if that write // also returned false. if (state.pipesCount === 1 && state.pipes[0] === dest && src.listenerCount('data') === 1 && !cleanedUp) { debug('false write response, pause', src._readableState.awaitDrain); src._readableState.awaitDrain++; } src.pause(); } } // if the dest has an error, then stop piping into it. // however, don't suppress the throwing behavior for this. function onerror(er) { debug('onerror', er); unpipe(); dest.removeListener('error', onerror); if (EElistenerCount(dest, 'error') === 0) dest.emit('error', er); } // This is a brutally ugly hack to make sure that our error handler // is attached before any userland ones. NEVER DO THIS. if (!dest._events || !dest._events.error) dest.on('error', onerror);else if (isArray(dest._events.error)) dest._events.error.unshift(onerror);else dest._events.error = [onerror, dest._events.error]; // Both close and finish should trigger unpipe, but only once. function onclose() { dest.removeListener('finish', onfinish); unpipe(); } dest.once('close', onclose); function onfinish() { debug('onfinish'); dest.removeListener('close', onclose); unpipe(); } dest.once('finish', onfinish); function unpipe() { debug('unpipe'); src.unpipe(dest); } // tell the dest that it's being piped to dest.emit('pipe', src); // start the flow if it hasn't been started already. if (!state.flowing) { debug('pipe resume'); src.resume(); } return dest; }; function pipeOnDrain(src) { return function () { var state = src._readableState; debug('pipeOnDrain', state.awaitDrain); if (state.awaitDrain) state.awaitDrain--; if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) { state.flowing = true; flow(src); } }; } Readable.prototype.unpipe = function (dest) { var state = this._readableState; // if we're not piping anywhere, then do nothing. if (state.pipesCount === 0) return this; // just one destination. most common case. if (state.pipesCount === 1) { // passed in one, but it's not the right one. if (dest && dest !== state.pipes) return this; if (!dest) dest = state.pipes; // got a match. state.pipes = null; state.pipesCount = 0; state.flowing = false; if (dest) dest.emit('unpipe', this); return this; } // slow case. multiple pipe destinations. if (!dest) { // remove all. var dests = state.pipes; var len = state.pipesCount; state.pipes = null; state.pipesCount = 0; state.flowing = false; for (var _i = 0; _i < len; _i++) { dests[_i].emit('unpipe', this); }return this; } // try to find the right one. var i = indexOf(state.pipes, dest); if (i === -1) return this; state.pipes.splice(i, 1); state.pipesCount -= 1; if (state.pipesCount === 1) state.pipes = state.pipes[0]; dest.emit('unpipe', this); return this; }; // set up data events if they are asked for // Ensure readable listeners eventually get something Readable.prototype.on = function (ev, fn) { var res = Stream.prototype.on.call(this, ev, fn); // If listening to data, and it has not explicitly been paused, // then call resume to start the flow of data on the next tick. if (ev === 'data' && false !== this._readableState.flowing) { this.resume(); } if (ev === 'readable' && !this._readableState.endEmitted) { var state = this._readableState; if (!state.readableListening) { state.readableListening = true; state.emittedReadable = false; state.needReadable = true; if (!state.reading) { processNextTick(nReadingNextTick, this); } else if (state.length) { emitReadable(this, state); } } } return res; }; Readable.prototype.addListener = Readable.prototype.on; function nReadingNextTick(self) { debug('readable nexttick read 0'); self.read(0); } // pause() and resume() are remnants of the legacy readable stream API // If the user uses them, then switch into old mode. Readable.prototype.resume = function () { var state = this._readableState; if (!state.flowing) { debug('resume'); state.flowing = true; resume(this, state); } return this; }; function resume(stream, state) { if (!state.resumeScheduled) { state.resumeScheduled = true; processNextTick(resume_, stream, state); } } function resume_(stream, state) { if (!state.reading) { debug('resume read 0'); stream.read(0); } state.resumeScheduled = false; stream.emit('resume'); flow(stream); if (state.flowing && !state.reading) stream.read(0); } Readable.prototype.pause = function () { debug('call pause flowing=%j', this._readableState.flowing); if (false !== this._readableState.flowing) { debug('pause'); this._readableState.flowing = false; this.emit('pause'); } return this; }; function flow(stream) { var state = stream._readableState; debug('flow', state.flowing); if (state.flowing) { do { var chunk = stream.read(); } while (null !== chunk && state.flowing); } } // wrap an old-style stream as the async data source. // This is *not* part of the readable stream interface. // It is an ugly unfortunate mess of history. Readable.prototype.wrap = function (stream) { var state = this._readableState; var paused = false; var self = this; stream.on('end', function () { debug('wrapped end'); if (state.decoder && !state.ended) { var chunk = state.decoder.end(); if (chunk && chunk.length) self.push(chunk); } self.push(null); }); stream.on('data', function (chunk) { debug('wrapped data'); if (state.decoder) chunk = state.decoder.write(chunk); // don't skip over falsy values in objectMode if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return; var ret = self.push(chunk); if (!ret) { paused = true; stream.pause(); } }); // proxy all the other methods. // important when wrapping filters and duplexes. for (var i in stream) { if (this[i] === undefined && typeof stream[i] === 'function') { this[i] = function (method) { return function () { return stream[method].apply(stream, arguments); }; }(i); } } // proxy certain important events. var events = ['error', 'close', 'destroy', 'pause', 'resume']; forEach(events, function (ev) { stream.on(ev, self.emit.bind(self, ev)); }); // when we try to consume some more bytes, simply unpause the // underlying stream. self._read = function (n) { debug('wrapped _read', n); if (paused) { paused = false; stream.resume(); } }; return self; }; // exposed for testing purposes only. Readable._fromList = fromList; // Pluck off n bytes from an array of buffers. // Length is the combined lengths of all the buffers in the list. function fromList(n, state) { var list = state.buffer; var length = state.length; var stringMode = !!state.decoder; var objectMode = !!state.objectMode; var ret; // nothing in the list, definitely empty. if (list.length === 0) return null; if (length === 0) ret = null;else if (objectMode) ret = list.shift();else if (!n || n >= length) { // read it all, truncate the array. if (stringMode) ret = list.join('');else if (list.length === 1) ret = list[0];else ret = Buffer.concat(list, length); list.length = 0; } else { // read just some of it. if (n < list[0].length) { // just take a part of the first list item. // slice is the same for buffers and strings. var buf = list[0]; ret = buf.slice(0, n); list[0] = buf.slice(n); } else if (n === list[0].length) { // first list is a perfect match ret = list.shift(); } else { // complex case. // we have enough to cover it, but it spans past the first buffer. if (stringMode) ret = '';else ret = new Buffer(n); var c = 0; for (var i = 0, l = list.length; i < l && c < n; i++) { var buf = list[0]; var cpy = Math.min(n - c, buf.length); if (stringMode) ret += buf.slice(0, cpy);else buf.copy(ret, c, 0, cpy); if (cpy < buf.length) list[0] = buf.slice(cpy);else list.shift(); c += cpy; } } } return ret; } function endReadable(stream) { var state = stream._readableState; // If we get here before consuming all the bytes, then that is a // bug in node. Should never happen. if (state.length > 0) throw new Error('endReadable called on non-empty stream'); if (!state.endEmitted) { state.ended = true; processNextTick(endReadableNT, state, stream); } } function endReadableNT(state, stream) { // Check that we didn't get one last unshift. if (!state.endEmitted && state.length === 0) { state.endEmitted = true; stream.readable = false; stream.emit('end'); } } function forEach(xs, f) { for (var i = 0, l = xs.length; i < l; i++) { f(xs[i], i); } } function indexOf(xs, x) { for (var i = 0, l = xs.length; i < l; i++) { if (xs[i] === x) return i; } return -1; } }).call(this,require('_process')) },{"./_stream_duplex":25,"_process":295,"buffer":61,"core-util-is":104,"events":144,"inherits":167,"isarray":23,"process-nextick-args":294,"string_decoder/":616,"util":33}],27:[function(require,module,exports){ (function (process){ // A bit simpler than readable streams. // Implement an async ._write(chunk, encoding, cb), and it'll handle all // the drain event emission and buffering. 'use strict'; module.exports = Writable; /**/ var processNextTick = require('process-nextick-args'); /**/ /**/ var asyncWrite = !process.browser && ['v0.10', 'v0.9.'].indexOf(process.version.slice(0, 5)) > -1 ? setImmediate : processNextTick; /**/ /**/ var Buffer = require('buffer').Buffer; /**/ Writable.WritableState = WritableState; /**/ var util = require('core-util-is'); util.inherits = require('inherits'); /**/ /**/ var internalUtil = { deprecate: require('util-deprecate') }; /**/ /**/ var Stream; (function () { try { Stream = require('st' + 'ream'); } catch (_) {} finally { if (!Stream) Stream = require('events').EventEmitter; } })(); /**/ var Buffer = require('buffer').Buffer; util.inherits(Writable, Stream); function nop() {} function WriteReq(chunk, encoding, cb) { this.chunk = chunk; this.encoding = encoding; this.callback = cb; this.next = null; } var Duplex; function WritableState(options, stream) { Duplex = Duplex || require('./_stream_duplex'); options = options || {}; // object stream flag to indicate whether or not this stream // contains buffers or objects. this.objectMode = !!options.objectMode; if (stream instanceof Duplex) this.objectMode = this.objectMode || !!options.writableObjectMode; // the point at which write() starts returning false // Note: 0 is a valid value, means that we always return false if // the entire buffer is not flushed immediately on write() var hwm = options.highWaterMark; var defaultHwm = this.objectMode ? 16 : 16 * 1024; this.highWaterMark = hwm || hwm === 0 ? hwm : defaultHwm; // cast to ints. this.highWaterMark = ~ ~this.highWaterMark; this.needDrain = false; // at the start of calling end() this.ending = false; // when end() has been called, and returned this.ended = false; // when 'finish' is emitted this.finished = false; // should we decode strings into buffers before passing to _write? // this is here so that some node-core streams can optimize string // handling at a lower level. var noDecode = options.decodeStrings === false; this.decodeStrings = !noDecode; // Crypto is kind of old and crusty. Historically, its default string // encoding is 'binary' so we have to make this configurable. // Everything else in the universe uses 'utf8', though. this.defaultEncoding = options.defaultEncoding || 'utf8'; // not an actual buffer we keep track of, but a measurement // of how much we're waiting to get pushed to some underlying // socket or file. this.length = 0; // a flag to see when we're in the middle of a write. this.writing = false; // when true all writes will be buffered until .uncork() call this.corked = 0; // a flag to be able to tell if the onwrite cb is called immediately, // or on a later tick. We set this to true at first, because any // actions that shouldn't happen until "later" should generally also // not happen before the first write call. this.sync = true; // a flag to know if we're processing previously buffered items, which // may call the _write() callback in the same tick, so that we don't // end up in an overlapped onwrite situation. this.bufferProcessing = false; // the callback that's passed to _write(chunk,cb) this.onwrite = function (er) { onwrite(stream, er); }; // the callback that the user supplies to write(chunk,encoding,cb) this.writecb = null; // the amount that is being written when _write is called. this.writelen = 0; this.bufferedRequest = null; this.lastBufferedRequest = null; // number of pending user-supplied write callbacks // this must be 0 before 'finish' can be emitted this.pendingcb = 0; // emit prefinish if the only thing we're waiting for is _write cbs // This is relevant for synchronous Transform streams this.prefinished = false; // True if the error was already emitted and should not be thrown again this.errorEmitted = false; // count buffered requests this.bufferedRequestCount = 0; // create the two objects needed to store the corked requests // they are not a linked list, as no new elements are inserted in there this.corkedRequestsFree = new CorkedRequest(this); this.corkedRequestsFree.next = new CorkedRequest(this); } WritableState.prototype.getBuffer = function writableStateGetBuffer() { var current = this.bufferedRequest; var out = []; while (current) { out.push(current); current = current.next; } return out; }; (function () { try { Object.defineProperty(WritableState.prototype, 'buffer', { get: internalUtil.deprecate(function () { return this.getBuffer(); }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.') }); } catch (_) {} })(); var Duplex; function Writable(options) { Duplex = Duplex || require('./_stream_duplex'); // Writable ctor is applied to Duplexes, though they're not // instanceof Writable, they're instanceof Readable. if (!(this instanceof Writable) && !(this instanceof Duplex)) return new Writable(options); this._writableState = new WritableState(options, this); // legacy. this.writable = true; if (options) { if (typeof options.write === 'function') this._write = options.write; if (typeof options.writev === 'function') this._writev = options.writev; } Stream.call(this); } // Otherwise people can pipe Writable streams, which is just wrong. Writable.prototype.pipe = function () { this.emit('error', new Error('Cannot pipe. Not readable.')); }; function writeAfterEnd(stream, cb) { var er = new Error('write after end'); // TODO: defer error events consistently everywhere, not just the cb stream.emit('error', er); processNextTick(cb, er); } // If we get something that is not a buffer, string, null, or undefined, // and we're not in objectMode, then that's an error. // Otherwise stream chunks are all considered to be of length=1, and the // watermarks determine how many objects to keep in the buffer, rather than // how many bytes or characters. function validChunk(stream, state, chunk, cb) { var valid = true; if (!Buffer.isBuffer(chunk) && typeof chunk !== 'string' && chunk !== null && chunk !== undefined && !state.objectMode) { var er = new TypeError('Invalid non-string/buffer chunk'); stream.emit('error', er); processNextTick(cb, er); valid = false; } return valid; } Writable.prototype.write = function (chunk, encoding, cb) { var state = this._writableState; var ret = false; if (typeof encoding === 'function') { cb = encoding; encoding = null; } if (Buffer.isBuffer(chunk)) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding; if (typeof cb !== 'function') cb = nop; if (state.ended) writeAfterEnd(this, cb);else if (validChunk(this, state, chunk, cb)) { state.pendingcb++; ret = writeOrBuffer(this, state, chunk, encoding, cb); } return ret; }; Writable.prototype.cork = function () { var state = this._writableState; state.corked++; }; Writable.prototype.uncork = function () { var state = this._writableState; if (state.corked) { state.corked--; if (!state.writing && !state.corked && !state.finished && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state); } }; Writable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) { // node::ParseEncoding() requires lower case. if (typeof encoding === 'string') encoding = encoding.toLowerCase(); if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new TypeError('Unknown encoding: ' + encoding); this._writableState.defaultEncoding = encoding; }; function decodeChunk(state, chunk, encoding) { if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') { chunk = new Buffer(chunk, encoding); } return chunk; } // if we're already writing something, then just put this // in the queue, and wait our turn. Otherwise, call _write // If we return false, then we need a drain event, so set that flag. function writeOrBuffer(stream, state, chunk, encoding, cb) { chunk = decodeChunk(state, chunk, encoding); if (Buffer.isBuffer(chunk)) encoding = 'buffer'; var len = state.objectMode ? 1 : chunk.length; state.length += len; var ret = state.length < state.highWaterMark; // we must ensure that previous needDrain will not be reset to false. if (!ret) state.needDrain = true; if (state.writing || state.corked) { var last = state.lastBufferedRequest; state.lastBufferedRequest = new WriteReq(chunk, encoding, cb); if (last) { last.next = state.lastBufferedRequest; } else { state.bufferedRequest = state.lastBufferedRequest; } state.bufferedRequestCount += 1; } else { doWrite(stream, state, false, len, chunk, encoding, cb); } return ret; } function doWrite(stream, state, writev, len, chunk, encoding, cb) { state.writelen = len; state.writecb = cb; state.writing = true; state.sync = true; if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite); state.sync = false; } function onwriteError(stream, state, sync, er, cb) { --state.pendingcb; if (sync) processNextTick(cb, er);else cb(er); stream._writableState.errorEmitted = true; stream.emit('error', er); } function onwriteStateUpdate(state) { state.writing = false; state.writecb = null; state.length -= state.writelen; state.writelen = 0; } function onwrite(stream, er) { var state = stream._writableState; var sync = state.sync; var cb = state.writecb; onwriteStateUpdate(state); if (er) onwriteError(stream, state, sync, er, cb);else { // Check if we're actually ready to finish, but don't emit yet var finished = needFinish(state); if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) { clearBuffer(stream, state); } if (sync) { /**/ asyncWrite(afterWrite, stream, state, finished, cb); /**/ } else { afterWrite(stream, state, finished, cb); } } } function afterWrite(stream, state, finished, cb) { if (!finished) onwriteDrain(stream, state); state.pendingcb--; cb(); finishMaybe(stream, state); } // Must force callback to be called on nextTick, so that we don't // emit 'drain' before the write() consumer gets the 'false' return // value, and has a chance to attach a 'drain' listener. function onwriteDrain(stream, state) { if (state.length === 0 && state.needDrain) { state.needDrain = false; stream.emit('drain'); } } // if there's something in the buffer waiting, then process it function clearBuffer(stream, state) { state.bufferProcessing = true; var entry = state.bufferedRequest; if (stream._writev && entry && entry.next) { // Fast case, write everything using _writev() var l = state.bufferedRequestCount; var buffer = new Array(l); var holder = state.corkedRequestsFree; holder.entry = entry; var count = 0; while (entry) { buffer[count] = entry; entry = entry.next; count += 1; } doWrite(stream, state, true, state.length, buffer, '', holder.finish); // doWrite is always async, defer these to save a bit of time // as the hot path ends with doWrite state.pendingcb++; state.lastBufferedRequest = null; state.corkedRequestsFree = holder.next; holder.next = null; } else { // Slow case, write chunks one-by-one while (entry) { var chunk = entry.chunk; var encoding = entry.encoding; var cb = entry.callback; var len = state.objectMode ? 1 : chunk.length; doWrite(stream, state, false, len, chunk, encoding, cb); entry = entry.next; // if we didn't call the onwrite immediately, then // it means that we need to wait until it does. // also, that means that the chunk and cb are currently // being processed, so move the buffer counter past them. if (state.writing) { break; } } if (entry === null) state.lastBufferedRequest = null; } state.bufferedRequestCount = 0; state.bufferedRequest = entry; state.bufferProcessing = false; } Writable.prototype._write = function (chunk, encoding, cb) { cb(new Error('not implemented')); }; Writable.prototype._writev = null; Writable.prototype.end = function (chunk, encoding, cb) { var state = this._writableState; if (typeof chunk === 'function') { cb = chunk; chunk = null; encoding = null; } else if (typeof encoding === 'function') { cb = encoding; encoding = null; } if (chunk !== null && chunk !== undefined) this.write(chunk, encoding); // .end() fully uncorks if (state.corked) { state.corked = 1; this.uncork(); } // ignore unnecessary end() calls. if (!state.ending && !state.finished) endWritable(this, state, cb); }; function needFinish(state) { return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing; } function prefinish(stream, state) { if (!state.prefinished) { state.prefinished = true; stream.emit('prefinish'); } } function finishMaybe(stream, state) { var need = needFinish(state); if (need) { if (state.pendingcb === 0) { prefinish(stream, state); state.finished = true; stream.emit('finish'); } else { prefinish(stream, state); } } return need; } function endWritable(stream, state, cb) { state.ending = true; finishMaybe(stream, state); if (cb) { if (state.finished) processNextTick(cb);else stream.once('finish', cb); } state.ended = true; stream.writable = false; } // It seems a linked list but it is not // there will be only 2 of these for each stream function CorkedRequest(state) { var _this = this; this.next = null; this.entry = null; this.finish = function (err) { var entry = _this.entry; _this.entry = null; while (entry) { var cb = entry.callback; state.pendingcb--; cb(err); entry = entry.next; } if (state.corkedRequestsFree) { state.corkedRequestsFree.next = _this; } else { state.corkedRequestsFree = _this; } }; } }).call(this,require('_process')) },{"./_stream_duplex":25,"_process":295,"buffer":61,"core-util-is":104,"events":144,"inherits":167,"process-nextick-args":294,"util-deprecate":634}],28:[function(require,module,exports){ var Buffer = require('buffer').Buffer var BLAKE2s = (function () { function BLAKE2s(digestLength, key) { if (typeof digestLength === "undefined") { digestLength = 32; } this.isFinished = false; this.digestLength = 32; this.blockLength = 64; this.iv = [ 0x6a09e667, 0xbb67ae85, 0x3c6ef372, 0xa54ff53a, 0x510e527f, 0x9b05688c, 0x1f83d9ab, 0x5be0cd19 ]; //TODO tree mode. if (digestLength <= 0) { digestLength = this.digestLength; } else if (digestLength > 32) { throw 'digestLength is too large'; } var keyLength = 0; if (typeof key == 'string') { key = this.stringToUtf8Array(key); keyLength = key.length; } else if (typeof key == 'object') { keyLength = key.length; } if (keyLength > 32) { throw 'key too long'; } var param = [digestLength & 0xff, keyLength, 1, 1]; this.h = this.iv.slice(0); // XOR part of parameter block. this.h[0] ^= this.load32(param, 0); this.x = new Array(64); this.t0 = 0; this.t1 = 0; this.f0 = 0; this.f1 = 0; this.nx = 0; this.digestLength = digestLength; if (keyLength > 0) { for (var i = 0; i < keyLength; i++) { this.x[i] = key[i]; } for (var i = keyLength; i < 64; i++) { this.x[i] = 0; } this.nx = 64; } } BLAKE2s.prototype.load32 = function (p, pos) { return ((p[pos] & 0xff) | ((p[pos + 1] & 0xff) << 8) | ((p[pos + 2] & 0xff) << 16) | ((p[pos + 3] & 0xff) << 24)) >>> 0; }; BLAKE2s.prototype.store32 = function (p, pos, v) { p[pos] = (v >>> 0) & 0xff; p[pos + 1] = (v >>> 8) & 0xff; p[pos + 2] = (v >>> 16) & 0xff; p[pos + 3] = (v >>> 24) & 0xff; }; BLAKE2s.prototype.processBlock = function (length) { this.t0 += length; if (this.t0 != this.t0 >>> 0) { this.t0 = 0; this.t1++; } var v0 = this.h[0], v1 = this.h[1], v2 = this.h[2], v3 = this.h[3], v4 = this.h[4], v5 = this.h[5], v6 = this.h[6], v7 = this.h[7], v8 = this.iv[0], v9 = this.iv[1], v10 = this.iv[2], v11 = this.iv[3], v12 = this.iv[4] ^ this.t0, v13 = this.iv[5] ^ this.t1, v14 = this.iv[6] ^ this.f0, v15 = this.iv[7] ^ this.f1; var m0 = this.load32(this.x, 0), m1 = this.load32(this.x, 4), m2 = this.load32(this.x, 8), m3 = this.load32(this.x, 12), m4 = this.load32(this.x, 16), m5 = this.load32(this.x, 20), m6 = this.load32(this.x, 24), m7 = this.load32(this.x, 28), m8 = this.load32(this.x, 32), m9 = this.load32(this.x, 36), m10 = this.load32(this.x, 40), m11 = this.load32(this.x, 44), m12 = this.load32(this.x, 48), m13 = this.load32(this.x, 52), m14 = this.load32(this.x, 56), m15 = this.load32(this.x, 60); // Round 1. v0 += m0; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 16) | v12 >>> 16; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 12) | v4 >>> 12; v1 += m2; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 16) | v13 >>> 16; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 12) | v5 >>> 12; v2 += m4; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 16) | v14 >>> 16; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 12) | v6 >>> 12; v3 += m6; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 16) | v15 >>> 16; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 12) | v7 >>> 12; v2 += m5; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 8) | v14 >>> 8; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 7) | v6 >>> 7; v3 += m7; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 8) | v15 >>> 8; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 7) | v7 >>> 7; v1 += m3; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 8) | v13 >>> 8; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 7) | v5 >>> 7; v0 += m1; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 8) | v12 >>> 8; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 7) | v4 >>> 7; v0 += m8; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 16) | v15 >>> 16; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 12) | v5 >>> 12; v1 += m10; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 16) | v12 >>> 16; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 12) | v6 >>> 12; v2 += m12; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 16) | v13 >>> 16; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 12) | v7 >>> 12; v3 += m14; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 16) | v14 >>> 16; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 12) | v4 >>> 12; v2 += m13; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 8) | v13 >>> 8; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 7) | v7 >>> 7; v3 += m15; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 8) | v14 >>> 8; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 7) | v4 >>> 7; v1 += m11; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 8) | v12 >>> 8; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 7) | v6 >>> 7; v0 += m9; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 8) | v15 >>> 8; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 7) | v5 >>> 7; // Round 2. v0 += m14; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 16) | v12 >>> 16; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 12) | v4 >>> 12; v1 += m4; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 16) | v13 >>> 16; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 12) | v5 >>> 12; v2 += m9; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 16) | v14 >>> 16; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 12) | v6 >>> 12; v3 += m13; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 16) | v15 >>> 16; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 12) | v7 >>> 12; v2 += m15; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 8) | v14 >>> 8; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 7) | v6 >>> 7; v3 += m6; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 8) | v15 >>> 8; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 7) | v7 >>> 7; v1 += m8; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 8) | v13 >>> 8; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 7) | v5 >>> 7; v0 += m10; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 8) | v12 >>> 8; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 7) | v4 >>> 7; v0 += m1; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 16) | v15 >>> 16; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 12) | v5 >>> 12; v1 += m0; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 16) | v12 >>> 16; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 12) | v6 >>> 12; v2 += m11; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 16) | v13 >>> 16; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 12) | v7 >>> 12; v3 += m5; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 16) | v14 >>> 16; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 12) | v4 >>> 12; v2 += m7; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 8) | v13 >>> 8; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 7) | v7 >>> 7; v3 += m3; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 8) | v14 >>> 8; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 7) | v4 >>> 7; v1 += m2; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 8) | v12 >>> 8; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 7) | v6 >>> 7; v0 += m12; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 8) | v15 >>> 8; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 7) | v5 >>> 7; // Round 3. v0 += m11; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 16) | v12 >>> 16; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 12) | v4 >>> 12; v1 += m12; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 16) | v13 >>> 16; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 12) | v5 >>> 12; v2 += m5; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 16) | v14 >>> 16; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 12) | v6 >>> 12; v3 += m15; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 16) | v15 >>> 16; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 12) | v7 >>> 12; v2 += m2; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 8) | v14 >>> 8; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 7) | v6 >>> 7; v3 += m13; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 8) | v15 >>> 8; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 7) | v7 >>> 7; v1 += m0; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 8) | v13 >>> 8; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 7) | v5 >>> 7; v0 += m8; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 8) | v12 >>> 8; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 7) | v4 >>> 7; v0 += m10; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 16) | v15 >>> 16; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 12) | v5 >>> 12; v1 += m3; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 16) | v12 >>> 16; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 12) | v6 >>> 12; v2 += m7; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 16) | v13 >>> 16; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 12) | v7 >>> 12; v3 += m9; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 16) | v14 >>> 16; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 12) | v4 >>> 12; v2 += m1; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 8) | v13 >>> 8; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 7) | v7 >>> 7; v3 += m4; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 8) | v14 >>> 8; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 7) | v4 >>> 7; v1 += m6; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 8) | v12 >>> 8; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 7) | v6 >>> 7; v0 += m14; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 8) | v15 >>> 8; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 7) | v5 >>> 7; // Round 4. v0 += m7; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 16) | v12 >>> 16; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 12) | v4 >>> 12; v1 += m3; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 16) | v13 >>> 16; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 12) | v5 >>> 12; v2 += m13; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 16) | v14 >>> 16; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 12) | v6 >>> 12; v3 += m11; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 16) | v15 >>> 16; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 12) | v7 >>> 12; v2 += m12; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 8) | v14 >>> 8; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 7) | v6 >>> 7; v3 += m14; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 8) | v15 >>> 8; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 7) | v7 >>> 7; v1 += m1; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 8) | v13 >>> 8; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 7) | v5 >>> 7; v0 += m9; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 8) | v12 >>> 8; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 7) | v4 >>> 7; v0 += m2; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 16) | v15 >>> 16; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 12) | v5 >>> 12; v1 += m5; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 16) | v12 >>> 16; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 12) | v6 >>> 12; v2 += m4; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 16) | v13 >>> 16; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 12) | v7 >>> 12; v3 += m15; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 16) | v14 >>> 16; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 12) | v4 >>> 12; v2 += m0; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 8) | v13 >>> 8; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 7) | v7 >>> 7; v3 += m8; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 8) | v14 >>> 8; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 7) | v4 >>> 7; v1 += m10; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 8) | v12 >>> 8; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 7) | v6 >>> 7; v0 += m6; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 8) | v15 >>> 8; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 7) | v5 >>> 7; // Round 5. v0 += m9; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 16) | v12 >>> 16; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 12) | v4 >>> 12; v1 += m5; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 16) | v13 >>> 16; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 12) | v5 >>> 12; v2 += m2; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 16) | v14 >>> 16; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 12) | v6 >>> 12; v3 += m10; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 16) | v15 >>> 16; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 12) | v7 >>> 12; v2 += m4; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 8) | v14 >>> 8; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 7) | v6 >>> 7; v3 += m15; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 8) | v15 >>> 8; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 7) | v7 >>> 7; v1 += m7; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 8) | v13 >>> 8; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 7) | v5 >>> 7; v0 += m0; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 8) | v12 >>> 8; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 7) | v4 >>> 7; v0 += m14; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 16) | v15 >>> 16; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 12) | v5 >>> 12; v1 += m11; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 16) | v12 >>> 16; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 12) | v6 >>> 12; v2 += m6; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 16) | v13 >>> 16; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 12) | v7 >>> 12; v3 += m3; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 16) | v14 >>> 16; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 12) | v4 >>> 12; v2 += m8; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 8) | v13 >>> 8; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 7) | v7 >>> 7; v3 += m13; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 8) | v14 >>> 8; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 7) | v4 >>> 7; v1 += m12; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 8) | v12 >>> 8; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 7) | v6 >>> 7; v0 += m1; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 8) | v15 >>> 8; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 7) | v5 >>> 7; // Round 6. v0 += m2; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 16) | v12 >>> 16; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 12) | v4 >>> 12; v1 += m6; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 16) | v13 >>> 16; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 12) | v5 >>> 12; v2 += m0; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 16) | v14 >>> 16; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 12) | v6 >>> 12; v3 += m8; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 16) | v15 >>> 16; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 12) | v7 >>> 12; v2 += m11; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 8) | v14 >>> 8; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 7) | v6 >>> 7; v3 += m3; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 8) | v15 >>> 8; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 7) | v7 >>> 7; v1 += m10; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 8) | v13 >>> 8; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 7) | v5 >>> 7; v0 += m12; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 8) | v12 >>> 8; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 7) | v4 >>> 7; v0 += m4; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 16) | v15 >>> 16; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 12) | v5 >>> 12; v1 += m7; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 16) | v12 >>> 16; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 12) | v6 >>> 12; v2 += m15; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 16) | v13 >>> 16; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 12) | v7 >>> 12; v3 += m1; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 16) | v14 >>> 16; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 12) | v4 >>> 12; v2 += m14; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 8) | v13 >>> 8; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 7) | v7 >>> 7; v3 += m9; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 8) | v14 >>> 8; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 7) | v4 >>> 7; v1 += m5; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 8) | v12 >>> 8; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 7) | v6 >>> 7; v0 += m13; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 8) | v15 >>> 8; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 7) | v5 >>> 7; // Round 7. v0 += m12; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 16) | v12 >>> 16; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 12) | v4 >>> 12; v1 += m1; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 16) | v13 >>> 16; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 12) | v5 >>> 12; v2 += m14; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 16) | v14 >>> 16; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 12) | v6 >>> 12; v3 += m4; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 16) | v15 >>> 16; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 12) | v7 >>> 12; v2 += m13; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 8) | v14 >>> 8; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 7) | v6 >>> 7; v3 += m10; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 8) | v15 >>> 8; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 7) | v7 >>> 7; v1 += m15; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 8) | v13 >>> 8; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 7) | v5 >>> 7; v0 += m5; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 8) | v12 >>> 8; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 7) | v4 >>> 7; v0 += m0; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 16) | v15 >>> 16; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 12) | v5 >>> 12; v1 += m6; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 16) | v12 >>> 16; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 12) | v6 >>> 12; v2 += m9; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 16) | v13 >>> 16; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 12) | v7 >>> 12; v3 += m8; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 16) | v14 >>> 16; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 12) | v4 >>> 12; v2 += m2; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 8) | v13 >>> 8; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 7) | v7 >>> 7; v3 += m11; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 8) | v14 >>> 8; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 7) | v4 >>> 7; v1 += m3; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 8) | v12 >>> 8; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 7) | v6 >>> 7; v0 += m7; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 8) | v15 >>> 8; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 7) | v5 >>> 7; // Round 8. v0 += m13; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 16) | v12 >>> 16; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 12) | v4 >>> 12; v1 += m7; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 16) | v13 >>> 16; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 12) | v5 >>> 12; v2 += m12; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 16) | v14 >>> 16; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 12) | v6 >>> 12; v3 += m3; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 16) | v15 >>> 16; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 12) | v7 >>> 12; v2 += m1; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 8) | v14 >>> 8; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 7) | v6 >>> 7; v3 += m9; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 8) | v15 >>> 8; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 7) | v7 >>> 7; v1 += m14; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 8) | v13 >>> 8; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 7) | v5 >>> 7; v0 += m11; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 8) | v12 >>> 8; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 7) | v4 >>> 7; v0 += m5; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 16) | v15 >>> 16; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 12) | v5 >>> 12; v1 += m15; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 16) | v12 >>> 16; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 12) | v6 >>> 12; v2 += m8; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 16) | v13 >>> 16; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 12) | v7 >>> 12; v3 += m2; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 16) | v14 >>> 16; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 12) | v4 >>> 12; v2 += m6; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 8) | v13 >>> 8; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 7) | v7 >>> 7; v3 += m10; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 8) | v14 >>> 8; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 7) | v4 >>> 7; v1 += m4; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 8) | v12 >>> 8; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 7) | v6 >>> 7; v0 += m0; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 8) | v15 >>> 8; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 7) | v5 >>> 7; // Round 9. v0 += m6; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 16) | v12 >>> 16; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 12) | v4 >>> 12; v1 += m14; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 16) | v13 >>> 16; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 12) | v5 >>> 12; v2 += m11; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 16) | v14 >>> 16; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 12) | v6 >>> 12; v3 += m0; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 16) | v15 >>> 16; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 12) | v7 >>> 12; v2 += m3; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 8) | v14 >>> 8; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 7) | v6 >>> 7; v3 += m8; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 8) | v15 >>> 8; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 7) | v7 >>> 7; v1 += m9; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 8) | v13 >>> 8; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 7) | v5 >>> 7; v0 += m15; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 8) | v12 >>> 8; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 7) | v4 >>> 7; v0 += m12; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 16) | v15 >>> 16; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 12) | v5 >>> 12; v1 += m13; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 16) | v12 >>> 16; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 12) | v6 >>> 12; v2 += m1; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 16) | v13 >>> 16; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 12) | v7 >>> 12; v3 += m10; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 16) | v14 >>> 16; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 12) | v4 >>> 12; v2 += m4; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 8) | v13 >>> 8; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 7) | v7 >>> 7; v3 += m5; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 8) | v14 >>> 8; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 7) | v4 >>> 7; v1 += m7; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 8) | v12 >>> 8; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 7) | v6 >>> 7; v0 += m2; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 8) | v15 >>> 8; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 7) | v5 >>> 7; // Round 10. v0 += m10; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 16) | v12 >>> 16; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 12) | v4 >>> 12; v1 += m8; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 16) | v13 >>> 16; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 12) | v5 >>> 12; v2 += m7; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 16) | v14 >>> 16; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 12) | v6 >>> 12; v3 += m1; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 16) | v15 >>> 16; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 12) | v7 >>> 12; v2 += m6; v2 += v6; v14 ^= v2; v14 = v14 << (32 - 8) | v14 >>> 8; v10 += v14; v6 ^= v10; v6 = v6 << (32 - 7) | v6 >>> 7; v3 += m5; v3 += v7; v15 ^= v3; v15 = v15 << (32 - 8) | v15 >>> 8; v11 += v15; v7 ^= v11; v7 = v7 << (32 - 7) | v7 >>> 7; v1 += m4; v1 += v5; v13 ^= v1; v13 = v13 << (32 - 8) | v13 >>> 8; v9 += v13; v5 ^= v9; v5 = v5 << (32 - 7) | v5 >>> 7; v0 += m2; v0 += v4; v12 ^= v0; v12 = v12 << (32 - 8) | v12 >>> 8; v8 += v12; v4 ^= v8; v4 = v4 << (32 - 7) | v4 >>> 7; v0 += m15; v0 += v5; v15 ^= v0; v15 = v15 << (32 - 16) | v15 >>> 16; v10 += v15; v5 ^= v10; v5 = v5 << (32 - 12) | v5 >>> 12; v1 += m9; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 16) | v12 >>> 16; v11 += v12; v6 ^= v11; v6 = v6 << (32 - 12) | v6 >>> 12; v2 += m3; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 16) | v13 >>> 16; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 12) | v7 >>> 12; v3 += m13; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 16) | v14 >>> 16; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 12) | v4 >>> 12; v2 += m12; v2 += v7; v13 ^= v2; v13 = v13 << (32 - 8) | v13 >>> 8; v8 += v13; v7 ^= v8; v7 = v7 << (32 - 7) | v7 >>> 7; v3 += m0; v3 += v4; v14 ^= v3; v14 = v14 << (32 - 8) | v14 >>> 8; v9 += v14; v4 ^= v9; v4 = v4 << (32 - 7) | v4 >>> 7; v1 += m14; v1 += v6; v12 ^= v1; v12 = v12 << (32 - 8) | v12 >>> 8; v11 += v12; v6 ^= v11; v6 = (v6 << (32 - 7)) | (v6 >>> 7); v0 += m11; v0 += v5; v15 ^= v0; v15 = (v15 << (32 - 8)) | (v15 >>> 8); v10 += v15; v5 ^= v10; v5 = (v5 << (32 - 7)) | (v5 >>> 7); this.h[0] ^= v0 ^ v8; this.h[1] ^= v1 ^ v9; this.h[2] ^= v2 ^ v10; this.h[3] ^= v3 ^ v11; this.h[4] ^= v4 ^ v12; this.h[5] ^= v5 ^ v13; this.h[6] ^= v6 ^ v14; this.h[7] ^= v7 ^ v15; }; BLAKE2s.prototype.stringToUtf8Array = function (s) { var arr = []; for (var i = 0; i < s.length; i++) { var c = s.charCodeAt(i); if (c < 128) { arr.push(c); } else if (c > 127 && c < 2048) { arr.push((c >> 6) | 192); arr.push((c & 63) | 128); } else { arr.push((c >> 12) | 224); arr.push(((c >> 6) & 63) | 128); arr.push((c & 64) | 128); } } return arr; }; BLAKE2s.prototype._update = function (p, offset, length) { if (typeof offset === "undefined") { offset = 0; } if (typeof length === "undefined") { length = p.length; } if (this.isFinished) { throw 'update() after calling digest()'; } if (typeof p == 'string') { if (offset != 0) { throw 'offset not supported for strings'; } p = this.stringToUtf8Array(p); length = p.length; offset = 0; } else if (typeof p != 'object') { throw 'unsupported object: string or array required'; } if (length == 0) { return; } var left = 64 - this.nx; if (length > left) { for (var i = 0; i < left; i++) { this.x[this.nx + i] = p[offset + i]; } this.processBlock(64); offset += left; length -= left; this.nx = 0; } while (length > 64) { for (var i = 0; i < 64; i++) { this.x[i] = p[offset + i]; } this.processBlock(64); offset += 64; length -= 64; this.nx = 0; } for (var i = 0; i < length; i++) { this.x[this.nx + i] = p[offset + i]; } this.nx += length; }; BLAKE2s.prototype.update = function (buffer, enc) { if(enc) buffer = new Buffer(buffer, enc) this._update(buffer) return this } BLAKE2s.prototype.digest = function (enc) { if (this.isFinished) { return this.result; } for (var i = this.nx; i < 64; i++) { this.x[i] = 0; } // Set last block flag. this.f0 = 0xffffffff; //TODO in tree mode, set f1 to 0xffffffff. this.processBlock(this.nx); var out = new Buffer(32); for (var i = 0; i < 8; i++) { var h = this.h[i]; out[i * 4 + 0] = (h >>> 0) & 0xff; out[i * 4 + 1] = (h >>> 8) & 0xff; out[i * 4 + 2] = (h >>> 16) & 0xff; out[i * 4 + 3] = (h >>> 24) & 0xff; } this.result = out.slice(0, this.digestLength); this.isFinished = true; return enc ? this.result.toString(enc) : this.result; }; return BLAKE2s; })(); if('undefined' === typeof module) window.Blake2s = BLAKE2s else module.exports = BLAKE2s },{"buffer":61}],29:[function(require,module,exports){ (function (module, exports) { 'use strict'; // Utils function assert (val, msg) { if (!val) throw new Error(msg || 'Assertion failed'); } // Could use `inherits` module, but don't want to move from single file // architecture yet. function inherits (ctor, superCtor) { ctor.super_ = superCtor; var TempCtor = function () {}; TempCtor.prototype = superCtor.prototype; ctor.prototype = new TempCtor(); ctor.prototype.constructor = ctor; } // BN function BN (number, base, endian) { if (BN.isBN(number)) { return number; } this.negative = 0; this.words = null; this.length = 0; // Reduction context this.red = null; if (number !== null) { if (base === 'le' || base === 'be') { endian = base; base = 10; } this._init(number || 0, base || 10, endian || 'be'); } } if (typeof module === 'object') { module.exports = BN; } else { exports.BN = BN; } BN.BN = BN; BN.wordSize = 26; var Buffer; try { Buffer = require('buf' + 'fer').Buffer; } catch (e) { } BN.isBN = function isBN (num) { return num !== null && typeof num === 'object' && num.constructor.name === 'BN' && Array.isArray(num.words); }; BN.max = function max (left, right) { if (left.cmp(right) > 0) return left; return right; }; BN.min = function min (left, right) { if (left.cmp(right) < 0) return left; return right; }; BN.prototype._init = function init (number, base, endian) { if (typeof number === 'number') { return this._initNumber(number, base, endian); } if (typeof number === 'object') { return this._initArray(number, base, endian); } if (base === 'hex') { base = 16; } assert(base === (base | 0) && base >= 2 && base <= 36); number = number.toString().replace(/\s+/g, ''); var start = 0; if (number[0] === '-') { start++; } if (base === 16) { this._parseHex(number, start); } else { this._parseBase(number, base, start); } if (number[0] === '-') { this.negative = 1; } this.strip(); if (endian !== 'le') return; this._initArray(this.toArray(), base, endian); }; BN.prototype._initNumber = function _initNumber (number, base, endian) { if (number < 0) { this.negative = 1; number = -number; } if (number < 0x4000000) { this.words = [ number & 0x3ffffff ]; this.length = 1; } else if (number < 0x10000000000000) { this.words = [ number & 0x3ffffff, (number / 0x4000000) & 0x3ffffff ]; this.length = 2; } else { assert(number < 0x20000000000000); // 2 ^ 53 (unsafe) this.words = [ number & 0x3ffffff, (number / 0x4000000) & 0x3ffffff, 1 ]; this.length = 3; } if (endian !== 'le') return; // Reverse the bytes this._initArray(this.toArray(), base, endian); }; BN.prototype._initArray = function _initArray (number, base, endian) { // Perhaps a Uint8Array assert(typeof number.length === 'number'); if (number.length <= 0) { this.words = [ 0 ]; this.length = 1; return this; } this.length = Math.ceil(number.length / 3); this.words = new Array(this.length); for (var i = 0; i < this.length; i++) { this.words[i] = 0; } var j, w; var off = 0; if (endian === 'be') { for (i = number.length - 1, j = 0; i >= 0; i -= 3) { w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16); this.words[j] |= (w << off) & 0x3ffffff; this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff; off += 24; if (off >= 26) { off -= 26; j++; } } } else if (endian === 'le') { for (i = 0, j = 0; i < number.length; i += 3) { w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16); this.words[j] |= (w << off) & 0x3ffffff; this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff; off += 24; if (off >= 26) { off -= 26; j++; } } } return this.strip(); }; function parseHex (str, start, end) { var r = 0; var len = Math.min(str.length, end); for (var i = start; i < len; i++) { var c = str.charCodeAt(i) - 48; r <<= 4; // 'a' - 'f' if (c >= 49 && c <= 54) { r |= c - 49 + 0xa; // 'A' - 'F' } else if (c >= 17 && c <= 22) { r |= c - 17 + 0xa; // '0' - '9' } else { r |= c & 0xf; } } return r; } BN.prototype._parseHex = function _parseHex (number, start) { // Create possibly bigger array to ensure that it fits the number this.length = Math.ceil((number.length - start) / 6); this.words = new Array(this.length); for (var i = 0; i < this.length; i++) { this.words[i] = 0; } var j, w; // Scan 24-bit chunks and add them to the number var off = 0; for (i = number.length - 6, j = 0; i >= start; i -= 6) { w = parseHex(number, i, i + 6); this.words[j] |= (w << off) & 0x3ffffff; // NOTE: `0x3fffff` is intentional here, 26bits max shift + 24bit hex limb this.words[j + 1] |= w >>> (26 - off) & 0x3fffff; off += 24; if (off >= 26) { off -= 26; j++; } } if (i + 6 !== start) { w = parseHex(number, start, i + 6); this.words[j] |= (w << off) & 0x3ffffff; this.words[j + 1] |= w >>> (26 - off) & 0x3fffff; } this.strip(); }; function parseBase (str, start, end, mul) { var r = 0; var len = Math.min(str.length, end); for (var i = start; i < len; i++) { var c = str.charCodeAt(i) - 48; r *= mul; // 'a' if (c >= 49) { r += c - 49 + 0xa; // 'A' } else if (c >= 17) { r += c - 17 + 0xa; // '0' - '9' } else { r += c; } } return r; } BN.prototype._parseBase = function _parseBase (number, base, start) { // Initialize as zero this.words = [ 0 ]; this.length = 1; // Find length of limb in base for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) { limbLen++; } limbLen--; limbPow = (limbPow / base) | 0; var total = number.length - start; var mod = total % limbLen; var end = Math.min(total, total - mod) + start; var word = 0; for (var i = start; i < end; i += limbLen) { word = parseBase(number, i, i + limbLen, base); this.imuln(limbPow); if (this.words[0] + word < 0x4000000) { this.words[0] += word; } else { this._iaddn(word); } } if (mod !== 0) { var pow = 1; word = parseBase(number, i, number.length, base); for (i = 0; i < mod; i++) { pow *= base; } this.imuln(pow); if (this.words[0] + word < 0x4000000) { this.words[0] += word; } else { this._iaddn(word); } } }; BN.prototype.copy = function copy (dest) { dest.words = new Array(this.length); for (var i = 0; i < this.length; i++) { dest.words[i] = this.words[i]; } dest.length = this.length; dest.negative = this.negative; dest.red = this.red; }; BN.prototype.clone = function clone () { var r = new BN(null); this.copy(r); return r; }; BN.prototype._expand = function _expand (size) { while (this.length < size) { this.words[this.length++] = 0; } return this; }; // Remove leading `0` from `this` BN.prototype.strip = function strip () { while (this.length > 1 && this.words[this.length - 1] === 0) { this.length--; } return this._normSign(); }; BN.prototype._normSign = function _normSign () { // -0 = 0 if (this.length === 1 && this.words[0] === 0) { this.negative = 0; } return this; }; BN.prototype.inspect = function inspect () { return (this.red ? ''; }; /* var zeros = []; var groupSizes = []; var groupBases = []; var s = ''; var i = -1; while (++i < BN.wordSize) { zeros[i] = s; s += '0'; } groupSizes[0] = 0; groupSizes[1] = 0; groupBases[0] = 0; groupBases[1] = 0; var base = 2 - 1; while (++base < 36 + 1) { var groupSize = 0; var groupBase = 1; while (groupBase < (1 << BN.wordSize) / base) { groupBase *= base; groupSize += 1; } groupSizes[base] = groupSize; groupBases[base] = groupBase; } */ var zeros = [ '', '0', '00', '000', '0000', '00000', '000000', '0000000', '00000000', '000000000', '0000000000', '00000000000', '000000000000', '0000000000000', '00000000000000', '000000000000000', '0000000000000000', '00000000000000000', '000000000000000000', '0000000000000000000', '00000000000000000000', '000000000000000000000', '0000000000000000000000', '00000000000000000000000', '000000000000000000000000', '0000000000000000000000000' ]; var groupSizes = [ 0, 0, 25, 16, 12, 11, 10, 9, 8, 8, 7, 7, 7, 7, 6, 6, 6, 6, 6, 6, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5 ]; var groupBases = [ 0, 0, 33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216, 43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625, 16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632, 6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149, 24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176 ]; BN.prototype.toString = function toString (base, padding) { base = base || 10; padding = padding | 0 || 1; var out; if (base === 16 || base === 'hex') { out = ''; var off = 0; var carry = 0; for (var i = 0; i < this.length; i++) { var w = this.words[i]; var word = (((w << off) | carry) & 0xffffff).toString(16); carry = (w >>> (24 - off)) & 0xffffff; if (carry !== 0 || i !== this.length - 1) { out = zeros[6 - word.length] + word + out; } else { out = word + out; } off += 2; if (off >= 26) { off -= 26; i--; } } if (carry !== 0) { out = carry.toString(16) + out; } while (out.length % padding !== 0) { out = '0' + out; } if (this.negative !== 0) { out = '-' + out; } return out; } if (base === (base | 0) && base >= 2 && base <= 36) { // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base)); var groupSize = groupSizes[base]; // var groupBase = Math.pow(base, groupSize); var groupBase = groupBases[base]; out = ''; var c = this.clone(); c.negative = 0; while (!c.isZero()) { var r = c.modn(groupBase).toString(base); c = c.idivn(groupBase); if (!c.isZero()) { out = zeros[groupSize - r.length] + r + out; } else { out = r + out; } } if (this.isZero()) { out = '0' + out; } while (out.length % padding !== 0) { out = '0' + out; } if (this.negative !== 0) { out = '-' + out; } return out; } assert(false, 'Base should be between 2 and 36'); }; BN.prototype.toNumber = function toNumber () { var ret = this.words[0]; if (this.length === 2) { ret += this.words[1] * 0x4000000; } else if (this.length === 3 && this.words[2] === 0x01) { // NOTE: at this stage it is known that the top bit is set ret += 0x10000000000000 + (this.words[1] * 0x4000000); } else if (this.length > 2) { assert(false, 'Number can only safely store up to 53 bits'); } return (this.negative !== 0) ? -ret : ret; }; BN.prototype.toJSON = function toJSON () { return this.toString(16); }; BN.prototype.toBuffer = function toBuffer (endian, length) { assert(typeof Buffer !== 'undefined'); return this.toArrayLike(Buffer, endian, length); }; BN.prototype.toArray = function toArray (endian, length) { return this.toArrayLike(Array, endian, length); }; BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) { var byteLength = this.byteLength(); var reqLength = length || Math.max(1, byteLength); assert(byteLength <= reqLength, 'byte array longer than desired length'); assert(reqLength > 0, 'Requested array length <= 0'); this.strip(); var littleEndian = endian === 'le'; var res = new ArrayType(reqLength); var b, i; var q = this.clone(); if (!littleEndian) { // Assume big-endian for (i = 0; i < reqLength - byteLength; i++) { res[i] = 0; } for (i = 0; !q.isZero(); i++) { b = q.andln(0xff); q.iushrn(8); res[reqLength - i - 1] = b; } } else { for (i = 0; !q.isZero(); i++) { b = q.andln(0xff); q.iushrn(8); res[i] = b; } for (; i < reqLength; i++) { res[i] = 0; } } return res; }; if (Math.clz32) { BN.prototype._countBits = function _countBits (w) { return 32 - Math.clz32(w); }; } else { BN.prototype._countBits = function _countBits (w) { var t = w; var r = 0; if (t >= 0x1000) { r += 13; t >>>= 13; } if (t >= 0x40) { r += 7; t >>>= 7; } if (t >= 0x8) { r += 4; t >>>= 4; } if (t >= 0x02) { r += 2; t >>>= 2; } return r + t; }; } BN.prototype._zeroBits = function _zeroBits (w) { // Short-cut if (w === 0) return 26; var t = w; var r = 0; if ((t & 0x1fff) === 0) { r += 13; t >>>= 13; } if ((t & 0x7f) === 0) { r += 7; t >>>= 7; } if ((t & 0xf) === 0) { r += 4; t >>>= 4; } if ((t & 0x3) === 0) { r += 2; t >>>= 2; } if ((t & 0x1) === 0) { r++; } return r; }; // Return number of used bits in a BN BN.prototype.bitLength = function bitLength () { var w = this.words[this.length - 1]; var hi = this._countBits(w); return (this.length - 1) * 26 + hi; }; function toBitArray (num) { var w = new Array(num.bitLength()); for (var bit = 0; bit < w.length; bit++) { var off = (bit / 26) | 0; var wbit = bit % 26; w[bit] = (num.words[off] & (1 << wbit)) >>> wbit; } return w; } // Number of trailing zero bits BN.prototype.zeroBits = function zeroBits () { if (this.isZero()) return 0; var r = 0; for (var i = 0; i < this.length; i++) { var b = this._zeroBits(this.words[i]); r += b; if (b !== 26) break; } return r; }; BN.prototype.byteLength = function byteLength () { return Math.ceil(this.bitLength() / 8); }; BN.prototype.toTwos = function toTwos (width) { if (this.negative !== 0) { return this.abs().inotn(width).iaddn(1); } return this.clone(); }; BN.prototype.fromTwos = function fromTwos (width) { if (this.testn(width - 1)) { return this.notn(width).iaddn(1).ineg(); } return this.clone(); }; BN.prototype.isNeg = function isNeg () { return this.negative !== 0; }; // Return negative clone of `this` BN.prototype.neg = function neg () { return this.clone().ineg(); }; BN.prototype.ineg = function ineg () { if (!this.isZero()) { this.negative ^= 1; } return this; }; // Or `num` with `this` in-place BN.prototype.iuor = function iuor (num) { while (this.length < num.length) { this.words[this.length++] = 0; } for (var i = 0; i < num.length; i++) { this.words[i] = this.words[i] | num.words[i]; } return this.strip(); }; BN.prototype.ior = function ior (num) { assert((this.negative | num.negative) === 0); return this.iuor(num); }; // Or `num` with `this` BN.prototype.or = function or (num) { if (this.length > num.length) return this.clone().ior(num); return num.clone().ior(this); }; BN.prototype.uor = function uor (num) { if (this.length > num.length) return this.clone().iuor(num); return num.clone().iuor(this); }; // And `num` with `this` in-place BN.prototype.iuand = function iuand (num) { // b = min-length(num, this) var b; if (this.length > num.length) { b = num; } else { b = this; } for (var i = 0; i < b.length; i++) { this.words[i] = this.words[i] & num.words[i]; } this.length = b.length; return this.strip(); }; BN.prototype.iand = function iand (num) { assert((this.negative | num.negative) === 0); return this.iuand(num); }; // And `num` with `this` BN.prototype.and = function and (num) { if (this.length > num.length) return this.clone().iand(num); return num.clone().iand(this); }; BN.prototype.uand = function uand (num) { if (this.length > num.length) return this.clone().iuand(num); return num.clone().iuand(this); }; // Xor `num` with `this` in-place BN.prototype.iuxor = function iuxor (num) { // a.length > b.length var a; var b; if (this.length > num.length) { a = this; b = num; } else { a = num; b = this; } for (var i = 0; i < b.length; i++) { this.words[i] = a.words[i] ^ b.words[i]; } if (this !== a) { for (; i < a.length; i++) { this.words[i] = a.words[i]; } } this.length = a.length; return this.strip(); }; BN.prototype.ixor = function ixor (num) { assert((this.negative | num.negative) === 0); return this.iuxor(num); }; // Xor `num` with `this` BN.prototype.xor = function xor (num) { if (this.length > num.length) return this.clone().ixor(num); return num.clone().ixor(this); }; BN.prototype.uxor = function uxor (num) { if (this.length > num.length) return this.clone().iuxor(num); return num.clone().iuxor(this); }; // Not ``this`` with ``width`` bitwidth BN.prototype.inotn = function inotn (width) { assert(typeof width === 'number' && width >= 0); var bytesNeeded = Math.ceil(width / 26) | 0; var bitsLeft = width % 26; // Extend the buffer with leading zeroes this._expand(bytesNeeded); if (bitsLeft > 0) { bytesNeeded--; } // Handle complete words for (var i = 0; i < bytesNeeded; i++) { this.words[i] = ~this.words[i] & 0x3ffffff; } // Handle the residue if (bitsLeft > 0) { this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft)); } // And remove leading zeroes return this.strip(); }; BN.prototype.notn = function notn (width) { return this.clone().inotn(width); }; // Set `bit` of `this` BN.prototype.setn = function setn (bit, val) { assert(typeof bit === 'number' && bit >= 0); var off = (bit / 26) | 0; var wbit = bit % 26; this._expand(off + 1); if (val) { this.words[off] = this.words[off] | (1 << wbit); } else { this.words[off] = this.words[off] & ~(1 << wbit); } return this.strip(); }; // Add `num` to `this` in-place BN.prototype.iadd = function iadd (num) { var r; // negative + positive if (this.negative !== 0 && num.negative === 0) { this.negative = 0; r = this.isub(num); this.negative ^= 1; return this._normSign(); // positive + negative } else if (this.negative === 0 && num.negative !== 0) { num.negative = 0; r = this.isub(num); num.negative = 1; return r._normSign(); } // a.length > b.length var a, b; if (this.length > num.length) { a = this; b = num; } else { a = num; b = this; } var carry = 0; for (var i = 0; i < b.length; i++) { r = (a.words[i] | 0) + (b.words[i] | 0) + carry; this.words[i] = r & 0x3ffffff; carry = r >>> 26; } for (; carry !== 0 && i < a.length; i++) { r = (a.words[i] | 0) + carry; this.words[i] = r & 0x3ffffff; carry = r >>> 26; } this.length = a.length; if (carry !== 0) { this.words[this.length] = carry; this.length++; // Copy the rest of the words } else if (a !== this) { for (; i < a.length; i++) { this.words[i] = a.words[i]; } } return this; }; // Add `num` to `this` BN.prototype.add = function add (num) { var res; if (num.negative !== 0 && this.negative === 0) { num.negative = 0; res = this.sub(num); num.negative ^= 1; return res; } else if (num.negative === 0 && this.negative !== 0) { this.negative = 0; res = num.sub(this); this.negative = 1; return res; } if (this.length > num.length) return this.clone().iadd(num); return num.clone().iadd(this); }; // Subtract `num` from `this` in-place BN.prototype.isub = function isub (num) { // this - (-num) = this + num if (num.negative !== 0) { num.negative = 0; var r = this.iadd(num); num.negative = 1; return r._normSign(); // -this - num = -(this + num) } else if (this.negative !== 0) { this.negative = 0; this.iadd(num); this.negative = 1; return this._normSign(); } // At this point both numbers are positive var cmp = this.cmp(num); // Optimization - zeroify if (cmp === 0) { this.negative = 0; this.length = 1; this.words[0] = 0; return this; } // a > b var a, b; if (cmp > 0) { a = this; b = num; } else { a = num; b = this; } var carry = 0; for (var i = 0; i < b.length; i++) { r = (a.words[i] | 0) - (b.words[i] | 0) + carry; carry = r >> 26; this.words[i] = r & 0x3ffffff; } for (; carry !== 0 && i < a.length; i++) { r = (a.words[i] | 0) + carry; carry = r >> 26; this.words[i] = r & 0x3ffffff; } // Copy rest of the words if (carry === 0 && i < a.length && a !== this) { for (; i < a.length; i++) { this.words[i] = a.words[i]; } } this.length = Math.max(this.length, i); if (a !== this) { this.negative = 1; } return this.strip(); }; // Subtract `num` from `this` BN.prototype.sub = function sub (num) { return this.clone().isub(num); }; function smallMulTo (self, num, out) { out.negative = num.negative ^ self.negative; var len = (self.length + num.length) | 0; out.length = len; len = (len - 1) | 0; // Peel one iteration (compiler can't do it, because of code complexity) var a = self.words[0] | 0; var b = num.words[0] | 0; var r = a * b; var lo = r & 0x3ffffff; var carry = (r / 0x4000000) | 0; out.words[0] = lo; for (var k = 1; k < len; k++) { // Sum all words with the same `i + j = k` and accumulate `ncarry`, // note that ncarry could be >= 0x3ffffff var ncarry = carry >>> 26; var rword = carry & 0x3ffffff; var maxJ = Math.min(k, num.length - 1); for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) { var i = (k - j) | 0; a = self.words[i] | 0; b = num.words[j] | 0; r = a * b + rword; ncarry += (r / 0x4000000) | 0; rword = r & 0x3ffffff; } out.words[k] = rword | 0; carry = ncarry | 0; } if (carry !== 0) { out.words[k] = carry | 0; } else { out.length--; } return out.strip(); } // TODO(indutny): it may be reasonable to omit it for users who don't need // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit // multiplication (like elliptic secp256k1). var comb10MulTo = function comb10MulTo (self, num, out) { var a = self.words; var b = num.words; var o = out.words; var c = 0; var lo; var mid; var hi; var a0 = a[0] | 0; var al0 = a0 & 0x1fff; var ah0 = a0 >>> 13; var a1 = a[1] | 0; var al1 = a1 & 0x1fff; var ah1 = a1 >>> 13; var a2 = a[2] | 0; var al2 = a2 & 0x1fff; var ah2 = a2 >>> 13; var a3 = a[3] | 0; var al3 = a3 & 0x1fff; var ah3 = a3 >>> 13; var a4 = a[4] | 0; var al4 = a4 & 0x1fff; var ah4 = a4 >>> 13; var a5 = a[5] | 0; var al5 = a5 & 0x1fff; var ah5 = a5 >>> 13; var a6 = a[6] | 0; var al6 = a6 & 0x1fff; var ah6 = a6 >>> 13; var a7 = a[7] | 0; var al7 = a7 & 0x1fff; var ah7 = a7 >>> 13; var a8 = a[8] | 0; var al8 = a8 & 0x1fff; var ah8 = a8 >>> 13; var a9 = a[9] | 0; var al9 = a9 & 0x1fff; var ah9 = a9 >>> 13; var b0 = b[0] | 0; var bl0 = b0 & 0x1fff; var bh0 = b0 >>> 13; var b1 = b[1] | 0; var bl1 = b1 & 0x1fff; var bh1 = b1 >>> 13; var b2 = b[2] | 0; var bl2 = b2 & 0x1fff; var bh2 = b2 >>> 13; var b3 = b[3] | 0; var bl3 = b3 & 0x1fff; var bh3 = b3 >>> 13; var b4 = b[4] | 0; var bl4 = b4 & 0x1fff; var bh4 = b4 >>> 13; var b5 = b[5] | 0; var bl5 = b5 & 0x1fff; var bh5 = b5 >>> 13; var b6 = b[6] | 0; var bl6 = b6 & 0x1fff; var bh6 = b6 >>> 13; var b7 = b[7] | 0; var bl7 = b7 & 0x1fff; var bh7 = b7 >>> 13; var b8 = b[8] | 0; var bl8 = b8 & 0x1fff; var bh8 = b8 >>> 13; var b9 = b[9] | 0; var bl9 = b9 & 0x1fff; var bh9 = b9 >>> 13; out.negative = self.negative ^ num.negative; out.length = 19; /* k = 0 */ lo = Math.imul(al0, bl0); mid = Math.imul(al0, bh0); mid += Math.imul(ah0, bl0); hi = Math.imul(ah0, bh0); var w0 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w0 >>> 26); w0 &= 0x3ffffff; /* k = 1 */ lo = Math.imul(al1, bl0); mid = Math.imul(al1, bh0); mid += Math.imul(ah1, bl0); hi = Math.imul(ah1, bh0); lo += Math.imul(al0, bl1); mid += Math.imul(al0, bh1); mid += Math.imul(ah0, bl1); hi += Math.imul(ah0, bh1); var w1 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w1 >>> 26); w1 &= 0x3ffffff; /* k = 2 */ lo = Math.imul(al2, bl0); mid = Math.imul(al2, bh0); mid += Math.imul(ah2, bl0); hi = Math.imul(ah2, bh0); lo += Math.imul(al1, bl1); mid += Math.imul(al1, bh1); mid += Math.imul(ah1, bl1); hi += Math.imul(ah1, bh1); lo += Math.imul(al0, bl2); mid += Math.imul(al0, bh2); mid += Math.imul(ah0, bl2); hi += Math.imul(ah0, bh2); var w2 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w2 >>> 26); w2 &= 0x3ffffff; /* k = 3 */ lo = Math.imul(al3, bl0); mid = Math.imul(al3, bh0); mid += Math.imul(ah3, bl0); hi = Math.imul(ah3, bh0); lo += Math.imul(al2, bl1); mid += Math.imul(al2, bh1); mid += Math.imul(ah2, bl1); hi += Math.imul(ah2, bh1); lo += Math.imul(al1, bl2); mid += Math.imul(al1, bh2); mid += Math.imul(ah1, bl2); hi += Math.imul(ah1, bh2); lo += Math.imul(al0, bl3); mid += Math.imul(al0, bh3); mid += Math.imul(ah0, bl3); hi += Math.imul(ah0, bh3); var w3 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w3 >>> 26); w3 &= 0x3ffffff; /* k = 4 */ lo = Math.imul(al4, bl0); mid = Math.imul(al4, bh0); mid += Math.imul(ah4, bl0); hi = Math.imul(ah4, bh0); lo += Math.imul(al3, bl1); mid += Math.imul(al3, bh1); mid += Math.imul(ah3, bl1); hi += Math.imul(ah3, bh1); lo += Math.imul(al2, bl2); mid += Math.imul(al2, bh2); mid += Math.imul(ah2, bl2); hi += Math.imul(ah2, bh2); lo += Math.imul(al1, bl3); mid += Math.imul(al1, bh3); mid += Math.imul(ah1, bl3); hi += Math.imul(ah1, bh3); lo += Math.imul(al0, bl4); mid += Math.imul(al0, bh4); mid += Math.imul(ah0, bl4); hi += Math.imul(ah0, bh4); var w4 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w4 >>> 26); w4 &= 0x3ffffff; /* k = 5 */ lo = Math.imul(al5, bl0); mid = Math.imul(al5, bh0); mid += Math.imul(ah5, bl0); hi = Math.imul(ah5, bh0); lo += Math.imul(al4, bl1); mid += Math.imul(al4, bh1); mid += Math.imul(ah4, bl1); hi += Math.imul(ah4, bh1); lo += Math.imul(al3, bl2); mid += Math.imul(al3, bh2); mid += Math.imul(ah3, bl2); hi += Math.imul(ah3, bh2); lo += Math.imul(al2, bl3); mid += Math.imul(al2, bh3); mid += Math.imul(ah2, bl3); hi += Math.imul(ah2, bh3); lo += Math.imul(al1, bl4); mid += Math.imul(al1, bh4); mid += Math.imul(ah1, bl4); hi += Math.imul(ah1, bh4); lo += Math.imul(al0, bl5); mid += Math.imul(al0, bh5); mid += Math.imul(ah0, bl5); hi += Math.imul(ah0, bh5); var w5 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w5 >>> 26); w5 &= 0x3ffffff; /* k = 6 */ lo = Math.imul(al6, bl0); mid = Math.imul(al6, bh0); mid += Math.imul(ah6, bl0); hi = Math.imul(ah6, bh0); lo += Math.imul(al5, bl1); mid += Math.imul(al5, bh1); mid += Math.imul(ah5, bl1); hi += Math.imul(ah5, bh1); lo += Math.imul(al4, bl2); mid += Math.imul(al4, bh2); mid += Math.imul(ah4, bl2); hi += Math.imul(ah4, bh2); lo += Math.imul(al3, bl3); mid += Math.imul(al3, bh3); mid += Math.imul(ah3, bl3); hi += Math.imul(ah3, bh3); lo += Math.imul(al2, bl4); mid += Math.imul(al2, bh4); mid += Math.imul(ah2, bl4); hi += Math.imul(ah2, bh4); lo += Math.imul(al1, bl5); mid += Math.imul(al1, bh5); mid += Math.imul(ah1, bl5); hi += Math.imul(ah1, bh5); lo += Math.imul(al0, bl6); mid += Math.imul(al0, bh6); mid += Math.imul(ah0, bl6); hi += Math.imul(ah0, bh6); var w6 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w6 >>> 26); w6 &= 0x3ffffff; /* k = 7 */ lo = Math.imul(al7, bl0); mid = Math.imul(al7, bh0); mid += Math.imul(ah7, bl0); hi = Math.imul(ah7, bh0); lo += Math.imul(al6, bl1); mid += Math.imul(al6, bh1); mid += Math.imul(ah6, bl1); hi += Math.imul(ah6, bh1); lo += Math.imul(al5, bl2); mid += Math.imul(al5, bh2); mid += Math.imul(ah5, bl2); hi += Math.imul(ah5, bh2); lo += Math.imul(al4, bl3); mid += Math.imul(al4, bh3); mid += Math.imul(ah4, bl3); hi += Math.imul(ah4, bh3); lo += Math.imul(al3, bl4); mid += Math.imul(al3, bh4); mid += Math.imul(ah3, bl4); hi += Math.imul(ah3, bh4); lo += Math.imul(al2, bl5); mid += Math.imul(al2, bh5); mid += Math.imul(ah2, bl5); hi += Math.imul(ah2, bh5); lo += Math.imul(al1, bl6); mid += Math.imul(al1, bh6); mid += Math.imul(ah1, bl6); hi += Math.imul(ah1, bh6); lo += Math.imul(al0, bl7); mid += Math.imul(al0, bh7); mid += Math.imul(ah0, bl7); hi += Math.imul(ah0, bh7); var w7 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w7 >>> 26); w7 &= 0x3ffffff; /* k = 8 */ lo = Math.imul(al8, bl0); mid = Math.imul(al8, bh0); mid += Math.imul(ah8, bl0); hi = Math.imul(ah8, bh0); lo += Math.imul(al7, bl1); mid += Math.imul(al7, bh1); mid += Math.imul(ah7, bl1); hi += Math.imul(ah7, bh1); lo += Math.imul(al6, bl2); mid += Math.imul(al6, bh2); mid += Math.imul(ah6, bl2); hi += Math.imul(ah6, bh2); lo += Math.imul(al5, bl3); mid += Math.imul(al5, bh3); mid += Math.imul(ah5, bl3); hi += Math.imul(ah5, bh3); lo += Math.imul(al4, bl4); mid += Math.imul(al4, bh4); mid += Math.imul(ah4, bl4); hi += Math.imul(ah4, bh4); lo += Math.imul(al3, bl5); mid += Math.imul(al3, bh5); mid += Math.imul(ah3, bl5); hi += Math.imul(ah3, bh5); lo += Math.imul(al2, bl6); mid += Math.imul(al2, bh6); mid += Math.imul(ah2, bl6); hi += Math.imul(ah2, bh6); lo += Math.imul(al1, bl7); mid += Math.imul(al1, bh7); mid += Math.imul(ah1, bl7); hi += Math.imul(ah1, bh7); lo += Math.imul(al0, bl8); mid += Math.imul(al0, bh8); mid += Math.imul(ah0, bl8); hi += Math.imul(ah0, bh8); var w8 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w8 >>> 26); w8 &= 0x3ffffff; /* k = 9 */ lo = Math.imul(al9, bl0); mid = Math.imul(al9, bh0); mid += Math.imul(ah9, bl0); hi = Math.imul(ah9, bh0); lo += Math.imul(al8, bl1); mid += Math.imul(al8, bh1); mid += Math.imul(ah8, bl1); hi += Math.imul(ah8, bh1); lo += Math.imul(al7, bl2); mid += Math.imul(al7, bh2); mid += Math.imul(ah7, bl2); hi += Math.imul(ah7, bh2); lo += Math.imul(al6, bl3); mid += Math.imul(al6, bh3); mid += Math.imul(ah6, bl3); hi += Math.imul(ah6, bh3); lo += Math.imul(al5, bl4); mid += Math.imul(al5, bh4); mid += Math.imul(ah5, bl4); hi += Math.imul(ah5, bh4); lo += Math.imul(al4, bl5); mid += Math.imul(al4, bh5); mid += Math.imul(ah4, bl5); hi += Math.imul(ah4, bh5); lo += Math.imul(al3, bl6); mid += Math.imul(al3, bh6); mid += Math.imul(ah3, bl6); hi += Math.imul(ah3, bh6); lo += Math.imul(al2, bl7); mid += Math.imul(al2, bh7); mid += Math.imul(ah2, bl7); hi += Math.imul(ah2, bh7); lo += Math.imul(al1, bl8); mid += Math.imul(al1, bh8); mid += Math.imul(ah1, bl8); hi += Math.imul(ah1, bh8); lo += Math.imul(al0, bl9); mid += Math.imul(al0, bh9); mid += Math.imul(ah0, bl9); hi += Math.imul(ah0, bh9); var w9 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w9 >>> 26); w9 &= 0x3ffffff; /* k = 10 */ lo = Math.imul(al9, bl1); mid = Math.imul(al9, bh1); mid += Math.imul(ah9, bl1); hi = Math.imul(ah9, bh1); lo += Math.imul(al8, bl2); mid += Math.imul(al8, bh2); mid += Math.imul(ah8, bl2); hi += Math.imul(ah8, bh2); lo += Math.imul(al7, bl3); mid += Math.imul(al7, bh3); mid += Math.imul(ah7, bl3); hi += Math.imul(ah7, bh3); lo += Math.imul(al6, bl4); mid += Math.imul(al6, bh4); mid += Math.imul(ah6, bl4); hi += Math.imul(ah6, bh4); lo += Math.imul(al5, bl5); mid += Math.imul(al5, bh5); mid += Math.imul(ah5, bl5); hi += Math.imul(ah5, bh5); lo += Math.imul(al4, bl6); mid += Math.imul(al4, bh6); mid += Math.imul(ah4, bl6); hi += Math.imul(ah4, bh6); lo += Math.imul(al3, bl7); mid += Math.imul(al3, bh7); mid += Math.imul(ah3, bl7); hi += Math.imul(ah3, bh7); lo += Math.imul(al2, bl8); mid += Math.imul(al2, bh8); mid += Math.imul(ah2, bl8); hi += Math.imul(ah2, bh8); lo += Math.imul(al1, bl9); mid += Math.imul(al1, bh9); mid += Math.imul(ah1, bl9); hi += Math.imul(ah1, bh9); var w10 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w10 >>> 26); w10 &= 0x3ffffff; /* k = 11 */ lo = Math.imul(al9, bl2); mid = Math.imul(al9, bh2); mid += Math.imul(ah9, bl2); hi = Math.imul(ah9, bh2); lo += Math.imul(al8, bl3); mid += Math.imul(al8, bh3); mid += Math.imul(ah8, bl3); hi += Math.imul(ah8, bh3); lo += Math.imul(al7, bl4); mid += Math.imul(al7, bh4); mid += Math.imul(ah7, bl4); hi += Math.imul(ah7, bh4); lo += Math.imul(al6, bl5); mid += Math.imul(al6, bh5); mid += Math.imul(ah6, bl5); hi += Math.imul(ah6, bh5); lo += Math.imul(al5, bl6); mid += Math.imul(al5, bh6); mid += Math.imul(ah5, bl6); hi += Math.imul(ah5, bh6); lo += Math.imul(al4, bl7); mid += Math.imul(al4, bh7); mid += Math.imul(ah4, bl7); hi += Math.imul(ah4, bh7); lo += Math.imul(al3, bl8); mid += Math.imul(al3, bh8); mid += Math.imul(ah3, bl8); hi += Math.imul(ah3, bh8); lo += Math.imul(al2, bl9); mid += Math.imul(al2, bh9); mid += Math.imul(ah2, bl9); hi += Math.imul(ah2, bh9); var w11 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w11 >>> 26); w11 &= 0x3ffffff; /* k = 12 */ lo = Math.imul(al9, bl3); mid = Math.imul(al9, bh3); mid += Math.imul(ah9, bl3); hi = Math.imul(ah9, bh3); lo += Math.imul(al8, bl4); mid += Math.imul(al8, bh4); mid += Math.imul(ah8, bl4); hi += Math.imul(ah8, bh4); lo += Math.imul(al7, bl5); mid += Math.imul(al7, bh5); mid += Math.imul(ah7, bl5); hi += Math.imul(ah7, bh5); lo += Math.imul(al6, bl6); mid += Math.imul(al6, bh6); mid += Math.imul(ah6, bl6); hi += Math.imul(ah6, bh6); lo += Math.imul(al5, bl7); mid += Math.imul(al5, bh7); mid += Math.imul(ah5, bl7); hi += Math.imul(ah5, bh7); lo += Math.imul(al4, bl8); mid += Math.imul(al4, bh8); mid += Math.imul(ah4, bl8); hi += Math.imul(ah4, bh8); lo += Math.imul(al3, bl9); mid += Math.imul(al3, bh9); mid += Math.imul(ah3, bl9); hi += Math.imul(ah3, bh9); var w12 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w12 >>> 26); w12 &= 0x3ffffff; /* k = 13 */ lo = Math.imul(al9, bl4); mid = Math.imul(al9, bh4); mid += Math.imul(ah9, bl4); hi = Math.imul(ah9, bh4); lo += Math.imul(al8, bl5); mid += Math.imul(al8, bh5); mid += Math.imul(ah8, bl5); hi += Math.imul(ah8, bh5); lo += Math.imul(al7, bl6); mid += Math.imul(al7, bh6); mid += Math.imul(ah7, bl6); hi += Math.imul(ah7, bh6); lo += Math.imul(al6, bl7); mid += Math.imul(al6, bh7); mid += Math.imul(ah6, bl7); hi += Math.imul(ah6, bh7); lo += Math.imul(al5, bl8); mid += Math.imul(al5, bh8); mid += Math.imul(ah5, bl8); hi += Math.imul(ah5, bh8); lo += Math.imul(al4, bl9); mid += Math.imul(al4, bh9); mid += Math.imul(ah4, bl9); hi += Math.imul(ah4, bh9); var w13 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w13 >>> 26); w13 &= 0x3ffffff; /* k = 14 */ lo = Math.imul(al9, bl5); mid = Math.imul(al9, bh5); mid += Math.imul(ah9, bl5); hi = Math.imul(ah9, bh5); lo += Math.imul(al8, bl6); mid += Math.imul(al8, bh6); mid += Math.imul(ah8, bl6); hi += Math.imul(ah8, bh6); lo += Math.imul(al7, bl7); mid += Math.imul(al7, bh7); mid += Math.imul(ah7, bl7); hi += Math.imul(ah7, bh7); lo += Math.imul(al6, bl8); mid += Math.imul(al6, bh8); mid += Math.imul(ah6, bl8); hi += Math.imul(ah6, bh8); lo += Math.imul(al5, bl9); mid += Math.imul(al5, bh9); mid += Math.imul(ah5, bl9); hi += Math.imul(ah5, bh9); var w14 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w14 >>> 26); w14 &= 0x3ffffff; /* k = 15 */ lo = Math.imul(al9, bl6); mid = Math.imul(al9, bh6); mid += Math.imul(ah9, bl6); hi = Math.imul(ah9, bh6); lo += Math.imul(al8, bl7); mid += Math.imul(al8, bh7); mid += Math.imul(ah8, bl7); hi += Math.imul(ah8, bh7); lo += Math.imul(al7, bl8); mid += Math.imul(al7, bh8); mid += Math.imul(ah7, bl8); hi += Math.imul(ah7, bh8); lo += Math.imul(al6, bl9); mid += Math.imul(al6, bh9); mid += Math.imul(ah6, bl9); hi += Math.imul(ah6, bh9); var w15 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w15 >>> 26); w15 &= 0x3ffffff; /* k = 16 */ lo = Math.imul(al9, bl7); mid = Math.imul(al9, bh7); mid += Math.imul(ah9, bl7); hi = Math.imul(ah9, bh7); lo += Math.imul(al8, bl8); mid += Math.imul(al8, bh8); mid += Math.imul(ah8, bl8); hi += Math.imul(ah8, bh8); lo += Math.imul(al7, bl9); mid += Math.imul(al7, bh9); mid += Math.imul(ah7, bl9); hi += Math.imul(ah7, bh9); var w16 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w16 >>> 26); w16 &= 0x3ffffff; /* k = 17 */ lo = Math.imul(al9, bl8); mid = Math.imul(al9, bh8); mid += Math.imul(ah9, bl8); hi = Math.imul(ah9, bh8); lo += Math.imul(al8, bl9); mid += Math.imul(al8, bh9); mid += Math.imul(ah8, bl9); hi += Math.imul(ah8, bh9); var w17 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w17 >>> 26); w17 &= 0x3ffffff; /* k = 18 */ lo = Math.imul(al9, bl9); mid = Math.imul(al9, bh9); mid += Math.imul(ah9, bl9); hi = Math.imul(ah9, bh9); var w18 = c + lo + ((mid & 0x1fff) << 13); c = hi + (mid >>> 13) + (w18 >>> 26); w18 &= 0x3ffffff; o[0] = w0; o[1] = w1; o[2] = w2; o[3] = w3; o[4] = w4; o[5] = w5; o[6] = w6; o[7] = w7; o[8] = w8; o[9] = w9; o[10] = w10; o[11] = w11; o[12] = w12; o[13] = w13; o[14] = w14; o[15] = w15; o[16] = w16; o[17] = w17; o[18] = w18; if (c !== 0) { o[19] = c; out.length++; } return out; }; // Polyfill comb if (!Math.imul) { comb10MulTo = smallMulTo; } function bigMulTo (self, num, out) { out.negative = num.negative ^ self.negative; out.length = self.length + num.length; var carry = 0; var hncarry = 0; for (var k = 0; k < out.length - 1; k++) { // Sum all words with the same `i + j = k` and accumulate `ncarry`, // note that ncarry could be >= 0x3ffffff var ncarry = hncarry; hncarry = 0; var rword = carry & 0x3ffffff; var maxJ = Math.min(k, num.length - 1); for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) { var i = k - j; var a = self.words[i] | 0; var b = num.words[j] | 0; var r = a * b; var lo = r & 0x3ffffff; ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0; lo = (lo + rword) | 0; rword = lo & 0x3ffffff; ncarry = (ncarry + (lo >>> 26)) | 0; hncarry += ncarry >>> 26; ncarry &= 0x3ffffff; } out.words[k] = rword; carry = ncarry; ncarry = hncarry; } if (carry !== 0) { out.words[k] = carry; } else { out.length--; } return out.strip(); } function jumboMulTo (self, num, out) { var fftm = new FFTM(); return fftm.mulp(self, num, out); } BN.prototype.mulTo = function mulTo (num, out) { var res; var len = this.length + num.length; if (this.length === 10 && num.length === 10) { res = comb10MulTo(this, num, out); } else if (len < 63) { res = smallMulTo(this, num, out); } else if (len < 1024) { res = bigMulTo(this, num, out); } else { res = jumboMulTo(this, num, out); } return res; }; // Cooley-Tukey algorithm for FFT // slightly revisited to rely on looping instead of recursion function FFTM (x, y) { this.x = x; this.y = y; } FFTM.prototype.makeRBT = function makeRBT (N) { var t = new Array(N); var l = BN.prototype._countBits(N) - 1; for (var i = 0; i < N; i++) { t[i] = this.revBin(i, l, N); } return t; }; // Returns binary-reversed representation of `x` FFTM.prototype.revBin = function revBin (x, l, N) { if (x === 0 || x === N - 1) return x; var rb = 0; for (var i = 0; i < l; i++) { rb |= (x & 1) << (l - i - 1); x >>= 1; } return rb; }; // Performs "tweedling" phase, therefore 'emulating' // behaviour of the recursive algorithm FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) { for (var i = 0; i < N; i++) { rtws[i] = rws[rbt[i]]; itws[i] = iws[rbt[i]]; } }; FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) { this.permute(rbt, rws, iws, rtws, itws, N); for (var s = 1; s < N; s <<= 1) { var l = s << 1; var rtwdf = Math.cos(2 * Math.PI / l); var itwdf = Math.sin(2 * Math.PI / l); for (var p = 0; p < N; p += l) { var rtwdf_ = rtwdf; var itwdf_ = itwdf; for (var j = 0; j < s; j++) { var re = rtws[p + j]; var ie = itws[p + j]; var ro = rtws[p + j + s]; var io = itws[p + j + s]; var rx = rtwdf_ * ro - itwdf_ * io; io = rtwdf_ * io + itwdf_ * ro; ro = rx; rtws[p + j] = re + ro; itws[p + j] = ie + io; rtws[p + j + s] = re - ro; itws[p + j + s] = ie - io; /* jshint maxdepth : false */ if (j !== l) { rx = rtwdf * rtwdf_ - itwdf * itwdf_; itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_; rtwdf_ = rx; } } } } }; FFTM.prototype.guessLen13b = function guessLen13b (n, m) { var N = Math.max(m, n) | 1; var odd = N & 1; var i = 0; for (N = N / 2 | 0; N; N = N >>> 1) { i++; } return 1 << i + 1 + odd; }; FFTM.prototype.conjugate = function conjugate (rws, iws, N) { if (N <= 1) return; for (var i = 0; i < N / 2; i++) { var t = rws[i]; rws[i] = rws[N - i - 1]; rws[N - i - 1] = t; t = iws[i]; iws[i] = -iws[N - i - 1]; iws[N - i - 1] = -t; } }; FFTM.prototype.normalize13b = function normalize13b (ws, N) { var carry = 0; for (var i = 0; i < N / 2; i++) { var w = Math.round(ws[2 * i + 1] / N) * 0x2000 + Math.round(ws[2 * i] / N) + carry; ws[i] = w & 0x3ffffff; if (w < 0x4000000) { carry = 0; } else { carry = w / 0x4000000 | 0; } } return ws; }; FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) { var carry = 0; for (var i = 0; i < len; i++) { carry = carry + (ws[i] | 0); rws[2 * i] = carry & 0x1fff; carry = carry >>> 13; rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13; } // Pad with zeroes for (i = 2 * len; i < N; ++i) { rws[i] = 0; } assert(carry === 0); assert((carry & ~0x1fff) === 0); }; FFTM.prototype.stub = function stub (N) { var ph = new Array(N); for (var i = 0; i < N; i++) { ph[i] = 0; } return ph; }; FFTM.prototype.mulp = function mulp (x, y, out) { var N = 2 * this.guessLen13b(x.length, y.length); var rbt = this.makeRBT(N); var _ = this.stub(N); var rws = new Array(N); var rwst = new Array(N); var iwst = new Array(N); var nrws = new Array(N); var nrwst = new Array(N); var niwst = new Array(N); var rmws = out.words; rmws.length = N; this.convert13b(x.words, x.length, rws, N); this.convert13b(y.words, y.length, nrws, N); this.transform(rws, _, rwst, iwst, N, rbt); this.transform(nrws, _, nrwst, niwst, N, rbt); for (var i = 0; i < N; i++) { var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i]; iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i]; rwst[i] = rx; } this.conjugate(rwst, iwst, N); this.transform(rwst, iwst, rmws, _, N, rbt); this.conjugate(rmws, _, N); this.normalize13b(rmws, N); out.negative = x.negative ^ y.negative; out.length = x.length + y.length; return out.strip(); }; // Multiply `this` by `num` BN.prototype.mul = function mul (num) { var out = new BN(null); out.words = new Array(this.length + num.length); return this.mulTo(num, out); }; // Multiply employing FFT BN.prototype.mulf = function mulf (num) { var out = new BN(null); out.words = new Array(this.length + num.length); return jumboMulTo(this, num, out); }; // In-place Multiplication BN.prototype.imul = function imul (num) { return this.clone().mulTo(num, this); }; BN.prototype.imuln = function imuln (num) { assert(typeof num === 'number'); assert(num < 0x4000000); // Carry var carry = 0; for (var i = 0; i < this.length; i++) { var w = (this.words[i] | 0) * num; var lo = (w & 0x3ffffff) + (carry & 0x3ffffff); carry >>= 26; carry += (w / 0x4000000) | 0; // NOTE: lo is 27bit maximum carry += lo >>> 26; this.words[i] = lo & 0x3ffffff; } if (carry !== 0) { this.words[i] = carry; this.length++; } return this; }; BN.prototype.muln = function muln (num) { return this.clone().imuln(num); }; // `this` * `this` BN.prototype.sqr = function sqr () { return this.mul(this); }; // `this` * `this` in-place BN.prototype.isqr = function isqr () { return this.imul(this.clone()); }; // Math.pow(`this`, `num`) BN.prototype.pow = function pow (num) { var w = toBitArray(num); if (w.length === 0) return new BN(1); // Skip leading zeroes var res = this; for (var i = 0; i < w.length; i++, res = res.sqr()) { if (w[i] !== 0) break; } if (++i < w.length) { for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) { if (w[i] === 0) continue; res = res.mul(q); } } return res; }; // Shift-left in-place BN.prototype.iushln = function iushln (bits) { assert(typeof bits === 'number' && bits >= 0); var r = bits % 26; var s = (bits - r) / 26; var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r); var i; if (r !== 0) { var carry = 0; for (i = 0; i < this.length; i++) { var newCarry = this.words[i] & carryMask; var c = ((this.words[i] | 0) - newCarry) << r; this.words[i] = c | carry; carry = newCarry >>> (26 - r); } if (carry) { this.words[i] = carry; this.length++; } } if (s !== 0) { for (i = this.length - 1; i >= 0; i--) { this.words[i + s] = this.words[i]; } for (i = 0; i < s; i++) { this.words[i] = 0; } this.length += s; } return this.strip(); }; BN.prototype.ishln = function ishln (bits) { // TODO(indutny): implement me assert(this.negative === 0); return this.iushln(bits); }; // Shift-right in-place // NOTE: `hint` is a lowest bit before trailing zeroes // NOTE: if `extended` is present - it will be filled with destroyed bits BN.prototype.iushrn = function iushrn (bits, hint, extended) { assert(typeof bits === 'number' && bits >= 0); var h; if (hint) { h = (hint - (hint % 26)) / 26; } else { h = 0; } var r = bits % 26; var s = Math.min((bits - r) / 26, this.length); var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r); var maskedWords = extended; h -= s; h = Math.max(0, h); // Extended mode, copy masked part if (maskedWords) { for (var i = 0; i < s; i++) { maskedWords.words[i] = this.words[i]; } maskedWords.length = s; } if (s === 0) { // No-op, we should not move anything at all } else if (this.length > s) { this.length -= s; for (i = 0; i < this.length; i++) { this.words[i] = this.words[i + s]; } } else { this.words[0] = 0; this.length = 1; } var carry = 0; for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) { var word = this.words[i] | 0; this.words[i] = (carry << (26 - r)) | (word >>> r); carry = word & mask; } // Push carried bits as a mask if (maskedWords && carry !== 0) { maskedWords.words[maskedWords.length++] = carry; } if (this.length === 0) { this.words[0] = 0; this.length = 1; } return this.strip(); }; BN.prototype.ishrn = function ishrn (bits, hint, extended) { // TODO(indutny): implement me assert(this.negative === 0); return this.iushrn(bits, hint, extended); }; // Shift-left BN.prototype.shln = function shln (bits) { return this.clone().ishln(bits); }; BN.prototype.ushln = function ushln (bits) { return this.clone().iushln(bits); }; // Shift-right BN.prototype.shrn = function shrn (bits) { return this.clone().ishrn(bits); }; BN.prototype.ushrn = function ushrn (bits) { return this.clone().iushrn(bits); }; // Test if n bit is set BN.prototype.testn = function testn (bit) { assert(typeof bit === 'number' && bit >= 0); var r = bit % 26; var s = (bit - r) / 26; var q = 1 << r; // Fast case: bit is much higher than all existing words if (this.length <= s) return false; // Check bit and return var w = this.words[s]; return !!(w & q); }; // Return only lowers bits of number (in-place) BN.prototype.imaskn = function imaskn (bits) { assert(typeof bits === 'number' && bits >= 0); var r = bits % 26; var s = (bits - r) / 26; assert(this.negative === 0, 'imaskn works only with positive numbers'); if (r !== 0) { s++; } this.length = Math.min(s, this.length); if (r !== 0) { var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r); this.words[this.length - 1] &= mask; } return this.strip(); }; // Return only lowers bits of number BN.prototype.maskn = function maskn (bits) { return this.clone().imaskn(bits); }; // Add plain number `num` to `this` BN.prototype.iaddn = function iaddn (num) { assert(typeof num === 'number'); assert(num < 0x4000000); if (num < 0) return this.isubn(-num); // Possible sign change if (this.negative !== 0) { if (this.length === 1 && (this.words[0] | 0) < num) { this.words[0] = num - (this.words[0] | 0); this.negative = 0; return this; } this.negative = 0; this.isubn(num); this.negative = 1; return this; } // Add without checks return this._iaddn(num); }; BN.prototype._iaddn = function _iaddn (num) { this.words[0] += num; // Carry for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) { this.words[i] -= 0x4000000; if (i === this.length - 1) { this.words[i + 1] = 1; } else { this.words[i + 1]++; } } this.length = Math.max(this.length, i + 1); return this; }; // Subtract plain number `num` from `this` BN.prototype.isubn = function isubn (num) { assert(typeof num === 'number'); assert(num < 0x4000000); if (num < 0) return this.iaddn(-num); if (this.negative !== 0) { this.negative = 0; this.iaddn(num); this.negative = 1; return this; } this.words[0] -= num; if (this.length === 1 && this.words[0] < 0) { this.words[0] = -this.words[0]; this.negative = 1; } else { // Carry for (var i = 0; i < this.length && this.words[i] < 0; i++) { this.words[i] += 0x4000000; this.words[i + 1] -= 1; } } return this.strip(); }; BN.prototype.addn = function addn (num) { return this.clone().iaddn(num); }; BN.prototype.subn = function subn (num) { return this.clone().isubn(num); }; BN.prototype.iabs = function iabs () { this.negative = 0; return this; }; BN.prototype.abs = function abs () { return this.clone().iabs(); }; BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) { var len = num.length + shift; var i; this._expand(len); var w; var carry = 0; for (i = 0; i < num.length; i++) { w = (this.words[i + shift] | 0) + carry; var right = (num.words[i] | 0) * mul; w -= right & 0x3ffffff; carry = (w >> 26) - ((right / 0x4000000) | 0); this.words[i + shift] = w & 0x3ffffff; } for (; i < this.length - shift; i++) { w = (this.words[i + shift] | 0) + carry; carry = w >> 26; this.words[i + shift] = w & 0x3ffffff; } if (carry === 0) return this.strip(); // Subtraction overflow assert(carry === -1); carry = 0; for (i = 0; i < this.length; i++) { w = -(this.words[i] | 0) + carry; carry = w >> 26; this.words[i] = w & 0x3ffffff; } this.negative = 1; return this.strip(); }; BN.prototype._wordDiv = function _wordDiv (num, mode) { var shift = this.length - num.length; var a = this.clone(); var b = num; // Normalize var bhi = b.words[b.length - 1] | 0; var bhiBits = this._countBits(bhi); shift = 26 - bhiBits; if (shift !== 0) { b = b.ushln(shift); a.iushln(shift); bhi = b.words[b.length - 1] | 0; } // Initialize quotient var m = a.length - b.length; var q; if (mode !== 'mod') { q = new BN(null); q.length = m + 1; q.words = new Array(q.length); for (var i = 0; i < q.length; i++) { q.words[i] = 0; } } var diff = a.clone()._ishlnsubmul(b, 1, m); if (diff.negative === 0) { a = diff; if (q) { q.words[m] = 1; } } for (var j = m - 1; j >= 0; j--) { var qj = (a.words[b.length + j] | 0) * 0x4000000 + (a.words[b.length + j - 1] | 0); // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max // (0x7ffffff) qj = Math.min((qj / bhi) | 0, 0x3ffffff); a._ishlnsubmul(b, qj, j); while (a.negative !== 0) { qj--; a.negative = 0; a._ishlnsubmul(b, 1, j); if (!a.isZero()) { a.negative ^= 1; } } if (q) { q.words[j] = qj; } } if (q) { q.strip(); } a.strip(); // Denormalize if (mode !== 'div' && shift !== 0) { a.iushrn(shift); } return { div: q || null, mod: a }; }; // NOTE: 1) `mode` can be set to `mod` to request mod only, // to `div` to request div only, or be absent to // request both div & mod // 2) `positive` is true if unsigned mod is requested BN.prototype.divmod = function divmod (num, mode, positive) { assert(!num.isZero()); if (this.isZero()) { return { div: new BN(0), mod: new BN(0) }; } var div, mod, res; if (this.negative !== 0 && num.negative === 0) { res = this.neg().divmod(num, mode); if (mode !== 'mod') { div = res.div.neg(); } if (mode !== 'div') { mod = res.mod.neg(); if (positive && mod.negative !== 0) { mod.iadd(num); } } return { div: div, mod: mod }; } if (this.negative === 0 && num.negative !== 0) { res = this.divmod(num.neg(), mode); if (mode !== 'mod') { div = res.div.neg(); } return { div: div, mod: res.mod }; } if ((this.negative & num.negative) !== 0) { res = this.neg().divmod(num.neg(), mode); if (mode !== 'div') { mod = res.mod.neg(); if (positive && mod.negative !== 0) { mod.isub(num); } } return { div: res.div, mod: mod }; } // Both numbers are positive at this point // Strip both numbers to approximate shift value if (num.length > this.length || this.cmp(num) < 0) { return { div: new BN(0), mod: this }; } // Very short reduction if (num.length === 1) { if (mode === 'div') { return { div: this.divn(num.words[0]), mod: null }; } if (mode === 'mod') { return { div: null, mod: new BN(this.modn(num.words[0])) }; } return { div: this.divn(num.words[0]), mod: new BN(this.modn(num.words[0])) }; } return this._wordDiv(num, mode); }; // Find `this` / `num` BN.prototype.div = function div (num) { return this.divmod(num, 'div', false).div; }; // Find `this` % `num` BN.prototype.mod = function mod (num) { return this.divmod(num, 'mod', false).mod; }; BN.prototype.umod = function umod (num) { return this.divmod(num, 'mod', true).mod; }; // Find Round(`this` / `num`) BN.prototype.divRound = function divRound (num) { var dm = this.divmod(num); // Fast case - exact division if (dm.mod.isZero()) return dm.div; var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod; var half = num.ushrn(1); var r2 = num.andln(1); var cmp = mod.cmp(half); // Round down if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div; // Round up return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1); }; BN.prototype.modn = function modn (num) { assert(num <= 0x3ffffff); var p = (1 << 26) % num; var acc = 0; for (var i = this.length - 1; i >= 0; i--) { acc = (p * acc + (this.words[i] | 0)) % num; } return acc; }; // In-place division by number BN.prototype.idivn = function idivn (num) { assert(num <= 0x3ffffff); var carry = 0; for (var i = this.length - 1; i >= 0; i--) { var w = (this.words[i] | 0) + carry * 0x4000000; this.words[i] = (w / num) | 0; carry = w % num; } return this.strip(); }; BN.prototype.divn = function divn (num) { return this.clone().idivn(num); }; BN.prototype.egcd = function egcd (p) { assert(p.negative === 0); assert(!p.isZero()); var x = this; var y = p.clone(); if (x.negative !== 0) { x = x.umod(p); } else { x = x.clone(); } // A * x + B * y = x var A = new BN(1); var B = new BN(0); // C * x + D * y = y var C = new BN(0); var D = new BN(1); var g = 0; while (x.isEven() && y.isEven()) { x.iushrn(1); y.iushrn(1); ++g; } var yp = y.clone(); var xp = x.clone(); while (!x.isZero()) { for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1); if (i > 0) { x.iushrn(i); while (i-- > 0) { if (A.isOdd() || B.isOdd()) { A.iadd(yp); B.isub(xp); } A.iushrn(1); B.iushrn(1); } } for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1); if (j > 0) { y.iushrn(j); while (j-- > 0) { if (C.isOdd() || D.isOdd()) { C.iadd(yp); D.isub(xp); } C.iushrn(1); D.iushrn(1); } } if (x.cmp(y) >= 0) { x.isub(y); A.isub(C); B.isub(D); } else { y.isub(x); C.isub(A); D.isub(B); } } return { a: C, b: D, gcd: y.iushln(g) }; }; // This is reduced incarnation of the binary EEA // above, designated to invert members of the // _prime_ fields F(p) at a maximal speed BN.prototype._invmp = function _invmp (p) { assert(p.negative === 0); assert(!p.isZero()); var a = this; var b = p.clone(); if (a.negative !== 0) { a = a.umod(p); } else { a = a.clone(); } var x1 = new BN(1); var x2 = new BN(0); var delta = b.clone(); while (a.cmpn(1) > 0 && b.cmpn(1) > 0) { for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1); if (i > 0) { a.iushrn(i); while (i-- > 0) { if (x1.isOdd()) { x1.iadd(delta); } x1.iushrn(1); } } for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1); if (j > 0) { b.iushrn(j); while (j-- > 0) { if (x2.isOdd()) { x2.iadd(delta); } x2.iushrn(1); } } if (a.cmp(b) >= 0) { a.isub(b); x1.isub(x2); } else { b.isub(a); x2.isub(x1); } } var res; if (a.cmpn(1) === 0) { res = x1; } else { res = x2; } if (res.cmpn(0) < 0) { res.iadd(p); } return res; }; BN.prototype.gcd = function gcd (num) { if (this.isZero()) return num.abs(); if (num.isZero()) return this.abs(); var a = this.clone(); var b = num.clone(); a.negative = 0; b.negative = 0; // Remove common factor of two for (var shift = 0; a.isEven() && b.isEven(); shift++) { a.iushrn(1); b.iushrn(1); } do { while (a.isEven()) { a.iushrn(1); } while (b.isEven()) { b.iushrn(1); } var r = a.cmp(b); if (r < 0) { // Swap `a` and `b` to make `a` always bigger than `b` var t = a; a = b; b = t; } else if (r === 0 || b.cmpn(1) === 0) { break; } a.isub(b); } while (true); return b.iushln(shift); }; // Invert number in the field F(num) BN.prototype.invm = function invm (num) { return this.egcd(num).a.umod(num); }; BN.prototype.isEven = function isEven () { return (this.words[0] & 1) === 0; }; BN.prototype.isOdd = function isOdd () { return (this.words[0] & 1) === 1; }; // And first word and num BN.prototype.andln = function andln (num) { return this.words[0] & num; }; // Increment at the bit position in-line BN.prototype.bincn = function bincn (bit) { assert(typeof bit === 'number'); var r = bit % 26; var s = (bit - r) / 26; var q = 1 << r; // Fast case: bit is much higher than all existing words if (this.length <= s) { this._expand(s + 1); this.words[s] |= q; return this; } // Add bit and propagate, if needed var carry = q; for (var i = s; carry !== 0 && i < this.length; i++) { var w = this.words[i] | 0; w += carry; carry = w >>> 26; w &= 0x3ffffff; this.words[i] = w; } if (carry !== 0) { this.words[i] = carry; this.length++; } return this; }; BN.prototype.isZero = function isZero () { return this.length === 1 && this.words[0] === 0; }; BN.prototype.cmpn = function cmpn (num) { var negative = num < 0; if (this.negative !== 0 && !negative) return -1; if (this.negative === 0 && negative) return 1; this.strip(); var res; if (this.length > 1) { res = 1; } else { if (negative) { num = -num; } assert(num <= 0x3ffffff, 'Number is too big'); var w = this.words[0] | 0; res = w === num ? 0 : w < num ? -1 : 1; } if (this.negative !== 0) return -res | 0; return res; }; // Compare two numbers and return: // 1 - if `this` > `num` // 0 - if `this` == `num` // -1 - if `this` < `num` BN.prototype.cmp = function cmp (num) { if (this.negative !== 0 && num.negative === 0) return -1; if (this.negative === 0 && num.negative !== 0) return 1; var res = this.ucmp(num); if (this.negative !== 0) return -res | 0; return res; }; // Unsigned comparison BN.prototype.ucmp = function ucmp (num) { // At this point both numbers have the same sign if (this.length > num.length) return 1; if (this.length < num.length) return -1; var res = 0; for (var i = this.length - 1; i >= 0; i--) { var a = this.words[i] | 0; var b = num.words[i] | 0; if (a === b) continue; if (a < b) { res = -1; } else if (a > b) { res = 1; } break; } return res; }; BN.prototype.gtn = function gtn (num) { return this.cmpn(num) === 1; }; BN.prototype.gt = function gt (num) { return this.cmp(num) === 1; }; BN.prototype.gten = function gten (num) { return this.cmpn(num) >= 0; }; BN.prototype.gte = function gte (num) { return this.cmp(num) >= 0; }; BN.prototype.ltn = function ltn (num) { return this.cmpn(num) === -1; }; BN.prototype.lt = function lt (num) { return this.cmp(num) === -1; }; BN.prototype.lten = function lten (num) { return this.cmpn(num) <= 0; }; BN.prototype.lte = function lte (num) { return this.cmp(num) <= 0; }; BN.prototype.eqn = function eqn (num) { return this.cmpn(num) === 0; }; BN.prototype.eq = function eq (num) { return this.cmp(num) === 0; }; // // A reduce context, could be using montgomery or something better, depending // on the `m` itself. // BN.red = function red (num) { return new Red(num); }; BN.prototype.toRed = function toRed (ctx) { assert(!this.red, 'Already a number in reduction context'); assert(this.negative === 0, 'red works only with positives'); return ctx.convertTo(this)._forceRed(ctx); }; BN.prototype.fromRed = function fromRed () { assert(this.red, 'fromRed works only with numbers in reduction context'); return this.red.convertFrom(this); }; BN.prototype._forceRed = function _forceRed (ctx) { this.red = ctx; return this; }; BN.prototype.forceRed = function forceRed (ctx) { assert(!this.red, 'Already a number in reduction context'); return this._forceRed(ctx); }; BN.prototype.redAdd = function redAdd (num) { assert(this.red, 'redAdd works only with red numbers'); return this.red.add(this, num); }; BN.prototype.redIAdd = function redIAdd (num) { assert(this.red, 'redIAdd works only with red numbers'); return this.red.iadd(this, num); }; BN.prototype.redSub = function redSub (num) { assert(this.red, 'redSub works only with red numbers'); return this.red.sub(this, num); }; BN.prototype.redISub = function redISub (num) { assert(this.red, 'redISub works only with red numbers'); return this.red.isub(this, num); }; BN.prototype.redShl = function redShl (num) { assert(this.red, 'redShl works only with red numbers'); return this.red.shl(this, num); }; BN.prototype.redMul = function redMul (num) { assert(this.red, 'redMul works only with red numbers'); this.red._verify2(this, num); return this.red.mul(this, num); }; BN.prototype.redIMul = function redIMul (num) { assert(this.red, 'redMul works only with red numbers'); this.red._verify2(this, num); return this.red.imul(this, num); }; BN.prototype.redSqr = function redSqr () { assert(this.red, 'redSqr works only with red numbers'); this.red._verify1(this); return this.red.sqr(this); }; BN.prototype.redISqr = function redISqr () { assert(this.red, 'redISqr works only with red numbers'); this.red._verify1(this); return this.red.isqr(this); }; // Square root over p BN.prototype.redSqrt = function redSqrt () { assert(this.red, 'redSqrt works only with red numbers'); this.red._verify1(this); return this.red.sqrt(this); }; BN.prototype.redInvm = function redInvm () { assert(this.red, 'redInvm works only with red numbers'); this.red._verify1(this); return this.red.invm(this); }; // Return negative clone of `this` % `red modulo` BN.prototype.redNeg = function redNeg () { assert(this.red, 'redNeg works only with red numbers'); this.red._verify1(this); return this.red.neg(this); }; BN.prototype.redPow = function redPow (num) { assert(this.red && !num.red, 'redPow(normalNum)'); this.red._verify1(this); return this.red.pow(this, num); }; // Prime numbers with efficient reduction var primes = { k256: null, p224: null, p192: null, p25519: null }; // Pseudo-Mersenne prime function MPrime (name, p) { // P = 2 ^ N - K this.name = name; this.p = new BN(p, 16); this.n = this.p.bitLength(); this.k = new BN(1).iushln(this.n).isub(this.p); this.tmp = this._tmp(); } MPrime.prototype._tmp = function _tmp () { var tmp = new BN(null); tmp.words = new Array(Math.ceil(this.n / 13)); return tmp; }; MPrime.prototype.ireduce = function ireduce (num) { // Assumes that `num` is less than `P^2` // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P) var r = num; var rlen; do { this.split(r, this.tmp); r = this.imulK(r); r = r.iadd(this.tmp); rlen = r.bitLength(); } while (rlen > this.n); var cmp = rlen < this.n ? -1 : r.ucmp(this.p); if (cmp === 0) { r.words[0] = 0; r.length = 1; } else if (cmp > 0) { r.isub(this.p); } else { r.strip(); } return r; }; MPrime.prototype.split = function split (input, out) { input.iushrn(this.n, 0, out); }; MPrime.prototype.imulK = function imulK (num) { return num.imul(this.k); }; function K256 () { MPrime.call( this, 'k256', 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f'); } inherits(K256, MPrime); K256.prototype.split = function split (input, output) { // 256 = 9 * 26 + 22 var mask = 0x3fffff; var outLen = Math.min(input.length, 9); for (var i = 0; i < outLen; i++) { output.words[i] = input.words[i]; } output.length = outLen; if (input.length <= 9) { input.words[0] = 0; input.length = 1; return; } // Shift by 9 limbs var prev = input.words[9]; output.words[output.length++] = prev & mask; for (i = 10; i < input.length; i++) { var next = input.words[i] | 0; input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22); prev = next; } prev >>>= 22; input.words[i - 10] = prev; if (prev === 0 && input.length > 10) { input.length -= 10; } else { input.length -= 9; } }; K256.prototype.imulK = function imulK (num) { // K = 0x1000003d1 = [ 0x40, 0x3d1 ] num.words[num.length] = 0; num.words[num.length + 1] = 0; num.length += 2; // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390 var lo = 0; for (var i = 0; i < num.length; i++) { var w = num.words[i] | 0; lo += w * 0x3d1; num.words[i] = lo & 0x3ffffff; lo = w * 0x40 + ((lo / 0x4000000) | 0); } // Fast length reduction if (num.words[num.length - 1] === 0) { num.length--; if (num.words[num.length - 1] === 0) { num.length--; } } return num; }; function P224 () { MPrime.call( this, 'p224', 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001'); } inherits(P224, MPrime); function P192 () { MPrime.call( this, 'p192', 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff'); } inherits(P192, MPrime); function P25519 () { // 2 ^ 255 - 19 MPrime.call( this, '25519', '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed'); } inherits(P25519, MPrime); P25519.prototype.imulK = function imulK (num) { // K = 0x13 var carry = 0; for (var i = 0; i < num.length; i++) { var hi = (num.words[i] | 0) * 0x13 + carry; var lo = hi & 0x3ffffff; hi >>>= 26; num.words[i] = lo; carry = hi; } if (carry !== 0) { num.words[num.length++] = carry; } return num; }; // Exported mostly for testing purposes, use plain name instead BN._prime = function prime (name) { // Cached version of prime if (primes[name]) return primes[name]; var prime; if (name === 'k256') { prime = new K256(); } else if (name === 'p224') { prime = new P224(); } else if (name === 'p192') { prime = new P192(); } else if (name === 'p25519') { prime = new P25519(); } else { throw new Error('Unknown prime ' + name); } primes[name] = prime; return prime; }; // // Base reduction engine // function Red (m) { if (typeof m === 'string') { var prime = BN._prime(m); this.m = prime.p; this.prime = prime; } else { assert(m.gtn(1), 'modulus must be greater than 1'); this.m = m; this.prime = null; } } Red.prototype._verify1 = function _verify1 (a) { assert(a.negative === 0, 'red works only with positives'); assert(a.red, 'red works only with red numbers'); }; Red.prototype._verify2 = function _verify2 (a, b) { assert((a.negative | b.negative) === 0, 'red works only with positives'); assert(a.red && a.red === b.red, 'red works only with red numbers'); }; Red.prototype.imod = function imod (a) { if (this.prime) return this.prime.ireduce(a)._forceRed(this); return a.umod(this.m)._forceRed(this); }; Red.prototype.neg = function neg (a) { if (a.isZero()) { return a.clone(); } return this.m.sub(a)._forceRed(this); }; Red.prototype.add = function add (a, b) { this._verify2(a, b); var res = a.add(b); if (res.cmp(this.m) >= 0) { res.isub(this.m); } return res._forceRed(this); }; Red.prototype.iadd = function iadd (a, b) { this._verify2(a, b); var res = a.iadd(b); if (res.cmp(this.m) >= 0) { res.isub(this.m); } return res; }; Red.prototype.sub = function sub (a, b) { this._verify2(a, b); var res = a.sub(b); if (res.cmpn(0) < 0) { res.iadd(this.m); } return res._forceRed(this); }; Red.prototype.isub = function isub (a, b) { this._verify2(a, b); var res = a.isub(b); if (res.cmpn(0) < 0) { res.iadd(this.m); } return res; }; Red.prototype.shl = function shl (a, num) { this._verify1(a); return this.imod(a.ushln(num)); }; Red.prototype.imul = function imul (a, b) { this._verify2(a, b); return this.imod(a.imul(b)); }; Red.prototype.mul = function mul (a, b) { this._verify2(a, b); return this.imod(a.mul(b)); }; Red.prototype.isqr = function isqr (a) { return this.imul(a, a.clone()); }; Red.prototype.sqr = function sqr (a) { return this.mul(a, a); }; Red.prototype.sqrt = function sqrt (a) { if (a.isZero()) return a.clone(); var mod3 = this.m.andln(3); assert(mod3 % 2 === 1); // Fast case if (mod3 === 3) { var pow = this.m.add(new BN(1)).iushrn(2); return this.pow(a, pow); } // Tonelli-Shanks algorithm (Totally unoptimized and slow) // // Find Q and S, that Q * 2 ^ S = (P - 1) var q = this.m.subn(1); var s = 0; while (!q.isZero() && q.andln(1) === 0) { s++; q.iushrn(1); } assert(!q.isZero()); var one = new BN(1).toRed(this); var nOne = one.redNeg(); // Find quadratic non-residue // NOTE: Max is such because of generalized Riemann hypothesis. var lpow = this.m.subn(1).iushrn(1); var z = this.m.bitLength(); z = new BN(2 * z * z).toRed(this); while (this.pow(z, lpow).cmp(nOne) !== 0) { z.redIAdd(nOne); } var c = this.pow(z, q); var r = this.pow(a, q.addn(1).iushrn(1)); var t = this.pow(a, q); var m = s; while (t.cmp(one) !== 0) { var tmp = t; for (var i = 0; tmp.cmp(one) !== 0; i++) { tmp = tmp.redSqr(); } assert(i < m); var b = this.pow(c, new BN(1).iushln(m - i - 1)); r = r.redMul(b); c = b.redSqr(); t = t.redMul(c); m = i; } return r; }; Red.prototype.invm = function invm (a) { var inv = a._invmp(this.m); if (inv.negative !== 0) { inv.negative = 0; return this.imod(inv).redNeg(); } else { return this.imod(inv); } }; Red.prototype.pow = function pow (a, num) { if (num.isZero()) return new BN(1); if (num.cmpn(1) === 0) return a.clone(); var windowSize = 4; var wnd = new Array(1 << windowSize); wnd[0] = new BN(1).toRed(this); wnd[1] = a; for (var i = 2; i < wnd.length; i++) { wnd[i] = this.mul(wnd[i - 1], a); } var res = wnd[0]; var current = 0; var currentLen = 0; var start = num.bitLength() % 26; if (start === 0) { start = 26; } for (i = num.length - 1; i >= 0; i--) { var word = num.words[i]; for (var j = start - 1; j >= 0; j--) { var bit = (word >> j) & 1; if (res !== wnd[0]) { res = this.sqr(res); } if (bit === 0 && current === 0) { currentLen = 0; continue; } current <<= 1; current |= bit; currentLen++; if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue; res = this.mul(res, wnd[current]); currentLen = 0; current = 0; } start = 26; } return res; }; Red.prototype.convertTo = function convertTo (num) { var r = num.umod(this.m); return r === num ? r.clone() : r; }; Red.prototype.convertFrom = function convertFrom (num) { var res = num.clone(); res.red = null; return res; }; // // Montgomery method engine // BN.mont = function mont (num) { return new Mont(num); }; function Mont (m) { Red.call(this, m); this.shift = this.m.bitLength(); if (this.shift % 26 !== 0) { this.shift += 26 - (this.shift % 26); } this.r = new BN(1).iushln(this.shift); this.r2 = this.imod(this.r.sqr()); this.rinv = this.r._invmp(this.m); this.minv = this.rinv.mul(this.r).isubn(1).div(this.m); this.minv = this.minv.umod(this.r); this.minv = this.r.sub(this.minv); } inherits(Mont, Red); Mont.prototype.convertTo = function convertTo (num) { return this.imod(num.ushln(this.shift)); }; Mont.prototype.convertFrom = function convertFrom (num) { var r = this.imod(num.mul(this.rinv)); r.red = null; return r; }; Mont.prototype.imul = function imul (a, b) { if (a.isZero() || b.isZero()) { a.words[0] = 0; a.length = 1; return a; } var t = a.imul(b); var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m); var u = t.isub(c).iushrn(this.shift); var res = u; if (u.cmp(this.m) >= 0) { res = u.isub(this.m); } else if (u.cmpn(0) < 0) { res = u.iadd(this.m); } return res._forceRed(this); }; Mont.prototype.mul = function mul (a, b) { if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this); var t = a.mul(b); var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m); var u = t.isub(c).iushrn(this.shift); var res = u; if (u.cmp(this.m) >= 0) { res = u.isub(this.m); } else if (u.cmpn(0) < 0) { res = u.iadd(this.m); } return res._forceRed(this); }; Mont.prototype.invm = function invm (a) { // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R var res = this.imod(a._invmp(this.m).mul(this.r2)); return res._forceRed(this); }; })(typeof module === 'undefined' || module, this); },{}],30:[function(require,module,exports){ var concatMap = require('concat-map'); var balanced = require('balanced-match'); module.exports = expandTop; var escSlash = '\0SLASH'+Math.random()+'\0'; var escOpen = '\0OPEN'+Math.random()+'\0'; var escClose = '\0CLOSE'+Math.random()+'\0'; var escComma = '\0COMMA'+Math.random()+'\0'; var escPeriod = '\0PERIOD'+Math.random()+'\0'; function numeric(str) { return parseInt(str, 10) == str ? parseInt(str, 10) : str.charCodeAt(0); } function escapeBraces(str) { return str.split('\\\\').join(escSlash) .split('\\{').join(escOpen) .split('\\}').join(escClose) .split('\\,').join(escComma) .split('\\.').join(escPeriod); } function unescapeBraces(str) { return str.split(escSlash).join('\\') .split(escOpen).join('{') .split(escClose).join('}') .split(escComma).join(',') .split(escPeriod).join('.'); } // Basically just str.split(","), but handling cases // where we have nested braced sections, which should be // treated as individual members, like {a,{b,c},d} function parseCommaParts(str) { if (!str) return ['']; var parts = []; var m = balanced('{', '}', str); if (!m) return str.split(','); var pre = m.pre; var body = m.body; var post = m.post; var p = pre.split(','); p[p.length-1] += '{' + body + '}'; var postParts = parseCommaParts(post); if (post.length) { p[p.length-1] += postParts.shift(); p.push.apply(p, postParts); } parts.push.apply(parts, p); return parts; } function expandTop(str) { if (!str) return []; return expand(escapeBraces(str), true).map(unescapeBraces); } function identity(e) { return e; } function embrace(str) { return '{' + str + '}'; } function isPadded(el) { return /^-?0\d/.test(el); } function lte(i, y) { return i <= y; } function gte(i, y) { return i >= y; } function expand(str, isTop) { var expansions = []; var m = balanced('{', '}', str); if (!m || /\$$/.test(m.pre)) return [str]; var isNumericSequence = /^-?\d+\.\.-?\d+(?:\.\.-?\d+)?$/.test(m.body); var isAlphaSequence = /^[a-zA-Z]\.\.[a-zA-Z](?:\.\.-?\d+)?$/.test(m.body); var isSequence = isNumericSequence || isAlphaSequence; var isOptions = /^(.*,)+(.+)?$/.test(m.body); if (!isSequence && !isOptions) { // {a},b} if (m.post.match(/,.*\}/)) { str = m.pre + '{' + m.body + escClose + m.post; return expand(str); } return [str]; } var n; if (isSequence) { n = m.body.split(/\.\./); } else { n = parseCommaParts(m.body); if (n.length === 1) { // x{{a,b}}y ==> x{a}y x{b}y n = expand(n[0], false).map(embrace); if (n.length === 1) { var post = m.post.length ? expand(m.post, false) : ['']; return post.map(function(p) { return m.pre + n[0] + p; }); } } } // at this point, n is the parts, and we know it's not a comma set // with a single entry. // no need to expand pre, since it is guaranteed to be free of brace-sets var pre = m.pre; var post = m.post.length ? expand(m.post, false) : ['']; var N; if (isSequence) { var x = numeric(n[0]); var y = numeric(n[1]); var width = Math.max(n[0].length, n[1].length) var incr = n.length == 3 ? Math.abs(numeric(n[2])) : 1; var test = lte; var reverse = y < x; if (reverse) { incr *= -1; test = gte; } var pad = n.some(isPadded); N = []; for (var i = x; test(i, y); i += incr) { var c; if (isAlphaSequence) { c = String.fromCharCode(i); if (c === '\\') c = ''; } else { c = String(i); if (pad) { var need = width - c.length; if (need > 0) { var z = new Array(need + 1).join('0'); if (i < 0) c = '-' + z + c.slice(1); else c = z + c; } } } N.push(c); } } else { N = concatMap(n, function(el) { return expand(el, false) }); } for (var j = 0; j < N.length; j++) { for (var k = 0; k < post.length; k++) { var expansion = pre + N[j] + post[k]; if (!isTop || isSequence || expansion) expansions.push(expansion); } } return expansions; } },{"balanced-match":18,"concat-map":85}],31:[function(require,module,exports){ (function (Buffer){ var udp = require('dgram') var pipe = require('stream').prototype.pipe var os = require('os') module.exports = function (port, loopback) { var addresses = {} var socket = udp.createSocket('udp4') socket.readable = socket.writable = true socket.write = function (message) { if('string' === typeof message) message = new Buffer(message, 'utf8') socket.send(message, 0, message.length, port, '255.255.255.255') return true } socket.end = function () { socket.close() } socket.on('close', function () { socket.emit('end') }) var latest = null socket.on('message', function (msg, other) { if(addresses[other.address] && other.port === port) { if(loopback === false) return msg.loopback = true } msg.port = other.port msg.address = other.address //if paused, remember the latest item. //otherwise just drop those messages. if(socket.paused) return latest = msg latest = null socket.emit('data', msg) }) socket.pause = function () { socket.paused = true return this } socket.resume = function () { socket.paused = false if(latest) { var msg = latest latest = null socket.emit('data', msg) } return this } socket.bind(port) socket.on('listening', function () { var ifaces = os.networkInterfaces() for(var k in ifaces) ifaces[k].forEach(function (address) { addresses[address.address] = true }) socket.setBroadcast(true) }) socket.pipe = pipe return socket } }).call(this,require("buffer").Buffer) },{"buffer":61,"dgram":58,"os":279,"stream":576}],32:[function(require,module,exports){ var r; module.exports = function rand(len) { if (!r) r = new Rand(null); return r.generate(len); }; function Rand(rand) { this.rand = rand; } module.exports.Rand = Rand; Rand.prototype.generate = function generate(len) { return this._rand(len); }; if (typeof window === 'object') { if (window.crypto && window.crypto.getRandomValues) { // Modern browsers Rand.prototype._rand = function _rand(n) { var arr = new Uint8Array(n); window.crypto.getRandomValues(arr); return arr; }; } else if (window.msCrypto && window.msCrypto.getRandomValues) { // IE Rand.prototype._rand = function _rand(n) { var arr = new Uint8Array(n); window.msCrypto.getRandomValues(arr); return arr; }; } else { // Old junk Rand.prototype._rand = function() { throw new Error('Not implemented yet'); }; } } else { // Node.js or Web worker try { var crypto = require('cry' + 'pto'); Rand.prototype._rand = function _rand(n) { return crypto.randomBytes(n); }; } catch (e) { // Emulate crypto API using randy Rand.prototype._rand = function _rand(n) { var res = new Uint8Array(n); for (var i = 0; i < res.length; i++) res[i] = this.rand.getByte(); return res; }; } } },{}],33:[function(require,module,exports){ },{}],34:[function(require,module,exports){ (function (Buffer){ // based on the aes implimentation in triple sec // https://github.com/keybase/triplesec // which is in turn based on the one from crypto-js // https://code.google.com/p/crypto-js/ var uint_max = Math.pow(2, 32) function fixup_uint32 (x) { var ret, x_pos ret = x > uint_max || x < 0 ? (x_pos = Math.abs(x) % uint_max, x < 0 ? uint_max - x_pos : x_pos) : x return ret } function scrub_vec (v) { for (var i = 0; i < v.length; v++) { v[i] = 0 } return false } function Global () { this.SBOX = [] this.INV_SBOX = [] this.SUB_MIX = [[], [], [], []] this.INV_SUB_MIX = [[], [], [], []] this.init() this.RCON = [0x00, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36] } Global.prototype.init = function () { var d, i, sx, t, x, x2, x4, x8, xi, _i d = (function () { var _i, _results _results = [] for (i = _i = 0; _i < 256; i = ++_i) { if (i < 128) { _results.push(i << 1) } else { _results.push((i << 1) ^ 0x11b) } } return _results })() x = 0 xi = 0 for (i = _i = 0; _i < 256; i = ++_i) { sx = xi ^ (xi << 1) ^ (xi << 2) ^ (xi << 3) ^ (xi << 4) sx = (sx >>> 8) ^ (sx & 0xff) ^ 0x63 this.SBOX[x] = sx this.INV_SBOX[sx] = x x2 = d[x] x4 = d[x2] x8 = d[x4] t = (d[sx] * 0x101) ^ (sx * 0x1010100) this.SUB_MIX[0][x] = (t << 24) | (t >>> 8) this.SUB_MIX[1][x] = (t << 16) | (t >>> 16) this.SUB_MIX[2][x] = (t << 8) | (t >>> 24) this.SUB_MIX[3][x] = t t = (x8 * 0x1010101) ^ (x4 * 0x10001) ^ (x2 * 0x101) ^ (x * 0x1010100) this.INV_SUB_MIX[0][sx] = (t << 24) | (t >>> 8) this.INV_SUB_MIX[1][sx] = (t << 16) | (t >>> 16) this.INV_SUB_MIX[2][sx] = (t << 8) | (t >>> 24) this.INV_SUB_MIX[3][sx] = t if (x === 0) { x = xi = 1 } else { x = x2 ^ d[d[d[x8 ^ x2]]] xi ^= d[d[xi]] } } return true } var G = new Global() AES.blockSize = 4 * 4 AES.prototype.blockSize = AES.blockSize AES.keySize = 256 / 8 AES.prototype.keySize = AES.keySize function bufferToArray (buf) { var len = buf.length / 4 var out = new Array(len) var i = -1 while (++i < len) { out[i] = buf.readUInt32BE(i * 4) } return out } function AES (key) { this._key = bufferToArray(key) this._doReset() } AES.prototype._doReset = function () { var invKsRow, keySize, keyWords, ksRow, ksRows, t keyWords = this._key keySize = keyWords.length this._nRounds = keySize + 6 ksRows = (this._nRounds + 1) * 4 this._keySchedule = [] for (ksRow = 0; ksRow < ksRows; ksRow++) { this._keySchedule[ksRow] = ksRow < keySize ? keyWords[ksRow] : (t = this._keySchedule[ksRow - 1], (ksRow % keySize) === 0 ? (t = (t << 8) | (t >>> 24), t = (G.SBOX[t >>> 24] << 24) | (G.SBOX[(t >>> 16) & 0xff] << 16) | (G.SBOX[(t >>> 8) & 0xff] << 8) | G.SBOX[t & 0xff], t ^= G.RCON[(ksRow / keySize) | 0] << 24) : keySize > 6 && ksRow % keySize === 4 ? t = (G.SBOX[t >>> 24] << 24) | (G.SBOX[(t >>> 16) & 0xff] << 16) | (G.SBOX[(t >>> 8) & 0xff] << 8) | G.SBOX[t & 0xff] : void 0, this._keySchedule[ksRow - keySize] ^ t) } this._invKeySchedule = [] for (invKsRow = 0; invKsRow < ksRows; invKsRow++) { ksRow = ksRows - invKsRow t = this._keySchedule[ksRow - (invKsRow % 4 ? 0 : 4)] this._invKeySchedule[invKsRow] = invKsRow < 4 || ksRow <= 4 ? t : G.INV_SUB_MIX[0][G.SBOX[t >>> 24]] ^ G.INV_SUB_MIX[1][G.SBOX[(t >>> 16) & 0xff]] ^ G.INV_SUB_MIX[2][G.SBOX[(t >>> 8) & 0xff]] ^ G.INV_SUB_MIX[3][G.SBOX[t & 0xff]] } return true } AES.prototype.encryptBlock = function (M) { M = bufferToArray(new Buffer(M)) var out = this._doCryptBlock(M, this._keySchedule, G.SUB_MIX, G.SBOX) var buf = new Buffer(16) buf.writeUInt32BE(out[0], 0) buf.writeUInt32BE(out[1], 4) buf.writeUInt32BE(out[2], 8) buf.writeUInt32BE(out[3], 12) return buf } AES.prototype.decryptBlock = function (M) { M = bufferToArray(new Buffer(M)) var temp = [M[3], M[1]] M[1] = temp[0] M[3] = temp[1] var out = this._doCryptBlock(M, this._invKeySchedule, G.INV_SUB_MIX, G.INV_SBOX) var buf = new Buffer(16) buf.writeUInt32BE(out[0], 0) buf.writeUInt32BE(out[3], 4) buf.writeUInt32BE(out[2], 8) buf.writeUInt32BE(out[1], 12) return buf } AES.prototype.scrub = function () { scrub_vec(this._keySchedule) scrub_vec(this._invKeySchedule) scrub_vec(this._key) } AES.prototype._doCryptBlock = function (M, keySchedule, SUB_MIX, SBOX) { var ksRow, s0, s1, s2, s3, t0, t1, t2, t3 s0 = M[0] ^ keySchedule[0] s1 = M[1] ^ keySchedule[1] s2 = M[2] ^ keySchedule[2] s3 = M[3] ^ keySchedule[3] ksRow = 4 for (var round = 1; round < this._nRounds; round++) { t0 = SUB_MIX[0][s0 >>> 24] ^ SUB_MIX[1][(s1 >>> 16) & 0xff] ^ SUB_MIX[2][(s2 >>> 8) & 0xff] ^ SUB_MIX[3][s3 & 0xff] ^ keySchedule[ksRow++] t1 = SUB_MIX[0][s1 >>> 24] ^ SUB_MIX[1][(s2 >>> 16) & 0xff] ^ SUB_MIX[2][(s3 >>> 8) & 0xff] ^ SUB_MIX[3][s0 & 0xff] ^ keySchedule[ksRow++] t2 = SUB_MIX[0][s2 >>> 24] ^ SUB_MIX[1][(s3 >>> 16) & 0xff] ^ SUB_MIX[2][(s0 >>> 8) & 0xff] ^ SUB_MIX[3][s1 & 0xff] ^ keySchedule[ksRow++] t3 = SUB_MIX[0][s3 >>> 24] ^ SUB_MIX[1][(s0 >>> 16) & 0xff] ^ SUB_MIX[2][(s1 >>> 8) & 0xff] ^ SUB_MIX[3][s2 & 0xff] ^ keySchedule[ksRow++] s0 = t0 s1 = t1 s2 = t2 s3 = t3 } t0 = ((SBOX[s0 >>> 24] << 24) | (SBOX[(s1 >>> 16) & 0xff] << 16) | (SBOX[(s2 >>> 8) & 0xff] << 8) | SBOX[s3 & 0xff]) ^ keySchedule[ksRow++] t1 = ((SBOX[s1 >>> 24] << 24) | (SBOX[(s2 >>> 16) & 0xff] << 16) | (SBOX[(s3 >>> 8) & 0xff] << 8) | SBOX[s0 & 0xff]) ^ keySchedule[ksRow++] t2 = ((SBOX[s2 >>> 24] << 24) | (SBOX[(s3 >>> 16) & 0xff] << 16) | (SBOX[(s0 >>> 8) & 0xff] << 8) | SBOX[s1 & 0xff]) ^ keySchedule[ksRow++] t3 = ((SBOX[s3 >>> 24] << 24) | (SBOX[(s0 >>> 16) & 0xff] << 16) | (SBOX[(s1 >>> 8) & 0xff] << 8) | SBOX[s2 & 0xff]) ^ keySchedule[ksRow++] return [ fixup_uint32(t0), fixup_uint32(t1), fixup_uint32(t2), fixup_uint32(t3) ] } exports.AES = AES }).call(this,require("buffer").Buffer) },{"buffer":61}],35:[function(require,module,exports){ (function (Buffer){ var aes = require('./aes') var Transform = require('cipher-base') var inherits = require('inherits') var GHASH = require('./ghash') var xor = require('buffer-xor') inherits(StreamCipher, Transform) module.exports = StreamCipher function StreamCipher (mode, key, iv, decrypt) { if (!(this instanceof StreamCipher)) { return new StreamCipher(mode, key, iv) } Transform.call(this) this._finID = Buffer.concat([iv, new Buffer([0, 0, 0, 1])]) iv = Buffer.concat([iv, new Buffer([0, 0, 0, 2])]) this._cipher = new aes.AES(key) this._prev = new Buffer(iv.length) this._cache = new Buffer('') this._secCache = new Buffer('') this._decrypt = decrypt this._alen = 0 this._len = 0 iv.copy(this._prev) this._mode = mode var h = new Buffer(4) h.fill(0) this._ghash = new GHASH(this._cipher.encryptBlock(h)) this._authTag = null this._called = false } StreamCipher.prototype._update = function (chunk) { if (!this._called && this._alen) { var rump = 16 - (this._alen % 16) if (rump < 16) { rump = new Buffer(rump) rump.fill(0) this._ghash.update(rump) } } this._called = true var out = this._mode.encrypt(this, chunk) if (this._decrypt) { this._ghash.update(chunk) } else { this._ghash.update(out) } this._len += chunk.length return out } StreamCipher.prototype._final = function () { if (this._decrypt && !this._authTag) { throw new Error('Unsupported state or unable to authenticate data') } var tag = xor(this._ghash.final(this._alen * 8, this._len * 8), this._cipher.encryptBlock(this._finID)) if (this._decrypt) { if (xorTest(tag, this._authTag)) { throw new Error('Unsupported state or unable to authenticate data') } } else { this._authTag = tag } this._cipher.scrub() } StreamCipher.prototype.getAuthTag = function getAuthTag () { if (!this._decrypt && Buffer.isBuffer(this._authTag)) { return this._authTag } else { throw new Error('Attempting to get auth tag in unsupported state') } } StreamCipher.prototype.setAuthTag = function setAuthTag (tag) { if (this._decrypt) { this._authTag = tag } else { throw new Error('Attempting to set auth tag in unsupported state') } } StreamCipher.prototype.setAAD = function setAAD (buf) { if (!this._called) { this._ghash.update(buf) this._alen += buf.length } else { throw new Error('Attempting to set AAD in unsupported state') } } function xorTest (a, b) { var out = 0 if (a.length !== b.length) { out++ } var len = Math.min(a.length, b.length) var i = -1 while (++i < len) { out += (a[i] ^ b[i]) } return out } }).call(this,require("buffer").Buffer) },{"./aes":34,"./ghash":39,"buffer":61,"buffer-xor":60,"cipher-base":81,"inherits":167}],36:[function(require,module,exports){ var ciphers = require('./encrypter') exports.createCipher = exports.Cipher = ciphers.createCipher exports.createCipheriv = exports.Cipheriv = ciphers.createCipheriv var deciphers = require('./decrypter') exports.createDecipher = exports.Decipher = deciphers.createDecipher exports.createDecipheriv = exports.Decipheriv = deciphers.createDecipheriv var modes = require('./modes') function getCiphers () { return Object.keys(modes) } exports.listCiphers = exports.getCiphers = getCiphers },{"./decrypter":37,"./encrypter":38,"./modes":40}],37:[function(require,module,exports){ (function (Buffer){ var aes = require('./aes') var Transform = require('cipher-base') var inherits = require('inherits') var modes = require('./modes') var StreamCipher = require('./streamCipher') var AuthCipher = require('./authCipher') var ebtk = require('evp_bytestokey') inherits(Decipher, Transform) function Decipher (mode, key, iv) { if (!(this instanceof Decipher)) { return new Decipher(mode, key, iv) } Transform.call(this) this._cache = new Splitter() this._last = void 0 this._cipher = new aes.AES(key) this._prev = new Buffer(iv.length) iv.copy(this._prev) this._mode = mode this._autopadding = true } Decipher.prototype._update = function (data) { this._cache.add(data) var chunk var thing var out = [] while ((chunk = this._cache.get(this._autopadding))) { thing = this._mode.decrypt(this, chunk) out.push(thing) } return Buffer.concat(out) } Decipher.prototype._final = function () { var chunk = this._cache.flush() if (this._autopadding) { return unpad(this._mode.decrypt(this, chunk)) } else if (chunk) { throw new Error('data not multiple of block length') } } Decipher.prototype.setAutoPadding = function (setTo) { this._autopadding = !!setTo return this } function Splitter () { if (!(this instanceof Splitter)) { return new Splitter() } this.cache = new Buffer('') } Splitter.prototype.add = function (data) { this.cache = Buffer.concat([this.cache, data]) } Splitter.prototype.get = function (autoPadding) { var out if (autoPadding) { if (this.cache.length > 16) { out = this.cache.slice(0, 16) this.cache = this.cache.slice(16) return out } } else { if (this.cache.length >= 16) { out = this.cache.slice(0, 16) this.cache = this.cache.slice(16) return out } } return null } Splitter.prototype.flush = function () { if (this.cache.length) { return this.cache } } function unpad (last) { var padded = last[15] var i = -1 while (++i < padded) { if (last[(i + (16 - padded))] !== padded) { throw new Error('unable to decrypt data') } } if (padded === 16) { return } return last.slice(0, 16 - padded) } var modelist = { ECB: require('./modes/ecb'), CBC: require('./modes/cbc'), CFB: require('./modes/cfb'), CFB8: require('./modes/cfb8'), CFB1: require('./modes/cfb1'), OFB: require('./modes/ofb'), CTR: require('./modes/ctr'), GCM: require('./modes/ctr') } function createDecipheriv (suite, password, iv) { var config = modes[suite.toLowerCase()] if (!config) { throw new TypeError('invalid suite type') } if (typeof iv === 'string') { iv = new Buffer(iv) } if (typeof password === 'string') { password = new Buffer(password) } if (password.length !== config.key / 8) { throw new TypeError('invalid key length ' + password.length) } if (iv.length !== config.iv) { throw new TypeError('invalid iv length ' + iv.length) } if (config.type === 'stream') { return new StreamCipher(modelist[config.mode], password, iv, true) } else if (config.type === 'auth') { return new AuthCipher(modelist[config.mode], password, iv, true) } return new Decipher(modelist[config.mode], password, iv) } function createDecipher (suite, password) { var config = modes[suite.toLowerCase()] if (!config) { throw new TypeError('invalid suite type') } var keys = ebtk(password, false, config.key, config.iv) return createDecipheriv(suite, keys.key, keys.iv) } exports.createDecipher = createDecipher exports.createDecipheriv = createDecipheriv }).call(this,require("buffer").Buffer) },{"./aes":34,"./authCipher":35,"./modes":40,"./modes/cbc":41,"./modes/cfb":42,"./modes/cfb1":43,"./modes/cfb8":44,"./modes/ctr":45,"./modes/ecb":46,"./modes/ofb":47,"./streamCipher":48,"buffer":61,"cipher-base":81,"evp_bytestokey":145,"inherits":167}],38:[function(require,module,exports){ (function (Buffer){ var aes = require('./aes') var Transform = require('cipher-base') var inherits = require('inherits') var modes = require('./modes') var ebtk = require('evp_bytestokey') var StreamCipher = require('./streamCipher') var AuthCipher = require('./authCipher') inherits(Cipher, Transform) function Cipher (mode, key, iv) { if (!(this instanceof Cipher)) { return new Cipher(mode, key, iv) } Transform.call(this) this._cache = new Splitter() this._cipher = new aes.AES(key) this._prev = new Buffer(iv.length) iv.copy(this._prev) this._mode = mode this._autopadding = true } Cipher.prototype._update = function (data) { this._cache.add(data) var chunk var thing var out = [] while ((chunk = this._cache.get())) { thing = this._mode.encrypt(this, chunk) out.push(thing) } return Buffer.concat(out) } Cipher.prototype._final = function () { var chunk = this._cache.flush() if (this._autopadding) { chunk = this._mode.encrypt(this, chunk) this._cipher.scrub() return chunk } else if (chunk.toString('hex') !== '10101010101010101010101010101010') { this._cipher.scrub() throw new Error('data not multiple of block length') } } Cipher.prototype.setAutoPadding = function (setTo) { this._autopadding = !!setTo return this } function Splitter () { if (!(this instanceof Splitter)) { return new Splitter() } this.cache = new Buffer('') } Splitter.prototype.add = function (data) { this.cache = Buffer.concat([this.cache, data]) } Splitter.prototype.get = function () { if (this.cache.length > 15) { var out = this.cache.slice(0, 16) this.cache = this.cache.slice(16) return out } return null } Splitter.prototype.flush = function () { var len = 16 - this.cache.length var padBuff = new Buffer(len) var i = -1 while (++i < len) { padBuff.writeUInt8(len, i) } var out = Buffer.concat([this.cache, padBuff]) return out } var modelist = { ECB: require('./modes/ecb'), CBC: require('./modes/cbc'), CFB: require('./modes/cfb'), CFB8: require('./modes/cfb8'), CFB1: require('./modes/cfb1'), OFB: require('./modes/ofb'), CTR: require('./modes/ctr'), GCM: require('./modes/ctr') } function createCipheriv (suite, password, iv) { var config = modes[suite.toLowerCase()] if (!config) { throw new TypeError('invalid suite type') } if (typeof iv === 'string') { iv = new Buffer(iv) } if (typeof password === 'string') { password = new Buffer(password) } if (password.length !== config.key / 8) { throw new TypeError('invalid key length ' + password.length) } if (iv.length !== config.iv) { throw new TypeError('invalid iv length ' + iv.length) } if (config.type === 'stream') { return new StreamCipher(modelist[config.mode], password, iv) } else if (config.type === 'auth') { return new AuthCipher(modelist[config.mode], password, iv) } return new Cipher(modelist[config.mode], password, iv) } function createCipher (suite, password) { var config = modes[suite.toLowerCase()] if (!config) { throw new TypeError('invalid suite type') } var keys = ebtk(password, false, config.key, config.iv) return createCipheriv(suite, keys.key, keys.iv) } exports.createCipheriv = createCipheriv exports.createCipher = createCipher }).call(this,require("buffer").Buffer) },{"./aes":34,"./authCipher":35,"./modes":40,"./modes/cbc":41,"./modes/cfb":42,"./modes/cfb1":43,"./modes/cfb8":44,"./modes/ctr":45,"./modes/ecb":46,"./modes/ofb":47,"./streamCipher":48,"buffer":61,"cipher-base":81,"evp_bytestokey":145,"inherits":167}],39:[function(require,module,exports){ (function (Buffer){ var zeros = new Buffer(16) zeros.fill(0) module.exports = GHASH function GHASH (key) { this.h = key this.state = new Buffer(16) this.state.fill(0) this.cache = new Buffer('') } // from http://bitwiseshiftleft.github.io/sjcl/doc/symbols/src/core_gcm.js.html // by Juho Vähä-Herttua GHASH.prototype.ghash = function (block) { var i = -1 while (++i < block.length) { this.state[i] ^= block[i] } this._multiply() } GHASH.prototype._multiply = function () { var Vi = toArray(this.h) var Zi = [0, 0, 0, 0] var j, xi, lsb_Vi var i = -1 while (++i < 128) { xi = (this.state[~~(i / 8)] & (1 << (7 - i % 8))) !== 0 if (xi) { // Z_i+1 = Z_i ^ V_i Zi = xor(Zi, Vi) } // Store the value of LSB(V_i) lsb_Vi = (Vi[3] & 1) !== 0 // V_i+1 = V_i >> 1 for (j = 3; j > 0; j--) { Vi[j] = (Vi[j] >>> 1) | ((Vi[j - 1] & 1) << 31) } Vi[0] = Vi[0] >>> 1 // If LSB(V_i) is 1, V_i+1 = (V_i >> 1) ^ R if (lsb_Vi) { Vi[0] = Vi[0] ^ (0xe1 << 24) } } this.state = fromArray(Zi) } GHASH.prototype.update = function (buf) { this.cache = Buffer.concat([this.cache, buf]) var chunk while (this.cache.length >= 16) { chunk = this.cache.slice(0, 16) this.cache = this.cache.slice(16) this.ghash(chunk) } } GHASH.prototype.final = function (abl, bl) { if (this.cache.length) { this.ghash(Buffer.concat([this.cache, zeros], 16)) } this.ghash(fromArray([ 0, abl, 0, bl ])) return this.state } function toArray (buf) { return [ buf.readUInt32BE(0), buf.readUInt32BE(4), buf.readUInt32BE(8), buf.readUInt32BE(12) ] } function fromArray (out) { out = out.map(fixup_uint32) var buf = new Buffer(16) buf.writeUInt32BE(out[0], 0) buf.writeUInt32BE(out[1], 4) buf.writeUInt32BE(out[2], 8) buf.writeUInt32BE(out[3], 12) return buf } var uint_max = Math.pow(2, 32) function fixup_uint32 (x) { var ret, x_pos ret = x > uint_max || x < 0 ? (x_pos = Math.abs(x) % uint_max, x < 0 ? uint_max - x_pos : x_pos) : x return ret } function xor (a, b) { return [ a[0] ^ b[0], a[1] ^ b[1], a[2] ^ b[2], a[3] ^ b[3] ] } }).call(this,require("buffer").Buffer) },{"buffer":61}],40:[function(require,module,exports){ exports['aes-128-ecb'] = { cipher: 'AES', key: 128, iv: 0, mode: 'ECB', type: 'block' } exports['aes-192-ecb'] = { cipher: 'AES', key: 192, iv: 0, mode: 'ECB', type: 'block' } exports['aes-256-ecb'] = { cipher: 'AES', key: 256, iv: 0, mode: 'ECB', type: 'block' } exports['aes-128-cbc'] = { cipher: 'AES', key: 128, iv: 16, mode: 'CBC', type: 'block' } exports['aes-192-cbc'] = { cipher: 'AES', key: 192, iv: 16, mode: 'CBC', type: 'block' } exports['aes-256-cbc'] = { cipher: 'AES', key: 256, iv: 16, mode: 'CBC', type: 'block' } exports['aes128'] = exports['aes-128-cbc'] exports['aes192'] = exports['aes-192-cbc'] exports['aes256'] = exports['aes-256-cbc'] exports['aes-128-cfb'] = { cipher: 'AES', key: 128, iv: 16, mode: 'CFB', type: 'stream' } exports['aes-192-cfb'] = { cipher: 'AES', key: 192, iv: 16, mode: 'CFB', type: 'stream' } exports['aes-256-cfb'] = { cipher: 'AES', key: 256, iv: 16, mode: 'CFB', type: 'stream' } exports['aes-128-cfb8'] = { cipher: 'AES', key: 128, iv: 16, mode: 'CFB8', type: 'stream' } exports['aes-192-cfb8'] = { cipher: 'AES', key: 192, iv: 16, mode: 'CFB8', type: 'stream' } exports['aes-256-cfb8'] = { cipher: 'AES', key: 256, iv: 16, mode: 'CFB8', type: 'stream' } exports['aes-128-cfb1'] = { cipher: 'AES', key: 128, iv: 16, mode: 'CFB1', type: 'stream' } exports['aes-192-cfb1'] = { cipher: 'AES', key: 192, iv: 16, mode: 'CFB1', type: 'stream' } exports['aes-256-cfb1'] = { cipher: 'AES', key: 256, iv: 16, mode: 'CFB1', type: 'stream' } exports['aes-128-ofb'] = { cipher: 'AES', key: 128, iv: 16, mode: 'OFB', type: 'stream' } exports['aes-192-ofb'] = { cipher: 'AES', key: 192, iv: 16, mode: 'OFB', type: 'stream' } exports['aes-256-ofb'] = { cipher: 'AES', key: 256, iv: 16, mode: 'OFB', type: 'stream' } exports['aes-128-ctr'] = { cipher: 'AES', key: 128, iv: 16, mode: 'CTR', type: 'stream' } exports['aes-192-ctr'] = { cipher: 'AES', key: 192, iv: 16, mode: 'CTR', type: 'stream' } exports['aes-256-ctr'] = { cipher: 'AES', key: 256, iv: 16, mode: 'CTR', type: 'stream' } exports['aes-128-gcm'] = { cipher: 'AES', key: 128, iv: 12, mode: 'GCM', type: 'auth' } exports['aes-192-gcm'] = { cipher: 'AES', key: 192, iv: 12, mode: 'GCM', type: 'auth' } exports['aes-256-gcm'] = { cipher: 'AES', key: 256, iv: 12, mode: 'GCM', type: 'auth' } },{}],41:[function(require,module,exports){ var xor = require('buffer-xor') exports.encrypt = function (self, block) { var data = xor(block, self._prev) self._prev = self._cipher.encryptBlock(data) return self._prev } exports.decrypt = function (self, block) { var pad = self._prev self._prev = block var out = self._cipher.decryptBlock(block) return xor(out, pad) } },{"buffer-xor":60}],42:[function(require,module,exports){ (function (Buffer){ var xor = require('buffer-xor') exports.encrypt = function (self, data, decrypt) { var out = new Buffer('') var len while (data.length) { if (self._cache.length === 0) { self._cache = self._cipher.encryptBlock(self._prev) self._prev = new Buffer('') } if (self._cache.length <= data.length) { len = self._cache.length out = Buffer.concat([out, encryptStart(self, data.slice(0, len), decrypt)]) data = data.slice(len) } else { out = Buffer.concat([out, encryptStart(self, data, decrypt)]) break } } return out } function encryptStart (self, data, decrypt) { var len = data.length var out = xor(data, self._cache) self._cache = self._cache.slice(len) self._prev = Buffer.concat([self._prev, decrypt ? data : out]) return out } }).call(this,require("buffer").Buffer) },{"buffer":61,"buffer-xor":60}],43:[function(require,module,exports){ (function (Buffer){ function encryptByte (self, byteParam, decrypt) { var pad var i = -1 var len = 8 var out = 0 var bit, value while (++i < len) { pad = self._cipher.encryptBlock(self._prev) bit = (byteParam & (1 << (7 - i))) ? 0x80 : 0 value = pad[0] ^ bit out += ((value & 0x80) >> (i % 8)) self._prev = shiftIn(self._prev, decrypt ? bit : value) } return out } exports.encrypt = function (self, chunk, decrypt) { var len = chunk.length var out = new Buffer(len) var i = -1 while (++i < len) { out[i] = encryptByte(self, chunk[i], decrypt) } return out } function shiftIn (buffer, value) { var len = buffer.length var i = -1 var out = new Buffer(buffer.length) buffer = Buffer.concat([buffer, new Buffer([value])]) while (++i < len) { out[i] = buffer[i] << 1 | buffer[i + 1] >> (7) } return out } }).call(this,require("buffer").Buffer) },{"buffer":61}],44:[function(require,module,exports){ (function (Buffer){ function encryptByte (self, byteParam, decrypt) { var pad = self._cipher.encryptBlock(self._prev) var out = pad[0] ^ byteParam self._prev = Buffer.concat([self._prev.slice(1), new Buffer([decrypt ? byteParam : out])]) return out } exports.encrypt = function (self, chunk, decrypt) { var len = chunk.length var out = new Buffer(len) var i = -1 while (++i < len) { out[i] = encryptByte(self, chunk[i], decrypt) } return out } }).call(this,require("buffer").Buffer) },{"buffer":61}],45:[function(require,module,exports){ (function (Buffer){ var xor = require('buffer-xor') function incr32 (iv) { var len = iv.length var item while (len--) { item = iv.readUInt8(len) if (item === 255) { iv.writeUInt8(0, len) } else { item++ iv.writeUInt8(item, len) break } } } function getBlock (self) { var out = self._cipher.encryptBlock(self._prev) incr32(self._prev) return out } exports.encrypt = function (self, chunk) { while (self._cache.length < chunk.length) { self._cache = Buffer.concat([self._cache, getBlock(self)]) } var pad = self._cache.slice(0, chunk.length) self._cache = self._cache.slice(chunk.length) return xor(chunk, pad) } }).call(this,require("buffer").Buffer) },{"buffer":61,"buffer-xor":60}],46:[function(require,module,exports){ exports.encrypt = function (self, block) { return self._cipher.encryptBlock(block) } exports.decrypt = function (self, block) { return self._cipher.decryptBlock(block) } },{}],47:[function(require,module,exports){ (function (Buffer){ var xor = require('buffer-xor') function getBlock (self) { self._prev = self._cipher.encryptBlock(self._prev) return self._prev } exports.encrypt = function (self, chunk) { while (self._cache.length < chunk.length) { self._cache = Buffer.concat([self._cache, getBlock(self)]) } var pad = self._cache.slice(0, chunk.length) self._cache = self._cache.slice(chunk.length) return xor(chunk, pad) } }).call(this,require("buffer").Buffer) },{"buffer":61,"buffer-xor":60}],48:[function(require,module,exports){ (function (Buffer){ var aes = require('./aes') var Transform = require('cipher-base') var inherits = require('inherits') inherits(StreamCipher, Transform) module.exports = StreamCipher function StreamCipher (mode, key, iv, decrypt) { if (!(this instanceof StreamCipher)) { return new StreamCipher(mode, key, iv) } Transform.call(this) this._cipher = new aes.AES(key) this._prev = new Buffer(iv.length) this._cache = new Buffer('') this._secCache = new Buffer('') this._decrypt = decrypt iv.copy(this._prev) this._mode = mode } StreamCipher.prototype._update = function (chunk) { return this._mode.encrypt(this, chunk, this._decrypt) } StreamCipher.prototype._final = function () { this._cipher.scrub() } }).call(this,require("buffer").Buffer) },{"./aes":34,"buffer":61,"cipher-base":81,"inherits":167}],49:[function(require,module,exports){ var ebtk = require('evp_bytestokey') var aes = require('browserify-aes/browser') var DES = require('browserify-des') var desModes = require('browserify-des/modes') var aesModes = require('browserify-aes/modes') function createCipher (suite, password) { var keyLen, ivLen suite = suite.toLowerCase() if (aesModes[suite]) { keyLen = aesModes[suite].key ivLen = aesModes[suite].iv } else if (desModes[suite]) { keyLen = desModes[suite].key * 8 ivLen = desModes[suite].iv } else { throw new TypeError('invalid suite type') } var keys = ebtk(password, false, keyLen, ivLen) return createCipheriv(suite, keys.key, keys.iv) } function createDecipher (suite, password) { var keyLen, ivLen suite = suite.toLowerCase() if (aesModes[suite]) { keyLen = aesModes[suite].key ivLen = aesModes[suite].iv } else if (desModes[suite]) { keyLen = desModes[suite].key * 8 ivLen = desModes[suite].iv } else { throw new TypeError('invalid suite type') } var keys = ebtk(password, false, keyLen, ivLen) return createDecipheriv(suite, keys.key, keys.iv) } function createCipheriv (suite, key, iv) { suite = suite.toLowerCase() if (aesModes[suite]) { return aes.createCipheriv(suite, key, iv) } else if (desModes[suite]) { return new DES({ key: key, iv: iv, mode: suite }) } else { throw new TypeError('invalid suite type') } } function createDecipheriv (suite, key, iv) { suite = suite.toLowerCase() if (aesModes[suite]) { return aes.createDecipheriv(suite, key, iv) } else if (desModes[suite]) { return new DES({ key: key, iv: iv, mode: suite, decrypt: true }) } else { throw new TypeError('invalid suite type') } } exports.createCipher = exports.Cipher = createCipher exports.createCipheriv = exports.Cipheriv = createCipheriv exports.createDecipher = exports.Decipher = createDecipher exports.createDecipheriv = exports.Decipheriv = createDecipheriv function getCiphers () { return Object.keys(desModes).concat(aes.getCiphers()) } exports.listCiphers = exports.getCiphers = getCiphers },{"browserify-aes/browser":36,"browserify-aes/modes":40,"browserify-des":50,"browserify-des/modes":51,"evp_bytestokey":145}],50:[function(require,module,exports){ (function (Buffer){ var CipherBase = require('cipher-base') var des = require('des.js') var inherits = require('inherits') var modes = { 'des-ede3-cbc': des.CBC.instantiate(des.EDE), 'des-ede3': des.EDE, 'des-ede-cbc': des.CBC.instantiate(des.EDE), 'des-ede': des.EDE, 'des-cbc': des.CBC.instantiate(des.DES), 'des-ecb': des.DES } modes.des = modes['des-cbc'] modes.des3 = modes['des-ede3-cbc'] module.exports = DES inherits(DES, CipherBase) function DES (opts) { CipherBase.call(this) var modeName = opts.mode.toLowerCase() var mode = modes[modeName] var type if (opts.decrypt) { type = 'decrypt' } else { type = 'encrypt' } var key = opts.key if (modeName === 'des-ede' || modeName === 'des-ede-cbc') { key = Buffer.concat([key, key.slice(0, 8)]) } var iv = opts.iv this._des = mode.create({ key: key, iv: iv, type: type }) } DES.prototype._update = function (data) { return new Buffer(this._des.update(data)) } DES.prototype._final = function () { return new Buffer(this._des.final()) } }).call(this,require("buffer").Buffer) },{"buffer":61,"cipher-base":81,"des.js":113,"inherits":167}],51:[function(require,module,exports){ exports['des-ecb'] = { key: 8, iv: 0 } exports['des-cbc'] = exports.des = { key: 8, iv: 8 } exports['des-ede3-cbc'] = exports.des3 = { key: 24, iv: 8 } exports['des-ede3'] = { key: 24, iv: 0 } exports['des-ede-cbc'] = { key: 16, iv: 8 } exports['des-ede'] = { key: 16, iv: 0 } },{}],52:[function(require,module,exports){ (function (Buffer){ var bn = require('bn.js'); var randomBytes = require('randombytes'); module.exports = crt; function blind(priv) { var r = getr(priv); var blinder = r.toRed(bn.mont(priv.modulus)) .redPow(new bn(priv.publicExponent)).fromRed(); return { blinder: blinder, unblinder:r.invm(priv.modulus) }; } function crt(msg, priv) { var blinds = blind(priv); var len = priv.modulus.byteLength(); var mod = bn.mont(priv.modulus); var blinded = new bn(msg).mul(blinds.blinder).umod(priv.modulus); var c1 = blinded.toRed(bn.mont(priv.prime1)); var c2 = blinded.toRed(bn.mont(priv.prime2)); var qinv = priv.coefficient; var p = priv.prime1; var q = priv.prime2; var m1 = c1.redPow(priv.exponent1); var m2 = c2.redPow(priv.exponent2); m1 = m1.fromRed(); m2 = m2.fromRed(); var h = m1.isub(m2).imul(qinv).umod(p); h.imul(q); m2.iadd(h); return new Buffer(m2.imul(blinds.unblinder).umod(priv.modulus).toArray(false, len)); } crt.getr = getr; function getr(priv) { var len = priv.modulus.byteLength(); var r = new bn(randomBytes(len)); while (r.cmp(priv.modulus) >= 0 || !r.umod(priv.prime1) || !r.umod(priv.prime2)) { r = new bn(randomBytes(len)); } return r; } }).call(this,require("buffer").Buffer) },{"bn.js":29,"buffer":61,"randombytes":403}],53:[function(require,module,exports){ (function (Buffer){ 'use strict' exports['RSA-SHA224'] = exports.sha224WithRSAEncryption = { sign: 'rsa', hash: 'sha224', id: new Buffer('302d300d06096086480165030402040500041c', 'hex') } exports['RSA-SHA256'] = exports.sha256WithRSAEncryption = { sign: 'rsa', hash: 'sha256', id: new Buffer('3031300d060960864801650304020105000420', 'hex') } exports['RSA-SHA384'] = exports.sha384WithRSAEncryption = { sign: 'rsa', hash: 'sha384', id: new Buffer('3041300d060960864801650304020205000430', 'hex') } exports['RSA-SHA512'] = exports.sha512WithRSAEncryption = { sign: 'rsa', hash: 'sha512', id: new Buffer('3051300d060960864801650304020305000440', 'hex') } exports['RSA-SHA1'] = { sign: 'rsa', hash: 'sha1', id: new Buffer('3021300906052b0e03021a05000414', 'hex') } exports['ecdsa-with-SHA1'] = { sign: 'ecdsa', hash: 'sha1', id: new Buffer('', 'hex') } exports.DSA = exports['DSA-SHA1'] = exports['DSA-SHA'] = { sign: 'dsa', hash: 'sha1', id: new Buffer('', 'hex') } exports['DSA-SHA224'] = exports['DSA-WITH-SHA224'] = { sign: 'dsa', hash: 'sha224', id: new Buffer('', 'hex') } exports['DSA-SHA256'] = exports['DSA-WITH-SHA256'] = { sign: 'dsa', hash: 'sha256', id: new Buffer('', 'hex') } exports['DSA-SHA384'] = exports['DSA-WITH-SHA384'] = { sign: 'dsa', hash: 'sha384', id: new Buffer('', 'hex') } exports['DSA-SHA512'] = exports['DSA-WITH-SHA512'] = { sign: 'dsa', hash: 'sha512', id: new Buffer('', 'hex') } exports['DSA-RIPEMD160'] = { sign: 'dsa', hash: 'rmd160', id: new Buffer('', 'hex') } exports['RSA-RIPEMD160'] = exports.ripemd160WithRSA = { sign: 'rsa', hash: 'rmd160', id: new Buffer('3021300906052b2403020105000414', 'hex') } exports['RSA-MD5'] = exports.md5WithRSAEncryption = { sign: 'rsa', hash: 'md5', id: new Buffer('3020300c06082a864886f70d020505000410', 'hex') } }).call(this,require("buffer").Buffer) },{"buffer":61}],54:[function(require,module,exports){ (function (Buffer){ var _algos = require('./algos') var createHash = require('create-hash') var inherits = require('inherits') var sign = require('./sign') var stream = require('stream') var verify = require('./verify') var algos = {} Object.keys(_algos).forEach(function (key) { algos[key] = algos[key.toLowerCase()] = _algos[key] }) function Sign (algorithm) { stream.Writable.call(this) var data = algos[algorithm] if (!data) { throw new Error('Unknown message digest') } this._hashType = data.hash this._hash = createHash(data.hash) this._tag = data.id this._signType = data.sign } inherits(Sign, stream.Writable) Sign.prototype._write = function _write (data, _, done) { this._hash.update(data) done() } Sign.prototype.update = function update (data, enc) { if (typeof data === 'string') { data = new Buffer(data, enc) } this._hash.update(data) return this } Sign.prototype.sign = function signMethod (key, enc) { this.end() var hash = this._hash.digest() var sig = sign(Buffer.concat([this._tag, hash]), key, this._hashType, this._signType) return enc ? sig.toString(enc) : sig } function Verify (algorithm) { stream.Writable.call(this) var data = algos[algorithm] if (!data) { throw new Error('Unknown message digest') } this._hash = createHash(data.hash) this._tag = data.id this._signType = data.sign } inherits(Verify, stream.Writable) Verify.prototype._write = function _write (data, _, done) { this._hash.update(data) done() } Verify.prototype.update = function update (data, enc) { if (typeof data === 'string') { data = new Buffer(data, enc) } this._hash.update(data) return this } Verify.prototype.verify = function verifyMethod (key, sig, enc) { if (typeof sig === 'string') { sig = new Buffer(sig, enc) } this.end() var hash = this._hash.digest() return verify(sig, Buffer.concat([this._tag, hash]), key, this._signType) } function createSign (algorithm) { return new Sign(algorithm) } function createVerify (algorithm) { return new Verify(algorithm) } module.exports = { Sign: createSign, Verify: createVerify, createSign: createSign, createVerify: createVerify } }).call(this,require("buffer").Buffer) },{"./algos":53,"./sign":56,"./verify":57,"buffer":61,"create-hash":106,"inherits":167,"stream":576}],55:[function(require,module,exports){ 'use strict' exports['1.3.132.0.10'] = 'secp256k1' exports['1.3.132.0.33'] = 'p224' exports['1.2.840.10045.3.1.1'] = 'p192' exports['1.2.840.10045.3.1.7'] = 'p256' exports['1.3.132.0.34'] = 'p384' exports['1.3.132.0.35'] = 'p521' },{}],56:[function(require,module,exports){ (function (Buffer){ // much of this based on https://github.com/indutny/self-signed/blob/gh-pages/lib/rsa.js var createHmac = require('create-hmac') var crt = require('browserify-rsa') var curves = require('./curves') var elliptic = require('elliptic') var parseKeys = require('parse-asn1') var BN = require('bn.js') var EC = elliptic.ec function sign (hash, key, hashType, signType) { var priv = parseKeys(key) if (priv.curve) { if (signType !== 'ecdsa') throw new Error('wrong private key type') return ecSign(hash, priv) } else if (priv.type === 'dsa') { if (signType !== 'dsa') { throw new Error('wrong private key type') } return dsaSign(hash, priv, hashType) } else { if (signType !== 'rsa') throw new Error('wrong private key type') } var len = priv.modulus.byteLength() var pad = [ 0, 1 ] while (hash.length + pad.length + 1 < len) { pad.push(0xff) } pad.push(0x00) var i = -1 while (++i < hash.length) { pad.push(hash[i]) } var out = crt(pad, priv) return out } function ecSign (hash, priv) { var curveId = curves[priv.curve.join('.')] if (!curveId) throw new Error('unknown curve ' + priv.curve.join('.')) var curve = new EC(curveId) var key = curve.genKeyPair() key._importPrivate(priv.privateKey) var out = key.sign(hash) return new Buffer(out.toDER()) } function dsaSign (hash, priv, algo) { var x = priv.params.priv_key var p = priv.params.p var q = priv.params.q var g = priv.params.g var r = new BN(0) var k var H = bits2int(hash, q).mod(q) var s = false var kv = getKey(x, q, hash, algo) while (s === false) { k = makeKey(q, kv, algo) r = makeR(g, k, p, q) s = k.invm(q).imul(H.add(x.mul(r))).mod(q) if (!s.cmpn(0)) { s = false r = new BN(0) } } return toDER(r, s) } function toDER (r, s) { r = r.toArray() s = s.toArray() // Pad values if (r[0] & 0x80) { r = [ 0 ].concat(r) } // Pad values if (s[0] & 0x80) { s = [0].concat(s) } var total = r.length + s.length + 4 var res = [ 0x30, total, 0x02, r.length ] res = res.concat(r, [ 0x02, s.length ], s) return new Buffer(res) } function getKey (x, q, hash, algo) { x = new Buffer(x.toArray()) if (x.length < q.byteLength()) { var zeros = new Buffer(q.byteLength() - x.length) zeros.fill(0) x = Buffer.concat([zeros, x]) } var hlen = hash.length var hbits = bits2octets(hash, q) var v = new Buffer(hlen) v.fill(1) var k = new Buffer(hlen) k.fill(0) k = createHmac(algo, k) .update(v) .update(new Buffer([0])) .update(x) .update(hbits) .digest() v = createHmac(algo, k) .update(v) .digest() k = createHmac(algo, k) .update(v) .update(new Buffer([1])) .update(x) .update(hbits) .digest() v = createHmac(algo, k) .update(v) .digest() return { k: k, v: v } } function bits2int (obits, q) { var bits = new BN(obits) var shift = (obits.length << 3) - q.bitLength() if (shift > 0) { bits.ishrn(shift) } return bits } function bits2octets (bits, q) { bits = bits2int(bits, q) bits = bits.mod(q) var out = new Buffer(bits.toArray()) if (out.length < q.byteLength()) { var zeros = new Buffer(q.byteLength() - out.length) zeros.fill(0) out = Buffer.concat([zeros, out]) } return out } function makeKey (q, kv, algo) { var t, k do { t = new Buffer('') while (t.length * 8 < q.bitLength()) { kv.v = createHmac(algo, kv.k) .update(kv.v) .digest() t = Buffer.concat([t, kv.v]) } k = bits2int(t, q) kv.k = createHmac(algo, kv.k) .update(kv.v) .update(new Buffer([0])) .digest() kv.v = createHmac(algo, kv.k) .update(kv.v) .digest() } while (k.cmp(q) !== -1) return k } function makeR (g, k, p, q) { return g.toRed(BN.mont(p)).redPow(k).fromRed().mod(q) } module.exports = sign module.exports.getKey = getKey module.exports.makeKey = makeKey }).call(this,require("buffer").Buffer) },{"./curves":55,"bn.js":29,"browserify-rsa":52,"buffer":61,"create-hmac":109,"elliptic":125,"parse-asn1":288}],57:[function(require,module,exports){ (function (Buffer){ // much of this based on https://github.com/indutny/self-signed/blob/gh-pages/lib/rsa.js var curves = require('./curves') var elliptic = require('elliptic') var parseKeys = require('parse-asn1') var BN = require('bn.js') var EC = elliptic.ec function verify (sig, hash, key, signType) { var pub = parseKeys(key) if (pub.type === 'ec') { if (signType !== 'ecdsa') { throw new Error('wrong public key type') } return ecVerify(sig, hash, pub) } else if (pub.type === 'dsa') { if (signType !== 'dsa') { throw new Error('wrong public key type') } return dsaVerify(sig, hash, pub) } else { if (signType !== 'rsa') { throw new Error('wrong public key type') } } var len = pub.modulus.byteLength() var pad = [ 1 ] var padNum = 0 while (hash.length + pad.length + 2 < len) { pad.push(0xff) padNum++ } pad.push(0x00) var i = -1 while (++i < hash.length) { pad.push(hash[i]) } pad = new Buffer(pad) var red = BN.mont(pub.modulus) sig = new BN(sig).toRed(red) sig = sig.redPow(new BN(pub.publicExponent)) sig = new Buffer(sig.fromRed().toArray()) var out = 0 if (padNum < 8) { out = 1 } len = Math.min(sig.length, pad.length) if (sig.length !== pad.length) { out = 1 } i = -1 while (++i < len) { out |= (sig[i] ^ pad[i]) } return out === 0 } function ecVerify (sig, hash, pub) { var curveId = curves[pub.data.algorithm.curve.join('.')] if (!curveId) throw new Error('unknown curve ' + pub.data.algorithm.curve.join('.')) var curve = new EC(curveId) var pubkey = pub.data.subjectPrivateKey.data return curve.verify(hash, sig, pubkey) } function dsaVerify (sig, hash, pub) { var p = pub.data.p var q = pub.data.q var g = pub.data.g var y = pub.data.pub_key var unpacked = parseKeys.signature.decode(sig, 'der') var s = unpacked.s var r = unpacked.r checkValue(s, q) checkValue(r, q) var montp = BN.mont(p) var w = s.invm(q) var v = g.toRed(montp) .redPow(new BN(hash).mul(w).mod(q)) .fromRed() .mul( y.toRed(montp) .redPow(r.mul(w).mod(q)) .fromRed() ).mod(p).mod(q) return !v.cmp(r) } function checkValue (b, q) { if (b.cmpn(0) <= 0) { throw new Error('invalid sig') } if (b.cmp(q) >= q) { throw new Error('invalid sig') } } module.exports = verify }).call(this,require("buffer").Buffer) },{"./curves":55,"bn.js":29,"buffer":61,"elliptic":125,"parse-asn1":288}],58:[function(require,module,exports){ arguments[4][33][0].apply(exports,arguments) },{"dup":33}],59:[function(require,module,exports){ var Buffer = require('buffer').Buffer; // for use with browserify module.exports = function (a, b) { if (!Buffer.isBuffer(a)) return undefined; if (!Buffer.isBuffer(b)) return undefined; if (typeof a.equals === 'function') return a.equals(b); if (a.length !== b.length) return false; for (var i = 0; i < a.length; i++) { if (a[i] !== b[i]) return false; } return true; }; },{"buffer":61}],60:[function(require,module,exports){ (function (Buffer){ module.exports = function xor (a, b) { var length = Math.min(a.length, b.length) var buffer = new Buffer(length) for (var i = 0; i < length; ++i) { buffer[i] = a[i] ^ b[i] } return buffer } }).call(this,require("buffer").Buffer) },{"buffer":61}],61:[function(require,module,exports){ (function (global){ /*! * The buffer module from node.js, for the browser. * * @author Feross Aboukhadijeh * @license MIT */ /* eslint-disable no-proto */ 'use strict' var base64 = require('base64-js') var ieee754 = require('ieee754') var isArray = require('isarray') exports.Buffer = Buffer exports.SlowBuffer = SlowBuffer exports.INSPECT_MAX_BYTES = 50 Buffer.poolSize = 8192 // not used by this implementation var rootParent = {} /** * If `Buffer.TYPED_ARRAY_SUPPORT`: * === true Use Uint8Array implementation (fastest) * === false Use Object implementation (most compatible, even IE6) * * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+, * Opera 11.6+, iOS 4.2+. * * Due to various browser bugs, sometimes the Object implementation will be used even * when the browser supports typed arrays. * * Note: * * - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances, * See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438. * * - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function. * * - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of * incorrect length in some situations. * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they * get the Object implementation, which is slower but behaves correctly. */ Buffer.TYPED_ARRAY_SUPPORT = global.TYPED_ARRAY_SUPPORT !== undefined ? global.TYPED_ARRAY_SUPPORT : typedArraySupport() function typedArraySupport () { try { var arr = new Uint8Array(1) arr.foo = function () { return 42 } return arr.foo() === 42 && // typed array instances can be augmented typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray` arr.subarray(1, 1).byteLength === 0 // ie10 has broken `subarray` } catch (e) { return false } } function kMaxLength () { return Buffer.TYPED_ARRAY_SUPPORT ? 0x7fffffff : 0x3fffffff } /** * The Buffer constructor returns instances of `Uint8Array` that have their * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of * `Uint8Array`, so the returned instances will have all the node `Buffer` methods * and the `Uint8Array` methods. Square bracket notation works as expected -- it * returns a single octet. * * The `Uint8Array` prototype remains unmodified. */ function Buffer (arg) { if (!(this instanceof Buffer)) { // Avoid going through an ArgumentsAdaptorTrampoline in the common case. if (arguments.length > 1) return new Buffer(arg, arguments[1]) return new Buffer(arg) } if (!Buffer.TYPED_ARRAY_SUPPORT) { this.length = 0 this.parent = undefined } // Common case. if (typeof arg === 'number') { return fromNumber(this, arg) } // Slightly less common case. if (typeof arg === 'string') { return fromString(this, arg, arguments.length > 1 ? arguments[1] : 'utf8') } // Unusual. return fromObject(this, arg) } // TODO: Legacy, not needed anymore. Remove in next major version. Buffer._augment = function (arr) { arr.__proto__ = Buffer.prototype return arr } function fromNumber (that, length) { that = allocate(that, length < 0 ? 0 : checked(length) | 0) if (!Buffer.TYPED_ARRAY_SUPPORT) { for (var i = 0; i < length; i++) { that[i] = 0 } } return that } function fromString (that, string, encoding) { if (typeof encoding !== 'string' || encoding === '') encoding = 'utf8' // Assumption: byteLength() return value is always < kMaxLength. var length = byteLength(string, encoding) | 0 that = allocate(that, length) that.write(string, encoding) return that } function fromObject (that, object) { if (Buffer.isBuffer(object)) return fromBuffer(that, object) if (isArray(object)) return fromArray(that, object) if (object == null) { throw new TypeError('must start with number, buffer, array or string') } if (typeof ArrayBuffer !== 'undefined') { if (object.buffer instanceof ArrayBuffer) { return fromTypedArray(that, object) } if (object instanceof ArrayBuffer) { return fromArrayBuffer(that, object) } } if (object.length) return fromArrayLike(that, object) return fromJsonObject(that, object) } function fromBuffer (that, buffer) { var length = checked(buffer.length) | 0 that = allocate(that, length) buffer.copy(that, 0, 0, length) return that } function fromArray (that, array) { var length = checked(array.length) | 0 that = allocate(that, length) for (var i = 0; i < length; i += 1) { that[i] = array[i] & 255 } return that } // Duplicate of fromArray() to keep fromArray() monomorphic. function fromTypedArray (that, array) { var length = checked(array.length) | 0 that = allocate(that, length) // Truncating the elements is probably not what people expect from typed // arrays with BYTES_PER_ELEMENT > 1 but it's compatible with the behavior // of the old Buffer constructor. for (var i = 0; i < length; i += 1) { that[i] = array[i] & 255 } return that } function fromArrayBuffer (that, array) { array.byteLength // this throws if `array` is not a valid ArrayBuffer if (Buffer.TYPED_ARRAY_SUPPORT) { // Return an augmented `Uint8Array` instance, for best performance that = new Uint8Array(array) that.__proto__ = Buffer.prototype } else { // Fallback: Return an object instance of the Buffer class that = fromTypedArray(that, new Uint8Array(array)) } return that } function fromArrayLike (that, array) { var length = checked(array.length) | 0 that = allocate(that, length) for (var i = 0; i < length; i += 1) { that[i] = array[i] & 255 } return that } // Deserialize { type: 'Buffer', data: [1,2,3,...] } into a Buffer object. // Returns a zero-length buffer for inputs that don't conform to the spec. function fromJsonObject (that, object) { var array var length = 0 if (object.type === 'Buffer' && isArray(object.data)) { array = object.data length = checked(array.length) | 0 } that = allocate(that, length) for (var i = 0; i < length; i += 1) { that[i] = array[i] & 255 } return that } if (Buffer.TYPED_ARRAY_SUPPORT) { Buffer.prototype.__proto__ = Uint8Array.prototype Buffer.__proto__ = Uint8Array if (typeof Symbol !== 'undefined' && Symbol.species && Buffer[Symbol.species] === Buffer) { // Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97 Object.defineProperty(Buffer, Symbol.species, { value: null, configurable: true }) } } else { // pre-set for values that may exist in the future Buffer.prototype.length = undefined Buffer.prototype.parent = undefined } function allocate (that, length) { if (Buffer.TYPED_ARRAY_SUPPORT) { // Return an augmented `Uint8Array` instance, for best performance that = new Uint8Array(length) that.__proto__ = Buffer.prototype } else { // Fallback: Return an object instance of the Buffer class that.length = length } var fromPool = length !== 0 && length <= Buffer.poolSize >>> 1 if (fromPool) that.parent = rootParent return that } function checked (length) { // Note: cannot use `length < kMaxLength` here because that fails when // length is NaN (which is otherwise coerced to zero.) if (length >= kMaxLength()) { throw new RangeError('Attempt to allocate Buffer larger than maximum ' + 'size: 0x' + kMaxLength().toString(16) + ' bytes') } return length | 0 } function SlowBuffer (subject, encoding) { if (!(this instanceof SlowBuffer)) return new SlowBuffer(subject, encoding) var buf = new Buffer(subject, encoding) delete buf.parent return buf } Buffer.isBuffer = function isBuffer (b) { return !!(b != null && b._isBuffer) } Buffer.compare = function compare (a, b) { if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) { throw new TypeError('Arguments must be Buffers') } if (a === b) return 0 var x = a.length var y = b.length for (var i = 0, len = Math.min(x, y); i < len; ++i) { if (a[i] !== b[i]) { x = a[i] y = b[i] break } } if (x < y) return -1 if (y < x) return 1 return 0 } Buffer.isEncoding = function isEncoding (encoding) { switch (String(encoding).toLowerCase()) { case 'hex': case 'utf8': case 'utf-8': case 'ascii': case 'binary': case 'base64': case 'raw': case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': return true default: return false } } Buffer.concat = function concat (list, length) { if (!isArray(list)) throw new TypeError('list argument must be an Array of Buffers.') if (list.length === 0) { return new Buffer(0) } var i if (length === undefined) { length = 0 for (i = 0; i < list.length; i++) { length += list[i].length } } var buf = new Buffer(length) var pos = 0 for (i = 0; i < list.length; i++) { var item = list[i] item.copy(buf, pos) pos += item.length } return buf } function byteLength (string, encoding) { if (typeof string !== 'string') string = '' + string var len = string.length if (len === 0) return 0 // Use a for loop to avoid recursion var loweredCase = false for (;;) { switch (encoding) { case 'ascii': case 'binary': // Deprecated case 'raw': case 'raws': return len case 'utf8': case 'utf-8': return utf8ToBytes(string).length case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': return len * 2 case 'hex': return len >>> 1 case 'base64': return base64ToBytes(string).length default: if (loweredCase) return utf8ToBytes(string).length // assume utf8 encoding = ('' + encoding).toLowerCase() loweredCase = true } } } Buffer.byteLength = byteLength function slowToString (encoding, start, end) { var loweredCase = false start = start | 0 end = end === undefined || end === Infinity ? this.length : end | 0 if (!encoding) encoding = 'utf8' if (start < 0) start = 0 if (end > this.length) end = this.length if (end <= start) return '' while (true) { switch (encoding) { case 'hex': return hexSlice(this, start, end) case 'utf8': case 'utf-8': return utf8Slice(this, start, end) case 'ascii': return asciiSlice(this, start, end) case 'binary': return binarySlice(this, start, end) case 'base64': return base64Slice(this, start, end) case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': return utf16leSlice(this, start, end) default: if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding) encoding = (encoding + '').toLowerCase() loweredCase = true } } } // The property is used by `Buffer.isBuffer` and `is-buffer` (in Safari 5-7) to detect // Buffer instances. Buffer.prototype._isBuffer = true Buffer.prototype.toString = function toString () { var length = this.length | 0 if (length === 0) return '' if (arguments.length === 0) return utf8Slice(this, 0, length) return slowToString.apply(this, arguments) } Buffer.prototype.equals = function equals (b) { if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer') if (this === b) return true return Buffer.compare(this, b) === 0 } Buffer.prototype.inspect = function inspect () { var str = '' var max = exports.INSPECT_MAX_BYTES if (this.length > 0) { str = this.toString('hex', 0, max).match(/.{2}/g).join(' ') if (this.length > max) str += ' ... ' } return '' } Buffer.prototype.compare = function compare (b) { if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer') return Buffer.compare(this, b) } Buffer.prototype.indexOf = function indexOf (val, byteOffset) { if (byteOffset > 0x7fffffff) byteOffset = 0x7fffffff else if (byteOffset < -0x80000000) byteOffset = -0x80000000 byteOffset >>= 0 if (this.length === 0) return -1 if (byteOffset >= this.length) return -1 // Negative offsets start from the end of the buffer if (byteOffset < 0) byteOffset = Math.max(this.length + byteOffset, 0) if (typeof val === 'string') { if (val.length === 0) return -1 // special case: looking for empty string always fails return String.prototype.indexOf.call(this, val, byteOffset) } if (Buffer.isBuffer(val)) { return arrayIndexOf(this, val, byteOffset) } if (typeof val === 'number') { if (Buffer.TYPED_ARRAY_SUPPORT && Uint8Array.prototype.indexOf === 'function') { return Uint8Array.prototype.indexOf.call(this, val, byteOffset) } return arrayIndexOf(this, [ val ], byteOffset) } function arrayIndexOf (arr, val, byteOffset) { var foundIndex = -1 for (var i = 0; byteOffset + i < arr.length; i++) { if (arr[byteOffset + i] === val[foundIndex === -1 ? 0 : i - foundIndex]) { if (foundIndex === -1) foundIndex = i if (i - foundIndex + 1 === val.length) return byteOffset + foundIndex } else { foundIndex = -1 } } return -1 } throw new TypeError('val must be string, number or Buffer') } function hexWrite (buf, string, offset, length) { offset = Number(offset) || 0 var remaining = buf.length - offset if (!length) { length = remaining } else { length = Number(length) if (length > remaining) { length = remaining } } // must be an even number of digits var strLen = string.length if (strLen % 2 !== 0) throw new Error('Invalid hex string') if (length > strLen / 2) { length = strLen / 2 } for (var i = 0; i < length; i++) { var parsed = parseInt(string.substr(i * 2, 2), 16) if (isNaN(parsed)) throw new Error('Invalid hex string') buf[offset + i] = parsed } return i } function utf8Write (buf, string, offset, length) { return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length) } function asciiWrite (buf, string, offset, length) { return blitBuffer(asciiToBytes(string), buf, offset, length) } function binaryWrite (buf, string, offset, length) { return asciiWrite(buf, string, offset, length) } function base64Write (buf, string, offset, length) { return blitBuffer(base64ToBytes(string), buf, offset, length) } function ucs2Write (buf, string, offset, length) { return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length) } Buffer.prototype.write = function write (string, offset, length, encoding) { // Buffer#write(string) if (offset === undefined) { encoding = 'utf8' length = this.length offset = 0 // Buffer#write(string, encoding) } else if (length === undefined && typeof offset === 'string') { encoding = offset length = this.length offset = 0 // Buffer#write(string, offset[, length][, encoding]) } else if (isFinite(offset)) { offset = offset | 0 if (isFinite(length)) { length = length | 0 if (encoding === undefined) encoding = 'utf8' } else { encoding = length length = undefined } // legacy write(string, encoding, offset, length) - remove in v0.13 } else { var swap = encoding encoding = offset offset = length | 0 length = swap } var remaining = this.length - offset if (length === undefined || length > remaining) length = remaining if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) { throw new RangeError('attempt to write outside buffer bounds') } if (!encoding) encoding = 'utf8' var loweredCase = false for (;;) { switch (encoding) { case 'hex': return hexWrite(this, string, offset, length) case 'utf8': case 'utf-8': return utf8Write(this, string, offset, length) case 'ascii': return asciiWrite(this, string, offset, length) case 'binary': return binaryWrite(this, string, offset, length) case 'base64': // Warning: maxLength not taken into account in base64Write return base64Write(this, string, offset, length) case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': return ucs2Write(this, string, offset, length) default: if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding) encoding = ('' + encoding).toLowerCase() loweredCase = true } } } Buffer.prototype.toJSON = function toJSON () { return { type: 'Buffer', data: Array.prototype.slice.call(this._arr || this, 0) } } function base64Slice (buf, start, end) { if (start === 0 && end === buf.length) { return base64.fromByteArray(buf) } else { return base64.fromByteArray(buf.slice(start, end)) } } function utf8Slice (buf, start, end) { end = Math.min(buf.length, end) var res = [] var i = start while (i < end) { var firstByte = buf[i] var codePoint = null var bytesPerSequence = (firstByte > 0xEF) ? 4 : (firstByte > 0xDF) ? 3 : (firstByte > 0xBF) ? 2 : 1 if (i + bytesPerSequence <= end) { var secondByte, thirdByte, fourthByte, tempCodePoint switch (bytesPerSequence) { case 1: if (firstByte < 0x80) { codePoint = firstByte } break case 2: secondByte = buf[i + 1] if ((secondByte & 0xC0) === 0x80) { tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F) if (tempCodePoint > 0x7F) { codePoint = tempCodePoint } } break case 3: secondByte = buf[i + 1] thirdByte = buf[i + 2] if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) { tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F) if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) { codePoint = tempCodePoint } } break case 4: secondByte = buf[i + 1] thirdByte = buf[i + 2] fourthByte = buf[i + 3] if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) { tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F) if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) { codePoint = tempCodePoint } } } } if (codePoint === null) { // we did not generate a valid codePoint so insert a // replacement char (U+FFFD) and advance only 1 byte codePoint = 0xFFFD bytesPerSequence = 1 } else if (codePoint > 0xFFFF) { // encode to utf16 (surrogate pair dance) codePoint -= 0x10000 res.push(codePoint >>> 10 & 0x3FF | 0xD800) codePoint = 0xDC00 | codePoint & 0x3FF } res.push(codePoint) i += bytesPerSequence } return decodeCodePointsArray(res) } // Based on http://stackoverflow.com/a/22747272/680742, the browser with // the lowest limit is Chrome, with 0x10000 args. // We go 1 magnitude less, for safety var MAX_ARGUMENTS_LENGTH = 0x1000 function decodeCodePointsArray (codePoints) { var len = codePoints.length if (len <= MAX_ARGUMENTS_LENGTH) { return String.fromCharCode.apply(String, codePoints) // avoid extra slice() } // Decode in chunks to avoid "call stack size exceeded". var res = '' var i = 0 while (i < len) { res += String.fromCharCode.apply( String, codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH) ) } return res } function asciiSlice (buf, start, end) { var ret = '' end = Math.min(buf.length, end) for (var i = start; i < end; i++) { ret += String.fromCharCode(buf[i] & 0x7F) } return ret } function binarySlice (buf, start, end) { var ret = '' end = Math.min(buf.length, end) for (var i = start; i < end; i++) { ret += String.fromCharCode(buf[i]) } return ret } function hexSlice (buf, start, end) { var len = buf.length if (!start || start < 0) start = 0 if (!end || end < 0 || end > len) end = len var out = '' for (var i = start; i < end; i++) { out += toHex(buf[i]) } return out } function utf16leSlice (buf, start, end) { var bytes = buf.slice(start, end) var res = '' for (var i = 0; i < bytes.length; i += 2) { res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256) } return res } Buffer.prototype.slice = function slice (start, end) { var len = this.length start = ~~start end = end === undefined ? len : ~~end if (start < 0) { start += len if (start < 0) start = 0 } else if (start > len) { start = len } if (end < 0) { end += len if (end < 0) end = 0 } else if (end > len) { end = len } if (end < start) end = start var newBuf if (Buffer.TYPED_ARRAY_SUPPORT) { newBuf = this.subarray(start, end) newBuf.__proto__ = Buffer.prototype } else { var sliceLen = end - start newBuf = new Buffer(sliceLen, undefined) for (var i = 0; i < sliceLen; i++) { newBuf[i] = this[i + start] } } if (newBuf.length) newBuf.parent = this.parent || this return newBuf } /* * Need to make sure that buffer isn't trying to write out of bounds. */ function checkOffset (offset, ext, length) { if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint') if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length') } Buffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) { offset = offset | 0 byteLength = byteLength | 0 if (!noAssert) checkOffset(offset, byteLength, this.length) var val = this[offset] var mul = 1 var i = 0 while (++i < byteLength && (mul *= 0x100)) { val += this[offset + i] * mul } return val } Buffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) { offset = offset | 0 byteLength = byteLength | 0 if (!noAssert) { checkOffset(offset, byteLength, this.length) } var val = this[offset + --byteLength] var mul = 1 while (byteLength > 0 && (mul *= 0x100)) { val += this[offset + --byteLength] * mul } return val } Buffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) { if (!noAssert) checkOffset(offset, 1, this.length) return this[offset] } Buffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) { if (!noAssert) checkOffset(offset, 2, this.length) return this[offset] | (this[offset + 1] << 8) } Buffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) { if (!noAssert) checkOffset(offset, 2, this.length) return (this[offset] << 8) | this[offset + 1] } Buffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) { if (!noAssert) checkOffset(offset, 4, this.length) return ((this[offset]) | (this[offset + 1] << 8) | (this[offset + 2] << 16)) + (this[offset + 3] * 0x1000000) } Buffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) { if (!noAssert) checkOffset(offset, 4, this.length) return (this[offset] * 0x1000000) + ((this[offset + 1] << 16) | (this[offset + 2] << 8) | this[offset + 3]) } Buffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) { offset = offset | 0 byteLength = byteLength | 0 if (!noAssert) checkOffset(offset, byteLength, this.length) var val = this[offset] var mul = 1 var i = 0 while (++i < byteLength && (mul *= 0x100)) { val += this[offset + i] * mul } mul *= 0x80 if (val >= mul) val -= Math.pow(2, 8 * byteLength) return val } Buffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) { offset = offset | 0 byteLength = byteLength | 0 if (!noAssert) checkOffset(offset, byteLength, this.length) var i = byteLength var mul = 1 var val = this[offset + --i] while (i > 0 && (mul *= 0x100)) { val += this[offset + --i] * mul } mul *= 0x80 if (val >= mul) val -= Math.pow(2, 8 * byteLength) return val } Buffer.prototype.readInt8 = function readInt8 (offset, noAssert) { if (!noAssert) checkOffset(offset, 1, this.length) if (!(this[offset] & 0x80)) return (this[offset]) return ((0xff - this[offset] + 1) * -1) } Buffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) { if (!noAssert) checkOffset(offset, 2, this.length) var val = this[offset] | (this[offset + 1] << 8) return (val & 0x8000) ? val | 0xFFFF0000 : val } Buffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) { if (!noAssert) checkOffset(offset, 2, this.length) var val = this[offset + 1] | (this[offset] << 8) return (val & 0x8000) ? val | 0xFFFF0000 : val } Buffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) { if (!noAssert) checkOffset(offset, 4, this.length) return (this[offset]) | (this[offset + 1] << 8) | (this[offset + 2] << 16) | (this[offset + 3] << 24) } Buffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) { if (!noAssert) checkOffset(offset, 4, this.length) return (this[offset] << 24) | (this[offset + 1] << 16) | (this[offset + 2] << 8) | (this[offset + 3]) } Buffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) { if (!noAssert) checkOffset(offset, 4, this.length) return ieee754.read(this, offset, true, 23, 4) } Buffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) { if (!noAssert) checkOffset(offset, 4, this.length) return ieee754.read(this, offset, false, 23, 4) } Buffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) { if (!noAssert) checkOffset(offset, 8, this.length) return ieee754.read(this, offset, true, 52, 8) } Buffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) { if (!noAssert) checkOffset(offset, 8, this.length) return ieee754.read(this, offset, false, 52, 8) } function checkInt (buf, value, offset, ext, max, min) { if (!Buffer.isBuffer(buf)) throw new TypeError('buffer must be a Buffer instance') if (value > max || value < min) throw new RangeError('value is out of bounds') if (offset + ext > buf.length) throw new RangeError('index out of range') } Buffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) { value = +value offset = offset | 0 byteLength = byteLength | 0 if (!noAssert) checkInt(this, value, offset, byteLength, Math.pow(2, 8 * byteLength), 0) var mul = 1 var i = 0 this[offset] = value & 0xFF while (++i < byteLength && (mul *= 0x100)) { this[offset + i] = (value / mul) & 0xFF } return offset + byteLength } Buffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) { value = +value offset = offset | 0 byteLength = byteLength | 0 if (!noAssert) checkInt(this, value, offset, byteLength, Math.pow(2, 8 * byteLength), 0) var i = byteLength - 1 var mul = 1 this[offset + i] = value & 0xFF while (--i >= 0 && (mul *= 0x100)) { this[offset + i] = (value / mul) & 0xFF } return offset + byteLength } Buffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) { value = +value offset = offset | 0 if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0) if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value) this[offset] = (value & 0xff) return offset + 1 } function objectWriteUInt16 (buf, value, offset, littleEndian) { if (value < 0) value = 0xffff + value + 1 for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; i++) { buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>> (littleEndian ? i : 1 - i) * 8 } } Buffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) { value = +value offset = offset | 0 if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0) if (Buffer.TYPED_ARRAY_SUPPORT) { this[offset] = (value & 0xff) this[offset + 1] = (value >>> 8) } else { objectWriteUInt16(this, value, offset, true) } return offset + 2 } Buffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) { value = +value offset = offset | 0 if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0) if (Buffer.TYPED_ARRAY_SUPPORT) { this[offset] = (value >>> 8) this[offset + 1] = (value & 0xff) } else { objectWriteUInt16(this, value, offset, false) } return offset + 2 } function objectWriteUInt32 (buf, value, offset, littleEndian) { if (value < 0) value = 0xffffffff + value + 1 for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; i++) { buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff } } Buffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) { value = +value offset = offset | 0 if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0) if (Buffer.TYPED_ARRAY_SUPPORT) { this[offset + 3] = (value >>> 24) this[offset + 2] = (value >>> 16) this[offset + 1] = (value >>> 8) this[offset] = (value & 0xff) } else { objectWriteUInt32(this, value, offset, true) } return offset + 4 } Buffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) { value = +value offset = offset | 0 if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0) if (Buffer.TYPED_ARRAY_SUPPORT) { this[offset] = (value >>> 24) this[offset + 1] = (value >>> 16) this[offset + 2] = (value >>> 8) this[offset + 3] = (value & 0xff) } else { objectWriteUInt32(this, value, offset, false) } return offset + 4 } Buffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) { value = +value offset = offset | 0 if (!noAssert) { var limit = Math.pow(2, 8 * byteLength - 1) checkInt(this, value, offset, byteLength, limit - 1, -limit) } var i = 0 var mul = 1 var sub = value < 0 ? 1 : 0 this[offset] = value & 0xFF while (++i < byteLength && (mul *= 0x100)) { this[offset + i] = ((value / mul) >> 0) - sub & 0xFF } return offset + byteLength } Buffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) { value = +value offset = offset | 0 if (!noAssert) { var limit = Math.pow(2, 8 * byteLength - 1) checkInt(this, value, offset, byteLength, limit - 1, -limit) } var i = byteLength - 1 var mul = 1 var sub = value < 0 ? 1 : 0 this[offset + i] = value & 0xFF while (--i >= 0 && (mul *= 0x100)) { this[offset + i] = ((value / mul) >> 0) - sub & 0xFF } return offset + byteLength } Buffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) { value = +value offset = offset | 0 if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80) if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value) if (value < 0) value = 0xff + value + 1 this[offset] = (value & 0xff) return offset + 1 } Buffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) { value = +value offset = offset | 0 if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000) if (Buffer.TYPED_ARRAY_SUPPORT) { this[offset] = (value & 0xff) this[offset + 1] = (value >>> 8) } else { objectWriteUInt16(this, value, offset, true) } return offset + 2 } Buffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) { value = +value offset = offset | 0 if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000) if (Buffer.TYPED_ARRAY_SUPPORT) { this[offset] = (value >>> 8) this[offset + 1] = (value & 0xff) } else { objectWriteUInt16(this, value, offset, false) } return offset + 2 } Buffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) { value = +value offset = offset | 0 if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000) if (Buffer.TYPED_ARRAY_SUPPORT) { this[offset] = (value & 0xff) this[offset + 1] = (value >>> 8) this[offset + 2] = (value >>> 16) this[offset + 3] = (value >>> 24) } else { objectWriteUInt32(this, value, offset, true) } return offset + 4 } Buffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) { value = +value offset = offset | 0 if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000) if (value < 0) value = 0xffffffff + value + 1 if (Buffer.TYPED_ARRAY_SUPPORT) { this[offset] = (value >>> 24) this[offset + 1] = (value >>> 16) this[offset + 2] = (value >>> 8) this[offset + 3] = (value & 0xff) } else { objectWriteUInt32(this, value, offset, false) } return offset + 4 } function checkIEEE754 (buf, value, offset, ext, max, min) { if (offset + ext > buf.length) throw new RangeError('index out of range') if (offset < 0) throw new RangeError('index out of range') } function writeFloat (buf, value, offset, littleEndian, noAssert) { if (!noAssert) { checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38) } ieee754.write(buf, value, offset, littleEndian, 23, 4) return offset + 4 } Buffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) { return writeFloat(this, value, offset, true, noAssert) } Buffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) { return writeFloat(this, value, offset, false, noAssert) } function writeDouble (buf, value, offset, littleEndian, noAssert) { if (!noAssert) { checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308) } ieee754.write(buf, value, offset, littleEndian, 52, 8) return offset + 8 } Buffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) { return writeDouble(this, value, offset, true, noAssert) } Buffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) { return writeDouble(this, value, offset, false, noAssert) } // copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length) Buffer.prototype.copy = function copy (target, targetStart, start, end) { if (!start) start = 0 if (!end && end !== 0) end = this.length if (targetStart >= target.length) targetStart = target.length if (!targetStart) targetStart = 0 if (end > 0 && end < start) end = start // Copy 0 bytes; we're done if (end === start) return 0 if (target.length === 0 || this.length === 0) return 0 // Fatal error conditions if (targetStart < 0) { throw new RangeError('targetStart out of bounds') } if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds') if (end < 0) throw new RangeError('sourceEnd out of bounds') // Are we oob? if (end > this.length) end = this.length if (target.length - targetStart < end - start) { end = target.length - targetStart + start } var len = end - start var i if (this === target && start < targetStart && targetStart < end) { // descending copy from end for (i = len - 1; i >= 0; i--) { target[i + targetStart] = this[i + start] } } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) { // ascending copy from start for (i = 0; i < len; i++) { target[i + targetStart] = this[i + start] } } else { Uint8Array.prototype.set.call( target, this.subarray(start, start + len), targetStart ) } return len } // fill(value, start=0, end=buffer.length) Buffer.prototype.fill = function fill (value, start, end) { if (!value) value = 0 if (!start) start = 0 if (!end) end = this.length if (end < start) throw new RangeError('end < start') // Fill 0 bytes; we're done if (end === start) return if (this.length === 0) return if (start < 0 || start >= this.length) throw new RangeError('start out of bounds') if (end < 0 || end > this.length) throw new RangeError('end out of bounds') var i if (typeof value === 'number') { for (i = start; i < end; i++) { this[i] = value } } else { var bytes = utf8ToBytes(value.toString()) var len = bytes.length for (i = start; i < end; i++) { this[i] = bytes[i % len] } } return this } // HELPER FUNCTIONS // ================ var INVALID_BASE64_RE = /[^+\/0-9A-Za-z-_]/g function base64clean (str) { // Node strips out invalid characters like \n and \t from the string, base64-js does not str = stringtrim(str).replace(INVALID_BASE64_RE, '') // Node converts strings with length < 2 to '' if (str.length < 2) return '' // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not while (str.length % 4 !== 0) { str = str + '=' } return str } function stringtrim (str) { if (str.trim) return str.trim() return str.replace(/^\s+|\s+$/g, '') } function toHex (n) { if (n < 16) return '0' + n.toString(16) return n.toString(16) } function utf8ToBytes (string, units) { units = units || Infinity var codePoint var length = string.length var leadSurrogate = null var bytes = [] for (var i = 0; i < length; i++) { codePoint = string.charCodeAt(i) // is surrogate component if (codePoint > 0xD7FF && codePoint < 0xE000) { // last char was a lead if (!leadSurrogate) { // no lead yet if (codePoint > 0xDBFF) { // unexpected trail if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) continue } else if (i + 1 === length) { // unpaired lead if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) continue } // valid lead leadSurrogate = codePoint continue } // 2 leads in a row if (codePoint < 0xDC00) { if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) leadSurrogate = codePoint continue } // valid surrogate pair codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000 } else if (leadSurrogate) { // valid bmp char, but last char was a lead if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD) } leadSurrogate = null // encode utf8 if (codePoint < 0x80) { if ((units -= 1) < 0) break bytes.push(codePoint) } else if (codePoint < 0x800) { if ((units -= 2) < 0) break bytes.push( codePoint >> 0x6 | 0xC0, codePoint & 0x3F | 0x80 ) } else if (codePoint < 0x10000) { if ((units -= 3) < 0) break bytes.push( codePoint >> 0xC | 0xE0, codePoint >> 0x6 & 0x3F | 0x80, codePoint & 0x3F | 0x80 ) } else if (codePoint < 0x110000) { if ((units -= 4) < 0) break bytes.push( codePoint >> 0x12 | 0xF0, codePoint >> 0xC & 0x3F | 0x80, codePoint >> 0x6 & 0x3F | 0x80, codePoint & 0x3F | 0x80 ) } else { throw new Error('Invalid code point') } } return bytes } function asciiToBytes (str) { var byteArray = [] for (var i = 0; i < str.length; i++) { // Node's code seems to be doing this and not & 0x7F.. byteArray.push(str.charCodeAt(i) & 0xFF) } return byteArray } function utf16leToBytes (str, units) { var c, hi, lo var byteArray = [] for (var i = 0; i < str.length; i++) { if ((units -= 2) < 0) break c = str.charCodeAt(i) hi = c >> 8 lo = c % 256 byteArray.push(lo) byteArray.push(hi) } return byteArray } function base64ToBytes (str) { return base64.toByteArray(base64clean(str)) } function blitBuffer (src, dst, offset, length) { for (var i = 0; i < length; i++) { if ((i + offset >= dst.length) || (i >= src.length)) break dst[i + offset] = src[i] } return i } }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) },{"base64-js":62,"ieee754":163,"isarray":63}],62:[function(require,module,exports){ 'use strict' exports.toByteArray = toByteArray exports.fromByteArray = fromByteArray var lookup = [] var revLookup = [] var Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array function init () { var code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/' for (var i = 0, len = code.length; i < len; ++i) { lookup[i] = code[i] revLookup[code.charCodeAt(i)] = i } revLookup['-'.charCodeAt(0)] = 62 revLookup['_'.charCodeAt(0)] = 63 } init() function toByteArray (b64) { var i, j, l, tmp, placeHolders, arr var len = b64.length if (len % 4 > 0) { throw new Error('Invalid string. Length must be a multiple of 4') } // the number of equal signs (place holders) // if there are two placeholders, than the two characters before it // represent one byte // if there is only one, then the three characters before it represent 2 bytes // this is just a cheap hack to not do indexOf twice placeHolders = b64[len - 2] === '=' ? 2 : b64[len - 1] === '=' ? 1 : 0 // base64 is 4/3 + up to two characters of the original data arr = new Arr(len * 3 / 4 - placeHolders) // if there are placeholders, only get up to the last complete 4 chars l = placeHolders > 0 ? len - 4 : len var L = 0 for (i = 0, j = 0; i < l; i += 4, j += 3) { tmp = (revLookup[b64.charCodeAt(i)] << 18) | (revLookup[b64.charCodeAt(i + 1)] << 12) | (revLookup[b64.charCodeAt(i + 2)] << 6) | revLookup[b64.charCodeAt(i + 3)] arr[L++] = (tmp >> 16) & 0xFF arr[L++] = (tmp >> 8) & 0xFF arr[L++] = tmp & 0xFF } if (placeHolders === 2) { tmp = (revLookup[b64.charCodeAt(i)] << 2) | (revLookup[b64.charCodeAt(i + 1)] >> 4) arr[L++] = tmp & 0xFF } else if (placeHolders === 1) { tmp = (revLookup[b64.charCodeAt(i)] << 10) | (revLookup[b64.charCodeAt(i + 1)] << 4) | (revLookup[b64.charCodeAt(i + 2)] >> 2) arr[L++] = (tmp >> 8) & 0xFF arr[L++] = tmp & 0xFF } return arr } function tripletToBase64 (num) { return lookup[num >> 18 & 0x3F] + lookup[num >> 12 & 0x3F] + lookup[num >> 6 & 0x3F] + lookup[num & 0x3F] } function encodeChunk (uint8, start, end) { var tmp var output = [] for (var i = start; i < end; i += 3) { tmp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2]) output.push(tripletToBase64(tmp)) } return output.join('') } function fromByteArray (uint8) { var tmp var len = uint8.length var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes var output = '' var parts = [] var maxChunkLength = 16383 // must be multiple of 3 // go through the array every three bytes, we'll deal with trailing stuff later for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) { parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength))) } // pad the end with zeros, but make sure to not forget the extra bytes if (extraBytes === 1) { tmp = uint8[len - 1] output += lookup[tmp >> 2] output += lookup[(tmp << 4) & 0x3F] output += '==' } else if (extraBytes === 2) { tmp = (uint8[len - 2] << 8) + (uint8[len - 1]) output += lookup[tmp >> 10] output += lookup[(tmp >> 4) & 0x3F] output += lookup[(tmp << 2) & 0x3F] output += '=' } parts.push(output) return parts.join('') } },{}],63:[function(require,module,exports){ arguments[4][23][0].apply(exports,arguments) },{"dup":23}],64:[function(require,module,exports){ module.exports = { "100": "Continue", "101": "Switching Protocols", "102": "Processing", "200": "OK", "201": "Created", "202": "Accepted", "203": "Non-Authoritative Information", "204": "No Content", "205": "Reset Content", "206": "Partial Content", "207": "Multi-Status", "208": "Already Reported", "226": "IM Used", "300": "Multiple Choices", "301": "Moved Permanently", "302": "Found", "303": "See Other", "304": "Not Modified", "305": "Use Proxy", "307": "Temporary Redirect", "308": "Permanent Redirect", "400": "Bad Request", "401": "Unauthorized", "402": "Payment Required", "403": "Forbidden", "404": "Not Found", "405": "Method Not Allowed", "406": "Not Acceptable", "407": "Proxy Authentication Required", "408": "Request Timeout", "409": "Conflict", "410": "Gone", "411": "Length Required", "412": "Precondition Failed", "413": "Payload Too Large", "414": "URI Too Long", "415": "Unsupported Media Type", "416": "Range Not Satisfiable", "417": "Expectation Failed", "418": "I'm a teapot", "421": "Misdirected Request", "422": "Unprocessable Entity", "423": "Locked", "424": "Failed Dependency", "425": "Unordered Collection", "426": "Upgrade Required", "428": "Precondition Required", "429": "Too Many Requests", "431": "Request Header Fields Too Large", "500": "Internal Server Error", "501": "Not Implemented", "502": "Bad Gateway", "503": "Service Unavailable", "504": "Gateway Timeout", "505": "HTTP Version Not Supported", "506": "Variant Also Negotiates", "507": "Insufficient Storage", "508": "Loop Detected", "509": "Bandwidth Limit Exceeded", "510": "Not Extended", "511": "Network Authentication Required" } },{}],65:[function(require,module,exports){ var base = require('typewise-core/base') var codecs = require('./codecs') var util = require('./util') // // extend core sorts defined by typewise with bytewise-specific functionality // // byte represents byte tag prefix in encoded form, enforcing binary total order // type tag is 1 byte, which gives us plenty of room to grow // // boundary types // base.bound.encode = util.encodeBaseBound // // value types // var sorts = base.sorts sorts.void.byte = 0xf0 sorts.null.byte = 0x10 var BOOLEAN = sorts.boolean BOOLEAN.sorts.false.byte = 0x20 BOOLEAN.sorts.true.byte = 0x21 BOOLEAN.bound.encode = util.encodeBound var NUMBER = sorts.number NUMBER.sorts.min.byte = 0x40 NUMBER.sorts.negative.byte = 0x41 NUMBER.sorts.positive.byte = 0x42 NUMBER.sorts.max.byte = 0x43 NUMBER.sorts.negative.codec = codecs.NEGATIVE_FLOAT NUMBER.sorts.positive.codec = codecs.POSITIVE_FLOAT NUMBER.bound.encode = util.encodeBound var DATE = sorts.date DATE.sorts.negative.byte = 0x51 DATE.sorts.positive.byte = 0x52 DATE.sorts.negative.codec = codecs.PRE_EPOCH_DATE DATE.sorts.positive.codec = codecs.POST_EPOCH_DATE DATE.bound.encode = util.encodeBound var BINARY = sorts.binary BINARY.byte = 0x60 BINARY.codec = codecs.UINT8 BINARY.bound.encode = util.encodeBound var STRING = sorts.string STRING.byte = 0x70 STRING.codec = codecs.UTF8 STRING.bound.encode = util.encodeBound var ARRAY = sorts.array ARRAY.byte = 0xa0 ARRAY.codec = codecs.LIST ARRAY.bound.encode = util.encodeListBound // var OBJECT = sorts.object // OBJECT.byte = 0xb0 // OBJECT.codec = codecs.HASH // OBJECT.bound.encode = util.encodeListBound module.exports = base },{"./codecs":66,"./util":68,"typewise-core/base":623}],66:[function(require,module,exports){ (function (Buffer){ var util = require('./util') var FLOAT_LENGTH = 8 function identity(value) { return value } function shortlexEncode(codec) { return function (source, base) { // stupid lazy implementation // TODO: allow length getter to be provided var length = util.encodeFloat(source.length) var body = codec.encode(source, base) return Buffer.concat([ length, body ]) } } function shortlexDecode(codec) { return function (buffer) { // stupid lazy implementation return codec.decode(this, buffer.slice(FLOAT_LENGTH)) } } function shortlexParse(codec) { // TODO return function (buffer, base) { throw new Error('NYI') } } function shortlex(codec) { return { encode: shortlexEncode(codec), decode: shortlexDecode(codec), parse: shortlexParse(codec) } } // // pairs of encode/decode functions // var codecs = exports codecs.HEX = { encode: function (source) { return new Buffer(source, 'hex') }, decode: function (buffer) { return buffer.toString('hex') } } codecs.UINT8 = { encode: identity, decode: identity, escape: util.escapeFlat, unescape: util.unescapeFlat } codecs.UINT8_SHORTLEX = shortlex(codecs.UINT8) codecs.UTF8 = { encode: function (source) { return new Buffer(source, 'utf8') }, decode: function (buffer) { return buffer.toString('utf8') }, escape: util.escapeFlatLow, unescape: util.unescapeFlatLow } codecs.UTF8_SHORTLEX = shortlex(codecs.UTF8) codecs.POSITIVE_FLOAT = { length: FLOAT_LENGTH, encode: util.encodeFloat, decode: util.decodeFloat } codecs.NEGATIVE_FLOAT = { length: FLOAT_LENGTH, encode: util.encodeFloat, decode: function (buffer) { return util.decodeFloat(buffer, null, true) } } codecs.POST_EPOCH_DATE = { length: FLOAT_LENGTH, encode: util.encodeFloat, decode: function (buffer) { return new Date(util.decodeFloat(buffer)) } } codecs.PRE_EPOCH_DATE = { length: FLOAT_LENGTH, encode: util.encodeFloat, decode: function (buffer) { return new Date(util.decodeFloat(buffer, null, true)) } } // // base encoding for complex structures // codecs.LIST = { encode: util.encodeList, decode: util.decodeList } codecs.TUPLE = shortlex(codecs.LIST) // // member order is preserved and accounted for in sort (except for number keys) // codecs.HASH = { // TODO // encode: util.encodeHash, // decode: util.decodeHash } codecs.RECORD = shortlex(codecs.HASH) }).call(this,require("buffer").Buffer) },{"./util":68,"buffer":61}],67:[function(require,module,exports){ (function (Buffer){ var assert = require('./util').assert var base = require('./base') var codecs = require('./codecs') var bytewise = exports // // expose type information // var sorts = bytewise.sorts = base.sorts bytewise.bound = base.bound bytewise.compare = base.compare bytewise.equal = base.equal // // generate a buffer with type's byte prefix from source value // function serialize(type, source, options) { var codec = type.codec if (!codec) return postEncode(new Buffer([ type.byte ]), options) var buffer = codec.encode(source, bytewise) if (options && options.nested && codec.escape) buffer = codec.escape(buffer) var hint = typeof codec.length === 'number' ? (codec.length + 1) : void 0 var buffers = [ new Buffer([ type.byte ]), buffer ] return postEncode(Buffer.concat(buffers, hint), options) } // // core encode logic // bytewise.encode = function(source, options) { // check for invalid/incomparable values assert(!base.invalid(source), 'Invalid value') // encode bound types (ranges) var boundary = base.bound.getBoundary(source) if (boundary) return boundary.encode(source, bytewise) // encode standard value-typed sorts var order = base.order var sort for (var i = 0, length = order.length; i < length; ++i) { sort = sorts[order[i]] if (sort.is(source)) { // loop over any subsorts defined on sort // TODO: clean up var subsorts = sort.sorts || { '': sort } for (key in subsorts) { var subsort = subsorts[key] if (subsort.is(source)) return serialize(subsort, source, options) } // source is an unsupported subsort assert(false, 'Unsupported sort value') } } // no type descriptor found assert(false, 'Unknown value') } // // core decode logic // bytewise.decode = function (buffer, options) { // attempt to decode string input using configurable codec if (typeof buffer === 'string') { buffer = bytewise.stringCodec.encode(buffer) } assert(!buffer || !buffer.undecodable, 'Encoded value not decodable') var byte = buffer[0] var type = bytewise.getType(byte) assert(type, 'Invalid encoding: ' + buffer) // if type provides a decoder it is passed the base type system as second arg var codec = type.codec if (codec) { var decoded = codec.decode(buffer.slice(1), bytewise) if (options && options.nested && codec.unescape) decoded = codec.unescape(decoded) return postDecode(decoded, options) } // nullary types without a codec must provide a value for their decoded form assert('value' in type, 'Unsupported encoding: ' + buffer) return postDecode(type.value, options) } // // process top level // function postEncode(encoded, options) { if (options === null) return encoded return bytewise.postEncode(encoded, options) } // // invoked after encoding with encoded buffer instance // bytewise.postEncode = function (encoded, options) { // override buffer toString method to default to hex to help coercion issues // TODO: just return pure buffer, do this toString hackery in bytewise encoded.toString = function (encoding) { if (!encoding) return bytewise.stringCodec.decode(encoded) return Buffer.prototype.toString.apply(encoded, arguments) } return encoded } function postDecode(decoded, options) { if (options === null) return decoded return bytewise.postDecode(decoded, options) } // // invoked after decoding with decoded value // bytewise.postDecode = function (decoded, options) { return decoded } // // registry mapping byte prefixes to type descriptors // var PREFIX_REGISTRY function registerType(type) { var byte = type && type.byte if (byte == null) return if (byte in PREFIX_REGISTRY) assert.deepEqual(type, PREFIX_REGISTRY[byte], 'Duplicate prefix: ' + byte) PREFIX_REGISTRY[type.byte] = type } function registerTypes(types) { for (var key in types) { registerType(types[key]) } } // // look up type descriptor associated with a given byte prefix // bytewise.getType = function (byte) { // construct and memoize byte prefix registry on first run if (!PREFIX_REGISTRY) { PREFIX_REGISTRY = {} // register sorts var sort for (var key in sorts) { sort = sorts[key] // if sort has subsorts register these instead sort.sorts ? registerTypes(sort.sorts) : registerType(sort) } } return PREFIX_REGISTRY[byte] } bytewise.buffer = true bytewise.stringCodec = codecs.HEX bytewise.type = 'bytewise-core' }).call(this,require("buffer").Buffer) },{"./base":65,"./codecs":66,"./util":68,"buffer":61}],68:[function(require,module,exports){ (function (Buffer){ var util = exports // // buffer compare // util.compare = require('typewise-core/collation').bitwise // // buffer equality // util.equal = function (a, b) { if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) return if (a === b) return true if (typeof a.equals === 'function') return a.equals(b) return util.compare(a, b) === 0 } var assert = util.assert = function (test, message) { if (!test) throw new TypeError(message) } var FLOAT_LENGTH = 8 util.invertBytes = function (buffer) { var bytes = [] for (var i = 0, end = buffer.length; i < end; ++i) { bytes.push(~buffer[i]) } return new Buffer(bytes) } util.encodeFloat = function (value) { var buffer = new Buffer(FLOAT_LENGTH) if (value < 0) { // // write negative numbers as negated positive values to invert bytes // buffer.writeDoubleBE(-value.valueOf(), 0) return util.invertBytes(buffer) } // // normalize -0 values to 0 // buffer.writeDoubleBE(value.valueOf() || 0, 0) return buffer } util.decodeFloat = function (buffer, base, negative) { assert(buffer.length === FLOAT_LENGTH, 'Invalid float encoding length') if (negative) buffer = util.invertBytes(buffer) var value = buffer.readDoubleBE(0) return negative ? -value : value } // // sigil for controlling the escapement functions (TODO: clean this up) // var SKIP_HIGH_BYTES = {} util.escapeFlat = function (buffer, options) { // // escape high and low bytes 0x00 and 0xff (and by necessity, 0x01 and 0xfe) // var b, bytes = [] for (var i = 0, end = buffer.length; i < end; ++i) { b = buffer[i] // // escape low bytes with 0x01 and by adding 1 // if (b === 0x01 || b === 0x00) bytes.push(0x01, b + 1) // // escape high bytes with 0xfe and by subtracting 1 // else if (options !== SKIP_HIGH_BYTES && (b === 0xfe || b === 0xff)) bytes.push(0xfe, b - 1) // // no escapement needed // else bytes.push(b) } return new Buffer(bytes) } util.unescapeFlat = function (buffer, options) { var b, bytes = [] // // don't escape last byte // for (var i = 0, end = buffer.length; i < end; ++i) { b = buffer[i] // // if low-byte escape tag use the following byte minus 1 // if (b === 0x01) bytes.push(buffer[++i] - 1) // // if high-byte escape tag use the following byte plus 1 // else if (options !== SKIP_HIGH_BYTES && b === 0xfe) bytes.push(buffer[++i] + 1) // // no unescapement needed // else bytes.push(b) } return new Buffer(bytes) } util.escapeFlatLow = function (buffer) { return util.escapeFlat(buffer, SKIP_HIGH_BYTES) } util.unescapeFlatLow = function (buffer) { return util.unescapeFlat(buffer, SKIP_HIGH_BYTES) } util.encodeList = function (source, base) { // TODO: cycle detection var buffers = [] var undecodable for (var i = 0, end = source.length; i < end; ++i) { var buffer = base.encode(source[i], null) // // bypass assertions for undecodable types (i.e. range bounds) // undecodable || (undecodable = buffer.undecodable) if (undecodable) { buffers.push(buffer) continue } var sort = base.getType(buffer[0]) assert(sort, 'List encoding failure: ' + buffer) // // escape sorts if it requires it and add closing byte for element // if (sort.codec && sort.codec.escape) buffers.push(sort.codec.escape(buffer), new Buffer([ 0x00 ])) else buffers.push(buffer) } // // close the list with an end byte // buffers.push(new Buffer([ 0x00 ])) buffer = Buffer.concat(buffers) // // propagate undecoable bit if set // undecodable && (buffer.undecodable = undecodable) return buffer } util.decodeList = function (buffer, base) { var result = util.parse(buffer, base) assert(result[1] === buffer.length, 'Invalid encoding') return result[0] } util.encodeHash = function (source, base) { // // packs hash into an array, e.g. `[ k1, v1, k2, v2, ... ]` // var list = [] Object.keys(source).forEach(function(key) { list.push(key) list.push(source[key]) }) return util.encodeList(list, base) } util.decodeHash = function (buffer, base) { var list = util.decodeList(buffer, base) var hash = Object.create(null) for (var i = 0, end = list.length; i < end; ++i) { hash[list[i]] = list[++i] } return hash } // // base parser for nested/recursive sorts // util.parse = function (buffer, base, sort) { // // parses and returns the first sort on the buffer and total bytes consumed // var codec = sort && sort.codec var index, end // // nullary // if (sort && !codec) return [ base.decode(new Buffer([ sort.byte ]), null), 0 ] // // custom parse implementation provided by sort // if (codec && codec.parse) return codec.parse(buffer, base, sort) // // fixed length sort, decode fixed bytes // var length = codec && codec.length if (typeof length === 'number') return [ codec.decode(buffer.slice(0, length)), length ] // // escaped sort, seek to end byte and unescape // if (codec && codec.unescape) { for (index = 0, end = buffer.length; index < end; ++index) { if (buffer[index] === 0x00) break } assert(index < buffer.length, 'No closing byte found for sequence') var unescaped = codec.unescape(buffer.slice(0, index)) // // add 1 to index to account for closing tag byte // return [ codec.decode(unescaped), index + 1 ] } // // recursive sort, resolve each item iteratively // index = 0 var list = [] var next while ((next = buffer[index]) !== 0x00) { sort = base.getType(next) var result = util.parse(buffer.slice(index + 1), base, sort) list.push(result[0]) // // offset current index by bytes consumed (plus a byte for the sort tag) // index += result[1] + 1 assert(index < buffer.length, 'No closing byte found for nested sequence') } // // return parsed list and bytes consumed (plus a byte for the closing tag) // return [ list, index + 1 ] } // // helpers for encoding boundary types // function encodeBound(data, base) { var prefix = data.prefix var buffer = prefix ? base.encode(prefix, null) : new Buffer([ data.byte ]) if (data.upper) buffer = Buffer.concat([ buffer, new Buffer([ 0xff ]) ]) return util.encodedBound(data, buffer) } util.encodeBound = function (data, base) { return util.encodedBound(data, encodeBound(data, base)) } util.encodeBaseBound = function (data, base) { return util.encodedBound(data, new Buffer([ data.upper ? 0xff : 0x00 ])) } util.encodeListBound = function (data, base) { var buffer = encodeBound(data, base) if (data.prefix) { // // trim off end byte if a prefix, and do some hackery if an upper bound // var endByte = buffer[buffer.length - 1] buffer = buffer.slice(0, -1) if (data.upper) buffer[buffer.length - 1] = endByte } return util.encodedBound(data, buffer) } // // add some metadata to generated buffer instance // util.encodedBound = function (data, buffer) { buffer.undecodable = true return buffer } }).call(this,require("buffer").Buffer) },{"buffer":61,"typewise-core/collation":624}],69:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015 Titus Wormer. All rights reserved. * @module ccount * @fileoverview Count characters. */ 'use strict'; /** * Count how many characters `character` occur in `value`. * * @example * ccount('foo(bar(baz)', '(') // 2 * ccount('foo(bar(baz)', ')') // 1 * * @param {string} value - Content, coerced to string. * @param {string} character - Single character to look * for. * @return {number} - Count. * @throws {Error} - when `character` is not a single * character. */ function ccount(value, character) { var index = -1; var count = 0; var length; value = String(value); length = value.length; if (typeof character !== 'string' || character.length !== 1) { throw new Error('Expected character'); } while (++index < length) { if (value.charAt(index) === character) { count++; } } return count; } /* * Expose. */ module.exports = ccount; },{}],70:[function(require,module,exports){ module.exports={ "nbsp": " ", "iexcl": "¡", "cent": "¢", "pound": "£", "curren": "¤", "yen": "¥", "brvbar": "¦", "sect": "§", "uml": "¨", "copy": "©", "ordf": "ª", "laquo": "«", "not": "¬", "shy": "­", "reg": "®", "macr": "¯", "deg": "°", "plusmn": "±", "sup2": "²", "sup3": "³", "acute": "´", "micro": "µ", "para": "¶", "middot": "·", "cedil": "¸", "sup1": "¹", "ordm": "º", "raquo": "»", "frac14": "¼", "frac12": "½", "frac34": "¾", "iquest": "¿", "Agrave": "À", "Aacute": "Á", "Acirc": "Â", "Atilde": "Ã", "Auml": "Ä", "Aring": "Å", "AElig": "Æ", "Ccedil": "Ç", "Egrave": "È", "Eacute": "É", "Ecirc": "Ê", "Euml": "Ë", "Igrave": "Ì", "Iacute": "Í", "Icirc": "Î", "Iuml": "Ï", "ETH": "Ð", "Ntilde": "Ñ", "Ograve": "Ò", "Oacute": "Ó", "Ocirc": "Ô", "Otilde": "Õ", "Ouml": "Ö", "times": "×", "Oslash": "Ø", "Ugrave": "Ù", "Uacute": "Ú", "Ucirc": "Û", "Uuml": "Ü", "Yacute": "Ý", "THORN": "Þ", "szlig": "ß", "agrave": "à", "aacute": "á", "acirc": "â", "atilde": "ã", "auml": "ä", "aring": "å", "aelig": "æ", "ccedil": "ç", "egrave": "è", "eacute": "é", "ecirc": "ê", "euml": "ë", "igrave": "ì", "iacute": "í", "icirc": "î", "iuml": "ï", "eth": "ð", "ntilde": "ñ", "ograve": "ò", "oacute": "ó", "ocirc": "ô", "otilde": "õ", "ouml": "ö", "divide": "÷", "oslash": "ø", "ugrave": "ù", "uacute": "ú", "ucirc": "û", "uuml": "ü", "yacute": "ý", "thorn": "þ", "yuml": "ÿ", "fnof": "ƒ", "Alpha": "Α", "Beta": "Β", "Gamma": "Γ", "Delta": "Δ", "Epsilon": "Ε", "Zeta": "Ζ", "Eta": "Η", "Theta": "Θ", "Iota": "Ι", "Kappa": "Κ", "Lambda": "Λ", "Mu": "Μ", "Nu": "Ν", "Xi": "Ξ", "Omicron": "Ο", "Pi": "Π", "Rho": "Ρ", "Sigma": "Σ", "Tau": "Τ", "Upsilon": "Υ", "Phi": "Φ", "Chi": "Χ", "Psi": "Ψ", "Omega": "Ω", "alpha": "α", "beta": "β", "gamma": "γ", "delta": "δ", "epsilon": "ε", "zeta": "ζ", "eta": "η", "theta": "θ", "iota": "ι", "kappa": "κ", "lambda": "λ", "mu": "μ", "nu": "ν", "xi": "ξ", "omicron": "ο", "pi": "π", "rho": "ρ", "sigmaf": "ς", "sigma": "σ", "tau": "τ", "upsilon": "υ", "phi": "φ", "chi": "χ", "psi": "ψ", "omega": "ω", "thetasym": "ϑ", "upsih": "ϒ", "piv": "ϖ", "bull": "•", "hellip": "…", "prime": "′", "Prime": "″", "oline": "‾", "frasl": "⁄", "weierp": "℘", "image": "ℑ", "real": "ℜ", "trade": "™", "alefsym": "ℵ", "larr": "←", "uarr": "↑", "rarr": "→", "darr": "↓", "harr": "↔", "crarr": "↵", "lArr": "⇐", "uArr": "⇑", "rArr": "⇒", "dArr": "⇓", "hArr": "⇔", "forall": "∀", "part": "∂", "exist": "∃", "empty": "∅", "nabla": "∇", "isin": "∈", "notin": "∉", "ni": "∋", "prod": "∏", "sum": "∑", "minus": "−", "lowast": "∗", "radic": "√", "prop": "∝", "infin": "∞", "ang": "∠", "and": "∧", "or": "∨", "cap": "∩", "cup": "∪", "int": "∫", "there4": "∴", "sim": "∼", "cong": "≅", "asymp": "≈", "ne": "≠", "equiv": "≡", "le": "≤", "ge": "≥", "sub": "⊂", "sup": "⊃", "nsub": "⊄", "sube": "⊆", "supe": "⊇", "oplus": "⊕", "otimes": "⊗", "perp": "⊥", "sdot": "⋅", "lceil": "⌈", "rceil": "⌉", "lfloor": "⌊", "rfloor": "⌋", "lang": "〈", "rang": "〉", "loz": "◊", "spades": "♠", "clubs": "♣", "hearts": "♥", "diams": "♦", "quot": "\"", "amp": "&", "lt": "<", "gt": ">", "OElig": "Œ", "oelig": "œ", "Scaron": "Š", "scaron": "š", "Yuml": "Ÿ", "circ": "ˆ", "tilde": "˜", "ensp": " ", "emsp": " ", "thinsp": " ", "zwnj": "‌", "zwj": "‍", "lrm": "‎", "rlm": "‏", "ndash": "–", "mdash": "—", "lsquo": "‘", "rsquo": "’", "sbquo": "‚", "ldquo": "“", "rdquo": "”", "bdquo": "„", "dagger": "†", "Dagger": "‡", "permil": "‰", "lsaquo": "‹", "rsaquo": "›", "euro": "€" } },{}],71:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015 Titus Wormer * @license MIT * @module character-entities-html4 * @fileoverview HTML4 character entity information. */ 'use strict'; /* eslint-env commonjs */ /* * Expose. */ module.exports = require('./index.json'); },{"./index.json":70}],72:[function(require,module,exports){ module.exports={ "AElig": "Æ", "AMP": "&", "Aacute": "Á", "Acirc": "Â", "Agrave": "À", "Aring": "Å", "Atilde": "Ã", "Auml": "Ä", "COPY": "©", "Ccedil": "Ç", "ETH": "Ð", "Eacute": "É", "Ecirc": "Ê", "Egrave": "È", "Euml": "Ë", "GT": ">", "Iacute": "Í", "Icirc": "Î", "Igrave": "Ì", "Iuml": "Ï", "LT": "<", "Ntilde": "Ñ", "Oacute": "Ó", "Ocirc": "Ô", "Ograve": "Ò", "Oslash": "Ø", "Otilde": "Õ", "Ouml": "Ö", "QUOT": "\"", "REG": "®", "THORN": "Þ", "Uacute": "Ú", "Ucirc": "Û", "Ugrave": "Ù", "Uuml": "Ü", "Yacute": "Ý", "aacute": "á", "acirc": "â", "acute": "´", "aelig": "æ", "agrave": "à", "amp": "&", "aring": "å", "atilde": "ã", "auml": "ä", "brvbar": "¦", "ccedil": "ç", "cedil": "¸", "cent": "¢", "copy": "©", "curren": "¤", "deg": "°", "divide": "÷", "eacute": "é", "ecirc": "ê", "egrave": "è", "eth": "ð", "euml": "ë", "frac12": "½", "frac14": "¼", "frac34": "¾", "gt": ">", "iacute": "í", "icirc": "î", "iexcl": "¡", "igrave": "ì", "iquest": "¿", "iuml": "ï", "laquo": "«", "lt": "<", "macr": "¯", "micro": "µ", "middot": "·", "nbsp": " ", "not": "¬", "ntilde": "ñ", "oacute": "ó", "ocirc": "ô", "ograve": "ò", "ordf": "ª", "ordm": "º", "oslash": "ø", "otilde": "õ", "ouml": "ö", "para": "¶", "plusmn": "±", "pound": "£", "quot": "\"", "raquo": "»", "reg": "®", "sect": "§", "shy": "­", "sup1": "¹", "sup2": "²", "sup3": "³", "szlig": "ß", "thorn": "þ", "times": "×", "uacute": "ú", "ucirc": "û", "ugrave": "ù", "uml": "¨", "uuml": "ü", "yacute": "ý", "yen": "¥", "yuml": "ÿ" } },{}],73:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015 Titus Wormer * @license MIT * @module character-entities-legacy * @fileoverview HTML legacy character entity information. */ 'use strict'; /* eslint-env commonjs */ /* * Expose. */ module.exports = require('./index.json'); },{"./index.json":72}],74:[function(require,module,exports){ module.exports={ "AElig": "Æ", "AMP": "&", "Aacute": "Á", "Abreve": "Ă", "Acirc": "Â", "Acy": "А", "Afr": "𝔄", "Agrave": "À", "Alpha": "Α", "Amacr": "Ā", "And": "⩓", "Aogon": "Ą", "Aopf": "𝔸", "ApplyFunction": "⁡", "Aring": "Å", "Ascr": "𝒜", "Assign": "≔", "Atilde": "Ã", "Auml": "Ä", "Backslash": "∖", "Barv": "⫧", "Barwed": "⌆", "Bcy": "Б", "Because": "∵", "Bernoullis": "ℬ", "Beta": "Β", "Bfr": "𝔅", "Bopf": "𝔹", "Breve": "˘", "Bscr": "ℬ", "Bumpeq": "≎", "CHcy": "Ч", "COPY": "©", "Cacute": "Ć", "Cap": "⋒", "CapitalDifferentialD": "ⅅ", "Cayleys": "ℭ", "Ccaron": "Č", "Ccedil": "Ç", "Ccirc": "Ĉ", "Cconint": "∰", "Cdot": "Ċ", "Cedilla": "¸", "CenterDot": "·", "Cfr": "ℭ", "Chi": "Χ", "CircleDot": "⊙", "CircleMinus": "⊖", "CirclePlus": "⊕", "CircleTimes": "⊗", "ClockwiseContourIntegral": "∲", "CloseCurlyDoubleQuote": "”", "CloseCurlyQuote": "’", "Colon": "∷", "Colone": "⩴", "Congruent": "≡", "Conint": "∯", "ContourIntegral": "∮", "Copf": "ℂ", "Coproduct": "∐", "CounterClockwiseContourIntegral": "∳", "Cross": "⨯", "Cscr": "𝒞", "Cup": "⋓", "CupCap": "≍", "DD": "ⅅ", "DDotrahd": "⤑", "DJcy": "Ђ", "DScy": "Ѕ", "DZcy": "Џ", "Dagger": "‡", "Darr": "↡", "Dashv": "⫤", "Dcaron": "Ď", "Dcy": "Д", "Del": "∇", "Delta": "Δ", "Dfr": "𝔇", "DiacriticalAcute": "´", "DiacriticalDot": "˙", "DiacriticalDoubleAcute": "˝", "DiacriticalGrave": "`", "DiacriticalTilde": "˜", "Diamond": "⋄", "DifferentialD": "ⅆ", "Dopf": "𝔻", "Dot": "¨", "DotDot": "⃜", "DotEqual": "≐", "DoubleContourIntegral": "∯", "DoubleDot": "¨", "DoubleDownArrow": "⇓", "DoubleLeftArrow": "⇐", "DoubleLeftRightArrow": "⇔", "DoubleLeftTee": "⫤", "DoubleLongLeftArrow": "⟸", "DoubleLongLeftRightArrow": "⟺", "DoubleLongRightArrow": "⟹", "DoubleRightArrow": "⇒", "DoubleRightTee": "⊨", "DoubleUpArrow": "⇑", "DoubleUpDownArrow": "⇕", "DoubleVerticalBar": "∥", "DownArrow": "↓", "DownArrowBar": "⤓", "DownArrowUpArrow": "⇵", "DownBreve": "̑", "DownLeftRightVector": "⥐", "DownLeftTeeVector": "⥞", "DownLeftVector": "↽", "DownLeftVectorBar": "⥖", "DownRightTeeVector": "⥟", "DownRightVector": "⇁", "DownRightVectorBar": "⥗", "DownTee": "⊤", "DownTeeArrow": "↧", "Downarrow": "⇓", "Dscr": "𝒟", "Dstrok": "Đ", "ENG": "Ŋ", "ETH": "Ð", "Eacute": "É", "Ecaron": "Ě", "Ecirc": "Ê", "Ecy": "Э", "Edot": "Ė", "Efr": "𝔈", "Egrave": "È", "Element": "∈", "Emacr": "Ē", "EmptySmallSquare": "◻", "EmptyVerySmallSquare": "▫", "Eogon": "Ę", "Eopf": "𝔼", "Epsilon": "Ε", "Equal": "⩵", "EqualTilde": "≂", "Equilibrium": "⇌", "Escr": "ℰ", "Esim": "⩳", "Eta": "Η", "Euml": "Ë", "Exists": "∃", "ExponentialE": "ⅇ", "Fcy": "Ф", "Ffr": "𝔉", "FilledSmallSquare": "◼", "FilledVerySmallSquare": "▪", "Fopf": "𝔽", "ForAll": "∀", "Fouriertrf": "ℱ", "Fscr": "ℱ", "GJcy": "Ѓ", "GT": ">", "Gamma": "Γ", "Gammad": "Ϝ", "Gbreve": "Ğ", "Gcedil": "Ģ", "Gcirc": "Ĝ", "Gcy": "Г", "Gdot": "Ġ", "Gfr": "𝔊", "Gg": "⋙", "Gopf": "𝔾", "GreaterEqual": "≥", "GreaterEqualLess": "⋛", "GreaterFullEqual": "≧", "GreaterGreater": "⪢", "GreaterLess": "≷", "GreaterSlantEqual": "⩾", "GreaterTilde": "≳", "Gscr": "𝒢", "Gt": "≫", "HARDcy": "Ъ", "Hacek": "ˇ", "Hat": "^", "Hcirc": "Ĥ", "Hfr": "ℌ", "HilbertSpace": "ℋ", "Hopf": "ℍ", "HorizontalLine": "─", "Hscr": "ℋ", "Hstrok": "Ħ", "HumpDownHump": "≎", "HumpEqual": "≏", "IEcy": "Е", "IJlig": "IJ", "IOcy": "Ё", "Iacute": "Í", "Icirc": "Î", "Icy": "И", "Idot": "İ", "Ifr": "ℑ", "Igrave": "Ì", "Im": "ℑ", "Imacr": "Ī", "ImaginaryI": "ⅈ", "Implies": "⇒", "Int": "∬", "Integral": "∫", "Intersection": "⋂", "InvisibleComma": "⁣", "InvisibleTimes": "⁢", "Iogon": "Į", "Iopf": "𝕀", "Iota": "Ι", "Iscr": "ℐ", "Itilde": "Ĩ", "Iukcy": "І", "Iuml": "Ï", "Jcirc": "Ĵ", "Jcy": "Й", "Jfr": "𝔍", "Jopf": "𝕁", "Jscr": "𝒥", "Jsercy": "Ј", "Jukcy": "Є", "KHcy": "Х", "KJcy": "Ќ", "Kappa": "Κ", "Kcedil": "Ķ", "Kcy": "К", "Kfr": "𝔎", "Kopf": "𝕂", "Kscr": "𝒦", "LJcy": "Љ", "LT": "<", "Lacute": "Ĺ", "Lambda": "Λ", "Lang": "⟪", "Laplacetrf": "ℒ", "Larr": "↞", "Lcaron": "Ľ", "Lcedil": "Ļ", "Lcy": "Л", "LeftAngleBracket": "⟨", "LeftArrow": "←", "LeftArrowBar": "⇤", "LeftArrowRightArrow": "⇆", "LeftCeiling": "⌈", "LeftDoubleBracket": "⟦", "LeftDownTeeVector": "⥡", "LeftDownVector": "⇃", "LeftDownVectorBar": "⥙", "LeftFloor": "⌊", "LeftRightArrow": "↔", "LeftRightVector": "⥎", "LeftTee": "⊣", "LeftTeeArrow": "↤", "LeftTeeVector": "⥚", "LeftTriangle": "⊲", "LeftTriangleBar": "⧏", "LeftTriangleEqual": "⊴", "LeftUpDownVector": "⥑", "LeftUpTeeVector": "⥠", "LeftUpVector": "↿", "LeftUpVectorBar": "⥘", "LeftVector": "↼", "LeftVectorBar": "⥒", "Leftarrow": "⇐", "Leftrightarrow": "⇔", "LessEqualGreater": "⋚", "LessFullEqual": "≦", "LessGreater": "≶", "LessLess": "⪡", "LessSlantEqual": "⩽", "LessTilde": "≲", "Lfr": "𝔏", "Ll": "⋘", "Lleftarrow": "⇚", "Lmidot": "Ŀ", "LongLeftArrow": "⟵", "LongLeftRightArrow": "⟷", "LongRightArrow": "⟶", "Longleftarrow": "⟸", "Longleftrightarrow": "⟺", "Longrightarrow": "⟹", "Lopf": "𝕃", "LowerLeftArrow": "↙", "LowerRightArrow": "↘", "Lscr": "ℒ", "Lsh": "↰", "Lstrok": "Ł", "Lt": "≪", "Map": "⤅", "Mcy": "М", "MediumSpace": " ", "Mellintrf": "ℳ", "Mfr": "𝔐", "MinusPlus": "∓", "Mopf": "𝕄", "Mscr": "ℳ", "Mu": "Μ", "NJcy": "Њ", "Nacute": "Ń", "Ncaron": "Ň", "Ncedil": "Ņ", "Ncy": "Н", "NegativeMediumSpace": "​", "NegativeThickSpace": "​", "NegativeThinSpace": "​", "NegativeVeryThinSpace": "​", "NestedGreaterGreater": "≫", "NestedLessLess": "≪", "NewLine": "\n", "Nfr": "𝔑", "NoBreak": "⁠", "NonBreakingSpace": " ", "Nopf": "ℕ", "Not": "⫬", "NotCongruent": "≢", "NotCupCap": "≭", "NotDoubleVerticalBar": "∦", "NotElement": "∉", "NotEqual": "≠", "NotEqualTilde": "≂̸", "NotExists": "∄", "NotGreater": "≯", "NotGreaterEqual": "≱", "NotGreaterFullEqual": "≧̸", "NotGreaterGreater": "≫̸", "NotGreaterLess": "≹", "NotGreaterSlantEqual": "⩾̸", "NotGreaterTilde": "≵", "NotHumpDownHump": "≎̸", "NotHumpEqual": "≏̸", "NotLeftTriangle": "⋪", "NotLeftTriangleBar": "⧏̸", "NotLeftTriangleEqual": "⋬", "NotLess": "≮", "NotLessEqual": "≰", "NotLessGreater": "≸", "NotLessLess": "≪̸", "NotLessSlantEqual": "⩽̸", "NotLessTilde": "≴", "NotNestedGreaterGreater": "⪢̸", "NotNestedLessLess": "⪡̸", "NotPrecedes": "⊀", "NotPrecedesEqual": "⪯̸", "NotPrecedesSlantEqual": "⋠", "NotReverseElement": "∌", "NotRightTriangle": "⋫", "NotRightTriangleBar": "⧐̸", "NotRightTriangleEqual": "⋭", "NotSquareSubset": "⊏̸", "NotSquareSubsetEqual": "⋢", "NotSquareSuperset": "⊐̸", "NotSquareSupersetEqual": "⋣", "NotSubset": "⊂⃒", "NotSubsetEqual": "⊈", "NotSucceeds": "⊁", "NotSucceedsEqual": "⪰̸", "NotSucceedsSlantEqual": "⋡", "NotSucceedsTilde": "≿̸", "NotSuperset": "⊃⃒", "NotSupersetEqual": "⊉", "NotTilde": "≁", "NotTildeEqual": "≄", "NotTildeFullEqual": "≇", "NotTildeTilde": "≉", "NotVerticalBar": "∤", "Nscr": "𝒩", "Ntilde": "Ñ", "Nu": "Ν", "OElig": "Œ", "Oacute": "Ó", "Ocirc": "Ô", "Ocy": "О", "Odblac": "Ő", "Ofr": "𝔒", "Ograve": "Ò", "Omacr": "Ō", "Omega": "Ω", "Omicron": "Ο", "Oopf": "𝕆", "OpenCurlyDoubleQuote": "“", "OpenCurlyQuote": "‘", "Or": "⩔", "Oscr": "𝒪", "Oslash": "Ø", "Otilde": "Õ", "Otimes": "⨷", "Ouml": "Ö", "OverBar": "‾", "OverBrace": "⏞", "OverBracket": "⎴", "OverParenthesis": "⏜", "PartialD": "∂", "Pcy": "П", "Pfr": "𝔓", "Phi": "Φ", "Pi": "Π", "PlusMinus": "±", "Poincareplane": "ℌ", "Popf": "ℙ", "Pr": "⪻", "Precedes": "≺", "PrecedesEqual": "⪯", "PrecedesSlantEqual": "≼", "PrecedesTilde": "≾", "Prime": "″", "Product": "∏", "Proportion": "∷", "Proportional": "∝", "Pscr": "𝒫", "Psi": "Ψ", "QUOT": "\"", "Qfr": "𝔔", "Qopf": "ℚ", "Qscr": "𝒬", "RBarr": "⤐", "REG": "®", "Racute": "Ŕ", "Rang": "⟫", "Rarr": "↠", "Rarrtl": "⤖", "Rcaron": "Ř", "Rcedil": "Ŗ", "Rcy": "Р", "Re": "ℜ", "ReverseElement": "∋", "ReverseEquilibrium": "⇋", "ReverseUpEquilibrium": "⥯", "Rfr": "ℜ", "Rho": "Ρ", "RightAngleBracket": "⟩", "RightArrow": "→", "RightArrowBar": "⇥", "RightArrowLeftArrow": "⇄", "RightCeiling": "⌉", "RightDoubleBracket": "⟧", "RightDownTeeVector": "⥝", "RightDownVector": "⇂", "RightDownVectorBar": "⥕", "RightFloor": "⌋", "RightTee": "⊢", "RightTeeArrow": "↦", "RightTeeVector": "⥛", "RightTriangle": "⊳", "RightTriangleBar": "⧐", "RightTriangleEqual": "⊵", "RightUpDownVector": "⥏", "RightUpTeeVector": "⥜", "RightUpVector": "↾", "RightUpVectorBar": "⥔", "RightVector": "⇀", "RightVectorBar": "⥓", "Rightarrow": "⇒", "Ropf": "ℝ", "RoundImplies": "⥰", "Rrightarrow": "⇛", "Rscr": "ℛ", "Rsh": "↱", "RuleDelayed": "⧴", "SHCHcy": "Щ", "SHcy": "Ш", "SOFTcy": "Ь", "Sacute": "Ś", "Sc": "⪼", "Scaron": "Š", "Scedil": "Ş", "Scirc": "Ŝ", "Scy": "С", "Sfr": "𝔖", "ShortDownArrow": "↓", "ShortLeftArrow": "←", "ShortRightArrow": "→", "ShortUpArrow": "↑", "Sigma": "Σ", "SmallCircle": "∘", "Sopf": "𝕊", "Sqrt": "√", "Square": "□", "SquareIntersection": "⊓", "SquareSubset": "⊏", "SquareSubsetEqual": "⊑", "SquareSuperset": "⊐", "SquareSupersetEqual": "⊒", "SquareUnion": "⊔", "Sscr": "𝒮", "Star": "⋆", "Sub": "⋐", "Subset": "⋐", "SubsetEqual": "⊆", "Succeeds": "≻", "SucceedsEqual": "⪰", "SucceedsSlantEqual": "≽", "SucceedsTilde": "≿", "SuchThat": "∋", "Sum": "∑", "Sup": "⋑", "Superset": "⊃", "SupersetEqual": "⊇", "Supset": "⋑", "THORN": "Þ", "TRADE": "™", "TSHcy": "Ћ", "TScy": "Ц", "Tab": "\t", "Tau": "Τ", "Tcaron": "Ť", "Tcedil": "Ţ", "Tcy": "Т", "Tfr": "𝔗", "Therefore": "∴", "Theta": "Θ", "ThickSpace": "  ", "ThinSpace": " ", "Tilde": "∼", "TildeEqual": "≃", "TildeFullEqual": "≅", "TildeTilde": "≈", "Topf": "𝕋", "TripleDot": "⃛", "Tscr": "𝒯", "Tstrok": "Ŧ", "Uacute": "Ú", "Uarr": "↟", "Uarrocir": "⥉", "Ubrcy": "Ў", "Ubreve": "Ŭ", "Ucirc": "Û", "Ucy": "У", "Udblac": "Ű", "Ufr": "𝔘", "Ugrave": "Ù", "Umacr": "Ū", "UnderBar": "_", "UnderBrace": "⏟", "UnderBracket": "⎵", "UnderParenthesis": "⏝", "Union": "⋃", "UnionPlus": "⊎", "Uogon": "Ų", "Uopf": "𝕌", "UpArrow": "↑", "UpArrowBar": "⤒", "UpArrowDownArrow": "⇅", "UpDownArrow": "↕", "UpEquilibrium": "⥮", "UpTee": "⊥", "UpTeeArrow": "↥", "Uparrow": "⇑", "Updownarrow": "⇕", "UpperLeftArrow": "↖", "UpperRightArrow": "↗", "Upsi": "ϒ", "Upsilon": "Υ", "Uring": "Ů", "Uscr": "𝒰", "Utilde": "Ũ", "Uuml": "Ü", "VDash": "⊫", "Vbar": "⫫", "Vcy": "В", "Vdash": "⊩", "Vdashl": "⫦", "Vee": "⋁", "Verbar": "‖", "Vert": "‖", "VerticalBar": "∣", "VerticalLine": "|", "VerticalSeparator": "❘", "VerticalTilde": "≀", "VeryThinSpace": " ", "Vfr": "𝔙", "Vopf": "𝕍", "Vscr": "𝒱", "Vvdash": "⊪", "Wcirc": "Ŵ", "Wedge": "⋀", "Wfr": "𝔚", "Wopf": "𝕎", "Wscr": "𝒲", "Xfr": "𝔛", "Xi": "Ξ", "Xopf": "𝕏", "Xscr": "𝒳", "YAcy": "Я", "YIcy": "Ї", "YUcy": "Ю", "Yacute": "Ý", "Ycirc": "Ŷ", "Ycy": "Ы", "Yfr": "𝔜", "Yopf": "𝕐", "Yscr": "𝒴", "Yuml": "Ÿ", "ZHcy": "Ж", "Zacute": "Ź", "Zcaron": "Ž", "Zcy": "З", "Zdot": "Ż", "ZeroWidthSpace": "​", "Zeta": "Ζ", "Zfr": "ℨ", "Zopf": "ℤ", "Zscr": "𝒵", "aacute": "á", "abreve": "ă", "ac": "∾", "acE": "∾̳", "acd": "∿", "acirc": "â", "acute": "´", "acy": "а", "aelig": "æ", "af": "⁡", "afr": "𝔞", "agrave": "à", "alefsym": "ℵ", "aleph": "ℵ", "alpha": "α", "amacr": "ā", "amalg": "⨿", "amp": "&", "and": "∧", "andand": "⩕", "andd": "⩜", "andslope": "⩘", "andv": "⩚", "ang": "∠", "ange": "⦤", "angle": "∠", "angmsd": "∡", "angmsdaa": "⦨", "angmsdab": "⦩", "angmsdac": "⦪", "angmsdad": "⦫", "angmsdae": "⦬", "angmsdaf": "⦭", "angmsdag": "⦮", "angmsdah": "⦯", "angrt": "∟", "angrtvb": "⊾", "angrtvbd": "⦝", "angsph": "∢", "angst": "Å", "angzarr": "⍼", "aogon": "ą", "aopf": "𝕒", "ap": "≈", "apE": "⩰", "apacir": "⩯", "ape": "≊", "apid": "≋", "apos": "'", "approx": "≈", "approxeq": "≊", "aring": "å", "ascr": "𝒶", "ast": "*", "asymp": "≈", "asympeq": "≍", "atilde": "ã", "auml": "ä", "awconint": "∳", "awint": "⨑", "bNot": "⫭", "backcong": "≌", "backepsilon": "϶", "backprime": "‵", "backsim": "∽", "backsimeq": "⋍", "barvee": "⊽", "barwed": "⌅", "barwedge": "⌅", "bbrk": "⎵", "bbrktbrk": "⎶", "bcong": "≌", "bcy": "б", "bdquo": "„", "becaus": "∵", "because": "∵", "bemptyv": "⦰", "bepsi": "϶", "bernou": "ℬ", "beta": "β", "beth": "ℶ", "between": "≬", "bfr": "𝔟", "bigcap": "⋂", "bigcirc": "◯", "bigcup": "⋃", "bigodot": "⨀", "bigoplus": "⨁", "bigotimes": "⨂", "bigsqcup": "⨆", "bigstar": "★", "bigtriangledown": "▽", "bigtriangleup": "△", "biguplus": "⨄", "bigvee": "⋁", "bigwedge": "⋀", "bkarow": "⤍", "blacklozenge": "⧫", "blacksquare": "▪", "blacktriangle": "▴", "blacktriangledown": "▾", "blacktriangleleft": "◂", "blacktriangleright": "▸", "blank": "␣", "blk12": "▒", "blk14": "░", "blk34": "▓", "block": "█", "bne": "=⃥", "bnequiv": "≡⃥", "bnot": "⌐", "bopf": "𝕓", "bot": "⊥", "bottom": "⊥", "bowtie": "⋈", "boxDL": "╗", "boxDR": "╔", "boxDl": "╖", "boxDr": "╓", "boxH": "═", "boxHD": "╦", "boxHU": "╩", "boxHd": "╤", "boxHu": "╧", "boxUL": "╝", "boxUR": "╚", "boxUl": "╜", "boxUr": "╙", "boxV": "║", "boxVH": "╬", "boxVL": "╣", "boxVR": "╠", "boxVh": "╫", "boxVl": "╢", "boxVr": "╟", "boxbox": "⧉", "boxdL": "╕", "boxdR": "╒", "boxdl": "┐", "boxdr": "┌", "boxh": "─", "boxhD": "╥", "boxhU": "╨", "boxhd": "┬", "boxhu": "┴", "boxminus": "⊟", "boxplus": "⊞", "boxtimes": "⊠", "boxuL": "╛", "boxuR": "╘", "boxul": "┘", "boxur": "└", "boxv": "│", "boxvH": "╪", "boxvL": "╡", "boxvR": "╞", "boxvh": "┼", "boxvl": "┤", "boxvr": "├", "bprime": "‵", "breve": "˘", "brvbar": "¦", "bscr": "𝒷", "bsemi": "⁏", "bsim": "∽", "bsime": "⋍", "bsol": "\\", "bsolb": "⧅", "bsolhsub": "⟈", "bull": "•", "bullet": "•", "bump": "≎", "bumpE": "⪮", "bumpe": "≏", "bumpeq": "≏", "cacute": "ć", "cap": "∩", "capand": "⩄", "capbrcup": "⩉", "capcap": "⩋", "capcup": "⩇", "capdot": "⩀", "caps": "∩︀", "caret": "⁁", "caron": "ˇ", "ccaps": "⩍", "ccaron": "č", "ccedil": "ç", "ccirc": "ĉ", "ccups": "⩌", "ccupssm": "⩐", "cdot": "ċ", "cedil": "¸", "cemptyv": "⦲", "cent": "¢", "centerdot": "·", "cfr": "𝔠", "chcy": "ч", "check": "✓", "checkmark": "✓", "chi": "χ", "cir": "○", "cirE": "⧃", "circ": "ˆ", "circeq": "≗", "circlearrowleft": "↺", "circlearrowright": "↻", "circledR": "®", "circledS": "Ⓢ", "circledast": "⊛", "circledcirc": "⊚", "circleddash": "⊝", "cire": "≗", "cirfnint": "⨐", "cirmid": "⫯", "cirscir": "⧂", "clubs": "♣", "clubsuit": "♣", "colon": ":", "colone": "≔", "coloneq": "≔", "comma": ",", "commat": "@", "comp": "∁", "compfn": "∘", "complement": "∁", "complexes": "ℂ", "cong": "≅", "congdot": "⩭", "conint": "∮", "copf": "𝕔", "coprod": "∐", "copy": "©", "copysr": "℗", "crarr": "↵", "cross": "✗", "cscr": "𝒸", "csub": "⫏", "csube": "⫑", "csup": "⫐", "csupe": "⫒", "ctdot": "⋯", "cudarrl": "⤸", "cudarrr": "⤵", "cuepr": "⋞", "cuesc": "⋟", "cularr": "↶", "cularrp": "⤽", "cup": "∪", "cupbrcap": "⩈", "cupcap": "⩆", "cupcup": "⩊", "cupdot": "⊍", "cupor": "⩅", "cups": "∪︀", "curarr": "↷", "curarrm": "⤼", "curlyeqprec": "⋞", "curlyeqsucc": "⋟", "curlyvee": "⋎", "curlywedge": "⋏", "curren": "¤", "curvearrowleft": "↶", "curvearrowright": "↷", "cuvee": "⋎", "cuwed": "⋏", "cwconint": "∲", "cwint": "∱", "cylcty": "⌭", "dArr": "⇓", "dHar": "⥥", "dagger": "†", "daleth": "ℸ", "darr": "↓", "dash": "‐", "dashv": "⊣", "dbkarow": "⤏", "dblac": "˝", "dcaron": "ď", "dcy": "д", "dd": "ⅆ", "ddagger": "‡", "ddarr": "⇊", "ddotseq": "⩷", "deg": "°", "delta": "δ", "demptyv": "⦱", "dfisht": "⥿", "dfr": "𝔡", "dharl": "⇃", "dharr": "⇂", "diam": "⋄", "diamond": "⋄", "diamondsuit": "♦", "diams": "♦", "die": "¨", "digamma": "ϝ", "disin": "⋲", "div": "÷", "divide": "÷", "divideontimes": "⋇", "divonx": "⋇", "djcy": "ђ", "dlcorn": "⌞", "dlcrop": "⌍", "dollar": "$", "dopf": "𝕕", "dot": "˙", "doteq": "≐", "doteqdot": "≑", "dotminus": "∸", "dotplus": "∔", "dotsquare": "⊡", "doublebarwedge": "⌆", "downarrow": "↓", "downdownarrows": "⇊", "downharpoonleft": "⇃", "downharpoonright": "⇂", "drbkarow": "⤐", "drcorn": "⌟", "drcrop": "⌌", "dscr": "𝒹", "dscy": "ѕ", "dsol": "⧶", "dstrok": "đ", "dtdot": "⋱", "dtri": "▿", "dtrif": "▾", "duarr": "⇵", "duhar": "⥯", "dwangle": "⦦", "dzcy": "џ", "dzigrarr": "⟿", "eDDot": "⩷", "eDot": "≑", "eacute": "é", "easter": "⩮", "ecaron": "ě", "ecir": "≖", "ecirc": "ê", "ecolon": "≕", "ecy": "э", "edot": "ė", "ee": "ⅇ", "efDot": "≒", "efr": "𝔢", "eg": "⪚", "egrave": "è", "egs": "⪖", "egsdot": "⪘", "el": "⪙", "elinters": "⏧", "ell": "ℓ", "els": "⪕", "elsdot": "⪗", "emacr": "ē", "empty": "∅", "emptyset": "∅", "emptyv": "∅", "emsp13": " ", "emsp14": " ", "emsp": " ", "eng": "ŋ", "ensp": " ", "eogon": "ę", "eopf": "𝕖", "epar": "⋕", "eparsl": "⧣", "eplus": "⩱", "epsi": "ε", "epsilon": "ε", "epsiv": "ϵ", "eqcirc": "≖", "eqcolon": "≕", "eqsim": "≂", "eqslantgtr": "⪖", "eqslantless": "⪕", "equals": "=", "equest": "≟", "equiv": "≡", "equivDD": "⩸", "eqvparsl": "⧥", "erDot": "≓", "erarr": "⥱", "escr": "ℯ", "esdot": "≐", "esim": "≂", "eta": "η", "eth": "ð", "euml": "ë", "euro": "€", "excl": "!", "exist": "∃", "expectation": "ℰ", "exponentiale": "ⅇ", "fallingdotseq": "≒", "fcy": "ф", "female": "♀", "ffilig": "ffi", "fflig": "ff", "ffllig": "ffl", "ffr": "𝔣", "filig": "fi", "fjlig": "fj", "flat": "♭", "fllig": "fl", "fltns": "▱", "fnof": "ƒ", "fopf": "𝕗", "forall": "∀", "fork": "⋔", "forkv": "⫙", "fpartint": "⨍", "frac12": "½", "frac13": "⅓", "frac14": "¼", "frac15": "⅕", "frac16": "⅙", "frac18": "⅛", "frac23": "⅔", "frac25": "⅖", "frac34": "¾", "frac35": "⅗", "frac38": "⅜", "frac45": "⅘", "frac56": "⅚", "frac58": "⅝", "frac78": "⅞", "frasl": "⁄", "frown": "⌢", "fscr": "𝒻", "gE": "≧", "gEl": "⪌", "gacute": "ǵ", "gamma": "γ", "gammad": "ϝ", "gap": "⪆", "gbreve": "ğ", "gcirc": "ĝ", "gcy": "г", "gdot": "ġ", "ge": "≥", "gel": "⋛", "geq": "≥", "geqq": "≧", "geqslant": "⩾", "ges": "⩾", "gescc": "⪩", "gesdot": "⪀", "gesdoto": "⪂", "gesdotol": "⪄", "gesl": "⋛︀", "gesles": "⪔", "gfr": "𝔤", "gg": "≫", "ggg": "⋙", "gimel": "ℷ", "gjcy": "ѓ", "gl": "≷", "glE": "⪒", "gla": "⪥", "glj": "⪤", "gnE": "≩", "gnap": "⪊", "gnapprox": "⪊", "gne": "⪈", "gneq": "⪈", "gneqq": "≩", "gnsim": "⋧", "gopf": "𝕘", "grave": "`", "gscr": "ℊ", "gsim": "≳", "gsime": "⪎", "gsiml": "⪐", "gt": ">", "gtcc": "⪧", "gtcir": "⩺", "gtdot": "⋗", "gtlPar": "⦕", "gtquest": "⩼", "gtrapprox": "⪆", "gtrarr": "⥸", "gtrdot": "⋗", "gtreqless": "⋛", "gtreqqless": "⪌", "gtrless": "≷", "gtrsim": "≳", "gvertneqq": "≩︀", "gvnE": "≩︀", "hArr": "⇔", "hairsp": " ", "half": "½", "hamilt": "ℋ", "hardcy": "ъ", "harr": "↔", "harrcir": "⥈", "harrw": "↭", "hbar": "ℏ", "hcirc": "ĥ", "hearts": "♥", "heartsuit": "♥", "hellip": "…", "hercon": "⊹", "hfr": "𝔥", "hksearow": "⤥", "hkswarow": "⤦", "hoarr": "⇿", "homtht": "∻", "hookleftarrow": "↩", "hookrightarrow": "↪", "hopf": "𝕙", "horbar": "―", "hscr": "𝒽", "hslash": "ℏ", "hstrok": "ħ", "hybull": "⁃", "hyphen": "‐", "iacute": "í", "ic": "⁣", "icirc": "î", "icy": "и", "iecy": "е", "iexcl": "¡", "iff": "⇔", "ifr": "𝔦", "igrave": "ì", "ii": "ⅈ", "iiiint": "⨌", "iiint": "∭", "iinfin": "⧜", "iiota": "℩", "ijlig": "ij", "imacr": "ī", "image": "ℑ", "imagline": "ℐ", "imagpart": "ℑ", "imath": "ı", "imof": "⊷", "imped": "Ƶ", "in": "∈", "incare": "℅", "infin": "∞", "infintie": "⧝", "inodot": "ı", "int": "∫", "intcal": "⊺", "integers": "ℤ", "intercal": "⊺", "intlarhk": "⨗", "intprod": "⨼", "iocy": "ё", "iogon": "į", "iopf": "𝕚", "iota": "ι", "iprod": "⨼", "iquest": "¿", "iscr": "𝒾", "isin": "∈", "isinE": "⋹", "isindot": "⋵", "isins": "⋴", "isinsv": "⋳", "isinv": "∈", "it": "⁢", "itilde": "ĩ", "iukcy": "і", "iuml": "ï", "jcirc": "ĵ", "jcy": "й", "jfr": "𝔧", "jmath": "ȷ", "jopf": "𝕛", "jscr": "𝒿", "jsercy": "ј", "jukcy": "є", "kappa": "κ", "kappav": "ϰ", "kcedil": "ķ", "kcy": "к", "kfr": "𝔨", "kgreen": "ĸ", "khcy": "х", "kjcy": "ќ", "kopf": "𝕜", "kscr": "𝓀", "lAarr": "⇚", "lArr": "⇐", "lAtail": "⤛", "lBarr": "⤎", "lE": "≦", "lEg": "⪋", "lHar": "⥢", "lacute": "ĺ", "laemptyv": "⦴", "lagran": "ℒ", "lambda": "λ", "lang": "⟨", "langd": "⦑", "langle": "⟨", "lap": "⪅", "laquo": "«", "larr": "←", "larrb": "⇤", "larrbfs": "⤟", "larrfs": "⤝", "larrhk": "↩", "larrlp": "↫", "larrpl": "⤹", "larrsim": "⥳", "larrtl": "↢", "lat": "⪫", "latail": "⤙", "late": "⪭", "lates": "⪭︀", "lbarr": "⤌", "lbbrk": "❲", "lbrace": "{", "lbrack": "[", "lbrke": "⦋", "lbrksld": "⦏", "lbrkslu": "⦍", "lcaron": "ľ", "lcedil": "ļ", "lceil": "⌈", "lcub": "{", "lcy": "л", "ldca": "⤶", "ldquo": "“", "ldquor": "„", "ldrdhar": "⥧", "ldrushar": "⥋", "ldsh": "↲", "le": "≤", "leftarrow": "←", "leftarrowtail": "↢", "leftharpoondown": "↽", "leftharpoonup": "↼", "leftleftarrows": "⇇", "leftrightarrow": "↔", "leftrightarrows": "⇆", "leftrightharpoons": "⇋", "leftrightsquigarrow": "↭", "leftthreetimes": "⋋", "leg": "⋚", "leq": "≤", "leqq": "≦", "leqslant": "⩽", "les": "⩽", "lescc": "⪨", "lesdot": "⩿", "lesdoto": "⪁", "lesdotor": "⪃", "lesg": "⋚︀", "lesges": "⪓", "lessapprox": "⪅", "lessdot": "⋖", "lesseqgtr": "⋚", "lesseqqgtr": "⪋", "lessgtr": "≶", "lesssim": "≲", "lfisht": "⥼", "lfloor": "⌊", "lfr": "𝔩", "lg": "≶", "lgE": "⪑", "lhard": "↽", "lharu": "↼", "lharul": "⥪", "lhblk": "▄", "ljcy": "љ", "ll": "≪", "llarr": "⇇", "llcorner": "⌞", "llhard": "⥫", "lltri": "◺", "lmidot": "ŀ", "lmoust": "⎰", "lmoustache": "⎰", "lnE": "≨", "lnap": "⪉", "lnapprox": "⪉", "lne": "⪇", "lneq": "⪇", "lneqq": "≨", "lnsim": "⋦", "loang": "⟬", "loarr": "⇽", "lobrk": "⟦", "longleftarrow": "⟵", "longleftrightarrow": "⟷", "longmapsto": "⟼", "longrightarrow": "⟶", "looparrowleft": "↫", "looparrowright": "↬", "lopar": "⦅", "lopf": "𝕝", "loplus": "⨭", "lotimes": "⨴", "lowast": "∗", "lowbar": "_", "loz": "◊", "lozenge": "◊", "lozf": "⧫", "lpar": "(", "lparlt": "⦓", "lrarr": "⇆", "lrcorner": "⌟", "lrhar": "⇋", "lrhard": "⥭", "lrm": "‎", "lrtri": "⊿", "lsaquo": "‹", "lscr": "𝓁", "lsh": "↰", "lsim": "≲", "lsime": "⪍", "lsimg": "⪏", "lsqb": "[", "lsquo": "‘", "lsquor": "‚", "lstrok": "ł", "lt": "<", "ltcc": "⪦", "ltcir": "⩹", "ltdot": "⋖", "lthree": "⋋", "ltimes": "⋉", "ltlarr": "⥶", "ltquest": "⩻", "ltrPar": "⦖", "ltri": "◃", "ltrie": "⊴", "ltrif": "◂", "lurdshar": "⥊", "luruhar": "⥦", "lvertneqq": "≨︀", "lvnE": "≨︀", "mDDot": "∺", "macr": "¯", "male": "♂", "malt": "✠", "maltese": "✠", "map": "↦", "mapsto": "↦", "mapstodown": "↧", "mapstoleft": "↤", "mapstoup": "↥", "marker": "▮", "mcomma": "⨩", "mcy": "м", "mdash": "—", "measuredangle": "∡", "mfr": "𝔪", "mho": "℧", "micro": "µ", "mid": "∣", "midast": "*", "midcir": "⫰", "middot": "·", "minus": "−", "minusb": "⊟", "minusd": "∸", "minusdu": "⨪", "mlcp": "⫛", "mldr": "…", "mnplus": "∓", "models": "⊧", "mopf": "𝕞", "mp": "∓", "mscr": "𝓂", "mstpos": "∾", "mu": "μ", "multimap": "⊸", "mumap": "⊸", "nGg": "⋙̸", "nGt": "≫⃒", "nGtv": "≫̸", "nLeftarrow": "⇍", "nLeftrightarrow": "⇎", "nLl": "⋘̸", "nLt": "≪⃒", "nLtv": "≪̸", "nRightarrow": "⇏", "nVDash": "⊯", "nVdash": "⊮", "nabla": "∇", "nacute": "ń", "nang": "∠⃒", "nap": "≉", "napE": "⩰̸", "napid": "≋̸", "napos": "ʼn", "napprox": "≉", "natur": "♮", "natural": "♮", "naturals": "ℕ", "nbsp": " ", "nbump": "≎̸", "nbumpe": "≏̸", "ncap": "⩃", "ncaron": "ň", "ncedil": "ņ", "ncong": "≇", "ncongdot": "⩭̸", "ncup": "⩂", "ncy": "н", "ndash": "–", "ne": "≠", "neArr": "⇗", "nearhk": "⤤", "nearr": "↗", "nearrow": "↗", "nedot": "≐̸", "nequiv": "≢", "nesear": "⤨", "nesim": "≂̸", "nexist": "∄", "nexists": "∄", "nfr": "𝔫", "ngE": "≧̸", "nge": "≱", "ngeq": "≱", "ngeqq": "≧̸", "ngeqslant": "⩾̸", "nges": "⩾̸", "ngsim": "≵", "ngt": "≯", "ngtr": "≯", "nhArr": "⇎", "nharr": "↮", "nhpar": "⫲", "ni": "∋", "nis": "⋼", "nisd": "⋺", "niv": "∋", "njcy": "њ", "nlArr": "⇍", "nlE": "≦̸", "nlarr": "↚", "nldr": "‥", "nle": "≰", "nleftarrow": "↚", "nleftrightarrow": "↮", "nleq": "≰", "nleqq": "≦̸", "nleqslant": "⩽̸", "nles": "⩽̸", "nless": "≮", "nlsim": "≴", "nlt": "≮", "nltri": "⋪", "nltrie": "⋬", "nmid": "∤", "nopf": "𝕟", "not": "¬", "notin": "∉", "notinE": "⋹̸", "notindot": "⋵̸", "notinva": "∉", "notinvb": "⋷", "notinvc": "⋶", "notni": "∌", "notniva": "∌", "notnivb": "⋾", "notnivc": "⋽", "npar": "∦", "nparallel": "∦", "nparsl": "⫽⃥", "npart": "∂̸", "npolint": "⨔", "npr": "⊀", "nprcue": "⋠", "npre": "⪯̸", "nprec": "⊀", "npreceq": "⪯̸", "nrArr": "⇏", "nrarr": "↛", "nrarrc": "⤳̸", "nrarrw": "↝̸", "nrightarrow": "↛", "nrtri": "⋫", "nrtrie": "⋭", "nsc": "⊁", "nsccue": "⋡", "nsce": "⪰̸", "nscr": "𝓃", "nshortmid": "∤", "nshortparallel": "∦", "nsim": "≁", "nsime": "≄", "nsimeq": "≄", "nsmid": "∤", "nspar": "∦", "nsqsube": "⋢", "nsqsupe": "⋣", "nsub": "⊄", "nsubE": "⫅̸", "nsube": "⊈", "nsubset": "⊂⃒", "nsubseteq": "⊈", "nsubseteqq": "⫅̸", "nsucc": "⊁", "nsucceq": "⪰̸", "nsup": "⊅", "nsupE": "⫆̸", "nsupe": "⊉", "nsupset": "⊃⃒", "nsupseteq": "⊉", "nsupseteqq": "⫆̸", "ntgl": "≹", "ntilde": "ñ", "ntlg": "≸", "ntriangleleft": "⋪", "ntrianglelefteq": "⋬", "ntriangleright": "⋫", "ntrianglerighteq": "⋭", "nu": "ν", "num": "#", "numero": "№", "numsp": " ", "nvDash": "⊭", "nvHarr": "⤄", "nvap": "≍⃒", "nvdash": "⊬", "nvge": "≥⃒", "nvgt": ">⃒", "nvinfin": "⧞", "nvlArr": "⤂", "nvle": "≤⃒", "nvlt": "<⃒", "nvltrie": "⊴⃒", "nvrArr": "⤃", "nvrtrie": "⊵⃒", "nvsim": "∼⃒", "nwArr": "⇖", "nwarhk": "⤣", "nwarr": "↖", "nwarrow": "↖", "nwnear": "⤧", "oS": "Ⓢ", "oacute": "ó", "oast": "⊛", "ocir": "⊚", "ocirc": "ô", "ocy": "о", "odash": "⊝", "odblac": "ő", "odiv": "⨸", "odot": "⊙", "odsold": "⦼", "oelig": "œ", "ofcir": "⦿", "ofr": "𝔬", "ogon": "˛", "ograve": "ò", "ogt": "⧁", "ohbar": "⦵", "ohm": "Ω", "oint": "∮", "olarr": "↺", "olcir": "⦾", "olcross": "⦻", "oline": "‾", "olt": "⧀", "omacr": "ō", "omega": "ω", "omicron": "ο", "omid": "⦶", "ominus": "⊖", "oopf": "𝕠", "opar": "⦷", "operp": "⦹", "oplus": "⊕", "or": "∨", "orarr": "↻", "ord": "⩝", "order": "ℴ", "orderof": "ℴ", "ordf": "ª", "ordm": "º", "origof": "⊶", "oror": "⩖", "orslope": "⩗", "orv": "⩛", "oscr": "ℴ", "oslash": "ø", "osol": "⊘", "otilde": "õ", "otimes": "⊗", "otimesas": "⨶", "ouml": "ö", "ovbar": "⌽", "par": "∥", "para": "¶", "parallel": "∥", "parsim": "⫳", "parsl": "⫽", "part": "∂", "pcy": "п", "percnt": "%", "period": ".", "permil": "‰", "perp": "⊥", "pertenk": "‱", "pfr": "𝔭", "phi": "φ", "phiv": "ϕ", "phmmat": "ℳ", "phone": "☎", "pi": "π", "pitchfork": "⋔", "piv": "ϖ", "planck": "ℏ", "planckh": "ℎ", "plankv": "ℏ", "plus": "+", "plusacir": "⨣", "plusb": "⊞", "pluscir": "⨢", "plusdo": "∔", "plusdu": "⨥", "pluse": "⩲", "plusmn": "±", "plussim": "⨦", "plustwo": "⨧", "pm": "±", "pointint": "⨕", "popf": "𝕡", "pound": "£", "pr": "≺", "prE": "⪳", "prap": "⪷", "prcue": "≼", "pre": "⪯", "prec": "≺", "precapprox": "⪷", "preccurlyeq": "≼", "preceq": "⪯", "precnapprox": "⪹", "precneqq": "⪵", "precnsim": "⋨", "precsim": "≾", "prime": "′", "primes": "ℙ", "prnE": "⪵", "prnap": "⪹", "prnsim": "⋨", "prod": "∏", "profalar": "⌮", "profline": "⌒", "profsurf": "⌓", "prop": "∝", "propto": "∝", "prsim": "≾", "prurel": "⊰", "pscr": "𝓅", "psi": "ψ", "puncsp": " ", "qfr": "𝔮", "qint": "⨌", "qopf": "𝕢", "qprime": "⁗", "qscr": "𝓆", "quaternions": "ℍ", "quatint": "⨖", "quest": "?", "questeq": "≟", "quot": "\"", "rAarr": "⇛", "rArr": "⇒", "rAtail": "⤜", "rBarr": "⤏", "rHar": "⥤", "race": "∽̱", "racute": "ŕ", "radic": "√", "raemptyv": "⦳", "rang": "⟩", "rangd": "⦒", "range": "⦥", "rangle": "⟩", "raquo": "»", "rarr": "→", "rarrap": "⥵", "rarrb": "⇥", "rarrbfs": "⤠", "rarrc": "⤳", "rarrfs": "⤞", "rarrhk": "↪", "rarrlp": "↬", "rarrpl": "⥅", "rarrsim": "⥴", "rarrtl": "↣", "rarrw": "↝", "ratail": "⤚", "ratio": "∶", "rationals": "ℚ", "rbarr": "⤍", "rbbrk": "❳", "rbrace": "}", "rbrack": "]", "rbrke": "⦌", "rbrksld": "⦎", "rbrkslu": "⦐", "rcaron": "ř", "rcedil": "ŗ", "rceil": "⌉", "rcub": "}", "rcy": "р", "rdca": "⤷", "rdldhar": "⥩", "rdquo": "”", "rdquor": "”", "rdsh": "↳", "real": "ℜ", "realine": "ℛ", "realpart": "ℜ", "reals": "ℝ", "rect": "▭", "reg": "®", "rfisht": "⥽", "rfloor": "⌋", "rfr": "𝔯", "rhard": "⇁", "rharu": "⇀", "rharul": "⥬", "rho": "ρ", "rhov": "ϱ", "rightarrow": "→", "rightarrowtail": "↣", "rightharpoondown": "⇁", "rightharpoonup": "⇀", "rightleftarrows": "⇄", "rightleftharpoons": "⇌", "rightrightarrows": "⇉", "rightsquigarrow": "↝", "rightthreetimes": "⋌", "ring": "˚", "risingdotseq": "≓", "rlarr": "⇄", "rlhar": "⇌", "rlm": "‏", "rmoust": "⎱", "rmoustache": "⎱", "rnmid": "⫮", "roang": "⟭", "roarr": "⇾", "robrk": "⟧", "ropar": "⦆", "ropf": "𝕣", "roplus": "⨮", "rotimes": "⨵", "rpar": ")", "rpargt": "⦔", "rppolint": "⨒", "rrarr": "⇉", "rsaquo": "›", "rscr": "𝓇", "rsh": "↱", "rsqb": "]", "rsquo": "’", "rsquor": "’", "rthree": "⋌", "rtimes": "⋊", "rtri": "▹", "rtrie": "⊵", "rtrif": "▸", "rtriltri": "⧎", "ruluhar": "⥨", "rx": "℞", "sacute": "ś", "sbquo": "‚", "sc": "≻", "scE": "⪴", "scap": "⪸", "scaron": "š", "sccue": "≽", "sce": "⪰", "scedil": "ş", "scirc": "ŝ", "scnE": "⪶", "scnap": "⪺", "scnsim": "⋩", "scpolint": "⨓", "scsim": "≿", "scy": "с", "sdot": "⋅", "sdotb": "⊡", "sdote": "⩦", "seArr": "⇘", "searhk": "⤥", "searr": "↘", "searrow": "↘", "sect": "§", "semi": ";", "seswar": "⤩", "setminus": "∖", "setmn": "∖", "sext": "✶", "sfr": "𝔰", "sfrown": "⌢", "sharp": "♯", "shchcy": "щ", "shcy": "ш", "shortmid": "∣", "shortparallel": "∥", "shy": "­", "sigma": "σ", "sigmaf": "ς", "sigmav": "ς", "sim": "∼", "simdot": "⩪", "sime": "≃", "simeq": "≃", "simg": "⪞", "simgE": "⪠", "siml": "⪝", "simlE": "⪟", "simne": "≆", "simplus": "⨤", "simrarr": "⥲", "slarr": "←", "smallsetminus": "∖", "smashp": "⨳", "smeparsl": "⧤", "smid": "∣", "smile": "⌣", "smt": "⪪", "smte": "⪬", "smtes": "⪬︀", "softcy": "ь", "sol": "/", "solb": "⧄", "solbar": "⌿", "sopf": "𝕤", "spades": "♠", "spadesuit": "♠", "spar": "∥", "sqcap": "⊓", "sqcaps": "⊓︀", "sqcup": "⊔", "sqcups": "⊔︀", "sqsub": "⊏", "sqsube": "⊑", "sqsubset": "⊏", "sqsubseteq": "⊑", "sqsup": "⊐", "sqsupe": "⊒", "sqsupset": "⊐", "sqsupseteq": "⊒", "squ": "□", "square": "□", "squarf": "▪", "squf": "▪", "srarr": "→", "sscr": "𝓈", "ssetmn": "∖", "ssmile": "⌣", "sstarf": "⋆", "star": "☆", "starf": "★", "straightepsilon": "ϵ", "straightphi": "ϕ", "strns": "¯", "sub": "⊂", "subE": "⫅", "subdot": "⪽", "sube": "⊆", "subedot": "⫃", "submult": "⫁", "subnE": "⫋", "subne": "⊊", "subplus": "⪿", "subrarr": "⥹", "subset": "⊂", "subseteq": "⊆", "subseteqq": "⫅", "subsetneq": "⊊", "subsetneqq": "⫋", "subsim": "⫇", "subsub": "⫕", "subsup": "⫓", "succ": "≻", "succapprox": "⪸", "succcurlyeq": "≽", "succeq": "⪰", "succnapprox": "⪺", "succneqq": "⪶", "succnsim": "⋩", "succsim": "≿", "sum": "∑", "sung": "♪", "sup1": "¹", "sup2": "²", "sup3": "³", "sup": "⊃", "supE": "⫆", "supdot": "⪾", "supdsub": "⫘", "supe": "⊇", "supedot": "⫄", "suphsol": "⟉", "suphsub": "⫗", "suplarr": "⥻", "supmult": "⫂", "supnE": "⫌", "supne": "⊋", "supplus": "⫀", "supset": "⊃", "supseteq": "⊇", "supseteqq": "⫆", "supsetneq": "⊋", "supsetneqq": "⫌", "supsim": "⫈", "supsub": "⫔", "supsup": "⫖", "swArr": "⇙", "swarhk": "⤦", "swarr": "↙", "swarrow": "↙", "swnwar": "⤪", "szlig": "ß", "target": "⌖", "tau": "τ", "tbrk": "⎴", "tcaron": "ť", "tcedil": "ţ", "tcy": "т", "tdot": "⃛", "telrec": "⌕", "tfr": "𝔱", "there4": "∴", "therefore": "∴", "theta": "θ", "thetasym": "ϑ", "thetav": "ϑ", "thickapprox": "≈", "thicksim": "∼", "thinsp": " ", "thkap": "≈", "thksim": "∼", "thorn": "þ", "tilde": "˜", "times": "×", "timesb": "⊠", "timesbar": "⨱", "timesd": "⨰", "tint": "∭", "toea": "⤨", "top": "⊤", "topbot": "⌶", "topcir": "⫱", "topf": "𝕥", "topfork": "⫚", "tosa": "⤩", "tprime": "‴", "trade": "™", "triangle": "▵", "triangledown": "▿", "triangleleft": "◃", "trianglelefteq": "⊴", "triangleq": "≜", "triangleright": "▹", "trianglerighteq": "⊵", "tridot": "◬", "trie": "≜", "triminus": "⨺", "triplus": "⨹", "trisb": "⧍", "tritime": "⨻", "trpezium": "⏢", "tscr": "𝓉", "tscy": "ц", "tshcy": "ћ", "tstrok": "ŧ", "twixt": "≬", "twoheadleftarrow": "↞", "twoheadrightarrow": "↠", "uArr": "⇑", "uHar": "⥣", "uacute": "ú", "uarr": "↑", "ubrcy": "ў", "ubreve": "ŭ", "ucirc": "û", "ucy": "у", "udarr": "⇅", "udblac": "ű", "udhar": "⥮", "ufisht": "⥾", "ufr": "𝔲", "ugrave": "ù", "uharl": "↿", "uharr": "↾", "uhblk": "▀", "ulcorn": "⌜", "ulcorner": "⌜", "ulcrop": "⌏", "ultri": "◸", "umacr": "ū", "uml": "¨", "uogon": "ų", "uopf": "𝕦", "uparrow": "↑", "updownarrow": "↕", "upharpoonleft": "↿", "upharpoonright": "↾", "uplus": "⊎", "upsi": "υ", "upsih": "ϒ", "upsilon": "υ", "upuparrows": "⇈", "urcorn": "⌝", "urcorner": "⌝", "urcrop": "⌎", "uring": "ů", "urtri": "◹", "uscr": "𝓊", "utdot": "⋰", "utilde": "ũ", "utri": "▵", "utrif": "▴", "uuarr": "⇈", "uuml": "ü", "uwangle": "⦧", "vArr": "⇕", "vBar": "⫨", "vBarv": "⫩", "vDash": "⊨", "vangrt": "⦜", "varepsilon": "ϵ", "varkappa": "ϰ", "varnothing": "∅", "varphi": "ϕ", "varpi": "ϖ", "varpropto": "∝", "varr": "↕", "varrho": "ϱ", "varsigma": "ς", "varsubsetneq": "⊊︀", "varsubsetneqq": "⫋︀", "varsupsetneq": "⊋︀", "varsupsetneqq": "⫌︀", "vartheta": "ϑ", "vartriangleleft": "⊲", "vartriangleright": "⊳", "vcy": "в", "vdash": "⊢", "vee": "∨", "veebar": "⊻", "veeeq": "≚", "vellip": "⋮", "verbar": "|", "vert": "|", "vfr": "𝔳", "vltri": "⊲", "vnsub": "⊂⃒", "vnsup": "⊃⃒", "vopf": "𝕧", "vprop": "∝", "vrtri": "⊳", "vscr": "𝓋", "vsubnE": "⫋︀", "vsubne": "⊊︀", "vsupnE": "⫌︀", "vsupne": "⊋︀", "vzigzag": "⦚", "wcirc": "ŵ", "wedbar": "⩟", "wedge": "∧", "wedgeq": "≙", "weierp": "℘", "wfr": "𝔴", "wopf": "𝕨", "wp": "℘", "wr": "≀", "wreath": "≀", "wscr": "𝓌", "xcap": "⋂", "xcirc": "◯", "xcup": "⋃", "xdtri": "▽", "xfr": "𝔵", "xhArr": "⟺", "xharr": "⟷", "xi": "ξ", "xlArr": "⟸", "xlarr": "⟵", "xmap": "⟼", "xnis": "⋻", "xodot": "⨀", "xopf": "𝕩", "xoplus": "⨁", "xotime": "⨂", "xrArr": "⟹", "xrarr": "⟶", "xscr": "𝓍", "xsqcup": "⨆", "xuplus": "⨄", "xutri": "△", "xvee": "⋁", "xwedge": "⋀", "yacute": "ý", "yacy": "я", "ycirc": "ŷ", "ycy": "ы", "yen": "¥", "yfr": "𝔶", "yicy": "ї", "yopf": "𝕪", "yscr": "𝓎", "yucy": "ю", "yuml": "ÿ", "zacute": "ź", "zcaron": "ž", "zcy": "з", "zdot": "ż", "zeetrf": "ℨ", "zeta": "ζ", "zfr": "𝔷", "zhcy": "ж", "zigrarr": "⇝", "zopf": "𝕫", "zscr": "𝓏", "zwj": "‍", "zwnj": "‌" } },{}],75:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015 Titus Wormer * @license MIT * @module character-entities * @fileoverview HTML character entity information. */ 'use strict'; /* eslint-env commonjs */ /* * Expose. */ module.exports = require('./index.json'); },{"./index.json":74}],76:[function(require,module,exports){ module.exports={ "0": "�", "128": "€", "130": "‚", "131": "ƒ", "132": "„", "133": "…", "134": "†", "135": "‡", "136": "ˆ", "137": "‰", "138": "Š", "139": "‹", "140": "Œ", "142": "Ž", "145": "‘", "146": "’", "147": "“", "148": "”", "149": "•", "150": "–", "151": "—", "152": "˜", "153": "™", "154": "š", "155": "›", "156": "œ", "158": "ž", "159": "Ÿ" } },{}],77:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015 Titus Wormer * @license MIT * @module character-reference-invalid * @fileoverview HTML invalid numeric character reference information. */ 'use strict'; /* eslint-env commonjs */ /* * Expose. */ module.exports = require('./index.json'); },{"./index.json":76}],78:[function(require,module,exports){ var _require = require //fool browserify module.exports = _require('chloridedown/build/Release/sodium') },{}],79:[function(require,module,exports){ module.exports = require('sodium-browserify') },{"sodium-browserify":515}],80:[function(require,module,exports){ (function (process){ if(process.env.CHLORIDE_JS) return module.exports = require('./browser') try { module.exports = require('./bindings') } catch (err) { console.error('error loading sodium bindings:', err.message) console.error('falling back to javascript version.') module.exports = require('./browser') } }).call(this,require('_process')) },{"./bindings":78,"./browser":79,"_process":295}],81:[function(require,module,exports){ (function (Buffer){ var Transform = require('stream').Transform var inherits = require('inherits') var StringDecoder = require('string_decoder').StringDecoder module.exports = CipherBase inherits(CipherBase, Transform) function CipherBase (hashMode) { Transform.call(this) this.hashMode = typeof hashMode === 'string' if (this.hashMode) { this[hashMode] = this._finalOrDigest } else { this.final = this._finalOrDigest } this._decoder = null this._encoding = null } CipherBase.prototype.update = function (data, inputEnc, outputEnc) { if (typeof data === 'string') { data = new Buffer(data, inputEnc) } var outData = this._update(data) if (this.hashMode) { return this } if (outputEnc) { outData = this._toString(outData, outputEnc) } return outData } CipherBase.prototype.setAutoPadding = function () {} CipherBase.prototype.getAuthTag = function () { throw new Error('trying to get auth tag in unsupported state') } CipherBase.prototype.setAuthTag = function () { throw new Error('trying to set auth tag in unsupported state') } CipherBase.prototype.setAAD = function () { throw new Error('trying to set aad in unsupported state') } CipherBase.prototype._transform = function (data, _, next) { var err try { if (this.hashMode) { this._update(data) } else { this.push(this._update(data)) } } catch (e) { err = e } finally { next(err) } } CipherBase.prototype._flush = function (done) { var err try { this.push(this._final()) } catch (e) { err = e } finally { done(err) } } CipherBase.prototype._finalOrDigest = function (outputEnc) { var outData = this._final() || new Buffer('') if (outputEnc) { outData = this._toString(outData, outputEnc, true) } return outData } CipherBase.prototype._toString = function (value, enc, final) { if (!this._decoder) { this._decoder = new StringDecoder(enc) this._encoding = enc } if (this._encoding !== enc) { throw new Error('can\'t switch encodings') } var out = this._decoder.write(value) if (final) { out += this._decoder.end() } return out } }).call(this,require("buffer").Buffer) },{"buffer":61,"inherits":167,"stream":576,"string_decoder":616}],82:[function(require,module,exports){ (function (Buffer){ var clone = (function() { 'use strict'; /** * Clones (copies) an Object using deep copying. * * This function supports circular references by default, but if you are certain * there are no circular references in your object, you can save some CPU time * by calling clone(obj, false). * * Caution: if `circular` is false and `parent` contains circular references, * your program may enter an infinite loop and crash. * * @param `parent` - the object to be cloned * @param `circular` - set to true if the object to be cloned may contain * circular references. (optional - true by default) * @param `depth` - set to a number if the object is only to be cloned to * a particular depth. (optional - defaults to Infinity) * @param `prototype` - sets the prototype to be used when cloning an object. * (optional - defaults to parent prototype). */ function clone(parent, circular, depth, prototype) { var filter; if (typeof circular === 'object') { depth = circular.depth; prototype = circular.prototype; filter = circular.filter; circular = circular.circular } // maintain two arrays for circular references, where corresponding parents // and children have the same index var allParents = []; var allChildren = []; var useBuffer = typeof Buffer != 'undefined'; if (typeof circular == 'undefined') circular = true; if (typeof depth == 'undefined') depth = Infinity; // recurse this function so we don't reset allParents and allChildren function _clone(parent, depth) { // cloning null always returns null if (parent === null) return null; if (depth == 0) return parent; var child; var proto; if (typeof parent != 'object') { return parent; } if (clone.__isArray(parent)) { child = []; } else if (clone.__isRegExp(parent)) { child = new RegExp(parent.source, __getRegExpFlags(parent)); if (parent.lastIndex) child.lastIndex = parent.lastIndex; } else if (clone.__isDate(parent)) { child = new Date(parent.getTime()); } else if (useBuffer && Buffer.isBuffer(parent)) { child = new Buffer(parent.length); parent.copy(child); return child; } else { if (typeof prototype == 'undefined') { proto = Object.getPrototypeOf(parent); child = Object.create(proto); } else { child = Object.create(prototype); proto = prototype; } } if (circular) { var index = allParents.indexOf(parent); if (index != -1) { return allChildren[index]; } allParents.push(parent); allChildren.push(child); } for (var i in parent) { var attrs; if (proto) { attrs = Object.getOwnPropertyDescriptor(proto, i); } if (attrs && attrs.set == null) { continue; } child[i] = _clone(parent[i], depth - 1); } return child; } return _clone(parent, depth); } /** * Simple flat clone using prototype, accepts only objects, usefull for property * override on FLAT configuration object (no nested props). * * USE WITH CAUTION! This may not behave as you wish if you do not know how this * works. */ clone.clonePrototype = function clonePrototype(parent) { if (parent === null) return null; var c = function () {}; c.prototype = parent; return new c(); }; // private utility functions function __objToStr(o) { return Object.prototype.toString.call(o); }; clone.__objToStr = __objToStr; function __isDate(o) { return typeof o === 'object' && __objToStr(o) === '[object Date]'; }; clone.__isDate = __isDate; function __isArray(o) { return typeof o === 'object' && __objToStr(o) === '[object Array]'; }; clone.__isArray = __isArray; function __isRegExp(o) { return typeof o === 'object' && __objToStr(o) === '[object RegExp]'; }; clone.__isRegExp = __isRegExp; function __getRegExpFlags(re) { var flags = ''; if (re.global) flags += 'g'; if (re.ignoreCase) flags += 'i'; if (re.multiline) flags += 'm'; return flags; }; clone.__getRegExpFlags = __getRegExpFlags; return clone; })(); if (typeof module === 'object' && module.exports) { module.exports = clone; } }).call(this,require("buffer").Buffer) },{"buffer":61}],83:[function(require,module,exports){ /** * slice() reference. */ var slice = Array.prototype.slice; /** * Expose `co`. */ module.exports = co; /** * Wrap the given generator `fn` and * return a thunk. * * @param {Function} fn * @return {Function} * @api public */ function co(fn) { var isGenFun = isGeneratorFunction(fn); return function (done) { var ctx = this; // in toThunk() below we invoke co() // with a generator, so optimize for // this case var gen = fn; // we only need to parse the arguments // if gen is a generator function. if (isGenFun) { var args = slice.call(arguments), len = args.length; var hasCallback = len && 'function' == typeof args[len - 1]; done = hasCallback ? args.pop() : error; gen = fn.apply(this, args); } else { done = done || error; } next(); // #92 // wrap the callback in a setImmediate // so that any of its errors aren't caught by `co` function exit(err, res) { setImmediate(function(){ done.call(ctx, err, res); }); } function next(err, res) { var ret; // multiple args if (arguments.length > 2) res = slice.call(arguments, 1); // error if (err) { try { ret = gen.throw(err); } catch (e) { return exit(e); } } // ok if (!err) { try { ret = gen.next(res); } catch (e) { return exit(e); } } // done if (ret.done) return exit(null, ret.value); // normalize ret.value = toThunk(ret.value, ctx); // run if ('function' == typeof ret.value) { var called = false; try { ret.value.call(ctx, function(){ if (called) return; called = true; next.apply(ctx, arguments); }); } catch (e) { setImmediate(function(){ if (called) return; called = true; next(e); }); } return; } // invalid next(new TypeError('You may only yield a function, promise, generator, array, or object, ' + 'but the following was passed: "' + String(ret.value) + '"')); } } } /** * Convert `obj` into a normalized thunk. * * @param {Mixed} obj * @param {Mixed} ctx * @return {Function} * @api private */ function toThunk(obj, ctx) { if (isGeneratorFunction(obj)) { return co(obj.call(ctx)); } if (isGenerator(obj)) { return co(obj); } if (isPromise(obj)) { return promiseToThunk(obj); } if ('function' == typeof obj) { return obj; } if (isObject(obj) || Array.isArray(obj)) { return objectToThunk.call(ctx, obj); } return obj; } /** * Convert an object of yieldables to a thunk. * * @param {Object} obj * @return {Function} * @api private */ function objectToThunk(obj){ var ctx = this; var isArray = Array.isArray(obj); return function(done){ var keys = Object.keys(obj); var pending = keys.length; var results = isArray ? new Array(pending) // predefine the array length : new obj.constructor(); var finished; if (!pending) { setImmediate(function(){ done(null, results) }); return; } // prepopulate object keys to preserve key ordering if (!isArray) { for (var i = 0; i < pending; i++) { results[keys[i]] = undefined; } } for (var i = 0; i < keys.length; i++) { run(obj[keys[i]], keys[i]); } function run(fn, key) { if (finished) return; try { fn = toThunk(fn, ctx); if ('function' != typeof fn) { results[key] = fn; return --pending || done(null, results); } fn.call(ctx, function(err, res){ if (finished) return; if (err) { finished = true; return done(err); } results[key] = res; --pending || done(null, results); }); } catch (err) { finished = true; done(err); } } } } /** * Convert `promise` to a thunk. * * @param {Object} promise * @return {Function} * @api private */ function promiseToThunk(promise) { return function(fn){ promise.then(function(res) { fn(null, res); }, fn); } } /** * Check if `obj` is a promise. * * @param {Object} obj * @return {Boolean} * @api private */ function isPromise(obj) { return obj && 'function' == typeof obj.then; } /** * Check if `obj` is a generator. * * @param {Mixed} obj * @return {Boolean} * @api private */ function isGenerator(obj) { return obj && 'function' == typeof obj.next && 'function' == typeof obj.throw; } /** * Check if `obj` is a generator function. * * @param {Mixed} obj * @return {Boolean} * @api private */ function isGeneratorFunction(obj) { return obj && obj.constructor && 'GeneratorFunction' == obj.constructor.name; } /** * Check for plain object. * * @param {Mixed} val * @return {Boolean} * @api private */ function isObject(val) { return val && Object == val.constructor; } /** * Throw `err` in a new stack. * * This is used when co() is invoked * without supplying a callback, which * should only be for demonstrational * purposes. * * @param {Error} err * @api private */ function error(err) { if (!err) return; setImmediate(function(){ throw err; }); } },{}],84:[function(require,module,exports){ 'use strict'; /* * Constants. */ var WHITE_SPACE_COLLAPSABLE = /\s+/g; var SPACE = ' '; /** * Replace multiple white-space characters with a single space. * * @example * collapse(' \t\nbar \nbaz\t'); // ' bar baz ' * * @param {string} value - Value with uncollapsed white-space, * coerced to string. * @return {string} - Value with collapsed white-space. */ function collapse(value) { return String(value).replace(WHITE_SPACE_COLLAPSABLE, SPACE); } /* * Expose. */ module.exports = collapse; },{}],85:[function(require,module,exports){ module.exports = function (xs, fn) { var res = []; for (var i = 0; i < xs.length; i++) { var x = fn(xs[i], i); if (isArray(x)) res.push.apply(res, x); else res.push(x); } return res; }; var isArray = Array.isArray || function (xs) { return Object.prototype.toString.call(xs) === '[object Array]'; }; },{}],86:[function(require,module,exports){ var cont = require('continuable') exports = module.exports = function (fun) { return cont.to(fun) } for(var k in cont) exports[k] = cont[k] exports.para = require('continuable-para') exports.series = require('continuable-series') },{"continuable":97,"continuable-para":91,"continuable-series":92}],87:[function(require,module,exports){ var maybeCallback = require("continuable/maybe-callback") module.exports = maybeCallback(hash) // hash := (tasks:Object>) // => Continuable> function hash(tasks) { return function continuable(callback) { var keys = Object.keys(tasks) var count = 0 var result = {} if (keys.length === 0) { return callback(null, result) } keys.forEach(function (key) { tasks[key](function (err, value) { if (err && result) { result = null callback(err) } else if (!err && result) { result[key] = value if (++count === keys.length) { callback(null, result) } } }) }) } } },{"continuable/maybe-callback":88}],88:[function(require,module,exports){ var slice = Array.prototype.slice /* Given a function that takes n arguments and returns a continuable return a function that takes n arguments and maybe a n+1th argument which is a callback or takes n arguments and returns a continuable This basically means that you can do this: ```js var readFile = maybeCallback(function (uri) { return function (cb) { fs.readFile(uri, cb) } }) readFile("./foo")(cb) readFile("./foo", cb) ``` Be warned this breaks if the last argument is a function */ module.exports = maybeCallback // maybeCallback := (fn: (Any, ...) => Continuable) => // (Any, ..., Callback?) => Continuable function maybeCallback(fn) { return function maybeContinuable() { var args = slice.call(arguments) var callback = args[args.length - 1] if (typeof callback === "function") { args.pop() } var continuable = fn.apply(null, args) if (typeof callback === "function") { continuable(callback) } else { return continuable } } } },{}],89:[function(require,module,exports){ var maybeCallback = require("continuable/maybe-callback") module.exports = maybeCallback(list) // list := (tasks:Array>) // => Continuable> function list(tasks) { return function continuable(callback) { var result = [] var count = 0 if (tasks.length === 0) { return callback(null, result) } tasks.forEach(function invokeSource(source, index) { source(function continuation(err, value) { if (err && result) { result = null callback(err) } else if (!err && result) { result[index] = value if (++count === tasks.length) { callback(null, result) } } }) }) } } },{"continuable/maybe-callback":90}],90:[function(require,module,exports){ arguments[4][88][0].apply(exports,arguments) },{"dup":88}],91:[function(require,module,exports){ var list = require('continuable-list') var hash = require('continuable-hash') module.exports = function (obj, cb) { if(Array.isArray(obj)) return list(obj, cb) else if('object' === typeof obj) return hash(obj, cb) else return list([].slice.call(arguments)) } },{"continuable-hash":87,"continuable-list":89}],92:[function(require,module,exports){ module.exports = function series (continuables, callback) { if('function' === typeof continuables) return series([].slice.call(arguments)) if (callback) { next(callback) } else { return next } function next (callback) { continuables.shift() (function (err, value) { if (err || !continuables.length) return callback(err, value) next (callback) }) } } },{}],93:[function(require,module,exports){ // both := (Continuable) => Continuable<[Error, Any]> module.exports = both function both(source) { return function continuable(callback) { source(function (err, value) { callback(null, [err || null, value]) }) } } },{}],94:[function(require,module,exports){ module.exports = chain // chain := (Continuable, lambda:(A) => Continuable) => Continuable function chain(source, lambda) { return function continuable(callback) { source(function continuation(err, value) { if (err) { return callback(err) } lambda(value)(callback) }) } } },{}],95:[function(require,module,exports){ var of = require("./of") module.exports = either // either := (source: Continuable, // left: (Error, cb?: Callback) => Continuable, // right?: (A) => Continuable) // => Continuable function either(cont, left, right) { right = right || of return function continuable(callback) { cont(function (err, value) { if (!err) { return right(value)(callback) } // the left function takes either a callback or // it returns a continuable. Both are valid var cont = left(err, callback) if (cont) { cont(callback) } }) } } },{"./of":102}],96:[function(require,module,exports){ module.exports = error // error := (Error) => Continuable function error(err) { return function continuable(callback) { callback(err) } } },{}],97:[function(require,module,exports){ var maybeCallback = require("./maybe-callback.js") maybeCallback.both = require("./both.js") maybeCallback.chain = require("./chain.js") maybeCallback.either = require("./either.js") maybeCallback.error = require("./error.js") maybeCallback.join = require("./join.js") maybeCallback.mapAsync = require("./map-async.js") maybeCallback.map = require("./map.js") maybeCallback.of = require("./of.js") maybeCallback.to = require("./to.js") module.exports = maybeCallback },{"./both.js":93,"./chain.js":94,"./either.js":95,"./error.js":96,"./join.js":98,"./map-async.js":99,"./map.js":100,"./maybe-callback.js":101,"./of.js":102,"./to.js":103}],98:[function(require,module,exports){ module.exports = join // join := (Continuable>) => Continuable function join(source) { return function continuable(callback) { source(function continuation(err, next) { if (err) { return callback(err) } next(callback) }) } } },{}],99:[function(require,module,exports){ module.exports = mapAsync // mapAsync := (Continuable, lambda: (A, Callback)) => Continuable function mapAsync(source, lambda) { return function continuable(callback) { source(function continuation(err, value) { if (err) { return callback(err) } lambda(value, callback) }) } } },{}],100:[function(require,module,exports){ module.exports = map // map := (Continuable, (A) => B) => Continuable function map(source, lambda) { return function continuable(callback) { source(function continuation(err, value) { if (err) { return callback(err) } callback(null, lambda(value)) }) } } },{}],101:[function(require,module,exports){ arguments[4][88][0].apply(exports,arguments) },{"dup":88}],102:[function(require,module,exports){ module.exports = of // of := (Value) => Continuable function of(value) { return function continuable(callback) { callback(null, value) } } },{}],103:[function(require,module,exports){ var slice = Array.prototype.slice module.exports = to function to(asyncFn) { return function () { var args = slice.call(arguments) var callback = args[args.length - 1] var self = this if (typeof callback === "function") { return asyncFn.apply(this, args) } return function continuable(callback) { var _args = args.slice() _args.push(callback) return asyncFn.apply(self, _args) } } } },{}],104:[function(require,module,exports){ (function (Buffer){ // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. // NOTE: These type checking functions intentionally don't use `instanceof` // because it is fragile and can be easily faked with `Object.create()`. function isArray(arg) { if (Array.isArray) { return Array.isArray(arg); } return objectToString(arg) === '[object Array]'; } exports.isArray = isArray; function isBoolean(arg) { return typeof arg === 'boolean'; } exports.isBoolean = isBoolean; function isNull(arg) { return arg === null; } exports.isNull = isNull; function isNullOrUndefined(arg) { return arg == null; } exports.isNullOrUndefined = isNullOrUndefined; function isNumber(arg) { return typeof arg === 'number'; } exports.isNumber = isNumber; function isString(arg) { return typeof arg === 'string'; } exports.isString = isString; function isSymbol(arg) { return typeof arg === 'symbol'; } exports.isSymbol = isSymbol; function isUndefined(arg) { return arg === void 0; } exports.isUndefined = isUndefined; function isRegExp(re) { return objectToString(re) === '[object RegExp]'; } exports.isRegExp = isRegExp; function isObject(arg) { return typeof arg === 'object' && arg !== null; } exports.isObject = isObject; function isDate(d) { return objectToString(d) === '[object Date]'; } exports.isDate = isDate; function isError(e) { return (objectToString(e) === '[object Error]' || e instanceof Error); } exports.isError = isError; function isFunction(arg) { return typeof arg === 'function'; } exports.isFunction = isFunction; function isPrimitive(arg) { return arg === null || typeof arg === 'boolean' || typeof arg === 'number' || typeof arg === 'string' || typeof arg === 'symbol' || // ES6 symbol typeof arg === 'undefined'; } exports.isPrimitive = isPrimitive; exports.isBuffer = Buffer.isBuffer; function objectToString(o) { return Object.prototype.toString.call(o); } }).call(this,{"isBuffer":require("../../is-buffer/index.js")}) },{"../../is-buffer/index.js":170}],105:[function(require,module,exports){ (function (Buffer){ var elliptic = require('elliptic'); var BN = require('bn.js'); module.exports = function createECDH(curve) { return new ECDH(curve); }; var aliases = { secp256k1: { name: 'secp256k1', byteLength: 32 }, secp224r1: { name: 'p224', byteLength: 28 }, prime256v1: { name: 'p256', byteLength: 32 }, prime192v1: { name: 'p192', byteLength: 24 }, ed25519: { name: 'ed25519', byteLength: 32 }, secp384r1: { name: 'p384', byteLength: 48 }, secp521r1: { name: 'p521', byteLength: 66 } }; aliases.p224 = aliases.secp224r1; aliases.p256 = aliases.secp256r1 = aliases.prime256v1; aliases.p192 = aliases.secp192r1 = aliases.prime192v1; aliases.p384 = aliases.secp384r1; aliases.p521 = aliases.secp521r1; function ECDH(curve) { this.curveType = aliases[curve]; if (!this.curveType ) { this.curveType = { name: curve }; } this.curve = new elliptic.ec(this.curveType.name); this.keys = void 0; } ECDH.prototype.generateKeys = function (enc, format) { this.keys = this.curve.genKeyPair(); return this.getPublicKey(enc, format); }; ECDH.prototype.computeSecret = function (other, inenc, enc) { inenc = inenc || 'utf8'; if (!Buffer.isBuffer(other)) { other = new Buffer(other, inenc); } var otherPub = this.curve.keyFromPublic(other).getPublic(); var out = otherPub.mul(this.keys.getPrivate()).getX(); return formatReturnValue(out, enc, this.curveType.byteLength); }; ECDH.prototype.getPublicKey = function (enc, format) { var key = this.keys.getPublic(format === 'compressed', true); if (format === 'hybrid') { if (key[key.length - 1] % 2) { key[0] = 7; } else { key [0] = 6; } } return formatReturnValue(key, enc); }; ECDH.prototype.getPrivateKey = function (enc) { return formatReturnValue(this.keys.getPrivate(), enc); }; ECDH.prototype.setPublicKey = function (pub, enc) { enc = enc || 'utf8'; if (!Buffer.isBuffer(pub)) { pub = new Buffer(pub, enc); } this.keys._importPublic(pub); return this; }; ECDH.prototype.setPrivateKey = function (priv, enc) { enc = enc || 'utf8'; if (!Buffer.isBuffer(priv)) { priv = new Buffer(priv, enc); } var _priv = new BN(priv); _priv = _priv.toString(16); this.keys._importPrivate(_priv); return this; }; function formatReturnValue(bn, enc, len) { if (!Array.isArray(bn)) { bn = bn.toArray(); } var buf = new Buffer(bn); if (len && buf.length < len) { var zeros = new Buffer(len - buf.length); zeros.fill(0); buf = Buffer.concat([zeros, buf]); } if (!enc) { return buf; } else { return buf.toString(enc); } } }).call(this,require("buffer").Buffer) },{"bn.js":29,"buffer":61,"elliptic":125}],106:[function(require,module,exports){ (function (Buffer){ 'use strict'; var inherits = require('inherits') var md5 = require('./md5') var rmd160 = require('ripemd160') var sha = require('sha.js') var Base = require('cipher-base') function HashNoConstructor(hash) { Base.call(this, 'digest') this._hash = hash this.buffers = [] } inherits(HashNoConstructor, Base) HashNoConstructor.prototype._update = function (data) { this.buffers.push(data) } HashNoConstructor.prototype._final = function () { var buf = Buffer.concat(this.buffers) var r = this._hash(buf) this.buffers = null return r } function Hash(hash) { Base.call(this, 'digest') this._hash = hash } inherits(Hash, Base) Hash.prototype._update = function (data) { this._hash.update(data) } Hash.prototype._final = function () { return this._hash.digest() } module.exports = function createHash (alg) { alg = alg.toLowerCase() if ('md5' === alg) return new HashNoConstructor(md5) if ('rmd160' === alg || 'ripemd160' === alg) return new HashNoConstructor(rmd160) return new Hash(sha(alg)) } }).call(this,require("buffer").Buffer) },{"./md5":108,"buffer":61,"cipher-base":81,"inherits":167,"ripemd160":424,"sha.js":507}],107:[function(require,module,exports){ (function (Buffer){ 'use strict'; var intSize = 4; var zeroBuffer = new Buffer(intSize); zeroBuffer.fill(0); var chrsz = 8; function toArray(buf, bigEndian) { if ((buf.length % intSize) !== 0) { var len = buf.length + (intSize - (buf.length % intSize)); buf = Buffer.concat([buf, zeroBuffer], len); } var arr = []; var fn = bigEndian ? buf.readInt32BE : buf.readInt32LE; for (var i = 0; i < buf.length; i += intSize) { arr.push(fn.call(buf, i)); } return arr; } function toBuffer(arr, size, bigEndian) { var buf = new Buffer(size); var fn = bigEndian ? buf.writeInt32BE : buf.writeInt32LE; for (var i = 0; i < arr.length; i++) { fn.call(buf, arr[i], i * 4, true); } return buf; } function hash(buf, fn, hashSize, bigEndian) { if (!Buffer.isBuffer(buf)) buf = new Buffer(buf); var arr = fn(toArray(buf, bigEndian), buf.length * chrsz); return toBuffer(arr, hashSize, bigEndian); } exports.hash = hash; }).call(this,require("buffer").Buffer) },{"buffer":61}],108:[function(require,module,exports){ 'use strict'; /* * A JavaScript implementation of the RSA Data Security, Inc. MD5 Message * Digest Algorithm, as defined in RFC 1321. * Version 2.1 Copyright (C) Paul Johnston 1999 - 2002. * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet * Distributed under the BSD License * See http://pajhome.org.uk/crypt/md5 for more info. */ var helpers = require('./helpers'); /* * Calculate the MD5 of an array of little-endian words, and a bit length */ function core_md5(x, len) { /* append padding */ x[len >> 5] |= 0x80 << ((len) % 32); x[(((len + 64) >>> 9) << 4) + 14] = len; var a = 1732584193; var b = -271733879; var c = -1732584194; var d = 271733878; for(var i = 0; i < x.length; i += 16) { var olda = a; var oldb = b; var oldc = c; var oldd = d; a = md5_ff(a, b, c, d, x[i+ 0], 7 , -680876936); d = md5_ff(d, a, b, c, x[i+ 1], 12, -389564586); c = md5_ff(c, d, a, b, x[i+ 2], 17, 606105819); b = md5_ff(b, c, d, a, x[i+ 3], 22, -1044525330); a = md5_ff(a, b, c, d, x[i+ 4], 7 , -176418897); d = md5_ff(d, a, b, c, x[i+ 5], 12, 1200080426); c = md5_ff(c, d, a, b, x[i+ 6], 17, -1473231341); b = md5_ff(b, c, d, a, x[i+ 7], 22, -45705983); a = md5_ff(a, b, c, d, x[i+ 8], 7 , 1770035416); d = md5_ff(d, a, b, c, x[i+ 9], 12, -1958414417); c = md5_ff(c, d, a, b, x[i+10], 17, -42063); b = md5_ff(b, c, d, a, x[i+11], 22, -1990404162); a = md5_ff(a, b, c, d, x[i+12], 7 , 1804603682); d = md5_ff(d, a, b, c, x[i+13], 12, -40341101); c = md5_ff(c, d, a, b, x[i+14], 17, -1502002290); b = md5_ff(b, c, d, a, x[i+15], 22, 1236535329); a = md5_gg(a, b, c, d, x[i+ 1], 5 , -165796510); d = md5_gg(d, a, b, c, x[i+ 6], 9 , -1069501632); c = md5_gg(c, d, a, b, x[i+11], 14, 643717713); b = md5_gg(b, c, d, a, x[i+ 0], 20, -373897302); a = md5_gg(a, b, c, d, x[i+ 5], 5 , -701558691); d = md5_gg(d, a, b, c, x[i+10], 9 , 38016083); c = md5_gg(c, d, a, b, x[i+15], 14, -660478335); b = md5_gg(b, c, d, a, x[i+ 4], 20, -405537848); a = md5_gg(a, b, c, d, x[i+ 9], 5 , 568446438); d = md5_gg(d, a, b, c, x[i+14], 9 , -1019803690); c = md5_gg(c, d, a, b, x[i+ 3], 14, -187363961); b = md5_gg(b, c, d, a, x[i+ 8], 20, 1163531501); a = md5_gg(a, b, c, d, x[i+13], 5 , -1444681467); d = md5_gg(d, a, b, c, x[i+ 2], 9 , -51403784); c = md5_gg(c, d, a, b, x[i+ 7], 14, 1735328473); b = md5_gg(b, c, d, a, x[i+12], 20, -1926607734); a = md5_hh(a, b, c, d, x[i+ 5], 4 , -378558); d = md5_hh(d, a, b, c, x[i+ 8], 11, -2022574463); c = md5_hh(c, d, a, b, x[i+11], 16, 1839030562); b = md5_hh(b, c, d, a, x[i+14], 23, -35309556); a = md5_hh(a, b, c, d, x[i+ 1], 4 , -1530992060); d = md5_hh(d, a, b, c, x[i+ 4], 11, 1272893353); c = md5_hh(c, d, a, b, x[i+ 7], 16, -155497632); b = md5_hh(b, c, d, a, x[i+10], 23, -1094730640); a = md5_hh(a, b, c, d, x[i+13], 4 , 681279174); d = md5_hh(d, a, b, c, x[i+ 0], 11, -358537222); c = md5_hh(c, d, a, b, x[i+ 3], 16, -722521979); b = md5_hh(b, c, d, a, x[i+ 6], 23, 76029189); a = md5_hh(a, b, c, d, x[i+ 9], 4 , -640364487); d = md5_hh(d, a, b, c, x[i+12], 11, -421815835); c = md5_hh(c, d, a, b, x[i+15], 16, 530742520); b = md5_hh(b, c, d, a, x[i+ 2], 23, -995338651); a = md5_ii(a, b, c, d, x[i+ 0], 6 , -198630844); d = md5_ii(d, a, b, c, x[i+ 7], 10, 1126891415); c = md5_ii(c, d, a, b, x[i+14], 15, -1416354905); b = md5_ii(b, c, d, a, x[i+ 5], 21, -57434055); a = md5_ii(a, b, c, d, x[i+12], 6 , 1700485571); d = md5_ii(d, a, b, c, x[i+ 3], 10, -1894986606); c = md5_ii(c, d, a, b, x[i+10], 15, -1051523); b = md5_ii(b, c, d, a, x[i+ 1], 21, -2054922799); a = md5_ii(a, b, c, d, x[i+ 8], 6 , 1873313359); d = md5_ii(d, a, b, c, x[i+15], 10, -30611744); c = md5_ii(c, d, a, b, x[i+ 6], 15, -1560198380); b = md5_ii(b, c, d, a, x[i+13], 21, 1309151649); a = md5_ii(a, b, c, d, x[i+ 4], 6 , -145523070); d = md5_ii(d, a, b, c, x[i+11], 10, -1120210379); c = md5_ii(c, d, a, b, x[i+ 2], 15, 718787259); b = md5_ii(b, c, d, a, x[i+ 9], 21, -343485551); a = safe_add(a, olda); b = safe_add(b, oldb); c = safe_add(c, oldc); d = safe_add(d, oldd); } return Array(a, b, c, d); } /* * These functions implement the four basic operations the algorithm uses. */ function md5_cmn(q, a, b, x, s, t) { return safe_add(bit_rol(safe_add(safe_add(a, q), safe_add(x, t)), s),b); } function md5_ff(a, b, c, d, x, s, t) { return md5_cmn((b & c) | ((~b) & d), a, b, x, s, t); } function md5_gg(a, b, c, d, x, s, t) { return md5_cmn((b & d) | (c & (~d)), a, b, x, s, t); } function md5_hh(a, b, c, d, x, s, t) { return md5_cmn(b ^ c ^ d, a, b, x, s, t); } function md5_ii(a, b, c, d, x, s, t) { return md5_cmn(c ^ (b | (~d)), a, b, x, s, t); } /* * Add integers, wrapping at 2^32. This uses 16-bit operations internally * to work around bugs in some JS interpreters. */ function safe_add(x, y) { var lsw = (x & 0xFFFF) + (y & 0xFFFF); var msw = (x >> 16) + (y >> 16) + (lsw >> 16); return (msw << 16) | (lsw & 0xFFFF); } /* * Bitwise rotate a 32-bit number to the left. */ function bit_rol(num, cnt) { return (num << cnt) | (num >>> (32 - cnt)); } module.exports = function md5(buf) { return helpers.hash(buf, core_md5, 16); }; },{"./helpers":107}],109:[function(require,module,exports){ (function (Buffer){ 'use strict'; var createHash = require('create-hash/browser'); var inherits = require('inherits') var Transform = require('stream').Transform var ZEROS = new Buffer(128) ZEROS.fill(0) function Hmac(alg, key) { Transform.call(this) alg = alg.toLowerCase() if (typeof key === 'string') { key = new Buffer(key) } var blocksize = (alg === 'sha512' || alg === 'sha384') ? 128 : 64 this._alg = alg this._key = key if (key.length > blocksize) { key = createHash(alg).update(key).digest() } else if (key.length < blocksize) { key = Buffer.concat([key, ZEROS], blocksize) } var ipad = this._ipad = new Buffer(blocksize) var opad = this._opad = new Buffer(blocksize) for (var i = 0; i < blocksize; i++) { ipad[i] = key[i] ^ 0x36 opad[i] = key[i] ^ 0x5C } this._hash = createHash(alg).update(ipad) } inherits(Hmac, Transform) Hmac.prototype.update = function (data, enc) { this._hash.update(data, enc) return this } Hmac.prototype._transform = function (data, _, next) { this._hash.update(data) next() } Hmac.prototype._flush = function (next) { this.push(this.digest()) next() } Hmac.prototype.digest = function (enc) { var h = this._hash.digest() return createHash(this._alg).update(this._opad).update(h).digest(enc) } module.exports = function createHmac(alg, key) { return new Hmac(alg, key) } }).call(this,require("buffer").Buffer) },{"buffer":61,"create-hash/browser":106,"inherits":167,"stream":576}],110:[function(require,module,exports){ 'use strict' exports.randomBytes = exports.rng = exports.pseudoRandomBytes = exports.prng = require('randombytes') exports.createHash = exports.Hash = require('create-hash') exports.createHmac = exports.Hmac = require('create-hmac') var hashes = ['sha1', 'sha224', 'sha256', 'sha384', 'sha512', 'md5', 'rmd160'].concat(Object.keys(require('browserify-sign/algos'))) exports.getHashes = function () { return hashes } var p = require('pbkdf2') exports.pbkdf2 = p.pbkdf2 exports.pbkdf2Sync = p.pbkdf2Sync var aes = require('browserify-cipher') ;[ 'Cipher', 'createCipher', 'Cipheriv', 'createCipheriv', 'Decipher', 'createDecipher', 'Decipheriv', 'createDecipheriv', 'getCiphers', 'listCiphers' ].forEach(function (key) { exports[key] = aes[key] }) var dh = require('diffie-hellman') ;[ 'DiffieHellmanGroup', 'createDiffieHellmanGroup', 'getDiffieHellman', 'createDiffieHellman', 'DiffieHellman' ].forEach(function (key) { exports[key] = dh[key] }) var sign = require('browserify-sign') ;[ 'createSign', 'Sign', 'createVerify', 'Verify' ].forEach(function (key) { exports[key] = sign[key] }) exports.createECDH = require('create-ecdh') var publicEncrypt = require('public-encrypt') ;[ 'publicEncrypt', 'privateEncrypt', 'publicDecrypt', 'privateDecrypt' ].forEach(function (key) { exports[key] = publicEncrypt[key] }) // the least I can do is make error messages for the rest of the node.js/crypto api. ;[ 'createCredentials' ].forEach(function (name) { exports[name] = function () { throw new Error([ 'sorry, ' + name + ' is not implemented yet', 'we accept pull requests', 'https://github.com/crypto-browserify/crypto-browserify' ].join('\n')) } }) },{"browserify-cipher":49,"browserify-sign":54,"browserify-sign/algos":53,"create-ecdh":105,"create-hash":106,"create-hmac":109,"diffie-hellman":120,"pbkdf2":292,"public-encrypt":297,"randombytes":403}],111:[function(require,module,exports){ (function (Buffer){ /*! * @description Recursive object extending * @author Viacheslav Lotsmanov * @license MIT * * The MIT License (MIT) * * Copyright (c) 2013-2015 Viacheslav Lotsmanov * * Permission is hereby granted, free of charge, to any person obtaining a copy of * this software and associated documentation files (the "Software"), to deal in * the Software without restriction, including without limitation the rights to * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of * the Software, and to permit persons to whom the Software is furnished to do so, * subject to the following conditions: * * The above copyright notice and this permission notice shall be included in all * copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ 'use strict'; function isSpecificValue(val) { return ( val instanceof Buffer || val instanceof Date || val instanceof RegExp ) ? true : false; } function cloneSpecificValue(val) { if (val instanceof Buffer) { var x = new Buffer(val.length); val.copy(x); return x; } else if (val instanceof Date) { return new Date(val.getTime()); } else if (val instanceof RegExp) { return new RegExp(val); } else { throw new Error('Unexpected situation'); } } /** * Recursive cloning array. */ function deepCloneArray(arr) { var clone = []; arr.forEach(function (item, index) { if (typeof item === 'object' && item !== null) { if (Array.isArray(item)) { clone[index] = deepCloneArray(item); } else if (isSpecificValue(item)) { clone[index] = cloneSpecificValue(item); } else { clone[index] = deepExtend({}, item); } } else { clone[index] = item; } }); return clone; } /** * Extening object that entered in first argument. * * Returns extended object or false if have no target object or incorrect type. * * If you wish to clone source object (without modify it), just use empty new * object as first argument, like this: * deepExtend({}, yourObj_1, [yourObj_N]); */ var deepExtend = module.exports = function (/*obj_1, [obj_2], [obj_N]*/) { if (arguments.length < 1 || typeof arguments[0] !== 'object') { return false; } if (arguments.length < 2) { return arguments[0]; } var target = arguments[0]; // convert arguments to array and cut off target object var args = Array.prototype.slice.call(arguments, 1); var val, src, clone; args.forEach(function (obj) { // skip argument if it is array or isn't object if (typeof obj !== 'object' || Array.isArray(obj)) { return; } Object.keys(obj).forEach(function (key) { src = target[key]; // source value val = obj[key]; // new value // recursion prevention if (val === target) { return; /** * if new value isn't object then just overwrite by new value * instead of extending. */ } else if (typeof val !== 'object' || val === null) { target[key] = val; return; // just clone arrays (and recursive clone objects inside) } else if (Array.isArray(val)) { target[key] = deepCloneArray(val); return; // custom cloning and overwrite for specific objects } else if (isSpecificValue(val)) { target[key] = cloneSpecificValue(val); return; // overwrite by new value if source isn't object or array } else if (typeof src !== 'object' || src === null || Array.isArray(src)) { target[key] = deepExtend({}, val); return; // source value and new value is objects both, extending... } else { target[key] = deepExtend(src, val); return; } }); }); return target; } }).call(this,require("buffer").Buffer) },{"buffer":61}],112:[function(require,module,exports){ module.exports = function () { for (var i = 0; i < arguments.length; i++) { if (arguments[i] !== undefined) return arguments[i]; } }; },{}],113:[function(require,module,exports){ 'use strict'; exports.utils = require('./des/utils'); exports.Cipher = require('./des/cipher'); exports.DES = require('./des/des'); exports.CBC = require('./des/cbc'); exports.EDE = require('./des/ede'); },{"./des/cbc":114,"./des/cipher":115,"./des/des":116,"./des/ede":117,"./des/utils":118}],114:[function(require,module,exports){ 'use strict'; var assert = require('minimalistic-assert'); var inherits = require('inherits'); var proto = {}; function CBCState(iv) { assert.equal(iv.length, 8, 'Invalid IV length'); this.iv = new Array(8); for (var i = 0; i < this.iv.length; i++) this.iv[i] = iv[i]; } function instantiate(Base) { function CBC(options) { Base.call(this, options); this._cbcInit(); } inherits(CBC, Base); var keys = Object.keys(proto); for (var i = 0; i < keys.length; i++) { var key = keys[i]; CBC.prototype[key] = proto[key]; } CBC.create = function create(options) { return new CBC(options); }; return CBC; } exports.instantiate = instantiate; proto._cbcInit = function _cbcInit() { var state = new CBCState(this.options.iv); this._cbcState = state; }; proto._update = function _update(inp, inOff, out, outOff) { var state = this._cbcState; var superProto = this.constructor.super_.prototype; var iv = state.iv; if (this.type === 'encrypt') { for (var i = 0; i < this.blockSize; i++) iv[i] ^= inp[inOff + i]; superProto._update.call(this, iv, 0, out, outOff); for (var i = 0; i < this.blockSize; i++) iv[i] = out[outOff + i]; } else { superProto._update.call(this, inp, inOff, out, outOff); for (var i = 0; i < this.blockSize; i++) out[outOff + i] ^= iv[i]; for (var i = 0; i < this.blockSize; i++) iv[i] = inp[inOff + i]; } }; },{"inherits":167,"minimalistic-assert":246}],115:[function(require,module,exports){ 'use strict'; var assert = require('minimalistic-assert'); function Cipher(options) { this.options = options; this.type = this.options.type; this.blockSize = 8; this._init(); this.buffer = new Array(this.blockSize); this.bufferOff = 0; } module.exports = Cipher; Cipher.prototype._init = function _init() { // Might be overrided }; Cipher.prototype.update = function update(data) { if (data.length === 0) return []; if (this.type === 'decrypt') return this._updateDecrypt(data); else return this._updateEncrypt(data); }; Cipher.prototype._buffer = function _buffer(data, off) { // Append data to buffer var min = Math.min(this.buffer.length - this.bufferOff, data.length - off); for (var i = 0; i < min; i++) this.buffer[this.bufferOff + i] = data[off + i]; this.bufferOff += min; // Shift next return min; }; Cipher.prototype._flushBuffer = function _flushBuffer(out, off) { this._update(this.buffer, 0, out, off); this.bufferOff = 0; return this.blockSize; }; Cipher.prototype._updateEncrypt = function _updateEncrypt(data) { var inputOff = 0; var outputOff = 0; var count = ((this.bufferOff + data.length) / this.blockSize) | 0; var out = new Array(count * this.blockSize); if (this.bufferOff !== 0) { inputOff += this._buffer(data, inputOff); if (this.bufferOff === this.buffer.length) outputOff += this._flushBuffer(out, outputOff); } // Write blocks var max = data.length - ((data.length - inputOff) % this.blockSize); for (; inputOff < max; inputOff += this.blockSize) { this._update(data, inputOff, out, outputOff); outputOff += this.blockSize; } // Queue rest for (; inputOff < data.length; inputOff++, this.bufferOff++) this.buffer[this.bufferOff] = data[inputOff]; return out; }; Cipher.prototype._updateDecrypt = function _updateDecrypt(data) { var inputOff = 0; var outputOff = 0; var count = Math.ceil((this.bufferOff + data.length) / this.blockSize) - 1; var out = new Array(count * this.blockSize); // TODO(indutny): optimize it, this is far from optimal for (; count > 0; count--) { inputOff += this._buffer(data, inputOff); outputOff += this._flushBuffer(out, outputOff); } // Buffer rest of the input inputOff += this._buffer(data, inputOff); return out; }; Cipher.prototype.final = function final(buffer) { var first; if (buffer) first = this.update(buffer); var last; if (this.type === 'encrypt') last = this._finalEncrypt(); else last = this._finalDecrypt(); if (first) return first.concat(last); else return last; }; Cipher.prototype._pad = function _pad(buffer, off) { if (off === 0) return false; while (off < buffer.length) buffer[off++] = 0; return true; }; Cipher.prototype._finalEncrypt = function _finalEncrypt() { if (!this._pad(this.buffer, this.bufferOff)) return []; var out = new Array(this.blockSize); this._update(this.buffer, 0, out, 0); return out; }; Cipher.prototype._unpad = function _unpad(buffer) { return buffer; }; Cipher.prototype._finalDecrypt = function _finalDecrypt() { assert.equal(this.bufferOff, this.blockSize, 'Not enough data to decrypt'); var out = new Array(this.blockSize); this._flushBuffer(out, 0); return this._unpad(out); }; },{"minimalistic-assert":246}],116:[function(require,module,exports){ 'use strict'; var assert = require('minimalistic-assert'); var inherits = require('inherits'); var des = require('../des'); var utils = des.utils; var Cipher = des.Cipher; function DESState() { this.tmp = new Array(2); this.keys = null; } function DES(options) { Cipher.call(this, options); var state = new DESState(); this._desState = state; this.deriveKeys(state, options.key); } inherits(DES, Cipher); module.exports = DES; DES.create = function create(options) { return new DES(options); }; var shiftTable = [ 1, 1, 2, 2, 2, 2, 2, 2, 1, 2, 2, 2, 2, 2, 2, 1 ]; DES.prototype.deriveKeys = function deriveKeys(state, key) { state.keys = new Array(16 * 2); assert.equal(key.length, this.blockSize, 'Invalid key length'); var kL = utils.readUInt32BE(key, 0); var kR = utils.readUInt32BE(key, 4); utils.pc1(kL, kR, state.tmp, 0); kL = state.tmp[0]; kR = state.tmp[1]; for (var i = 0; i < state.keys.length; i += 2) { var shift = shiftTable[i >>> 1]; kL = utils.r28shl(kL, shift); kR = utils.r28shl(kR, shift); utils.pc2(kL, kR, state.keys, i); } }; DES.prototype._update = function _update(inp, inOff, out, outOff) { var state = this._desState; var l = utils.readUInt32BE(inp, inOff); var r = utils.readUInt32BE(inp, inOff + 4); // Initial Permutation utils.ip(l, r, state.tmp, 0); l = state.tmp[0]; r = state.tmp[1]; if (this.type === 'encrypt') this._encrypt(state, l, r, state.tmp, 0); else this._decrypt(state, l, r, state.tmp, 0); l = state.tmp[0]; r = state.tmp[1]; utils.writeUInt32BE(out, l, outOff); utils.writeUInt32BE(out, r, outOff + 4); }; DES.prototype._pad = function _pad(buffer, off) { var value = buffer.length - off; for (var i = off; i < buffer.length; i++) buffer[i] = value; return true; }; DES.prototype._unpad = function _unpad(buffer) { var pad = buffer[buffer.length - 1]; for (var i = buffer.length - pad; i < buffer.length; i++) assert.equal(buffer[i], pad); return buffer.slice(0, buffer.length - pad); }; DES.prototype._encrypt = function _encrypt(state, lStart, rStart, out, off) { var l = lStart; var r = rStart; // Apply f() x16 times for (var i = 0; i < state.keys.length; i += 2) { var keyL = state.keys[i]; var keyR = state.keys[i + 1]; // f(r, k) utils.expand(r, state.tmp, 0); keyL ^= state.tmp[0]; keyR ^= state.tmp[1]; var s = utils.substitute(keyL, keyR); var f = utils.permute(s); var t = r; r = (l ^ f) >>> 0; l = t; } // Reverse Initial Permutation utils.rip(r, l, out, off); }; DES.prototype._decrypt = function _decrypt(state, lStart, rStart, out, off) { var l = rStart; var r = lStart; // Apply f() x16 times for (var i = state.keys.length - 2; i >= 0; i -= 2) { var keyL = state.keys[i]; var keyR = state.keys[i + 1]; // f(r, k) utils.expand(l, state.tmp, 0); keyL ^= state.tmp[0]; keyR ^= state.tmp[1]; var s = utils.substitute(keyL, keyR); var f = utils.permute(s); var t = l; l = (r ^ f) >>> 0; r = t; } // Reverse Initial Permutation utils.rip(l, r, out, off); }; },{"../des":113,"inherits":167,"minimalistic-assert":246}],117:[function(require,module,exports){ 'use strict'; var assert = require('minimalistic-assert'); var inherits = require('inherits'); var des = require('../des'); var Cipher = des.Cipher; var DES = des.DES; function EDEState(type, key) { assert.equal(key.length, 24, 'Invalid key length'); var k1 = key.slice(0, 8); var k2 = key.slice(8, 16); var k3 = key.slice(16, 24); if (type === 'encrypt') { this.ciphers = [ DES.create({ type: 'encrypt', key: k1 }), DES.create({ type: 'decrypt', key: k2 }), DES.create({ type: 'encrypt', key: k3 }) ]; } else { this.ciphers = [ DES.create({ type: 'decrypt', key: k3 }), DES.create({ type: 'encrypt', key: k2 }), DES.create({ type: 'decrypt', key: k1 }) ]; } } function EDE(options) { Cipher.call(this, options); var state = new EDEState(this.type, this.options.key); this._edeState = state; } inherits(EDE, Cipher); module.exports = EDE; EDE.create = function create(options) { return new EDE(options); }; EDE.prototype._update = function _update(inp, inOff, out, outOff) { var state = this._edeState; state.ciphers[0]._update(inp, inOff, out, outOff); state.ciphers[1]._update(out, outOff, out, outOff); state.ciphers[2]._update(out, outOff, out, outOff); }; EDE.prototype._pad = DES.prototype._pad; EDE.prototype._unpad = DES.prototype._unpad; },{"../des":113,"inherits":167,"minimalistic-assert":246}],118:[function(require,module,exports){ 'use strict'; exports.readUInt32BE = function readUInt32BE(bytes, off) { var res = (bytes[0 + off] << 24) | (bytes[1 + off] << 16) | (bytes[2 + off] << 8) | bytes[3 + off]; return res >>> 0; }; exports.writeUInt32BE = function writeUInt32BE(bytes, value, off) { bytes[0 + off] = value >>> 24; bytes[1 + off] = (value >>> 16) & 0xff; bytes[2 + off] = (value >>> 8) & 0xff; bytes[3 + off] = value & 0xff; }; exports.ip = function ip(inL, inR, out, off) { var outL = 0; var outR = 0; for (var i = 6; i >= 0; i -= 2) { for (var j = 0; j <= 24; j += 8) { outL <<= 1; outL |= (inR >>> (j + i)) & 1; } for (var j = 0; j <= 24; j += 8) { outL <<= 1; outL |= (inL >>> (j + i)) & 1; } } for (var i = 6; i >= 0; i -= 2) { for (var j = 1; j <= 25; j += 8) { outR <<= 1; outR |= (inR >>> (j + i)) & 1; } for (var j = 1; j <= 25; j += 8) { outR <<= 1; outR |= (inL >>> (j + i)) & 1; } } out[off + 0] = outL >>> 0; out[off + 1] = outR >>> 0; }; exports.rip = function rip(inL, inR, out, off) { var outL = 0; var outR = 0; for (var i = 0; i < 4; i++) { for (var j = 24; j >= 0; j -= 8) { outL <<= 1; outL |= (inR >>> (j + i)) & 1; outL <<= 1; outL |= (inL >>> (j + i)) & 1; } } for (var i = 4; i < 8; i++) { for (var j = 24; j >= 0; j -= 8) { outR <<= 1; outR |= (inR >>> (j + i)) & 1; outR <<= 1; outR |= (inL >>> (j + i)) & 1; } } out[off + 0] = outL >>> 0; out[off + 1] = outR >>> 0; }; exports.pc1 = function pc1(inL, inR, out, off) { var outL = 0; var outR = 0; // 7, 15, 23, 31, 39, 47, 55, 63 // 6, 14, 22, 30, 39, 47, 55, 63 // 5, 13, 21, 29, 39, 47, 55, 63 // 4, 12, 20, 28 for (var i = 7; i >= 5; i--) { for (var j = 0; j <= 24; j += 8) { outL <<= 1; outL |= (inR >> (j + i)) & 1; } for (var j = 0; j <= 24; j += 8) { outL <<= 1; outL |= (inL >> (j + i)) & 1; } } for (var j = 0; j <= 24; j += 8) { outL <<= 1; outL |= (inR >> (j + i)) & 1; } // 1, 9, 17, 25, 33, 41, 49, 57 // 2, 10, 18, 26, 34, 42, 50, 58 // 3, 11, 19, 27, 35, 43, 51, 59 // 36, 44, 52, 60 for (var i = 1; i <= 3; i++) { for (var j = 0; j <= 24; j += 8) { outR <<= 1; outR |= (inR >> (j + i)) & 1; } for (var j = 0; j <= 24; j += 8) { outR <<= 1; outR |= (inL >> (j + i)) & 1; } } for (var j = 0; j <= 24; j += 8) { outR <<= 1; outR |= (inL >> (j + i)) & 1; } out[off + 0] = outL >>> 0; out[off + 1] = outR >>> 0; }; exports.r28shl = function r28shl(num, shift) { return ((num << shift) & 0xfffffff) | (num >>> (28 - shift)); }; var pc2table = [ // inL => outL 14, 11, 17, 4, 27, 23, 25, 0, 13, 22, 7, 18, 5, 9, 16, 24, 2, 20, 12, 21, 1, 8, 15, 26, // inR => outR 15, 4, 25, 19, 9, 1, 26, 16, 5, 11, 23, 8, 12, 7, 17, 0, 22, 3, 10, 14, 6, 20, 27, 24 ]; exports.pc2 = function pc2(inL, inR, out, off) { var outL = 0; var outR = 0; var len = pc2table.length >>> 1; for (var i = 0; i < len; i++) { outL <<= 1; outL |= (inL >>> pc2table[i]) & 0x1; } for (var i = len; i < pc2table.length; i++) { outR <<= 1; outR |= (inR >>> pc2table[i]) & 0x1; } out[off + 0] = outL >>> 0; out[off + 1] = outR >>> 0; }; exports.expand = function expand(r, out, off) { var outL = 0; var outR = 0; outL = ((r & 1) << 5) | (r >>> 27); for (var i = 23; i >= 15; i -= 4) { outL <<= 6; outL |= (r >>> i) & 0x3f; } for (var i = 11; i >= 3; i -= 4) { outR |= (r >>> i) & 0x3f; outR <<= 6; } outR |= ((r & 0x1f) << 1) | (r >>> 31); out[off + 0] = outL >>> 0; out[off + 1] = outR >>> 0; }; var sTable = [ 14, 0, 4, 15, 13, 7, 1, 4, 2, 14, 15, 2, 11, 13, 8, 1, 3, 10, 10, 6, 6, 12, 12, 11, 5, 9, 9, 5, 0, 3, 7, 8, 4, 15, 1, 12, 14, 8, 8, 2, 13, 4, 6, 9, 2, 1, 11, 7, 15, 5, 12, 11, 9, 3, 7, 14, 3, 10, 10, 0, 5, 6, 0, 13, 15, 3, 1, 13, 8, 4, 14, 7, 6, 15, 11, 2, 3, 8, 4, 14, 9, 12, 7, 0, 2, 1, 13, 10, 12, 6, 0, 9, 5, 11, 10, 5, 0, 13, 14, 8, 7, 10, 11, 1, 10, 3, 4, 15, 13, 4, 1, 2, 5, 11, 8, 6, 12, 7, 6, 12, 9, 0, 3, 5, 2, 14, 15, 9, 10, 13, 0, 7, 9, 0, 14, 9, 6, 3, 3, 4, 15, 6, 5, 10, 1, 2, 13, 8, 12, 5, 7, 14, 11, 12, 4, 11, 2, 15, 8, 1, 13, 1, 6, 10, 4, 13, 9, 0, 8, 6, 15, 9, 3, 8, 0, 7, 11, 4, 1, 15, 2, 14, 12, 3, 5, 11, 10, 5, 14, 2, 7, 12, 7, 13, 13, 8, 14, 11, 3, 5, 0, 6, 6, 15, 9, 0, 10, 3, 1, 4, 2, 7, 8, 2, 5, 12, 11, 1, 12, 10, 4, 14, 15, 9, 10, 3, 6, 15, 9, 0, 0, 6, 12, 10, 11, 1, 7, 13, 13, 8, 15, 9, 1, 4, 3, 5, 14, 11, 5, 12, 2, 7, 8, 2, 4, 14, 2, 14, 12, 11, 4, 2, 1, 12, 7, 4, 10, 7, 11, 13, 6, 1, 8, 5, 5, 0, 3, 15, 15, 10, 13, 3, 0, 9, 14, 8, 9, 6, 4, 11, 2, 8, 1, 12, 11, 7, 10, 1, 13, 14, 7, 2, 8, 13, 15, 6, 9, 15, 12, 0, 5, 9, 6, 10, 3, 4, 0, 5, 14, 3, 12, 10, 1, 15, 10, 4, 15, 2, 9, 7, 2, 12, 6, 9, 8, 5, 0, 6, 13, 1, 3, 13, 4, 14, 14, 0, 7, 11, 5, 3, 11, 8, 9, 4, 14, 3, 15, 2, 5, 12, 2, 9, 8, 5, 12, 15, 3, 10, 7, 11, 0, 14, 4, 1, 10, 7, 1, 6, 13, 0, 11, 8, 6, 13, 4, 13, 11, 0, 2, 11, 14, 7, 15, 4, 0, 9, 8, 1, 13, 10, 3, 14, 12, 3, 9, 5, 7, 12, 5, 2, 10, 15, 6, 8, 1, 6, 1, 6, 4, 11, 11, 13, 13, 8, 12, 1, 3, 4, 7, 10, 14, 7, 10, 9, 15, 5, 6, 0, 8, 15, 0, 14, 5, 2, 9, 3, 2, 12, 13, 1, 2, 15, 8, 13, 4, 8, 6, 10, 15, 3, 11, 7, 1, 4, 10, 12, 9, 5, 3, 6, 14, 11, 5, 0, 0, 14, 12, 9, 7, 2, 7, 2, 11, 1, 4, 14, 1, 7, 9, 4, 12, 10, 14, 8, 2, 13, 0, 15, 6, 12, 10, 9, 13, 0, 15, 3, 3, 5, 5, 6, 8, 11 ]; exports.substitute = function substitute(inL, inR) { var out = 0; for (var i = 0; i < 4; i++) { var b = (inL >>> (18 - i * 6)) & 0x3f; var sb = sTable[i * 0x40 + b]; out <<= 4; out |= sb; } for (var i = 0; i < 4; i++) { var b = (inR >>> (18 - i * 6)) & 0x3f; var sb = sTable[4 * 0x40 + i * 0x40 + b]; out <<= 4; out |= sb; } return out >>> 0; }; var permuteTable = [ 16, 25, 12, 11, 3, 20, 4, 15, 31, 17, 9, 6, 27, 14, 1, 22, 30, 24, 8, 18, 0, 5, 29, 23, 13, 19, 2, 26, 10, 21, 28, 7 ]; exports.permute = function permute(num) { var out = 0; for (var i = 0; i < permuteTable.length; i++) { out <<= 1; out |= (num >>> permuteTable[i]) & 0x1; } return out >>> 0; }; exports.padSplit = function padSplit(num, size, group) { var str = num.toString(2); while (str.length < size) str = '0' + str; var out = []; for (var i = 0; i < size; i += group) out.push(str.slice(i, i + group)); return out.join(' '); }; },{}],119:[function(require,module,exports){ 'use strict'; /* * Dependencies. */ var repeat = require('repeat-string'); /* * Constants. */ var TAB = '\t'; var NEWLINE = '\n'; var SPACE = ' '; /** * Replace tabs with spaces, being smart about which * column the tab is at and which size should be used. * * @example * detab('\tfoo\nbar\tbaz'); // ' foo\nbar baz' * detab('\tfoo\nbar\tbaz', 2); // ' foo\nbar baz' * detab('\tfoo\nbar\tbaz', 8); // ' foo\nbar baz' * * @param {string} value - Value with tabs. * @param {number?} [size=4] - Tab-size. * @return {string} - Value without tabs. */ function detab(value, size) { var string = typeof value === 'string'; var length = string && value.length; var index = -1; var column = -1; var tabSize = size || 4; var result = ''; var character; var add; if (!string) { throw new Error('detab expected string'); } while (++index < length) { character = value.charAt(index); if (character === TAB) { add = tabSize - ((column + 1) % tabSize); result += repeat(SPACE, add); column += add; continue; } if (character === NEWLINE) { column = -1; } else { column++; } result += character; } return result; } /* * Expose. */ module.exports = detab; },{"repeat-string":422}],120:[function(require,module,exports){ (function (Buffer){ var generatePrime = require('./lib/generatePrime') var primes = require('./lib/primes.json') var DH = require('./lib/dh') function getDiffieHellman (mod) { var prime = new Buffer(primes[mod].prime, 'hex') var gen = new Buffer(primes[mod].gen, 'hex') return new DH(prime, gen) } var ENCODINGS = { 'binary': true, 'hex': true, 'base64': true } function createDiffieHellman (prime, enc, generator, genc) { if (Buffer.isBuffer(enc) || ENCODINGS[enc] === undefined) { return createDiffieHellman(prime, 'binary', enc, generator) } enc = enc || 'binary' genc = genc || 'binary' generator = generator || new Buffer([2]) if (!Buffer.isBuffer(generator)) { generator = new Buffer(generator, genc) } if (typeof prime === 'number') { return new DH(generatePrime(prime, generator), generator, true) } if (!Buffer.isBuffer(prime)) { prime = new Buffer(prime, enc) } return new DH(prime, generator, true) } exports.DiffieHellmanGroup = exports.createDiffieHellmanGroup = exports.getDiffieHellman = getDiffieHellman exports.createDiffieHellman = exports.DiffieHellman = createDiffieHellman }).call(this,require("buffer").Buffer) },{"./lib/dh":121,"./lib/generatePrime":122,"./lib/primes.json":123,"buffer":61}],121:[function(require,module,exports){ (function (Buffer){ var BN = require('bn.js'); var MillerRabin = require('miller-rabin'); var millerRabin = new MillerRabin(); var TWENTYFOUR = new BN(24); var ELEVEN = new BN(11); var TEN = new BN(10); var THREE = new BN(3); var SEVEN = new BN(7); var primes = require('./generatePrime'); var randomBytes = require('randombytes'); module.exports = DH; function setPublicKey(pub, enc) { enc = enc || 'utf8'; if (!Buffer.isBuffer(pub)) { pub = new Buffer(pub, enc); } this._pub = new BN(pub); return this; } function setPrivateKey(priv, enc) { enc = enc || 'utf8'; if (!Buffer.isBuffer(priv)) { priv = new Buffer(priv, enc); } this._priv = new BN(priv); return this; } var primeCache = {}; function checkPrime(prime, generator) { var gen = generator.toString('hex'); var hex = [gen, prime.toString(16)].join('_'); if (hex in primeCache) { return primeCache[hex]; } var error = 0; if (prime.isEven() || !primes.simpleSieve || !primes.fermatTest(prime) || !millerRabin.test(prime)) { //not a prime so +1 error += 1; if (gen === '02' || gen === '05') { // we'd be able to check the generator // it would fail so +8 error += 8; } else { //we wouldn't be able to test the generator // so +4 error += 4; } primeCache[hex] = error; return error; } if (!millerRabin.test(prime.shrn(1))) { //not a safe prime error += 2; } var rem; switch (gen) { case '02': if (prime.mod(TWENTYFOUR).cmp(ELEVEN)) { // unsuidable generator error += 8; } break; case '05': rem = prime.mod(TEN); if (rem.cmp(THREE) && rem.cmp(SEVEN)) { // prime mod 10 needs to equal 3 or 7 error += 8; } break; default: error += 4; } primeCache[hex] = error; return error; } function DH(prime, generator, malleable) { this.setGenerator(generator); this.__prime = new BN(prime); this._prime = BN.mont(this.__prime); this._primeLen = prime.length; this._pub = undefined; this._priv = undefined; this._primeCode = undefined; if (malleable) { this.setPublicKey = setPublicKey; this.setPrivateKey = setPrivateKey; } else { this._primeCode = 8; } } Object.defineProperty(DH.prototype, 'verifyError', { enumerable: true, get: function () { if (typeof this._primeCode !== 'number') { this._primeCode = checkPrime(this.__prime, this.__gen); } return this._primeCode; } }); DH.prototype.generateKeys = function () { if (!this._priv) { this._priv = new BN(randomBytes(this._primeLen)); } this._pub = this._gen.toRed(this._prime).redPow(this._priv).fromRed(); return this.getPublicKey(); }; DH.prototype.computeSecret = function (other) { other = new BN(other); other = other.toRed(this._prime); var secret = other.redPow(this._priv).fromRed(); var out = new Buffer(secret.toArray()); var prime = this.getPrime(); if (out.length < prime.length) { var front = new Buffer(prime.length - out.length); front.fill(0); out = Buffer.concat([front, out]); } return out; }; DH.prototype.getPublicKey = function getPublicKey(enc) { return formatReturnValue(this._pub, enc); }; DH.prototype.getPrivateKey = function getPrivateKey(enc) { return formatReturnValue(this._priv, enc); }; DH.prototype.getPrime = function (enc) { return formatReturnValue(this.__prime, enc); }; DH.prototype.getGenerator = function (enc) { return formatReturnValue(this._gen, enc); }; DH.prototype.setGenerator = function (gen, enc) { enc = enc || 'utf8'; if (!Buffer.isBuffer(gen)) { gen = new Buffer(gen, enc); } this.__gen = gen; this._gen = new BN(gen); return this; }; function formatReturnValue(bn, enc) { var buf = new Buffer(bn.toArray()); if (!enc) { return buf; } else { return buf.toString(enc); } } }).call(this,require("buffer").Buffer) },{"./generatePrime":122,"bn.js":29,"buffer":61,"miller-rabin":242,"randombytes":403}],122:[function(require,module,exports){ var randomBytes = require('randombytes'); module.exports = findPrime; findPrime.simpleSieve = simpleSieve; findPrime.fermatTest = fermatTest; var BN = require('bn.js'); var TWENTYFOUR = new BN(24); var MillerRabin = require('miller-rabin'); var millerRabin = new MillerRabin(); var ONE = new BN(1); var TWO = new BN(2); var FIVE = new BN(5); var SIXTEEN = new BN(16); var EIGHT = new BN(8); var TEN = new BN(10); var THREE = new BN(3); var SEVEN = new BN(7); var ELEVEN = new BN(11); var FOUR = new BN(4); var TWELVE = new BN(12); var primes = null; function _getPrimes() { if (primes !== null) return primes; var limit = 0x100000; var res = []; res[0] = 2; for (var i = 1, k = 3; k < limit; k += 2) { var sqrt = Math.ceil(Math.sqrt(k)); for (var j = 0; j < i && res[j] <= sqrt; j++) if (k % res[j] === 0) break; if (i !== j && res[j] <= sqrt) continue; res[i++] = k; } primes = res; return res; } function simpleSieve(p) { var primes = _getPrimes(); for (var i = 0; i < primes.length; i++) if (p.modn(primes[i]) === 0) { if (p.cmpn(primes[i]) === 0) { return true; } else { return false; } } return true; } function fermatTest(p) { var red = BN.mont(p); return TWO.toRed(red).redPow(p.subn(1)).fromRed().cmpn(1) === 0; } function findPrime(bits, gen) { if (bits < 16) { // this is what openssl does if (gen === 2 || gen === 5) { return new BN([0x8c, 0x7b]); } else { return new BN([0x8c, 0x27]); } } gen = new BN(gen); var num, n2; while (true) { num = new BN(randomBytes(Math.ceil(bits / 8))); while (num.bitLength() > bits) { num.ishrn(1); } if (num.isEven()) { num.iadd(ONE); } if (!num.testn(1)) { num.iadd(TWO); } if (!gen.cmp(TWO)) { while (num.mod(TWENTYFOUR).cmp(ELEVEN)) { num.iadd(FOUR); } } else if (!gen.cmp(FIVE)) { while (num.mod(TEN).cmp(THREE)) { num.iadd(FOUR); } } n2 = num.shrn(1); if (simpleSieve(n2) && simpleSieve(num) && fermatTest(n2) && fermatTest(num) && millerRabin.test(n2) && millerRabin.test(num)) { return num; } } } },{"bn.js":29,"miller-rabin":242,"randombytes":403}],123:[function(require,module,exports){ module.exports={ "modp1": { "gen": "02", "prime": "ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a63a3620ffffffffffffffff" }, "modp2": { "gen": "02", "prime": "ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece65381ffffffffffffffff" }, "modp5": { "gen": "02", "prime": "ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca237327ffffffffffffffff" }, "modp14": { "gen": "02", "prime": "ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aacaa68ffffffffffffffff" }, "modp15": { "gen": "02", "prime": "ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a93ad2caffffffffffffffff" }, "modp16": { "gen": "02", "prime": "ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a92108011a723c12a787e6d788719a10bdba5b2699c327186af4e23c1a946834b6150bda2583e9ca2ad44ce8dbbbc2db04de8ef92e8efc141fbecaa6287c59474e6bc05d99b2964fa090c3a2233ba186515be7ed1f612970cee2d7afb81bdd762170481cd0069127d5b05aa993b4ea988d8fddc186ffb7dc90a6c08f4df435c934063199ffffffffffffffff" }, "modp17": { "gen": "02", "prime": "ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a92108011a723c12a787e6d788719a10bdba5b2699c327186af4e23c1a946834b6150bda2583e9ca2ad44ce8dbbbc2db04de8ef92e8efc141fbecaa6287c59474e6bc05d99b2964fa090c3a2233ba186515be7ed1f612970cee2d7afb81bdd762170481cd0069127d5b05aa993b4ea988d8fddc186ffb7dc90a6c08f4df435c93402849236c3fab4d27c7026c1d4dcb2602646dec9751e763dba37bdf8ff9406ad9e530ee5db382f413001aeb06a53ed9027d831179727b0865a8918da3edbebcf9b14ed44ce6cbaced4bb1bdb7f1447e6cc254b332051512bd7af426fb8f401378cd2bf5983ca01c64b92ecf032ea15d1721d03f482d7ce6e74fef6d55e702f46980c82b5a84031900b1c9e59e7c97fbec7e8f323a97a7e36cc88be0f1d45b7ff585ac54bd407b22b4154aacc8f6d7ebf48e1d814cc5ed20f8037e0a79715eef29be32806a1d58bb7c5da76f550aa3d8a1fbff0eb19ccb1a313d55cda56c9ec2ef29632387fe8d76e3c0468043e8f663f4860ee12bf2d5b0b7474d6e694f91e6dcc4024ffffffffffffffff" }, "modp18": { "gen": "02", "prime": "ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a92108011a723c12a787e6d788719a10bdba5b2699c327186af4e23c1a946834b6150bda2583e9ca2ad44ce8dbbbc2db04de8ef92e8efc141fbecaa6287c59474e6bc05d99b2964fa090c3a2233ba186515be7ed1f612970cee2d7afb81bdd762170481cd0069127d5b05aa993b4ea988d8fddc186ffb7dc90a6c08f4df435c93402849236c3fab4d27c7026c1d4dcb2602646dec9751e763dba37bdf8ff9406ad9e530ee5db382f413001aeb06a53ed9027d831179727b0865a8918da3edbebcf9b14ed44ce6cbaced4bb1bdb7f1447e6cc254b332051512bd7af426fb8f401378cd2bf5983ca01c64b92ecf032ea15d1721d03f482d7ce6e74fef6d55e702f46980c82b5a84031900b1c9e59e7c97fbec7e8f323a97a7e36cc88be0f1d45b7ff585ac54bd407b22b4154aacc8f6d7ebf48e1d814cc5ed20f8037e0a79715eef29be32806a1d58bb7c5da76f550aa3d8a1fbff0eb19ccb1a313d55cda56c9ec2ef29632387fe8d76e3c0468043e8f663f4860ee12bf2d5b0b7474d6e694f91e6dbe115974a3926f12fee5e438777cb6a932df8cd8bec4d073b931ba3bc832b68d9dd300741fa7bf8afc47ed2576f6936ba424663aab639c5ae4f5683423b4742bf1c978238f16cbe39d652de3fdb8befc848ad922222e04a4037c0713eb57a81a23f0c73473fc646cea306b4bcbc8862f8385ddfa9d4b7fa2c087e879683303ed5bdd3a062b3cf5b3a278a66d2a13f83f44f82ddf310ee074ab6a364597e899a0255dc164f31cc50846851df9ab48195ded7ea1b1d510bd7ee74d73faf36bc31ecfa268359046f4eb879f924009438b481c6cd7889a002ed5ee382bc9190da6fc026e479558e4475677e9aa9e3050e2765694dfc81f56e880b96e7160c980dd98edd3dfffffffffffffffff" } } },{}],124:[function(require,module,exports){ // Simple wrapper around SJCL's ECC Implementation - v0.3.0 - https://github.com/jpillora/eccjs // Jaime Pillora - MIT/BSD(sljc) Copyright 2014 (function(window,undefined) {/** @fileOverview Javascript cryptography implementation. * * Crush to remove comments, shorten variable names and * generally reduce transmission size. * * @author Emily Stark * @author Mike Hamburg * @author Dan Boneh */ "use strict"; /*jslint indent: 2, bitwise: false, nomen: false, plusplus: false, white: false, regexp: false */ /*global document, window, escape, unescape, module, require, Uint32Array */ /** @namespace The Stanford Javascript Crypto Library, top-level namespace. */ var sjcl = { /** @namespace Symmetric ciphers. */ cipher: {}, /** @namespace Hash functions. Right now only SHA256 is implemented. */ hash: {}, /** @namespace Key exchange functions. Right now only SRP is implemented. */ keyexchange: {}, /** @namespace Block cipher modes of operation. */ mode: {}, /** @namespace Miscellaneous. HMAC and PBKDF2. */ misc: {}, /** * @namespace Bit array encoders and decoders. * * @description * The members of this namespace are functions which translate between * SJCL's bitArrays and other objects (usually strings). Because it * isn't always clear which direction is encoding and which is decoding, * the method names are "fromBits" and "toBits". */ codec: {}, /** @namespace Exceptions. */ exception: { /** @constructor Ciphertext is corrupt. */ corrupt: function(message) { this.toString = function() { return "CORRUPT: "+this.message; }; this.message = message; }, /** @constructor Invalid parameter. */ invalid: function(message) { this.toString = function() { return "INVALID: "+this.message; }; this.message = message; }, /** @constructor Bug or missing feature in SJCL. @constructor */ bug: function(message) { this.toString = function() { return "BUG: "+this.message; }; this.message = message; }, /** @constructor Something isn't ready. */ notReady: function(message) { this.toString = function() { return "NOT READY: "+this.message; }; this.message = message; } } }; /** @fileOverview Low-level AES implementation. * * This file contains a low-level implementation of AES, optimized for * size and for efficiency on several browsers. It is based on * OpenSSL's aes_core.c, a public-domain implementation by Vincent * Rijmen, Antoon Bosselaers and Paulo Barreto. * * An older version of this implementation is available in the public * domain, but this one is (c) Emily Stark, Mike Hamburg, Dan Boneh, * Stanford University 2008-2010 and BSD-licensed for liability * reasons. * * @author Emily Stark * @author Mike Hamburg * @author Dan Boneh */ /** * Schedule out an AES key for both encryption and decryption. This * is a low-level class. Use a cipher mode to do bulk encryption. * * @constructor * @param {Array} key The key as an array of 4, 6 or 8 words. * * @class Advanced Encryption Standard (low-level interface) */ sjcl.cipher.aes = function (key) { if (!this._tables[0][0][0]) { this._precompute(); } var i, j, tmp, encKey, decKey, sbox = this._tables[0][4], decTable = this._tables[1], keyLen = key.length, rcon = 1; if (keyLen !== 4 && keyLen !== 6 && keyLen !== 8) { throw new sjcl.exception.invalid("invalid aes key size"); } this._key = [encKey = key.slice(0), decKey = []]; // schedule encryption keys for (i = keyLen; i < 4 * keyLen + 28; i++) { tmp = encKey[i-1]; // apply sbox if (i%keyLen === 0 || (keyLen === 8 && i%keyLen === 4)) { tmp = sbox[tmp>>>24]<<24 ^ sbox[tmp>>16&255]<<16 ^ sbox[tmp>>8&255]<<8 ^ sbox[tmp&255]; // shift rows and add rcon if (i%keyLen === 0) { tmp = tmp<<8 ^ tmp>>>24 ^ rcon<<24; rcon = rcon<<1 ^ (rcon>>7)*283; } } encKey[i] = encKey[i-keyLen] ^ tmp; } // schedule decryption keys for (j = 0; i; j++, i--) { tmp = encKey[j&3 ? i : i - 4]; if (i<=4 || j<4) { decKey[j] = tmp; } else { decKey[j] = decTable[0][sbox[tmp>>>24 ]] ^ decTable[1][sbox[tmp>>16 & 255]] ^ decTable[2][sbox[tmp>>8 & 255]] ^ decTable[3][sbox[tmp & 255]]; } } }; sjcl.cipher.aes.prototype = { // public /* Something like this might appear here eventually name: "AES", blockSize: 4, keySizes: [4,6,8], */ /** * Encrypt an array of 4 big-endian words. * @param {Array} data The plaintext. * @return {Array} The ciphertext. */ encrypt:function (data) { return this._crypt(data,0); }, /** * Decrypt an array of 4 big-endian words. * @param {Array} data The ciphertext. * @return {Array} The plaintext. */ decrypt:function (data) { return this._crypt(data,1); }, /** * The expanded S-box and inverse S-box tables. These will be computed * on the client so that we don't have to send them down the wire. * * There are two tables, _tables[0] is for encryption and * _tables[1] is for decryption. * * The first 4 sub-tables are the expanded S-box with MixColumns. The * last (_tables[01][4]) is the S-box itself. * * @private */ _tables: [[[],[],[],[],[]],[[],[],[],[],[]]], /** * Expand the S-box tables. * * @private */ _precompute: function () { var encTable = this._tables[0], decTable = this._tables[1], sbox = encTable[4], sboxInv = decTable[4], i, x, xInv, d=[], th=[], x2, x4, x8, s, tEnc, tDec; // Compute double and third tables for (i = 0; i < 256; i++) { th[( d[i] = i<<1 ^ (i>>7)*283 )^i]=i; } for (x = xInv = 0; !sbox[x]; x ^= x2 || 1, xInv = th[xInv] || 1) { // Compute sbox s = xInv ^ xInv<<1 ^ xInv<<2 ^ xInv<<3 ^ xInv<<4; s = s>>8 ^ s&255 ^ 99; sbox[x] = s; sboxInv[s] = x; // Compute MixColumns x8 = d[x4 = d[x2 = d[x]]]; tDec = x8*0x1010101 ^ x4*0x10001 ^ x2*0x101 ^ x*0x1010100; tEnc = d[s]*0x101 ^ s*0x1010100; for (i = 0; i < 4; i++) { encTable[i][x] = tEnc = tEnc<<24 ^ tEnc>>>8; decTable[i][s] = tDec = tDec<<24 ^ tDec>>>8; } } // Compactify. Considerable speedup on Firefox. for (i = 0; i < 5; i++) { encTable[i] = encTable[i].slice(0); decTable[i] = decTable[i].slice(0); } }, /** * Encryption and decryption core. * @param {Array} input Four words to be encrypted or decrypted. * @param dir The direction, 0 for encrypt and 1 for decrypt. * @return {Array} The four encrypted or decrypted words. * @private */ _crypt:function (input, dir) { if (input.length !== 4) { throw new sjcl.exception.invalid("invalid aes block size"); } var key = this._key[dir], // state variables a,b,c,d are loaded with pre-whitened data a = input[0] ^ key[0], b = input[dir ? 3 : 1] ^ key[1], c = input[2] ^ key[2], d = input[dir ? 1 : 3] ^ key[3], a2, b2, c2, nInnerRounds = key.length/4 - 2, i, kIndex = 4, out = [0,0,0,0], table = this._tables[dir], // load up the tables t0 = table[0], t1 = table[1], t2 = table[2], t3 = table[3], sbox = table[4]; // Inner rounds. Cribbed from OpenSSL. for (i = 0; i < nInnerRounds; i++) { a2 = t0[a>>>24] ^ t1[b>>16 & 255] ^ t2[c>>8 & 255] ^ t3[d & 255] ^ key[kIndex]; b2 = t0[b>>>24] ^ t1[c>>16 & 255] ^ t2[d>>8 & 255] ^ t3[a & 255] ^ key[kIndex + 1]; c2 = t0[c>>>24] ^ t1[d>>16 & 255] ^ t2[a>>8 & 255] ^ t3[b & 255] ^ key[kIndex + 2]; d = t0[d>>>24] ^ t1[a>>16 & 255] ^ t2[b>>8 & 255] ^ t3[c & 255] ^ key[kIndex + 3]; kIndex += 4; a=a2; b=b2; c=c2; } // Last round. for (i = 0; i < 4; i++) { out[dir ? 3&-i : i] = sbox[a>>>24 ]<<24 ^ sbox[b>>16 & 255]<<16 ^ sbox[c>>8 & 255]<<8 ^ sbox[d & 255] ^ key[kIndex++]; a2=a; a=b; b=c; c=d; d=a2; } return out; } }; /** @fileOverview Arrays of bits, encoded as arrays of Numbers. * * @author Emily Stark * @author Mike Hamburg * @author Dan Boneh */ /** @namespace Arrays of bits, encoded as arrays of Numbers. * * @description *

* These objects are the currency accepted by SJCL's crypto functions. *

* *

* Most of our crypto primitives operate on arrays of 4-byte words internally, * but many of them can take arguments that are not a multiple of 4 bytes. * This library encodes arrays of bits (whose size need not be a multiple of 8 * bits) as arrays of 32-bit words. The bits are packed, big-endian, into an * array of words, 32 bits at a time. Since the words are double-precision * floating point numbers, they fit some extra data. We use this (in a private, * possibly-changing manner) to encode the number of bits actually present * in the last word of the array. *

* *

* Because bitwise ops clear this out-of-band data, these arrays can be passed * to ciphers like AES which want arrays of words. *

*/ sjcl.bitArray = { /** * Array slices in units of bits. * @param {bitArray} a The array to slice. * @param {Number} bstart The offset to the start of the slice, in bits. * @param {Number} bend The offset to the end of the slice, in bits. If this is undefined, * slice until the end of the array. * @return {bitArray} The requested slice. */ bitSlice: function (a, bstart, bend) { a = sjcl.bitArray._shiftRight(a.slice(bstart/32), 32 - (bstart & 31)).slice(1); return (bend === undefined) ? a : sjcl.bitArray.clamp(a, bend-bstart); }, /** * Extract a number packed into a bit array. * @param {bitArray} a The array to slice. * @param {Number} bstart The offset to the start of the slice, in bits. * @param {Number} length The length of the number to extract. * @return {Number} The requested slice. */ extract: function(a, bstart, blength) { // FIXME: this Math.floor is not necessary at all, but for some reason // seems to suppress a bug in the Chromium JIT. var x, sh = Math.floor((-bstart-blength) & 31); if ((bstart + blength - 1 ^ bstart) & -32) { // it crosses a boundary x = (a[bstart/32|0] << (32 - sh)) ^ (a[bstart/32+1|0] >>> sh); } else { // within a single word x = a[bstart/32|0] >>> sh; } return x & ((1< 0 && len) { a[l-1] = sjcl.bitArray.partial(len, a[l-1] & 0x80000000 >> (len-1), 1); } return a; }, /** * Make a partial word for a bit array. * @param {Number} len The number of bits in the word. * @param {Number} x The bits. * @param {Number} [0] _end Pass 1 if x has already been shifted to the high side. * @return {Number} The partial word. */ partial: function (len, x, _end) { if (len === 32) { return x; } return (_end ? x|0 : x << (32-len)) + len * 0x10000000000; }, /** * Get the number of bits used by a partial word. * @param {Number} x The partial word. * @return {Number} The number of bits used by the partial word. */ getPartial: function (x) { return Math.round(x/0x10000000000) || 32; }, /** * Compare two arrays for equality in a predictable amount of time. * @param {bitArray} a The first array. * @param {bitArray} b The second array. * @return {boolean} true if a == b; false otherwise. */ equal: function (a, b) { if (sjcl.bitArray.bitLength(a) !== sjcl.bitArray.bitLength(b)) { return false; } var x = 0, i; for (i=0; i= 32; shift -= 32) { out.push(carry); carry = 0; } if (shift === 0) { return out.concat(a); } for (i=0; i>>shift); carry = a[i] << (32-shift); } last2 = a.length ? a[a.length-1] : 0; shift2 = sjcl.bitArray.getPartial(last2); out.push(sjcl.bitArray.partial(shift+shift2 & 31, (shift + shift2 > 32) ? carry : out.pop(),1)); return out; }, /** xor a block of 4 words together. * @private */ _xor4: function(x,y) { return [x[0]^y[0],x[1]^y[1],x[2]^y[2],x[3]^y[3]]; } }; /** @fileOverview Bit array codec implementations. * * @author Emily Stark * @author Mike Hamburg * @author Dan Boneh */ /** @namespace UTF-8 strings */ sjcl.codec.utf8String = { /** Convert from a bitArray to a UTF-8 string. */ fromBits: function (arr) { var out = "", bl = sjcl.bitArray.bitLength(arr), i, tmp; for (i=0; i>> 24); tmp <<= 8; } return decodeURIComponent(escape(out)); }, /** Convert from a UTF-8 string to a bitArray. */ toBits: function (str) { str = unescape(encodeURIComponent(str)); var out = [], i, tmp=0; for (i=0; i>>bits) >>> 26); if (bits < 6) { ta = arr[i] << (6-bits); bits += 26; i++; } else { ta <<= 6; bits -= 6; } } while ((out.length & 3) && !_noEquals) { out += "="; } return out; }, /** Convert from a base64 string to a bitArray */ toBits: function(str, _url) { str = str.replace(/\s|=/g,''); var out = [], i, bits=0, c = sjcl.codec.base64._chars, ta=0, x; if (_url) { c = c.substr(0,62) + '-_'; } for (i=0; i 26) { bits -= 26; out.push(ta ^ x>>>bits); ta = x << (32-bits); } else { bits += 6; ta ^= x << (32-bits); } } if (bits&56) { out.push(sjcl.bitArray.partial(bits&56, ta, 1)); } return out; } }; sjcl.codec.base64url = { fromBits: function (arr) { return sjcl.codec.base64.fromBits(arr,1,1); }, toBits: function (str) { return sjcl.codec.base64.toBits(str,1); } }; /** @fileOverview Javascript SHA-256 implementation. * * An older version of this implementation is available in the public * domain, but this one is (c) Emily Stark, Mike Hamburg, Dan Boneh, * Stanford University 2008-2010 and BSD-licensed for liability * reasons. * * Special thanks to Aldo Cortesi for pointing out several bugs in * this code. * * @author Emily Stark * @author Mike Hamburg * @author Dan Boneh */ /** * Context for a SHA-256 operation in progress. * @constructor * @class Secure Hash Algorithm, 256 bits. */ sjcl.hash.sha256 = function (hash) { if (!this._key[0]) { this._precompute(); } if (hash) { this._h = hash._h.slice(0); this._buffer = hash._buffer.slice(0); this._length = hash._length; } else { this.reset(); } }; /** * Hash a string or an array of words. * @static * @param {bitArray|String} data the data to hash. * @return {bitArray} The hash value, an array of 16 big-endian words. */ sjcl.hash.sha256.hash = function (data) { return (new sjcl.hash.sha256()).update(data).finalize(); }; sjcl.hash.sha256.prototype = { /** * The hash's block size, in bits. * @constant */ blockSize: 512, /** * Reset the hash state. * @return this */ reset:function () { this._h = this._init.slice(0); this._buffer = []; this._length = 0; return this; }, /** * Input several words to the hash. * @param {bitArray|String} data the data to hash. * @return this */ update: function (data) { if (typeof data === "string") { data = sjcl.codec.utf8String.toBits(data); } var i, b = this._buffer = sjcl.bitArray.concat(this._buffer, data), ol = this._length, nl = this._length = ol + sjcl.bitArray.bitLength(data); for (i = 512+ol & -512; i <= nl; i+= 512) { this._block(b.splice(0,16)); } return this; }, /** * Complete hashing and output the hash value. * @return {bitArray} The hash value, an array of 8 big-endian words. */ finalize:function () { var i, b = this._buffer, h = this._h; // Round out and push the buffer b = sjcl.bitArray.concat(b, [sjcl.bitArray.partial(1,1)]); // Round out the buffer to a multiple of 16 words, less the 2 length words. for (i = b.length + 2; i & 15; i++) { b.push(0); } // append the length b.push(Math.floor(this._length / 0x100000000)); b.push(this._length | 0); while (b.length) { this._block(b.splice(0,16)); } this.reset(); return h; }, /** * The SHA-256 initialization vector, to be precomputed. * @private */ _init:[], /* _init:[0x6a09e667,0xbb67ae85,0x3c6ef372,0xa54ff53a,0x510e527f,0x9b05688c,0x1f83d9ab,0x5be0cd19], */ /** * The SHA-256 hash key, to be precomputed. * @private */ _key:[], /* _key: [0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5, 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5, 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3, 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174, 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc, 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da, 0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7, 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967, 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13, 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85, 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3, 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070, 0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5, 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3, 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208, 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2], */ /** * Function to precompute _init and _key. * @private */ _precompute: function () { var i = 0, prime = 2, factor; function frac(x) { return (x-Math.floor(x)) * 0x100000000 | 0; } outer: for (; i<64; prime++) { for (factor=2; factor*factor <= prime; factor++) { if (prime % factor === 0) { // not a prime continue outer; } } if (i<8) { this._init[i] = frac(Math.pow(prime, 1/2)); } this._key[i] = frac(Math.pow(prime, 1/3)); i++; } }, /** * Perform one cycle of SHA-256. * @param {bitArray} words one block of words. * @private */ _block:function (words) { var i, tmp, a, b, w = words.slice(0), h = this._h, k = this._key, h0 = h[0], h1 = h[1], h2 = h[2], h3 = h[3], h4 = h[4], h5 = h[5], h6 = h[6], h7 = h[7]; /* Rationale for placement of |0 : * If a value can overflow is original 32 bits by a factor of more than a few * million (2^23 ish), there is a possibility that it might overflow the * 53-bit mantissa and lose precision. * * To avoid this, we clamp back to 32 bits by |'ing with 0 on any value that * propagates around the loop, and on the hash state h[]. I don't believe * that the clamps on h4 and on h0 are strictly necessary, but it's close * (for h4 anyway), and better safe than sorry. * * The clamps on h[] are necessary for the output to be correct even in the * common case and for short inputs. */ for (i=0; i<64; i++) { // load up the input word for this round if (i<16) { tmp = w[i]; } else { a = w[(i+1 ) & 15]; b = w[(i+14) & 15]; tmp = w[i&15] = ((a>>>7 ^ a>>>18 ^ a>>>3 ^ a<<25 ^ a<<14) + (b>>>17 ^ b>>>19 ^ b>>>10 ^ b<<15 ^ b<<13) + w[i&15] + w[(i+9) & 15]) | 0; } tmp = (tmp + h7 + (h4>>>6 ^ h4>>>11 ^ h4>>>25 ^ h4<<26 ^ h4<<21 ^ h4<<7) + (h6 ^ h4&(h5^h6)) + k[i]); // | 0; // shift register h7 = h6; h6 = h5; h5 = h4; h4 = h3 + tmp | 0; h3 = h2; h2 = h1; h1 = h0; h0 = (tmp + ((h1&h2) ^ (h3&(h1^h2))) + (h1>>>2 ^ h1>>>13 ^ h1>>>22 ^ h1<<30 ^ h1<<19 ^ h1<<10)) | 0; } h[0] = h[0]+h0 | 0; h[1] = h[1]+h1 | 0; h[2] = h[2]+h2 | 0; h[3] = h[3]+h3 | 0; h[4] = h[4]+h4 | 0; h[5] = h[5]+h5 | 0; h[6] = h[6]+h6 | 0; h[7] = h[7]+h7 | 0; } }; /** @fileOverview CCM mode implementation. * * Special thanks to Roy Nicholson for pointing out a bug in our * implementation. * * @author Emily Stark * @author Mike Hamburg * @author Dan Boneh */ /** @namespace CTR mode with CBC MAC. */ sjcl.mode.ccm = { /** The name of the mode. * @constant */ name: "ccm", /** Encrypt in CCM mode. * @static * @param {Object} prf The pseudorandom function. It must have a block size of 16 bytes. * @param {bitArray} plaintext The plaintext data. * @param {bitArray} iv The initialization value. * @param {bitArray} [adata=[]] The authenticated data. * @param {Number} [tlen=64] the desired tag length, in bits. * @return {bitArray} The encrypted data, an array of bytes. */ encrypt: function(prf, plaintext, iv, adata, tlen) { var L, i, out = plaintext.slice(0), tag, w=sjcl.bitArray, ivl = w.bitLength(iv) / 8, ol = w.bitLength(out) / 8; tlen = tlen || 64; adata = adata || []; if (ivl < 7) { throw new sjcl.exception.invalid("ccm: iv must be at least 7 bytes"); } // compute the length of the length for (L=2; L<4 && ol >>> 8*L; L++) {} if (L < 15 - ivl) { L = 15-ivl; } iv = w.clamp(iv,8*(15-L)); // compute the tag tag = sjcl.mode.ccm._computeTag(prf, plaintext, iv, adata, tlen, L); // encrypt out = sjcl.mode.ccm._ctrMode(prf, out, iv, tag, tlen, L); return w.concat(out.data, out.tag); }, /** Decrypt in CCM mode. * @static * @param {Object} prf The pseudorandom function. It must have a block size of 16 bytes. * @param {bitArray} ciphertext The ciphertext data. * @param {bitArray} iv The initialization value. * @param {bitArray} [[]] adata The authenticated data. * @param {Number} [64] tlen the desired tag length, in bits. * @return {bitArray} The decrypted data. */ decrypt: function(prf, ciphertext, iv, adata, tlen) { tlen = tlen || 64; adata = adata || []; var L, i, w=sjcl.bitArray, ivl = w.bitLength(iv) / 8, ol = w.bitLength(ciphertext), out = w.clamp(ciphertext, ol - tlen), tag = w.bitSlice(ciphertext, ol - tlen), tag2; ol = (ol - tlen) / 8; if (ivl < 7) { throw new sjcl.exception.invalid("ccm: iv must be at least 7 bytes"); } // compute the length of the length for (L=2; L<4 && ol >>> 8*L; L++) {} if (L < 15 - ivl) { L = 15-ivl; } iv = w.clamp(iv,8*(15-L)); // decrypt out = sjcl.mode.ccm._ctrMode(prf, out, iv, tag, tlen, L); // check the tag tag2 = sjcl.mode.ccm._computeTag(prf, out.data, iv, adata, tlen, L); if (!w.equal(out.tag, tag2)) { throw new sjcl.exception.corrupt("ccm: tag doesn't match"); } return out.data; }, /* Compute the (unencrypted) authentication tag, according to the CCM specification * @param {Object} prf The pseudorandom function. * @param {bitArray} plaintext The plaintext data. * @param {bitArray} iv The initialization value. * @param {bitArray} adata The authenticated data. * @param {Number} tlen the desired tag length, in bits. * @return {bitArray} The tag, but not yet encrypted. * @private */ _computeTag: function(prf, plaintext, iv, adata, tlen, L) { // compute B[0] var q, mac, field = 0, offset = 24, tmp, i, macData = [], w=sjcl.bitArray, xor = w._xor4; tlen /= 8; // check tag length and message length if (tlen % 2 || tlen < 4 || tlen > 16) { throw new sjcl.exception.invalid("ccm: invalid tag length"); } if (adata.length > 0xFFFFFFFF || plaintext.length > 0xFFFFFFFF) { // I don't want to deal with extracting high words from doubles. throw new sjcl.exception.bug("ccm: can't deal with 4GiB or more data"); } // mac the flags mac = [w.partial(8, (adata.length ? 1<<6 : 0) | (tlen-2) << 2 | L-1)]; // mac the iv and length mac = w.concat(mac, iv); mac[3] |= w.bitLength(plaintext)/8; mac = prf.encrypt(mac); if (adata.length) { // mac the associated data. start with its length... tmp = w.bitLength(adata)/8; if (tmp <= 0xFEFF) { macData = [w.partial(16, tmp)]; } else if (tmp <= 0xFFFFFFFF) { macData = w.concat([w.partial(16,0xFFFE)], [tmp]); } // else ... // mac the data itself macData = w.concat(macData, adata); for (i=0; i>>31, x[1]<<1 ^ x[2]>>>31, x[2]<<1 ^ x[3]>>>31, x[3]<<1 ^ (x[0]>>>31)*0x87]; } }; /** @fileOverview GCM mode implementation. * * @author Juho Vähä-Herttua */ /** @namespace Galois/Counter mode. */ sjcl.mode.gcm = { /** The name of the mode. * @constant */ name: "gcm", /** Encrypt in GCM mode. * @static * @param {Object} prf The pseudorandom function. It must have a block size of 16 bytes. * @param {bitArray} plaintext The plaintext data. * @param {bitArray} iv The initialization value. * @param {bitArray} [adata=[]] The authenticated data. * @param {Number} [tlen=128] The desired tag length, in bits. * @return {bitArray} The encrypted data, an array of bytes. */ encrypt: function (prf, plaintext, iv, adata, tlen) { var out, data = plaintext.slice(0), w=sjcl.bitArray; tlen = tlen || 128; adata = adata || []; // encrypt and tag out = sjcl.mode.gcm._ctrMode(true, prf, data, adata, iv, tlen); return w.concat(out.data, out.tag); }, /** Decrypt in GCM mode. * @static * @param {Object} prf The pseudorandom function. It must have a block size of 16 bytes. * @param {bitArray} ciphertext The ciphertext data. * @param {bitArray} iv The initialization value. * @param {bitArray} [adata=[]] The authenticated data. * @param {Number} [tlen=128] The desired tag length, in bits. * @return {bitArray} The decrypted data. */ decrypt: function (prf, ciphertext, iv, adata, tlen) { var out, data = ciphertext.slice(0), tag, w=sjcl.bitArray, l=w.bitLength(data); tlen = tlen || 128; adata = adata || []; // Slice tag out of data if (tlen <= l) { tag = w.bitSlice(data, l-tlen); data = w.bitSlice(data, 0, l-tlen); } else { tag = data; data = []; } // decrypt and tag out = sjcl.mode.gcm._ctrMode(false, prf, data, adata, iv, tlen); if (!w.equal(out.tag, tag)) { throw new sjcl.exception.corrupt("gcm: tag doesn't match"); } return out.data; }, /* Compute the galois multiplication of X and Y * @private */ _galoisMultiply: function (x, y) { var i, j, xi, Zi, Vi, lsb_Vi, w=sjcl.bitArray, xor=w._xor4; Zi = [0,0,0,0]; Vi = y.slice(0); // Block size is 128 bits, run 128 times to get Z_128 for (i=0; i<128; i++) { xi = (x[Math.floor(i/32)] & (1 << (31-i%32))) !== 0; if (xi) { // Z_i+1 = Z_i ^ V_i Zi = xor(Zi, Vi); } // Store the value of LSB(V_i) lsb_Vi = (Vi[3] & 1) !== 0; // V_i+1 = V_i >> 1 for (j=3; j>0; j--) { Vi[j] = (Vi[j] >>> 1) | ((Vi[j-1]&1) << 31); } Vi[0] = Vi[0] >>> 1; // If LSB(V_i) is 1, V_i+1 = (V_i >> 1) ^ R if (lsb_Vi) { Vi[0] = Vi[0] ^ (0xe1 << 24); } } return Zi; }, _ghash: function(H, Y0, data) { var Yi, i, l = data.length; Yi = Y0.slice(0); for (i=0; i bs) { key = Hash.hash(key); } for (i=0; iUse sjcl.random as a singleton for this class!
*

* This random number generator is a derivative of Ferguson and Schneier's * generator Fortuna. It collects entropy from various events into several * pools, implemented by streaming SHA-256 instances. It differs from * ordinary Fortuna in a few ways, though. *

* *

* Most importantly, it has an entropy estimator. This is present because * there is a strong conflict here between making the generator available * as soon as possible, and making sure that it doesn't "run on empty". * In Fortuna, there is a saved state file, and the system is likely to have * time to warm up. *

* *

* Second, because users are unlikely to stay on the page for very long, * and to speed startup time, the number of pools increases logarithmically: * a new pool is created when the previous one is actually used for a reseed. * This gives the same asymptotic guarantees as Fortuna, but gives more * entropy to early reseeds. *

* *

* The entire mechanism here feels pretty klunky. Furthermore, there are * several improvements that should be made, including support for * dedicated cryptographic functions that may be present in some browsers; * state files in local storage; cookies containing randomness; etc. So * look for improvements in future versions. *

*/ sjcl.prng = function(defaultParanoia) { /* private */ this._pools = [new sjcl.hash.sha256()]; this._poolEntropy = [0]; this._reseedCount = 0; this._robins = {}; this._eventId = 0; this._collectorIds = {}; this._collectorIdNext = 0; this._strength = 0; this._poolStrength = 0; this._nextReseed = 0; this._key = [0,0,0,0,0,0,0,0]; this._counter = [0,0,0,0]; this._cipher = undefined; this._defaultParanoia = defaultParanoia; /* event listener stuff */ this._collectorsStarted = false; this._callbacks = {progress: {}, seeded: {}}; this._callbackI = 0; /* constants */ this._NOT_READY = 0; this._READY = 1; this._REQUIRES_RESEED = 2; this._MAX_WORDS_PER_BURST = 65536; this._PARANOIA_LEVELS = [0,48,64,96,128,192,256,384,512,768,1024]; this._MILLISECONDS_PER_RESEED = 30000; this._BITS_PER_RESEED = 80; }; sjcl.prng.prototype = { /** Generate several random words, and return them in an array. * A word consists of 32 bits (4 bytes) * @param {Number} nwords The number of words to generate. */ randomWords: function (nwords, paranoia) { var out = [], i, readiness = this.isReady(paranoia), g; if (readiness === this._NOT_READY) { throw new sjcl.exception.notReady("generator isn't seeded"); } else if (readiness & this._REQUIRES_RESEED) { this._reseedFromPools(!(readiness & this._READY)); } for (i=0; i0) { estimatedEntropy++; tmp = tmp >>> 1; } } } this._pools[robin].update([id,this._eventId++,2,estimatedEntropy,t,data.length].concat(data)); } break; case "string": if (estimatedEntropy === undefined) { /* English text has just over 1 bit per character of entropy. * But this might be HTML or something, and have far less * entropy than English... Oh well, let's just say one bit. */ estimatedEntropy = data.length; } this._pools[robin].update([id,this._eventId++,3,estimatedEntropy,t,data.length]); this._pools[robin].update(data); break; default: err=1; } if (err) { throw new sjcl.exception.bug("random: addEntropy only supports number, array of numbers or string"); } /* record the new strength */ this._poolEntropy[robin] += estimatedEntropy; this._poolStrength += estimatedEntropy; /* fire off events */ if (oldReady === this._NOT_READY) { if (this.isReady() !== this._NOT_READY) { this._fireEvent("seeded", Math.max(this._strength, this._poolStrength)); } this._fireEvent("progress", this.getProgress()); } }, /** Is the generator ready? */ isReady: function (paranoia) { var entropyRequired = this._PARANOIA_LEVELS[ (paranoia !== undefined) ? paranoia : this._defaultParanoia ]; if (this._strength && this._strength >= entropyRequired) { return (this._poolEntropy[0] > this._BITS_PER_RESEED && (new Date()).valueOf() > this._nextReseed) ? this._REQUIRES_RESEED | this._READY : this._READY; } else { return (this._poolStrength >= entropyRequired) ? this._REQUIRES_RESEED | this._NOT_READY : this._NOT_READY; } }, /** Get the generator's progress toward readiness, as a fraction */ getProgress: function (paranoia) { var entropyRequired = this._PARANOIA_LEVELS[ paranoia ? paranoia : this._defaultParanoia ]; if (this._strength >= entropyRequired) { return 1.0; } else { return (this._poolStrength > entropyRequired) ? 1.0 : this._poolStrength / entropyRequired; } }, /** start the built-in entropy collectors */ startCollectors: function () { if (this._collectorsStarted) { return; } this._eventListener = { loadTimeCollector: this._bind(this._loadTimeCollector), mouseCollector: this._bind(this._mouseCollector), keyboardCollector: this._bind(this._keyboardCollector), accelerometerCollector: this._bind(this._accelerometerCollector) } if (window.addEventListener) { window.addEventListener("load", this._eventListener.loadTimeCollector, false); window.addEventListener("mousemove", this._eventListener.mouseCollector, false); window.addEventListener("keypress", this._eventListener.keyboardCollector, false); window.addEventListener("devicemotion", this._eventListener.accelerometerCollector, false); } else if (document.attachEvent) { document.attachEvent("onload", this._eventListener.loadTimeCollector); document.attachEvent("onmousemove", this._eventListener.mouseCollector); document.attachEvent("keypress", this._eventListener.keyboardCollector); } else { throw new sjcl.exception.bug("can't attach event"); } this._collectorsStarted = true; }, /** stop the built-in entropy collectors */ stopCollectors: function () { if (!this._collectorsStarted) { return; } if (window.removeEventListener) { window.removeEventListener("load", this._eventListener.loadTimeCollector, false); window.removeEventListener("mousemove", this._eventListener.mouseCollector, false); window.removeEventListener("keypress", this._eventListener.keyboardCollector, false); window.removeEventListener("devicemotion", this._eventListener.accelerometerCollector, false); } else if (document.detachEvent) { document.detachEvent("onload", this._eventListener.loadTimeCollector); document.detachEvent("onmousemove", this._eventListener.mouseCollector); document.detachEvent("keypress", this._eventListener.keyboardCollector); } this._collectorsStarted = false; }, /* use a cookie to store entropy. useCookie: function (all_cookies) { throw new sjcl.exception.bug("random: useCookie is unimplemented"); },*/ /** add an event listener for progress or seeded-ness. */ addEventListener: function (name, callback) { this._callbacks[name][this._callbackI++] = callback; }, /** remove an event listener for progress or seeded-ness */ removeEventListener: function (name, cb) { var i, j, cbs=this._callbacks[name], jsTemp=[]; /* I'm not sure if this is necessary; in C++, iterating over a * collection and modifying it at the same time is a no-no. */ for (j in cbs) { if (cbs.hasOwnProperty(j) && cbs[j] === cb) { jsTemp.push(j); } } for (i=0; i= 1 << this._pools.length) { this._pools.push(new sjcl.hash.sha256()); this._poolEntropy.push(0); } /* how strong was this reseed? */ this._poolStrength -= strength; if (strength > this._strength) { this._strength = strength; } this._reseedCount ++; this._reseed(reseedData); }, _keyboardCollector: function () { this._addCurrentTimeToEntropy(1); }, _mouseCollector: function (ev) { var x = ev.x || ev.clientX || ev.offsetX || 0, y = ev.y || ev.clientY || ev.offsetY || 0; sjcl.random.addEntropy([x,y], 2, "mouse"); this._addCurrentTimeToEntropy(0); }, _loadTimeCollector: function () { this._addCurrentTimeToEntropy(2); }, _addCurrentTimeToEntropy: function (estimatedEntropy) { if (window && window.performance && typeof window.performance.now === "function") { //how much entropy do we want to add here? sjcl.random.addEntropy(window.performance.now(), estimatedEntropy, "loadtime"); } else { sjcl.random.addEntropy((new Date()).valueOf(), estimatedEntropy, "loadtime"); } }, _accelerometerCollector: function (ev) { var ac = ev.accelerationIncludingGravity.x||ev.accelerationIncludingGravity.y||ev.accelerationIncludingGravity.z; var or = ""; if(window.orientation){ or = window.orientation; } sjcl.random.addEntropy([ac,or], 3, "accelerometer"); this._addCurrentTimeToEntropy(0); }, _fireEvent: function (name, arg) { var j, cbs=sjcl.random._callbacks[name], cbsTemp=[]; /* TODO: there is a race condition between removing collectors and firing them */ /* I'm not sure if this is necessary; in C++, iterating over a * collection and modifying it at the same time is a no-no. */ for (j in cbs) { if (cbs.hasOwnProperty(j)) { cbsTemp.push(cbs[j]); } } for (j=0; j 4)) { throw new sjcl.exception.invalid("json encrypt: invalid parameters"); } if (typeof password === "string") { tmp = sjcl.misc.cachedPbkdf2(password, p); password = tmp.key.slice(0,p.ks/32); p.salt = tmp.salt; } else if (sjcl.ecc && password instanceof sjcl.ecc.elGamal.publicKey) { tmp = password.kem(); p.kemtag = tmp.tag; password = tmp.key.slice(0,p.ks/32); } if (typeof plaintext === "string") { plaintext = sjcl.codec.utf8String.toBits(plaintext); } if (typeof adata === "string") { adata = sjcl.codec.utf8String.toBits(adata); } prp = new sjcl.cipher[p.cipher](password); /* return the json data */ j._add(rp, p); rp.key = password; /* do the encryption */ p.ct = sjcl.mode[p.mode].encrypt(prp, plaintext, p.iv, adata, p.ts); //return j.encode(j._subtract(p, j.defaults)); return p; }, /** Simple encryption function. * @param {String|bitArray} password The password or key. * @param {String} plaintext The data to encrypt. * @param {Object} [params] The parameters including tag, iv and salt. * @param {Object} [rp] A returned version with filled-in parameters. * @return {String} The ciphertext serialized data. * @throws {sjcl.exception.invalid} if a parameter is invalid. */ encrypt: function (password, plaintext, params, rp) { var j = sjcl.json, p = j._encrypt.apply(j, arguments); return j.encode(p); }, /** Simple decryption function. * @param {String|bitArray} password The password or key. * @param {Object} ciphertext The cipher raw data to decrypt. * @param {Object} [params] Additional non-default parameters. * @param {Object} [rp] A returned object with filled parameters. * @return {String} The plaintext. * @throws {sjcl.exception.invalid} if a parameter is invalid. * @throws {sjcl.exception.corrupt} if the ciphertext is corrupt. */ _decrypt: function (password, ciphertext, params, rp) { params = params || {}; rp = rp || {}; var j = sjcl.json, p = j._add(j._add(j._add({},j.defaults),ciphertext), params, true), ct, tmp, prp, adata=p.adata; if (typeof p.salt === "string") { p.salt = sjcl.codec.base64.toBits(p.salt); } if (typeof p.iv === "string") { p.iv = sjcl.codec.base64.toBits(p.iv); } if (!sjcl.mode[p.mode] || !sjcl.cipher[p.cipher] || (typeof password === "string" && p.iter <= 100) || (p.ts !== 64 && p.ts !== 96 && p.ts !== 128) || (p.ks !== 128 && p.ks !== 192 && p.ks !== 256) || (!p.iv) || (p.iv.length < 2 || p.iv.length > 4)) { throw new sjcl.exception.invalid("json decrypt: invalid parameters"); } if (typeof password === "string") { tmp = sjcl.misc.cachedPbkdf2(password, p); password = tmp.key.slice(0,p.ks/32); p.salt = tmp.salt; } else if (sjcl.ecc && password instanceof sjcl.ecc.elGamal.secretKey) { password = password.unkem(sjcl.codec.base64.toBits(p.kemtag)).slice(0,p.ks/32); } if (typeof adata === "string") { adata = sjcl.codec.utf8String.toBits(adata); } prp = new sjcl.cipher[p.cipher](password); /* do the decryption */ ct = sjcl.mode[p.mode].decrypt(prp, p.ct, p.iv, adata, p.ts); /* return the json data */ j._add(rp, p); rp.key = password; return sjcl.codec.utf8String.fromBits(ct); }, /** Simple decryption function. * @param {String|bitArray} password The password or key. * @param {String} ciphertext The ciphertext to decrypt. * @param {Object} [params] Additional non-default parameters. * @param {Object} [rp] A returned object with filled parameters. * @return {String} The plaintext. * @throws {sjcl.exception.invalid} if a parameter is invalid. * @throws {sjcl.exception.corrupt} if the ciphertext is corrupt. */ decrypt: function (password, ciphertext, params, rp) { var j = sjcl.json; return j._decrypt(password, j.decode(ciphertext), params, rp); }, /** Encode a flat structure into a JSON string. * @param {Object} obj The structure to encode. * @return {String} A JSON string. * @throws {sjcl.exception.invalid} if obj has a non-alphanumeric property. * @throws {sjcl.exception.bug} if a parameter has an unsupported type. */ encode: function (obj) { var i, out='{', comma=''; for (i in obj) { if (obj.hasOwnProperty(i)) { if (!i.match(/^[a-z0-9]+$/i)) { throw new sjcl.exception.invalid("json encode: invalid property name"); } out += comma + '"' + i + '":'; comma = ','; switch (typeof obj[i]) { case 'number': case 'boolean': out += obj[i]; break; case 'string': out += '"' + escape(obj[i]) + '"'; break; case 'object': out += '"' + sjcl.codec.base64.fromBits(obj[i],0) + '"'; break; default: throw new sjcl.exception.bug("json encode: unsupported type"); } } } return out+'}'; }, /** Decode a simple (flat) JSON string into a structure. The ciphertext, * adata, salt and iv will be base64-decoded. * @param {String} str The string. * @return {Object} The decoded structure. * @throws {sjcl.exception.invalid} if str isn't (simple) JSON. */ decode: function (str) { str = str.replace(/\s/g,''); if (!str.match(/^\{.*\}$/)) { throw new sjcl.exception.invalid("json decode: this isn't json!"); } var a = str.replace(/^\{|\}$/g, '').split(/,/), out={}, i, m; for (i=0; i= this.limbs.length) ? 0 : this.limbs[i]; }, /** * Constant time comparison function. * Returns 1 if this >= that, or zero otherwise. */ greaterEquals: function(that) { if (typeof that === "number") { that = new this._class(that); } var less = 0, greater = 0, i, a, b; i = Math.max(this.limbs.length, that.limbs.length) - 1; for (; i>= 0; i--) { a = this.getLimb(i); b = that.getLimb(i); greater |= (b - a) & ~less; less |= (a - b) & ~greater; } return (greater | ~less) >>> 31; }, /** * Convert to a hex string. */ toString: function() { this.fullReduce(); var out="", i, s, l = this.limbs; for (i=0; i < this.limbs.length; i++) { s = l[i].toString(16); while (i < this.limbs.length - 1 && s.length < 6) { s = "0" + s; } out = s + out; } return "0x"+out; }, /** this += that. Does not normalize. */ addM: function(that) { if (typeof(that) !== "object") { that = new this._class(that); } var i, l=this.limbs, ll=that.limbs; for (i=l.length; i> r; } if (carry) { l.push(carry); } return this; }, /** this /= 2, rounded down. Requires normalized; ends up normalized. */ halveM: function() { var i, carry=0, tmp, r=this.radix, l=this.limbs; for (i=l.length-1; i>=0; i--) { tmp = l[i]; l[i] = (tmp+carry)>>1; carry = (tmp&1) << r; } if (!l[l.length-1]) { l.pop(); } return this; }, /** this -= that. Does not normalize. */ subM: function(that) { if (typeof(that) !== "object") { that = new this._class(that); } var i, l=this.limbs, ll=that.limbs; for (i=l.length; i 0; ci--) { that.halveM(); if (out.greaterEquals(that)) { out.subM(that).normalize(); } } return out.trim(); }, /** return inverse mod prime p. p must be odd. Binary extended Euclidean algorithm mod p. */ inverseMod: function(p) { var a = new sjcl.bn(1), b = new sjcl.bn(0), x = new sjcl.bn(this), y = new sjcl.bn(p), tmp, i, nz=1; if (!(p.limbs[0] & 1)) { throw (new sjcl.exception.invalid("inverseMod: p must be odd")); } // invariant: y is odd do { if (x.limbs[0] & 1) { if (!x.greaterEquals(y)) { // x < y; swap everything tmp = x; x = y; y = tmp; tmp = a; a = b; b = tmp; } x.subM(y); x.normalize(); if (!a.greaterEquals(b)) { a.addM(p); } a.subM(b); } // cut everything in half x.halveM(); if (a.limbs[0] & 1) { a.addM(p); } a.normalize(); a.halveM(); // check for termination: x ?= 0 for (i=nz=0; i= 0; i--) { out = w.concat(out, [w.partial(Math.min(this.radix,len), this.getLimb(i))]); len -= this.radix; } return out; }, /** Return the length in bits, rounded up to the nearest byte. */ bitLength: function() { this.fullReduce(); var out = this.radix * (this.limbs.length - 1), b = this.limbs[this.limbs.length - 1]; for (; b; b >>>= 1) { out ++; } return out+7 & -8; } }; /** @memberOf sjcl.bn * @this { sjcl.bn } */ sjcl.bn.fromBits = function(bits) { var Class = this, out = new Class(), words=[], w=sjcl.bitArray, t = this.prototype, l = Math.min(this.bitLength || 0x100000000, w.bitLength(bits)), e = l % t.radix || t.radix; words[0] = w.extract(bits, 0, e); for (; e < l; e += t.radix) { words.unshift(w.extract(bits, e, t.radix)); } out.limbs = words; return out; }; sjcl.bn.prototype.ipv = 1 / (sjcl.bn.prototype.placeVal = Math.pow(2,sjcl.bn.prototype.radix)); sjcl.bn.prototype.radixMask = (1 << sjcl.bn.prototype.radix) - 1; /** * Creates a new subclass of bn, based on reduction modulo a pseudo-Mersenne prime, * i.e. a prime of the form 2^e + sum(a * 2^b),where the sum is negative and sparse. */ sjcl.bn.pseudoMersennePrime = function(exponent, coeff) { /** @constructor * @private */ function p(it) { this.initWith(it); /*if (this.limbs[this.modOffset]) { this.reduce(); }*/ } var ppr = p.prototype = new sjcl.bn(), i, tmp, mo; mo = ppr.modOffset = Math.ceil(tmp = exponent / ppr.radix); ppr.exponent = exponent; ppr.offset = []; ppr.factor = []; ppr.minOffset = mo; ppr.fullMask = 0; ppr.fullOffset = []; ppr.fullFactor = []; ppr.modulus = p.modulus = new sjcl.bn(Math.pow(2,exponent)); ppr.fullMask = 0|-Math.pow(2, exponent % ppr.radix); for (i=0; i mo) { l = limbs.pop(); ll = limbs.length; for (k=0; k=0; i--) { for (j=sjcl.bn.prototype.radix-4; j>=0; j-=4) { out = out.doubl().doubl().doubl().doubl().add(multiples[k[i]>>j & 0xF]); } } return out; }, /** * Multiply this point by k, added to affine2*k2, and return the answer in Jacobian coordinates. * @param {bigInt} k The coefficient to multiply this by. * @param {sjcl.ecc.point} affine This point in affine coordinates. * @param {bigInt} k2 The coefficient to multiply affine2 this by. * @param {sjcl.ecc.point} affine The other point in affine coordinates. * @return {sjcl.ecc.pointJac} The result of the multiplication and addition, in Jacobian coordinates. */ mult2: function(k1, affine, k2, affine2) { if (typeof(k1) === "number") { k1 = [k1]; } else if (k1.limbs !== undefined) { k1 = k1.normalize().limbs; } if (typeof(k2) === "number") { k2 = [k2]; } else if (k2.limbs !== undefined) { k2 = k2.normalize().limbs; } var i, j, out = new sjcl.ecc.point(this.curve).toJac(), m1 = affine.multiples(), m2 = affine2.multiples(), l1, l2; for (i=Math.max(k1.length,k2.length)-1; i>=0; i--) { l1 = k1[i] | 0; l2 = k2[i] | 0; for (j=sjcl.bn.prototype.radix-4; j>=0; j-=4) { out = out.doubl().doubl().doubl().doubl().add(m1[l1>>j & 0xF]).add(m2[l2>>j & 0xF]); } } return out; }, isValid: function() { var z2 = this.z.square(), z4 = z2.square(), z6 = z4.mul(z2); return this.y.square().equals( this.curve.b.mul(z6).add(this.x.mul( this.curve.a.mul(z4).add(this.x.square())))); } }; /** * Construct an elliptic curve. Most users will not use this and instead start with one of the NIST curves defined below. * * @constructor * @param {bigInt} p The prime modulus. * @param {bigInt} r The prime order of the curve. * @param {bigInt} a The constant a in the equation of the curve y^2 = x^3 + ax + b (for NIST curves, a is always -3). * @param {bigInt} x The x coordinate of a base point of the curve. * @param {bigInt} y The y coordinate of a base point of the curve. */ sjcl.ecc.curve = function(Field, r, a, b, x, y) { this.field = Field; this.r = new sjcl.bn(r); this.a = new Field(a); this.b = new Field(b); this.G = new sjcl.ecc.point(this, new Field(x), new Field(y)); }; sjcl.ecc.curve.prototype.fromBits = function (bits) { var w = sjcl.bitArray, l = this.field.prototype.exponent + 7 & -8, p = new sjcl.ecc.point(this, this.field.fromBits(w.bitSlice(bits, 0, l)), this.field.fromBits(w.bitSlice(bits, l, 2*l))); if (!p.isValid()) { throw new sjcl.exception.corrupt("not on the curve!"); } return p; }; sjcl.ecc.curves = { c192: new sjcl.ecc.curve( sjcl.bn.prime.p192, "0xffffffffffffffffffffffff99def836146bc9b1b4d22831", -3, "0x64210519e59c80e70fa7e9ab72243049feb8deecc146b9b1", "0x188da80eb03090f67cbf20eb43a18800f4ff0afd82ff1012", "0x07192b95ffc8da78631011ed6b24cdd573f977a11e794811"), c224: new sjcl.ecc.curve( sjcl.bn.prime.p224, "0xffffffffffffffffffffffffffff16a2e0b8f03e13dd29455c5c2a3d", -3, "0xb4050a850c04b3abf54132565044b0b7d7bfd8ba270b39432355ffb4", "0xb70e0cbd6bb4bf7f321390b94a03c1d356c21122343280d6115c1d21", "0xbd376388b5f723fb4c22dfe6cd4375a05a07476444d5819985007e34"), c256: new sjcl.ecc.curve( sjcl.bn.prime.p256, "0xffffffff00000000ffffffffffffffffbce6faada7179e84f3b9cac2fc632551", -3, "0x5ac635d8aa3a93e7b3ebbd55769886bc651d06b0cc53b0f63bce3c3e27d2604b", "0x6b17d1f2e12c4247f8bce6e563a440f277037d812deb33a0f4a13945d898c296", "0x4fe342e2fe1a7f9b8ee7eb4a7c0f9e162bce33576b315ececbb6406837bf51f5"), c384: new sjcl.ecc.curve( sjcl.bn.prime.p384, "0xffffffffffffffffffffffffffffffffffffffffffffffffc7634d81f4372ddf581a0db248b0a77aecec196accc52973", -3, "0xb3312fa7e23ee7e4988e056be3f82d19181d9c6efe8141120314088f5013875ac656398d8a2ed19d2a85c8edd3ec2aef", "0xaa87ca22be8b05378eb1c71ef320ad746e1d3b628ba79b9859f741e082542a385502f25dbf55296c3a545e3872760ab7", "0x3617de4a96262c6f5d9e98bf9292dc29f8f41dbd289a147ce9da3113b5f0b8c00a60b1ce1d7e819d7a431d7c90ea0e5f"), k192: new sjcl.ecc.curve( sjcl.bn.prime.p192k, "0xfffffffffffffffffffffffe26f2fc170f69466a74defd8d", 0, 3, "0xdb4ff10ec057e9ae26b07d0280b7f4341da5d1b1eae06c7d", "0x9b2f2f6d9c5628a7844163d015be86344082aa88d95e2f9d"), k224: new sjcl.ecc.curve( sjcl.bn.prime.p224k, "0x010000000000000000000000000001dce8d2ec6184caf0a971769fb1f7", 0, 5, "0xa1455b334df099df30fc28a169a467e9e47075a90f7e650eb6b7a45c", "0x7e089fed7fba344282cafbd6f7e319f7c0b0bd59e2ca4bdb556d61a5"), k256: new sjcl.ecc.curve( sjcl.bn.prime.p256k, "0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141", 0, 7, "0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798", "0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8") }; /** our basicKey classes */ sjcl.ecc.basicKey = { /** ecc publicKey. * @constructor * @param {curve} curve the elliptic curve * @param {point} point the point on the curve */ publicKey: function(curve, point) { this._curve = curve; this._curveBitLength = curve.r.bitLength(); if (point instanceof Array) { this._point = curve.fromBits(point); } else { this._point = point; } /** get this keys point data * @return x and y as bitArrays */ this.get = function() { var pointbits = this._point.toBits(); var len = sjcl.bitArray.bitLength(pointbits); var x = sjcl.bitArray.bitSlice(pointbits, 0, len/2); var y = sjcl.bitArray.bitSlice(pointbits, len/2); return { x: x, y: y }; }; }, /** ecc secretKey * @constructor * @param {curve} curve the elliptic curve * @param exponent */ secretKey: function(curve, exponent) { this._curve = curve; this._curveBitLength = curve.r.bitLength(); this._exponent = exponent; /** get this keys exponent data * @return {bitArray} exponent */ this.get = function () { return this._exponent.toBits(); }; } }; /** @private */ sjcl.ecc.basicKey.generateKeys = function(cn) { return function generateKeys(curve, paranoia, sec) { curve = curve || 256; paranoia = paranoia || 0; if (typeof curve === "number") { curve = sjcl.ecc.curves['c'+curve]; if (curve === undefined) { throw new sjcl.exception.invalid("no such curve"); } } sec = sec || sjcl.bn.random(curve.r, paranoia); var pub = curve.G.mult(sec); return { pub: new sjcl.ecc[cn].publicKey(curve, pub), sec: new sjcl.ecc[cn].secretKey(curve, sec) }; }; }; /** elGamal keys */ sjcl.ecc.elGamal = { /** generate keys * @function * @param curve * @param {int} paranoia Paranoia for generation (default 6) * @param {secretKey} sec secret Key to use. used to get the publicKey for ones secretKey */ generateKeys: sjcl.ecc.basicKey.generateKeys("elGamal"), /** elGamal publicKey. * @constructor * @augments sjcl.ecc.basicKey.publicKey */ publicKey: function (curve, point) { sjcl.ecc.basicKey.publicKey.apply(this, arguments); }, /** elGamal secretKey * @constructor * @augments sjcl.ecc.basicKey.secretKey */ secretKey: function (curve, exponent) { sjcl.ecc.basicKey.secretKey.apply(this, arguments); } }; sjcl.ecc.elGamal.publicKey.prototype = { /** Kem function of elGamal Public Key * @param paranoia paranoia to use for randomization. * @return {object} key and tag. unkem(tag) with the corresponding secret key results in the key returned. */ kem: function(paranoia) { var sec = sjcl.bn.random(this._curve.r, paranoia), tag = this._curve.G.mult(sec).toBits(), key = sjcl.hash.sha256.hash(this._point.mult(sec).toBits()); return { key: key, tag: tag }; } }; sjcl.ecc.elGamal.secretKey.prototype = { /** UnKem function of elGamal Secret Key * @param {bitArray} tag The Tag to decrypt. * @return {bitArray} decrypted key. */ unkem: function(tag) { return sjcl.hash.sha256.hash(this._curve.fromBits(tag).mult(this._exponent).toBits()); }, /** Diffie-Hellmann function * @param {elGamal.publicKey} pk The Public Key to do Diffie-Hellmann with * @return {bitArray} diffie-hellmann result for this key combination. */ dh: function(pk) { return sjcl.hash.sha256.hash(pk._point.mult(this._exponent).toBits()); } }; /** ecdsa keys */ sjcl.ecc.ecdsa = { /** generate keys * @function * @param curve * @param {int} paranoia Paranoia for generation (default 6) * @param {secretKey} sec secret Key to use. used to get the publicKey for ones secretKey */ generateKeys: sjcl.ecc.basicKey.generateKeys("ecdsa") }; /** ecdsa publicKey. * @constructor * @augments sjcl.ecc.basicKey.publicKey */ sjcl.ecc.ecdsa.publicKey = function (curve, point) { sjcl.ecc.basicKey.publicKey.apply(this, arguments); }; /** specific functions for ecdsa publicKey. */ sjcl.ecc.ecdsa.publicKey.prototype = { /** Diffie-Hellmann function * @param {bitArray} hash hash to verify. * @param {bitArray} rs signature bitArray. * @param {boolean} fakeLegacyVersion use old legacy version */ verify: function(hash, rs, fakeLegacyVersion) { if (sjcl.bitArray.bitLength(hash) > this._curveBitLength) { hash = sjcl.bitArray.clamp(hash, this._curveBitLength); } var w = sjcl.bitArray, R = this._curve.r, l = this._curveBitLength, r = sjcl.bn.fromBits(w.bitSlice(rs,0,l)), ss = sjcl.bn.fromBits(w.bitSlice(rs,l,2*l)), s = fakeLegacyVersion ? ss : ss.inverseMod(R), hG = sjcl.bn.fromBits(hash).mul(s).mod(R), hA = r.mul(s).mod(R), r2 = this._curve.G.mult2(hG, hA, this._point).x; if (r.equals(0) || ss.equals(0) || r.greaterEquals(R) || ss.greaterEquals(R) || !r2.equals(r)) { if (fakeLegacyVersion === undefined) { return this.verify(hash, rs, true); } else { throw (new sjcl.exception.corrupt("signature didn't check out")); } } return true; } }; /** ecdsa secretKey * @constructor * @augments sjcl.ecc.basicKey.publicKey */ sjcl.ecc.ecdsa.secretKey = function (curve, exponent) { sjcl.ecc.basicKey.secretKey.apply(this, arguments); }; /** specific functions for ecdsa secretKey. */ sjcl.ecc.ecdsa.secretKey.prototype = { /** Diffie-Hellmann function * @param {bitArray} hash hash to sign. * @param {int} paranoia paranoia for random number generation * @param {boolean} fakeLegacyVersion use old legacy version */ sign: function(hash, paranoia, fakeLegacyVersion, fixedKForTesting) { if (sjcl.bitArray.bitLength(hash) > this._curveBitLength) { hash = sjcl.bitArray.clamp(hash, this._curveBitLength); } var R = this._curve.r, l = R.bitLength(), k = fixedKForTesting || sjcl.bn.random(R.sub(1), paranoia).add(1), r = this._curve.G.mult(k).x.mod(R), ss = sjcl.bn.fromBits(hash).add(r.mul(this._exponent)), s = fakeLegacyVersion ? ss.inverseMod(R).mul(k).mod(R) : ss.mul(k.inverseMod(R)).mod(R); return sjcl.bitArray.concat(r.toBits(l), s.toBits(l)); } }; var ecc = {}, DEFAULT_CURVE = 192, ENC_DEC = ecc.ENC_DEC = {}, SIG_VER = ecc.SIG_VER = {}, elg = eccAPI('elGamal'), dsa = eccAPI('ecdsa'), sha256 = hashAPI('sha256'); ecc.sjcl = sjcl; ecc.generate = function(type, curve) { if(!curve) curve = DEFAULT_CURVE; var keys, pub, sec; if(type === ENC_DEC) { pub = 'enc'; sec = 'dec'; keys = elg.generate(curve); } else if(type === SIG_VER) { pub = 'ver'; sec = 'sig'; keys = dsa.generate(curve); } else throw "eccjs: generate: Unknown type"; var newkeys = {}; newkeys[pub] = exportPublic(keys.pub); newkeys[sec] = exportSecret(keys.sec); return newkeys; }; var cache = { enc: {}, dec: {}, sig: {}, ver: {} }; ecc.encrypt = function(enckey, plaintext) { var kem = cache.enc[enckey]; if(!kem) { kem = cache.enc[enckey] = elg.importPublic(enckey).kem(); kem.tagHex = sjcl.codec.hex.fromBits(kem.tag); } var obj = sjcl.json._encrypt(kem.key, plaintext); obj.tag = kem.tagHex; return JSON.stringify(obj); }; ecc.decrypt = function(deckey, ciphertext) { var obj = JSON.parse(ciphertext); var kem = cache.dec[deckey]; if(!kem) { kem = cache.dec[deckey] = elg.importSecret(deckey); kem.$keys = {}; } var key = kem.$keys[obj.tag]; if(!key) key = kem.$keys[obj.tag] = kem.unkem(sjcl.codec.hex.toBits(obj.tag)); return sjcl.json._decrypt(key, obj); }; ecc.sign = function(sigkey, text, hash) { var key = cache.sig[sigkey]; if(!key) key = cache.sig[sigkey] = dsa.importSecret(sigkey); //hash first if(hash !== false) text = sha256.hash(text); return key.sign(text); }; ecc.verify = function(verkey, signature, text, hash) { var key = cache.ver[verkey]; if(!key) key = cache.ver[verkey] = dsa.importPublic(verkey); //hash first if(hash !== false) text = sha256.hash(text); try { return key.verify(text, signature); } catch(e) { return false; } }; //ecc algorithm helpers function eccAPI(algoName) { var algo = sjcl.ecc[algoName]; if(!algo) throw new Error("Missing ECC algorithm: " + algoName); return { generate: function(curve) { var keys = algo.generateKeys(curve, 1); keys.pub.$curve = curve; keys.sec.$curve = curve; return keys; }, importPublic: function(keyStr) { var key = extract(keyStr); return new algo.publicKey(key.curve, sjcl.codec.hex.toBits(key.hex)); }, importSecret: function(keyStr) { var key = extract(keyStr); return new algo.secretKey(key.curve, new sjcl.bn(key.hex)); } }; } function extract(str) { return { curve: sjcl.ecc.curves['c'+str.substr(0, 3)], hex: str.substr(3) }; } function exportPublic(keyObj) { var obj = keyObj.get(); return keyObj.$curve + sjcl.codec.hex.fromBits(obj.x) + sjcl.codec.hex.fromBits(obj.y); } function exportSecret(keyObj) { return keyObj.$curve + sjcl.codec.hex.fromBits(keyObj.get()); } //hash algorithm helpers function hashAPI(algoName) { var algo = sjcl.hash[algoName]; if(!algo) throw new Error("Missing hash algorithm: " + algoName); return { hash: function(input) { return algo.hash(input); } }; } //publicise if(typeof module !== 'undefined' && module.exports) module.exports = ecc; else window.ecc = ecc; }(this)); },{"crypto":110}],125:[function(require,module,exports){ 'use strict'; var elliptic = exports; elliptic.version = require('../package.json').version; elliptic.utils = require('./elliptic/utils'); elliptic.rand = require('brorand'); elliptic.hmacDRBG = require('./elliptic/hmac-drbg'); elliptic.curve = require('./elliptic/curve'); elliptic.curves = require('./elliptic/curves'); // Protocols elliptic.ec = require('./elliptic/ec'); elliptic.eddsa = require('./elliptic/eddsa'); },{"../package.json":141,"./elliptic/curve":128,"./elliptic/curves":131,"./elliptic/ec":132,"./elliptic/eddsa":135,"./elliptic/hmac-drbg":138,"./elliptic/utils":140,"brorand":32}],126:[function(require,module,exports){ 'use strict'; var BN = require('bn.js'); var elliptic = require('../../elliptic'); var utils = elliptic.utils; var getNAF = utils.getNAF; var getJSF = utils.getJSF; var assert = utils.assert; function BaseCurve(type, conf) { this.type = type; this.p = new BN(conf.p, 16); // Use Montgomery, when there is no fast reduction for the prime this.red = conf.prime ? BN.red(conf.prime) : BN.mont(this.p); // Useful for many curves this.zero = new BN(0).toRed(this.red); this.one = new BN(1).toRed(this.red); this.two = new BN(2).toRed(this.red); // Curve configuration, optional this.n = conf.n && new BN(conf.n, 16); this.g = conf.g && this.pointFromJSON(conf.g, conf.gRed); // Temporary arrays this._wnafT1 = new Array(4); this._wnafT2 = new Array(4); this._wnafT3 = new Array(4); this._wnafT4 = new Array(4); } module.exports = BaseCurve; BaseCurve.prototype.point = function point() { throw new Error('Not implemented'); }; BaseCurve.prototype.validate = function validate() { throw new Error('Not implemented'); }; BaseCurve.prototype._fixedNafMul = function _fixedNafMul(p, k) { assert(p.precomputed); var doubles = p._getDoubles(); var naf = getNAF(k, 1); var I = (1 << (doubles.step + 1)) - (doubles.step % 2 === 0 ? 2 : 1); I /= 3; // Translate into more windowed form var repr = []; for (var j = 0; j < naf.length; j += doubles.step) { var nafW = 0; for (var k = j + doubles.step - 1; k >= j; k--) nafW = (nafW << 1) + naf[k]; repr.push(nafW); } var a = this.jpoint(null, null, null); var b = this.jpoint(null, null, null); for (var i = I; i > 0; i--) { for (var j = 0; j < repr.length; j++) { var nafW = repr[j]; if (nafW === i) b = b.mixedAdd(doubles.points[j]); else if (nafW === -i) b = b.mixedAdd(doubles.points[j].neg()); } a = a.add(b); } return a.toP(); }; BaseCurve.prototype._wnafMul = function _wnafMul(p, k) { var w = 4; // Precompute window var nafPoints = p._getNAFPoints(w); w = nafPoints.wnd; var wnd = nafPoints.points; // Get NAF form var naf = getNAF(k, w); // Add `this`*(N+1) for every w-NAF index var acc = this.jpoint(null, null, null); for (var i = naf.length - 1; i >= 0; i--) { // Count zeroes for (var k = 0; i >= 0 && naf[i] === 0; i--) k++; if (i >= 0) k++; acc = acc.dblp(k); if (i < 0) break; var z = naf[i]; assert(z !== 0); if (p.type === 'affine') { // J +- P if (z > 0) acc = acc.mixedAdd(wnd[(z - 1) >> 1]); else acc = acc.mixedAdd(wnd[(-z - 1) >> 1].neg()); } else { // J +- J if (z > 0) acc = acc.add(wnd[(z - 1) >> 1]); else acc = acc.add(wnd[(-z - 1) >> 1].neg()); } } return p.type === 'affine' ? acc.toP() : acc; }; BaseCurve.prototype._wnafMulAdd = function _wnafMulAdd(defW, points, coeffs, len) { var wndWidth = this._wnafT1; var wnd = this._wnafT2; var naf = this._wnafT3; // Fill all arrays var max = 0; for (var i = 0; i < len; i++) { var p = points[i]; var nafPoints = p._getNAFPoints(defW); wndWidth[i] = nafPoints.wnd; wnd[i] = nafPoints.points; } // Comb small window NAFs for (var i = len - 1; i >= 1; i -= 2) { var a = i - 1; var b = i; if (wndWidth[a] !== 1 || wndWidth[b] !== 1) { naf[a] = getNAF(coeffs[a], wndWidth[a]); naf[b] = getNAF(coeffs[b], wndWidth[b]); max = Math.max(naf[a].length, max); max = Math.max(naf[b].length, max); continue; } var comb = [ points[a], /* 1 */ null, /* 3 */ null, /* 5 */ points[b] /* 7 */ ]; // Try to avoid Projective points, if possible if (points[a].y.cmp(points[b].y) === 0) { comb[1] = points[a].add(points[b]); comb[2] = points[a].toJ().mixedAdd(points[b].neg()); } else if (points[a].y.cmp(points[b].y.redNeg()) === 0) { comb[1] = points[a].toJ().mixedAdd(points[b]); comb[2] = points[a].add(points[b].neg()); } else { comb[1] = points[a].toJ().mixedAdd(points[b]); comb[2] = points[a].toJ().mixedAdd(points[b].neg()); } var index = [ -3, /* -1 -1 */ -1, /* -1 0 */ -5, /* -1 1 */ -7, /* 0 -1 */ 0, /* 0 0 */ 7, /* 0 1 */ 5, /* 1 -1 */ 1, /* 1 0 */ 3 /* 1 1 */ ]; var jsf = getJSF(coeffs[a], coeffs[b]); max = Math.max(jsf[0].length, max); naf[a] = new Array(max); naf[b] = new Array(max); for (var j = 0; j < max; j++) { var ja = jsf[0][j] | 0; var jb = jsf[1][j] | 0; naf[a][j] = index[(ja + 1) * 3 + (jb + 1)]; naf[b][j] = 0; wnd[a] = comb; } } var acc = this.jpoint(null, null, null); var tmp = this._wnafT4; for (var i = max; i >= 0; i--) { var k = 0; while (i >= 0) { var zero = true; for (var j = 0; j < len; j++) { tmp[j] = naf[j][i] | 0; if (tmp[j] !== 0) zero = false; } if (!zero) break; k++; i--; } if (i >= 0) k++; acc = acc.dblp(k); if (i < 0) break; for (var j = 0; j < len; j++) { var z = tmp[j]; var p; if (z === 0) continue; else if (z > 0) p = wnd[j][(z - 1) >> 1]; else if (z < 0) p = wnd[j][(-z - 1) >> 1].neg(); if (p.type === 'affine') acc = acc.mixedAdd(p); else acc = acc.add(p); } } // Zeroify references for (var i = 0; i < len; i++) wnd[i] = null; return acc.toP(); }; function BasePoint(curve, type) { this.curve = curve; this.type = type; this.precomputed = null; } BaseCurve.BasePoint = BasePoint; BasePoint.prototype.eq = function eq(/*other*/) { throw new Error('Not implemented'); }; BasePoint.prototype.validate = function validate() { return this.curve.validate(this); }; BaseCurve.prototype.decodePoint = function decodePoint(bytes, enc) { bytes = utils.toArray(bytes, enc); var len = this.p.byteLength(); if (bytes[0] === 0x04 && bytes.length - 1 === 2 * len) { return this.point(bytes.slice(1, 1 + len), bytes.slice(1 + len, 1 + 2 * len)); } else if ((bytes[0] === 0x02 || bytes[0] === 0x03) && bytes.length - 1 === len) { return this.pointFromX(bytes.slice(1, 1 + len), bytes[0] === 0x03); } throw new Error('Unknown point format'); }; BasePoint.prototype.encodeCompressed = function encodeCompressed(enc) { return this.encode(enc, true); }; BasePoint.prototype._encode = function _encode(compact) { var len = this.curve.p.byteLength(); var x = this.getX().toArray('be', len); if (compact) return [ this.getY().isEven() ? 0x02 : 0x03 ].concat(x); return [ 0x04 ].concat(x, this.getY().toArray('be', len)) ; }; BasePoint.prototype.encode = function encode(enc, compact) { return utils.encode(this._encode(compact), enc); }; BasePoint.prototype.precompute = function precompute(power) { if (this.precomputed) return this; var precomputed = { doubles: null, naf: null, beta: null }; precomputed.naf = this._getNAFPoints(8); precomputed.doubles = this._getDoubles(4, power); precomputed.beta = this._getBeta(); this.precomputed = precomputed; return this; }; BasePoint.prototype._hasDoubles = function _hasDoubles(k) { if (!this.precomputed) return false; var doubles = this.precomputed.doubles; if (!doubles) return false; return doubles.points.length >= Math.ceil((k.bitLength() + 1) / doubles.step); }; BasePoint.prototype._getDoubles = function _getDoubles(step, power) { if (this.precomputed && this.precomputed.doubles) return this.precomputed.doubles; var doubles = [ this ]; var acc = this; for (var i = 0; i < power; i += step) { for (var j = 0; j < step; j++) acc = acc.dbl(); doubles.push(acc); } return { step: step, points: doubles }; }; BasePoint.prototype._getNAFPoints = function _getNAFPoints(wnd) { if (this.precomputed && this.precomputed.naf) return this.precomputed.naf; var res = [ this ]; var max = (1 << wnd) - 1; var dbl = max === 1 ? null : this.dbl(); for (var i = 1; i < max; i++) res[i] = res[i - 1].add(dbl); return { wnd: wnd, points: res }; }; BasePoint.prototype._getBeta = function _getBeta() { return null; }; BasePoint.prototype.dblp = function dblp(k) { var r = this; for (var i = 0; i < k; i++) r = r.dbl(); return r; }; },{"../../elliptic":125,"bn.js":29}],127:[function(require,module,exports){ 'use strict'; var curve = require('../curve'); var elliptic = require('../../elliptic'); var BN = require('bn.js'); var inherits = require('inherits'); var Base = curve.base; var assert = elliptic.utils.assert; function EdwardsCurve(conf) { // NOTE: Important as we are creating point in Base.call() this.twisted = (conf.a | 0) !== 1; this.mOneA = this.twisted && (conf.a | 0) === -1; this.extended = this.mOneA; Base.call(this, 'edwards', conf); this.a = new BN(conf.a, 16).umod(this.red.m); this.a = this.a.toRed(this.red); this.c = new BN(conf.c, 16).toRed(this.red); this.c2 = this.c.redSqr(); this.d = new BN(conf.d, 16).toRed(this.red); this.dd = this.d.redAdd(this.d); assert(!this.twisted || this.c.fromRed().cmpn(1) === 0); this.oneC = (conf.c | 0) === 1; } inherits(EdwardsCurve, Base); module.exports = EdwardsCurve; EdwardsCurve.prototype._mulA = function _mulA(num) { if (this.mOneA) return num.redNeg(); else return this.a.redMul(num); }; EdwardsCurve.prototype._mulC = function _mulC(num) { if (this.oneC) return num; else return this.c.redMul(num); }; // Just for compatibility with Short curve EdwardsCurve.prototype.jpoint = function jpoint(x, y, z, t) { return this.point(x, y, z, t); }; EdwardsCurve.prototype.pointFromX = function pointFromX(x, odd) { x = new BN(x, 16); if (!x.red) x = x.toRed(this.red); var x2 = x.redSqr(); var rhs = this.c2.redSub(this.a.redMul(x2)); var lhs = this.one.redSub(this.c2.redMul(this.d).redMul(x2)); var y2 = rhs.redMul(lhs.redInvm()); var y = y2.redSqrt(); if (y.redSqr().redSub(y2).cmp(this.zero) !== 0) throw new Error('invalid point'); var isOdd = y.fromRed().isOdd(); if (odd && !isOdd || !odd && isOdd) y = y.redNeg(); return this.point(x, y); }; EdwardsCurve.prototype.pointFromY = function pointFromY(y, odd) { y = new BN(y, 16); if (!y.red) y = y.toRed(this.red); // x^2 = (y^2 - 1) / (d y^2 + 1) var y2 = y.redSqr(); var lhs = y2.redSub(this.one); var rhs = y2.redMul(this.d).redAdd(this.one); var x2 = lhs.redMul(rhs.redInvm()); if (x2.cmp(this.zero) === 0) { if (odd) throw new Error('invalid point'); else return this.point(this.zero, y); } var x = x2.redSqrt(); if (x.redSqr().redSub(x2).cmp(this.zero) !== 0) throw new Error('invalid point'); if (x.isOdd() !== odd) x = x.redNeg(); return this.point(x, y); }; EdwardsCurve.prototype.validate = function validate(point) { if (point.isInfinity()) return true; // Curve: A * X^2 + Y^2 = C^2 * (1 + D * X^2 * Y^2) point.normalize(); var x2 = point.x.redSqr(); var y2 = point.y.redSqr(); var lhs = x2.redMul(this.a).redAdd(y2); var rhs = this.c2.redMul(this.one.redAdd(this.d.redMul(x2).redMul(y2))); return lhs.cmp(rhs) === 0; }; function Point(curve, x, y, z, t) { Base.BasePoint.call(this, curve, 'projective'); if (x === null && y === null && z === null) { this.x = this.curve.zero; this.y = this.curve.one; this.z = this.curve.one; this.t = this.curve.zero; this.zOne = true; } else { this.x = new BN(x, 16); this.y = new BN(y, 16); this.z = z ? new BN(z, 16) : this.curve.one; this.t = t && new BN(t, 16); if (!this.x.red) this.x = this.x.toRed(this.curve.red); if (!this.y.red) this.y = this.y.toRed(this.curve.red); if (!this.z.red) this.z = this.z.toRed(this.curve.red); if (this.t && !this.t.red) this.t = this.t.toRed(this.curve.red); this.zOne = this.z === this.curve.one; // Use extended coordinates if (this.curve.extended && !this.t) { this.t = this.x.redMul(this.y); if (!this.zOne) this.t = this.t.redMul(this.z.redInvm()); } } } inherits(Point, Base.BasePoint); EdwardsCurve.prototype.pointFromJSON = function pointFromJSON(obj) { return Point.fromJSON(this, obj); }; EdwardsCurve.prototype.point = function point(x, y, z, t) { return new Point(this, x, y, z, t); }; Point.fromJSON = function fromJSON(curve, obj) { return new Point(curve, obj[0], obj[1], obj[2]); }; Point.prototype.inspect = function inspect() { if (this.isInfinity()) return ''; return ''; }; Point.prototype.isInfinity = function isInfinity() { // XXX This code assumes that zero is always zero in red return this.x.cmpn(0) === 0 && this.y.cmp(this.z) === 0; }; Point.prototype._extDbl = function _extDbl() { // hyperelliptic.org/EFD/g1p/auto-twisted-extended-1.html // #doubling-dbl-2008-hwcd // 4M + 4S // A = X1^2 var a = this.x.redSqr(); // B = Y1^2 var b = this.y.redSqr(); // C = 2 * Z1^2 var c = this.z.redSqr(); c = c.redIAdd(c); // D = a * A var d = this.curve._mulA(a); // E = (X1 + Y1)^2 - A - B var e = this.x.redAdd(this.y).redSqr().redISub(a).redISub(b); // G = D + B var g = d.redAdd(b); // F = G - C var f = g.redSub(c); // H = D - B var h = d.redSub(b); // X3 = E * F var nx = e.redMul(f); // Y3 = G * H var ny = g.redMul(h); // T3 = E * H var nt = e.redMul(h); // Z3 = F * G var nz = f.redMul(g); return this.curve.point(nx, ny, nz, nt); }; Point.prototype._projDbl = function _projDbl() { // hyperelliptic.org/EFD/g1p/auto-twisted-projective.html // #doubling-dbl-2008-bbjlp // #doubling-dbl-2007-bl // and others // Generally 3M + 4S or 2M + 4S // B = (X1 + Y1)^2 var b = this.x.redAdd(this.y).redSqr(); // C = X1^2 var c = this.x.redSqr(); // D = Y1^2 var d = this.y.redSqr(); var nx; var ny; var nz; if (this.curve.twisted) { // E = a * C var e = this.curve._mulA(c); // F = E + D var f = e.redAdd(d); if (this.zOne) { // X3 = (B - C - D) * (F - 2) nx = b.redSub(c).redSub(d).redMul(f.redSub(this.curve.two)); // Y3 = F * (E - D) ny = f.redMul(e.redSub(d)); // Z3 = F^2 - 2 * F nz = f.redSqr().redSub(f).redSub(f); } else { // H = Z1^2 var h = this.z.redSqr(); // J = F - 2 * H var j = f.redSub(h).redISub(h); // X3 = (B-C-D)*J nx = b.redSub(c).redISub(d).redMul(j); // Y3 = F * (E - D) ny = f.redMul(e.redSub(d)); // Z3 = F * J nz = f.redMul(j); } } else { // E = C + D var e = c.redAdd(d); // H = (c * Z1)^2 var h = this.curve._mulC(this.c.redMul(this.z)).redSqr(); // J = E - 2 * H var j = e.redSub(h).redSub(h); // X3 = c * (B - E) * J nx = this.curve._mulC(b.redISub(e)).redMul(j); // Y3 = c * E * (C - D) ny = this.curve._mulC(e).redMul(c.redISub(d)); // Z3 = E * J nz = e.redMul(j); } return this.curve.point(nx, ny, nz); }; Point.prototype.dbl = function dbl() { if (this.isInfinity()) return this; // Double in extended coordinates if (this.curve.extended) return this._extDbl(); else return this._projDbl(); }; Point.prototype._extAdd = function _extAdd(p) { // hyperelliptic.org/EFD/g1p/auto-twisted-extended-1.html // #addition-add-2008-hwcd-3 // 8M // A = (Y1 - X1) * (Y2 - X2) var a = this.y.redSub(this.x).redMul(p.y.redSub(p.x)); // B = (Y1 + X1) * (Y2 + X2) var b = this.y.redAdd(this.x).redMul(p.y.redAdd(p.x)); // C = T1 * k * T2 var c = this.t.redMul(this.curve.dd).redMul(p.t); // D = Z1 * 2 * Z2 var d = this.z.redMul(p.z.redAdd(p.z)); // E = B - A var e = b.redSub(a); // F = D - C var f = d.redSub(c); // G = D + C var g = d.redAdd(c); // H = B + A var h = b.redAdd(a); // X3 = E * F var nx = e.redMul(f); // Y3 = G * H var ny = g.redMul(h); // T3 = E * H var nt = e.redMul(h); // Z3 = F * G var nz = f.redMul(g); return this.curve.point(nx, ny, nz, nt); }; Point.prototype._projAdd = function _projAdd(p) { // hyperelliptic.org/EFD/g1p/auto-twisted-projective.html // #addition-add-2008-bbjlp // #addition-add-2007-bl // 10M + 1S // A = Z1 * Z2 var a = this.z.redMul(p.z); // B = A^2 var b = a.redSqr(); // C = X1 * X2 var c = this.x.redMul(p.x); // D = Y1 * Y2 var d = this.y.redMul(p.y); // E = d * C * D var e = this.curve.d.redMul(c).redMul(d); // F = B - E var f = b.redSub(e); // G = B + E var g = b.redAdd(e); // X3 = A * F * ((X1 + Y1) * (X2 + Y2) - C - D) var tmp = this.x.redAdd(this.y).redMul(p.x.redAdd(p.y)).redISub(c).redISub(d); var nx = a.redMul(f).redMul(tmp); var ny; var nz; if (this.curve.twisted) { // Y3 = A * G * (D - a * C) ny = a.redMul(g).redMul(d.redSub(this.curve._mulA(c))); // Z3 = F * G nz = f.redMul(g); } else { // Y3 = A * G * (D - C) ny = a.redMul(g).redMul(d.redSub(c)); // Z3 = c * F * G nz = this.curve._mulC(f).redMul(g); } return this.curve.point(nx, ny, nz); }; Point.prototype.add = function add(p) { if (this.isInfinity()) return p; if (p.isInfinity()) return this; if (this.curve.extended) return this._extAdd(p); else return this._projAdd(p); }; Point.prototype.mul = function mul(k) { if (this._hasDoubles(k)) return this.curve._fixedNafMul(this, k); else return this.curve._wnafMul(this, k); }; Point.prototype.mulAdd = function mulAdd(k1, p, k2) { return this.curve._wnafMulAdd(1, [ this, p ], [ k1, k2 ], 2); }; Point.prototype.normalize = function normalize() { if (this.zOne) return this; // Normalize coordinates var zi = this.z.redInvm(); this.x = this.x.redMul(zi); this.y = this.y.redMul(zi); if (this.t) this.t = this.t.redMul(zi); this.z = this.curve.one; this.zOne = true; return this; }; Point.prototype.neg = function neg() { return this.curve.point(this.x.redNeg(), this.y, this.z, this.t && this.t.redNeg()); }; Point.prototype.getX = function getX() { this.normalize(); return this.x.fromRed(); }; Point.prototype.getY = function getY() { this.normalize(); return this.y.fromRed(); }; Point.prototype.eq = function eq(other) { return this === other || this.getX().cmp(other.getX()) === 0 && this.getY().cmp(other.getY()) === 0; }; // Compatibility with BaseCurve Point.prototype.toP = Point.prototype.normalize; Point.prototype.mixedAdd = Point.prototype.add; },{"../../elliptic":125,"../curve":128,"bn.js":29,"inherits":167}],128:[function(require,module,exports){ 'use strict'; var curve = exports; curve.base = require('./base'); curve.short = require('./short'); curve.mont = require('./mont'); curve.edwards = require('./edwards'); },{"./base":126,"./edwards":127,"./mont":129,"./short":130}],129:[function(require,module,exports){ 'use strict'; var curve = require('../curve'); var BN = require('bn.js'); var inherits = require('inherits'); var Base = curve.base; var elliptic = require('../../elliptic'); var utils = elliptic.utils; function MontCurve(conf) { Base.call(this, 'mont', conf); this.a = new BN(conf.a, 16).toRed(this.red); this.b = new BN(conf.b, 16).toRed(this.red); this.i4 = new BN(4).toRed(this.red).redInvm(); this.two = new BN(2).toRed(this.red); this.a24 = this.i4.redMul(this.a.redAdd(this.two)); } inherits(MontCurve, Base); module.exports = MontCurve; MontCurve.prototype.validate = function validate(point) { var x = point.normalize().x; var x2 = x.redSqr(); var rhs = x2.redMul(x).redAdd(x2.redMul(this.a)).redAdd(x); var y = rhs.redSqrt(); return y.redSqr().cmp(rhs) === 0; }; function Point(curve, x, z) { Base.BasePoint.call(this, curve, 'projective'); if (x === null && z === null) { this.x = this.curve.one; this.z = this.curve.zero; } else { this.x = new BN(x, 16); this.z = new BN(z, 16); if (!this.x.red) this.x = this.x.toRed(this.curve.red); if (!this.z.red) this.z = this.z.toRed(this.curve.red); } } inherits(Point, Base.BasePoint); MontCurve.prototype.decodePoint = function decodePoint(bytes, enc) { return this.point(utils.toArray(bytes, enc), 1); }; MontCurve.prototype.point = function point(x, z) { return new Point(this, x, z); }; MontCurve.prototype.pointFromJSON = function pointFromJSON(obj) { return Point.fromJSON(this, obj); }; Point.prototype.precompute = function precompute() { // No-op }; Point.prototype._encode = function _encode() { return this.getX().toArray('be', this.curve.p.byteLength()); }; Point.fromJSON = function fromJSON(curve, obj) { return new Point(curve, obj[0], obj[1] || curve.one); }; Point.prototype.inspect = function inspect() { if (this.isInfinity()) return ''; return ''; }; Point.prototype.isInfinity = function isInfinity() { // XXX This code assumes that zero is always zero in red return this.z.cmpn(0) === 0; }; Point.prototype.dbl = function dbl() { // http://hyperelliptic.org/EFD/g1p/auto-montgom-xz.html#doubling-dbl-1987-m-3 // 2M + 2S + 4A // A = X1 + Z1 var a = this.x.redAdd(this.z); // AA = A^2 var aa = a.redSqr(); // B = X1 - Z1 var b = this.x.redSub(this.z); // BB = B^2 var bb = b.redSqr(); // C = AA - BB var c = aa.redSub(bb); // X3 = AA * BB var nx = aa.redMul(bb); // Z3 = C * (BB + A24 * C) var nz = c.redMul(bb.redAdd(this.curve.a24.redMul(c))); return this.curve.point(nx, nz); }; Point.prototype.add = function add() { throw new Error('Not supported on Montgomery curve'); }; Point.prototype.diffAdd = function diffAdd(p, diff) { // http://hyperelliptic.org/EFD/g1p/auto-montgom-xz.html#diffadd-dadd-1987-m-3 // 4M + 2S + 6A // A = X2 + Z2 var a = this.x.redAdd(this.z); // B = X2 - Z2 var b = this.x.redSub(this.z); // C = X3 + Z3 var c = p.x.redAdd(p.z); // D = X3 - Z3 var d = p.x.redSub(p.z); // DA = D * A var da = d.redMul(a); // CB = C * B var cb = c.redMul(b); // X5 = Z1 * (DA + CB)^2 var nx = diff.z.redMul(da.redAdd(cb).redSqr()); // Z5 = X1 * (DA - CB)^2 var nz = diff.x.redMul(da.redISub(cb).redSqr()); return this.curve.point(nx, nz); }; Point.prototype.mul = function mul(k) { var t = k.clone(); var a = this; // (N / 2) * Q + Q var b = this.curve.point(null, null); // (N / 2) * Q var c = this; // Q for (var bits = []; t.cmpn(0) !== 0; t.iushrn(1)) bits.push(t.andln(1)); for (var i = bits.length - 1; i >= 0; i--) { if (bits[i] === 0) { // N * Q + Q = ((N / 2) * Q + Q)) + (N / 2) * Q a = a.diffAdd(b, c); // N * Q = 2 * ((N / 2) * Q + Q)) b = b.dbl(); } else { // N * Q = ((N / 2) * Q + Q) + ((N / 2) * Q) b = a.diffAdd(b, c); // N * Q + Q = 2 * ((N / 2) * Q + Q) a = a.dbl(); } } return b; }; Point.prototype.mulAdd = function mulAdd() { throw new Error('Not supported on Montgomery curve'); }; Point.prototype.eq = function eq(other) { return this.getX().cmp(other.getX()) === 0; }; Point.prototype.normalize = function normalize() { this.x = this.x.redMul(this.z.redInvm()); this.z = this.curve.one; return this; }; Point.prototype.getX = function getX() { // Normalize coordinates this.normalize(); return this.x.fromRed(); }; },{"../../elliptic":125,"../curve":128,"bn.js":29,"inherits":167}],130:[function(require,module,exports){ 'use strict'; var curve = require('../curve'); var elliptic = require('../../elliptic'); var BN = require('bn.js'); var inherits = require('inherits'); var Base = curve.base; var assert = elliptic.utils.assert; function ShortCurve(conf) { Base.call(this, 'short', conf); this.a = new BN(conf.a, 16).toRed(this.red); this.b = new BN(conf.b, 16).toRed(this.red); this.tinv = this.two.redInvm(); this.zeroA = this.a.fromRed().cmpn(0) === 0; this.threeA = this.a.fromRed().sub(this.p).cmpn(-3) === 0; // If the curve is endomorphic, precalculate beta and lambda this.endo = this._getEndomorphism(conf); this._endoWnafT1 = new Array(4); this._endoWnafT2 = new Array(4); } inherits(ShortCurve, Base); module.exports = ShortCurve; ShortCurve.prototype._getEndomorphism = function _getEndomorphism(conf) { // No efficient endomorphism if (!this.zeroA || !this.g || !this.n || this.p.modn(3) !== 1) return; // Compute beta and lambda, that lambda * P = (beta * Px; Py) var beta; var lambda; if (conf.beta) { beta = new BN(conf.beta, 16).toRed(this.red); } else { var betas = this._getEndoRoots(this.p); // Choose the smallest beta beta = betas[0].cmp(betas[1]) < 0 ? betas[0] : betas[1]; beta = beta.toRed(this.red); } if (conf.lambda) { lambda = new BN(conf.lambda, 16); } else { // Choose the lambda that is matching selected beta var lambdas = this._getEndoRoots(this.n); if (this.g.mul(lambdas[0]).x.cmp(this.g.x.redMul(beta)) === 0) { lambda = lambdas[0]; } else { lambda = lambdas[1]; assert(this.g.mul(lambda).x.cmp(this.g.x.redMul(beta)) === 0); } } // Get basis vectors, used for balanced length-two representation var basis; if (conf.basis) { basis = conf.basis.map(function(vec) { return { a: new BN(vec.a, 16), b: new BN(vec.b, 16) }; }); } else { basis = this._getEndoBasis(lambda); } return { beta: beta, lambda: lambda, basis: basis }; }; ShortCurve.prototype._getEndoRoots = function _getEndoRoots(num) { // Find roots of for x^2 + x + 1 in F // Root = (-1 +- Sqrt(-3)) / 2 // var red = num === this.p ? this.red : BN.mont(num); var tinv = new BN(2).toRed(red).redInvm(); var ntinv = tinv.redNeg(); var s = new BN(3).toRed(red).redNeg().redSqrt().redMul(tinv); var l1 = ntinv.redAdd(s).fromRed(); var l2 = ntinv.redSub(s).fromRed(); return [ l1, l2 ]; }; ShortCurve.prototype._getEndoBasis = function _getEndoBasis(lambda) { // aprxSqrt >= sqrt(this.n) var aprxSqrt = this.n.ushrn(Math.floor(this.n.bitLength() / 2)); // 3.74 // Run EGCD, until r(L + 1) < aprxSqrt var u = lambda; var v = this.n.clone(); var x1 = new BN(1); var y1 = new BN(0); var x2 = new BN(0); var y2 = new BN(1); // NOTE: all vectors are roots of: a + b * lambda = 0 (mod n) var a0; var b0; // First vector var a1; var b1; // Second vector var a2; var b2; var prevR; var i = 0; var r; var x; while (u.cmpn(0) !== 0) { var q = v.div(u); r = v.sub(q.mul(u)); x = x2.sub(q.mul(x1)); var y = y2.sub(q.mul(y1)); if (!a1 && r.cmp(aprxSqrt) < 0) { a0 = prevR.neg(); b0 = x1; a1 = r.neg(); b1 = x; } else if (a1 && ++i === 2) { break; } prevR = r; v = u; u = r; x2 = x1; x1 = x; y2 = y1; y1 = y; } a2 = r.neg(); b2 = x; var len1 = a1.sqr().add(b1.sqr()); var len2 = a2.sqr().add(b2.sqr()); if (len2.cmp(len1) >= 0) { a2 = a0; b2 = b0; } // Normalize signs if (a1.negative) { a1 = a1.neg(); b1 = b1.neg(); } if (a2.negative) { a2 = a2.neg(); b2 = b2.neg(); } return [ { a: a1, b: b1 }, { a: a2, b: b2 } ]; }; ShortCurve.prototype._endoSplit = function _endoSplit(k) { var basis = this.endo.basis; var v1 = basis[0]; var v2 = basis[1]; var c1 = v2.b.mul(k).divRound(this.n); var c2 = v1.b.neg().mul(k).divRound(this.n); var p1 = c1.mul(v1.a); var p2 = c2.mul(v2.a); var q1 = c1.mul(v1.b); var q2 = c2.mul(v2.b); // Calculate answer var k1 = k.sub(p1).sub(p2); var k2 = q1.add(q2).neg(); return { k1: k1, k2: k2 }; }; ShortCurve.prototype.pointFromX = function pointFromX(x, odd) { x = new BN(x, 16); if (!x.red) x = x.toRed(this.red); var y2 = x.redSqr().redMul(x).redIAdd(x.redMul(this.a)).redIAdd(this.b); var y = y2.redSqrt(); if (y.redSqr().redSub(y2).cmp(this.zero) !== 0) throw new Error('invalid point'); // XXX Is there any way to tell if the number is odd without converting it // to non-red form? var isOdd = y.fromRed().isOdd(); if (odd && !isOdd || !odd && isOdd) y = y.redNeg(); return this.point(x, y); }; ShortCurve.prototype.validate = function validate(point) { if (point.inf) return true; var x = point.x; var y = point.y; var ax = this.a.redMul(x); var rhs = x.redSqr().redMul(x).redIAdd(ax).redIAdd(this.b); return y.redSqr().redISub(rhs).cmpn(0) === 0; }; ShortCurve.prototype._endoWnafMulAdd = function _endoWnafMulAdd(points, coeffs) { var npoints = this._endoWnafT1; var ncoeffs = this._endoWnafT2; for (var i = 0; i < points.length; i++) { var split = this._endoSplit(coeffs[i]); var p = points[i]; var beta = p._getBeta(); if (split.k1.negative) { split.k1.ineg(); p = p.neg(true); } if (split.k2.negative) { split.k2.ineg(); beta = beta.neg(true); } npoints[i * 2] = p; npoints[i * 2 + 1] = beta; ncoeffs[i * 2] = split.k1; ncoeffs[i * 2 + 1] = split.k2; } var res = this._wnafMulAdd(1, npoints, ncoeffs, i * 2); // Clean-up references to points and coefficients for (var j = 0; j < i * 2; j++) { npoints[j] = null; ncoeffs[j] = null; } return res; }; function Point(curve, x, y, isRed) { Base.BasePoint.call(this, curve, 'affine'); if (x === null && y === null) { this.x = null; this.y = null; this.inf = true; } else { this.x = new BN(x, 16); this.y = new BN(y, 16); // Force redgomery representation when loading from JSON if (isRed) { this.x.forceRed(this.curve.red); this.y.forceRed(this.curve.red); } if (!this.x.red) this.x = this.x.toRed(this.curve.red); if (!this.y.red) this.y = this.y.toRed(this.curve.red); this.inf = false; } } inherits(Point, Base.BasePoint); ShortCurve.prototype.point = function point(x, y, isRed) { return new Point(this, x, y, isRed); }; ShortCurve.prototype.pointFromJSON = function pointFromJSON(obj, red) { return Point.fromJSON(this, obj, red); }; Point.prototype._getBeta = function _getBeta() { if (!this.curve.endo) return; var pre = this.precomputed; if (pre && pre.beta) return pre.beta; var beta = this.curve.point(this.x.redMul(this.curve.endo.beta), this.y); if (pre) { var curve = this.curve; var endoMul = function(p) { return curve.point(p.x.redMul(curve.endo.beta), p.y); }; pre.beta = beta; beta.precomputed = { beta: null, naf: pre.naf && { wnd: pre.naf.wnd, points: pre.naf.points.map(endoMul) }, doubles: pre.doubles && { step: pre.doubles.step, points: pre.doubles.points.map(endoMul) } }; } return beta; }; Point.prototype.toJSON = function toJSON() { if (!this.precomputed) return [ this.x, this.y ]; return [ this.x, this.y, this.precomputed && { doubles: this.precomputed.doubles && { step: this.precomputed.doubles.step, points: this.precomputed.doubles.points.slice(1) }, naf: this.precomputed.naf && { wnd: this.precomputed.naf.wnd, points: this.precomputed.naf.points.slice(1) } } ]; }; Point.fromJSON = function fromJSON(curve, obj, red) { if (typeof obj === 'string') obj = JSON.parse(obj); var res = curve.point(obj[0], obj[1], red); if (!obj[2]) return res; function obj2point(obj) { return curve.point(obj[0], obj[1], red); } var pre = obj[2]; res.precomputed = { beta: null, doubles: pre.doubles && { step: pre.doubles.step, points: [ res ].concat(pre.doubles.points.map(obj2point)) }, naf: pre.naf && { wnd: pre.naf.wnd, points: [ res ].concat(pre.naf.points.map(obj2point)) } }; return res; }; Point.prototype.inspect = function inspect() { if (this.isInfinity()) return ''; return ''; }; Point.prototype.isInfinity = function isInfinity() { return this.inf; }; Point.prototype.add = function add(p) { // O + P = P if (this.inf) return p; // P + O = P if (p.inf) return this; // P + P = 2P if (this.eq(p)) return this.dbl(); // P + (-P) = O if (this.neg().eq(p)) return this.curve.point(null, null); // P + Q = O if (this.x.cmp(p.x) === 0) return this.curve.point(null, null); var c = this.y.redSub(p.y); if (c.cmpn(0) !== 0) c = c.redMul(this.x.redSub(p.x).redInvm()); var nx = c.redSqr().redISub(this.x).redISub(p.x); var ny = c.redMul(this.x.redSub(nx)).redISub(this.y); return this.curve.point(nx, ny); }; Point.prototype.dbl = function dbl() { if (this.inf) return this; // 2P = O var ys1 = this.y.redAdd(this.y); if (ys1.cmpn(0) === 0) return this.curve.point(null, null); var a = this.curve.a; var x2 = this.x.redSqr(); var dyinv = ys1.redInvm(); var c = x2.redAdd(x2).redIAdd(x2).redIAdd(a).redMul(dyinv); var nx = c.redSqr().redISub(this.x.redAdd(this.x)); var ny = c.redMul(this.x.redSub(nx)).redISub(this.y); return this.curve.point(nx, ny); }; Point.prototype.getX = function getX() { return this.x.fromRed(); }; Point.prototype.getY = function getY() { return this.y.fromRed(); }; Point.prototype.mul = function mul(k) { k = new BN(k, 16); if (this._hasDoubles(k)) return this.curve._fixedNafMul(this, k); else if (this.curve.endo) return this.curve._endoWnafMulAdd([ this ], [ k ]); else return this.curve._wnafMul(this, k); }; Point.prototype.mulAdd = function mulAdd(k1, p2, k2) { var points = [ this, p2 ]; var coeffs = [ k1, k2 ]; if (this.curve.endo) return this.curve._endoWnafMulAdd(points, coeffs); else return this.curve._wnafMulAdd(1, points, coeffs, 2); }; Point.prototype.eq = function eq(p) { return this === p || this.inf === p.inf && (this.inf || this.x.cmp(p.x) === 0 && this.y.cmp(p.y) === 0); }; Point.prototype.neg = function neg(_precompute) { if (this.inf) return this; var res = this.curve.point(this.x, this.y.redNeg()); if (_precompute && this.precomputed) { var pre = this.precomputed; var negate = function(p) { return p.neg(); }; res.precomputed = { naf: pre.naf && { wnd: pre.naf.wnd, points: pre.naf.points.map(negate) }, doubles: pre.doubles && { step: pre.doubles.step, points: pre.doubles.points.map(negate) } }; } return res; }; Point.prototype.toJ = function toJ() { if (this.inf) return this.curve.jpoint(null, null, null); var res = this.curve.jpoint(this.x, this.y, this.curve.one); return res; }; function JPoint(curve, x, y, z) { Base.BasePoint.call(this, curve, 'jacobian'); if (x === null && y === null && z === null) { this.x = this.curve.one; this.y = this.curve.one; this.z = new BN(0); } else { this.x = new BN(x, 16); this.y = new BN(y, 16); this.z = new BN(z, 16); } if (!this.x.red) this.x = this.x.toRed(this.curve.red); if (!this.y.red) this.y = this.y.toRed(this.curve.red); if (!this.z.red) this.z = this.z.toRed(this.curve.red); this.zOne = this.z === this.curve.one; } inherits(JPoint, Base.BasePoint); ShortCurve.prototype.jpoint = function jpoint(x, y, z) { return new JPoint(this, x, y, z); }; JPoint.prototype.toP = function toP() { if (this.isInfinity()) return this.curve.point(null, null); var zinv = this.z.redInvm(); var zinv2 = zinv.redSqr(); var ax = this.x.redMul(zinv2); var ay = this.y.redMul(zinv2).redMul(zinv); return this.curve.point(ax, ay); }; JPoint.prototype.neg = function neg() { return this.curve.jpoint(this.x, this.y.redNeg(), this.z); }; JPoint.prototype.add = function add(p) { // O + P = P if (this.isInfinity()) return p; // P + O = P if (p.isInfinity()) return this; // 12M + 4S + 7A var pz2 = p.z.redSqr(); var z2 = this.z.redSqr(); var u1 = this.x.redMul(pz2); var u2 = p.x.redMul(z2); var s1 = this.y.redMul(pz2.redMul(p.z)); var s2 = p.y.redMul(z2.redMul(this.z)); var h = u1.redSub(u2); var r = s1.redSub(s2); if (h.cmpn(0) === 0) { if (r.cmpn(0) !== 0) return this.curve.jpoint(null, null, null); else return this.dbl(); } var h2 = h.redSqr(); var h3 = h2.redMul(h); var v = u1.redMul(h2); var nx = r.redSqr().redIAdd(h3).redISub(v).redISub(v); var ny = r.redMul(v.redISub(nx)).redISub(s1.redMul(h3)); var nz = this.z.redMul(p.z).redMul(h); return this.curve.jpoint(nx, ny, nz); }; JPoint.prototype.mixedAdd = function mixedAdd(p) { // O + P = P if (this.isInfinity()) return p.toJ(); // P + O = P if (p.isInfinity()) return this; // 8M + 3S + 7A var z2 = this.z.redSqr(); var u1 = this.x; var u2 = p.x.redMul(z2); var s1 = this.y; var s2 = p.y.redMul(z2).redMul(this.z); var h = u1.redSub(u2); var r = s1.redSub(s2); if (h.cmpn(0) === 0) { if (r.cmpn(0) !== 0) return this.curve.jpoint(null, null, null); else return this.dbl(); } var h2 = h.redSqr(); var h3 = h2.redMul(h); var v = u1.redMul(h2); var nx = r.redSqr().redIAdd(h3).redISub(v).redISub(v); var ny = r.redMul(v.redISub(nx)).redISub(s1.redMul(h3)); var nz = this.z.redMul(h); return this.curve.jpoint(nx, ny, nz); }; JPoint.prototype.dblp = function dblp(pow) { if (pow === 0) return this; if (this.isInfinity()) return this; if (!pow) return this.dbl(); if (this.curve.zeroA || this.curve.threeA) { var r = this; for (var i = 0; i < pow; i++) r = r.dbl(); return r; } // 1M + 2S + 1A + N * (4S + 5M + 8A) // N = 1 => 6M + 6S + 9A var a = this.curve.a; var tinv = this.curve.tinv; var jx = this.x; var jy = this.y; var jz = this.z; var jz4 = jz.redSqr().redSqr(); // Reuse results var jyd = jy.redAdd(jy); for (var i = 0; i < pow; i++) { var jx2 = jx.redSqr(); var jyd2 = jyd.redSqr(); var jyd4 = jyd2.redSqr(); var c = jx2.redAdd(jx2).redIAdd(jx2).redIAdd(a.redMul(jz4)); var t1 = jx.redMul(jyd2); var nx = c.redSqr().redISub(t1.redAdd(t1)); var t2 = t1.redISub(nx); var dny = c.redMul(t2); dny = dny.redIAdd(dny).redISub(jyd4); var nz = jyd.redMul(jz); if (i + 1 < pow) jz4 = jz4.redMul(jyd4); jx = nx; jz = nz; jyd = dny; } return this.curve.jpoint(jx, jyd.redMul(tinv), jz); }; JPoint.prototype.dbl = function dbl() { if (this.isInfinity()) return this; if (this.curve.zeroA) return this._zeroDbl(); else if (this.curve.threeA) return this._threeDbl(); else return this._dbl(); }; JPoint.prototype._zeroDbl = function _zeroDbl() { var nx; var ny; var nz; // Z = 1 if (this.zOne) { // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html // #doubling-mdbl-2007-bl // 1M + 5S + 14A // XX = X1^2 var xx = this.x.redSqr(); // YY = Y1^2 var yy = this.y.redSqr(); // YYYY = YY^2 var yyyy = yy.redSqr(); // S = 2 * ((X1 + YY)^2 - XX - YYYY) var s = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy); s = s.redIAdd(s); // M = 3 * XX + a; a = 0 var m = xx.redAdd(xx).redIAdd(xx); // T = M ^ 2 - 2*S var t = m.redSqr().redISub(s).redISub(s); // 8 * YYYY var yyyy8 = yyyy.redIAdd(yyyy); yyyy8 = yyyy8.redIAdd(yyyy8); yyyy8 = yyyy8.redIAdd(yyyy8); // X3 = T nx = t; // Y3 = M * (S - T) - 8 * YYYY ny = m.redMul(s.redISub(t)).redISub(yyyy8); // Z3 = 2*Y1 nz = this.y.redAdd(this.y); } else { // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html // #doubling-dbl-2009-l // 2M + 5S + 13A // A = X1^2 var a = this.x.redSqr(); // B = Y1^2 var b = this.y.redSqr(); // C = B^2 var c = b.redSqr(); // D = 2 * ((X1 + B)^2 - A - C) var d = this.x.redAdd(b).redSqr().redISub(a).redISub(c); d = d.redIAdd(d); // E = 3 * A var e = a.redAdd(a).redIAdd(a); // F = E^2 var f = e.redSqr(); // 8 * C var c8 = c.redIAdd(c); c8 = c8.redIAdd(c8); c8 = c8.redIAdd(c8); // X3 = F - 2 * D nx = f.redISub(d).redISub(d); // Y3 = E * (D - X3) - 8 * C ny = e.redMul(d.redISub(nx)).redISub(c8); // Z3 = 2 * Y1 * Z1 nz = this.y.redMul(this.z); nz = nz.redIAdd(nz); } return this.curve.jpoint(nx, ny, nz); }; JPoint.prototype._threeDbl = function _threeDbl() { var nx; var ny; var nz; // Z = 1 if (this.zOne) { // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-3.html // #doubling-mdbl-2007-bl // 1M + 5S + 15A // XX = X1^2 var xx = this.x.redSqr(); // YY = Y1^2 var yy = this.y.redSqr(); // YYYY = YY^2 var yyyy = yy.redSqr(); // S = 2 * ((X1 + YY)^2 - XX - YYYY) var s = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy); s = s.redIAdd(s); // M = 3 * XX + a var m = xx.redAdd(xx).redIAdd(xx).redIAdd(this.curve.a); // T = M^2 - 2 * S var t = m.redSqr().redISub(s).redISub(s); // X3 = T nx = t; // Y3 = M * (S - T) - 8 * YYYY var yyyy8 = yyyy.redIAdd(yyyy); yyyy8 = yyyy8.redIAdd(yyyy8); yyyy8 = yyyy8.redIAdd(yyyy8); ny = m.redMul(s.redISub(t)).redISub(yyyy8); // Z3 = 2 * Y1 nz = this.y.redAdd(this.y); } else { // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-3.html#doubling-dbl-2001-b // 3M + 5S // delta = Z1^2 var delta = this.z.redSqr(); // gamma = Y1^2 var gamma = this.y.redSqr(); // beta = X1 * gamma var beta = this.x.redMul(gamma); // alpha = 3 * (X1 - delta) * (X1 + delta) var alpha = this.x.redSub(delta).redMul(this.x.redAdd(delta)); alpha = alpha.redAdd(alpha).redIAdd(alpha); // X3 = alpha^2 - 8 * beta var beta4 = beta.redIAdd(beta); beta4 = beta4.redIAdd(beta4); var beta8 = beta4.redAdd(beta4); nx = alpha.redSqr().redISub(beta8); // Z3 = (Y1 + Z1)^2 - gamma - delta nz = this.y.redAdd(this.z).redSqr().redISub(gamma).redISub(delta); // Y3 = alpha * (4 * beta - X3) - 8 * gamma^2 var ggamma8 = gamma.redSqr(); ggamma8 = ggamma8.redIAdd(ggamma8); ggamma8 = ggamma8.redIAdd(ggamma8); ggamma8 = ggamma8.redIAdd(ggamma8); ny = alpha.redMul(beta4.redISub(nx)).redISub(ggamma8); } return this.curve.jpoint(nx, ny, nz); }; JPoint.prototype._dbl = function _dbl() { var a = this.curve.a; // 4M + 6S + 10A var jx = this.x; var jy = this.y; var jz = this.z; var jz4 = jz.redSqr().redSqr(); var jx2 = jx.redSqr(); var jy2 = jy.redSqr(); var c = jx2.redAdd(jx2).redIAdd(jx2).redIAdd(a.redMul(jz4)); var jxd4 = jx.redAdd(jx); jxd4 = jxd4.redIAdd(jxd4); var t1 = jxd4.redMul(jy2); var nx = c.redSqr().redISub(t1.redAdd(t1)); var t2 = t1.redISub(nx); var jyd8 = jy2.redSqr(); jyd8 = jyd8.redIAdd(jyd8); jyd8 = jyd8.redIAdd(jyd8); jyd8 = jyd8.redIAdd(jyd8); var ny = c.redMul(t2).redISub(jyd8); var nz = jy.redAdd(jy).redMul(jz); return this.curve.jpoint(nx, ny, nz); }; JPoint.prototype.trpl = function trpl() { if (!this.curve.zeroA) return this.dbl().add(this); // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html#tripling-tpl-2007-bl // 5M + 10S + ... // XX = X1^2 var xx = this.x.redSqr(); // YY = Y1^2 var yy = this.y.redSqr(); // ZZ = Z1^2 var zz = this.z.redSqr(); // YYYY = YY^2 var yyyy = yy.redSqr(); // M = 3 * XX + a * ZZ2; a = 0 var m = xx.redAdd(xx).redIAdd(xx); // MM = M^2 var mm = m.redSqr(); // E = 6 * ((X1 + YY)^2 - XX - YYYY) - MM var e = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy); e = e.redIAdd(e); e = e.redAdd(e).redIAdd(e); e = e.redISub(mm); // EE = E^2 var ee = e.redSqr(); // T = 16*YYYY var t = yyyy.redIAdd(yyyy); t = t.redIAdd(t); t = t.redIAdd(t); t = t.redIAdd(t); // U = (M + E)^2 - MM - EE - T var u = m.redIAdd(e).redSqr().redISub(mm).redISub(ee).redISub(t); // X3 = 4 * (X1 * EE - 4 * YY * U) var yyu4 = yy.redMul(u); yyu4 = yyu4.redIAdd(yyu4); yyu4 = yyu4.redIAdd(yyu4); var nx = this.x.redMul(ee).redISub(yyu4); nx = nx.redIAdd(nx); nx = nx.redIAdd(nx); // Y3 = 8 * Y1 * (U * (T - U) - E * EE) var ny = this.y.redMul(u.redMul(t.redISub(u)).redISub(e.redMul(ee))); ny = ny.redIAdd(ny); ny = ny.redIAdd(ny); ny = ny.redIAdd(ny); // Z3 = (Z1 + E)^2 - ZZ - EE var nz = this.z.redAdd(e).redSqr().redISub(zz).redISub(ee); return this.curve.jpoint(nx, ny, nz); }; JPoint.prototype.mul = function mul(k, kbase) { k = new BN(k, kbase); return this.curve._wnafMul(this, k); }; JPoint.prototype.eq = function eq(p) { if (p.type === 'affine') return this.eq(p.toJ()); if (this === p) return true; // x1 * z2^2 == x2 * z1^2 var z2 = this.z.redSqr(); var pz2 = p.z.redSqr(); if (this.x.redMul(pz2).redISub(p.x.redMul(z2)).cmpn(0) !== 0) return false; // y1 * z2^3 == y2 * z1^3 var z3 = z2.redMul(this.z); var pz3 = pz2.redMul(p.z); return this.y.redMul(pz3).redISub(p.y.redMul(z3)).cmpn(0) === 0; }; JPoint.prototype.inspect = function inspect() { if (this.isInfinity()) return ''; return ''; }; JPoint.prototype.isInfinity = function isInfinity() { // XXX This code assumes that zero is always zero in red return this.z.cmpn(0) === 0; }; },{"../../elliptic":125,"../curve":128,"bn.js":29,"inherits":167}],131:[function(require,module,exports){ 'use strict'; var curves = exports; var hash = require('hash.js'); var elliptic = require('../elliptic'); var assert = elliptic.utils.assert; function PresetCurve(options) { if (options.type === 'short') this.curve = new elliptic.curve.short(options); else if (options.type === 'edwards') this.curve = new elliptic.curve.edwards(options); else this.curve = new elliptic.curve.mont(options); this.g = this.curve.g; this.n = this.curve.n; this.hash = options.hash; assert(this.g.validate(), 'Invalid curve'); assert(this.g.mul(this.n).isInfinity(), 'Invalid curve, G*N != O'); } curves.PresetCurve = PresetCurve; function defineCurve(name, options) { Object.defineProperty(curves, name, { configurable: true, enumerable: true, get: function() { var curve = new PresetCurve(options); Object.defineProperty(curves, name, { configurable: true, enumerable: true, value: curve }); return curve; } }); } defineCurve('p192', { type: 'short', prime: 'p192', p: 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff', a: 'ffffffff ffffffff ffffffff fffffffe ffffffff fffffffc', b: '64210519 e59c80e7 0fa7e9ab 72243049 feb8deec c146b9b1', n: 'ffffffff ffffffff ffffffff 99def836 146bc9b1 b4d22831', hash: hash.sha256, gRed: false, g: [ '188da80e b03090f6 7cbf20eb 43a18800 f4ff0afd 82ff1012', '07192b95 ffc8da78 631011ed 6b24cdd5 73f977a1 1e794811' ] }); defineCurve('p224', { type: 'short', prime: 'p224', p: 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001', a: 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff fffffffe', b: 'b4050a85 0c04b3ab f5413256 5044b0b7 d7bfd8ba 270b3943 2355ffb4', n: 'ffffffff ffffffff ffffffff ffff16a2 e0b8f03e 13dd2945 5c5c2a3d', hash: hash.sha256, gRed: false, g: [ 'b70e0cbd 6bb4bf7f 321390b9 4a03c1d3 56c21122 343280d6 115c1d21', 'bd376388 b5f723fb 4c22dfe6 cd4375a0 5a074764 44d58199 85007e34' ] }); defineCurve('p256', { type: 'short', prime: null, p: 'ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff ffffffff', a: 'ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff fffffffc', b: '5ac635d8 aa3a93e7 b3ebbd55 769886bc 651d06b0 cc53b0f6 3bce3c3e 27d2604b', n: 'ffffffff 00000000 ffffffff ffffffff bce6faad a7179e84 f3b9cac2 fc632551', hash: hash.sha256, gRed: false, g: [ '6b17d1f2 e12c4247 f8bce6e5 63a440f2 77037d81 2deb33a0 f4a13945 d898c296', '4fe342e2 fe1a7f9b 8ee7eb4a 7c0f9e16 2bce3357 6b315ece cbb64068 37bf51f5' ] }); defineCurve('p384', { type: 'short', prime: null, p: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' + 'fffffffe ffffffff 00000000 00000000 ffffffff', a: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' + 'fffffffe ffffffff 00000000 00000000 fffffffc', b: 'b3312fa7 e23ee7e4 988e056b e3f82d19 181d9c6e fe814112 0314088f ' + '5013875a c656398d 8a2ed19d 2a85c8ed d3ec2aef', n: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff c7634d81 ' + 'f4372ddf 581a0db2 48b0a77a ecec196a ccc52973', hash: hash.sha384, gRed: false, g: [ 'aa87ca22 be8b0537 8eb1c71e f320ad74 6e1d3b62 8ba79b98 59f741e0 82542a38 ' + '5502f25d bf55296c 3a545e38 72760ab7', '3617de4a 96262c6f 5d9e98bf 9292dc29 f8f41dbd 289a147c e9da3113 b5f0b8c0 ' + '0a60b1ce 1d7e819d 7a431d7c 90ea0e5f' ] }); defineCurve('p521', { type: 'short', prime: null, p: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' + 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' + 'ffffffff ffffffff ffffffff ffffffff ffffffff', a: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' + 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' + 'ffffffff ffffffff ffffffff ffffffff fffffffc', b: '00000051 953eb961 8e1c9a1f 929a21a0 b68540ee a2da725b ' + '99b315f3 b8b48991 8ef109e1 56193951 ec7e937b 1652c0bd ' + '3bb1bf07 3573df88 3d2c34f1 ef451fd4 6b503f00', n: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' + 'ffffffff ffffffff fffffffa 51868783 bf2f966b 7fcc0148 ' + 'f709a5d0 3bb5c9b8 899c47ae bb6fb71e 91386409', hash: hash.sha512, gRed: false, g: [ '000000c6 858e06b7 0404e9cd 9e3ecb66 2395b442 9c648139 ' + '053fb521 f828af60 6b4d3dba a14b5e77 efe75928 fe1dc127 ' + 'a2ffa8de 3348b3c1 856a429b f97e7e31 c2e5bd66', '00000118 39296a78 9a3bc004 5c8a5fb4 2c7d1bd9 98f54449 ' + '579b4468 17afbd17 273e662c 97ee7299 5ef42640 c550b901 ' + '3fad0761 353c7086 a272c240 88be9476 9fd16650' ] }); defineCurve('curve25519', { type: 'mont', prime: 'p25519', p: '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed', a: '76d06', b: '0', n: '1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed', hash: hash.sha256, gRed: false, g: [ '9' ] }); defineCurve('ed25519', { type: 'edwards', prime: 'p25519', p: '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed', a: '-1', c: '1', // -121665 * (121666^(-1)) (mod P) d: '52036cee2b6ffe73 8cc740797779e898 00700a4d4141d8ab 75eb4dca135978a3', n: '1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed', hash: hash.sha256, gRed: false, g: [ '216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a', // 4/5 '6666666666666666666666666666666666666666666666666666666666666658' ] }); var pre; try { pre = require('./precomputed/secp256k1'); } catch (e) { pre = undefined; } defineCurve('secp256k1', { type: 'short', prime: 'k256', p: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f', a: '0', b: '7', n: 'ffffffff ffffffff ffffffff fffffffe baaedce6 af48a03b bfd25e8c d0364141', h: '1', hash: hash.sha256, // Precomputed endomorphism beta: '7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee', lambda: '5363ad4cc05c30e0a5261c028812645a122e22ea20816678df02967c1b23bd72', basis: [ { a: '3086d221a7d46bcde86c90e49284eb15', b: '-e4437ed6010e88286f547fa90abfe4c3' }, { a: '114ca50f7a8e2f3f657c1108d9d44cfd8', b: '3086d221a7d46bcde86c90e49284eb15' } ], gRed: false, g: [ '79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798', '483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8', pre ] }); },{"../elliptic":125,"./precomputed/secp256k1":139,"hash.js":155}],132:[function(require,module,exports){ 'use strict'; var BN = require('bn.js'); var elliptic = require('../../elliptic'); var utils = elliptic.utils; var assert = utils.assert; var KeyPair = require('./key'); var Signature = require('./signature'); function EC(options) { if (!(this instanceof EC)) return new EC(options); // Shortcut `elliptic.ec(curve-name)` if (typeof options === 'string') { assert(elliptic.curves.hasOwnProperty(options), 'Unknown curve ' + options); options = elliptic.curves[options]; } // Shortcut for `elliptic.ec(elliptic.curves.curveName)` if (options instanceof elliptic.curves.PresetCurve) options = { curve: options }; this.curve = options.curve.curve; this.n = this.curve.n; this.nh = this.n.ushrn(1); this.g = this.curve.g; // Point on curve this.g = options.curve.g; this.g.precompute(options.curve.n.bitLength() + 1); // Hash for function for DRBG this.hash = options.hash || options.curve.hash; } module.exports = EC; EC.prototype.keyPair = function keyPair(options) { return new KeyPair(this, options); }; EC.prototype.keyFromPrivate = function keyFromPrivate(priv, enc) { return KeyPair.fromPrivate(this, priv, enc); }; EC.prototype.keyFromPublic = function keyFromPublic(pub, enc) { return KeyPair.fromPublic(this, pub, enc); }; EC.prototype.genKeyPair = function genKeyPair(options) { if (!options) options = {}; // Instantiate Hmac_DRBG var drbg = new elliptic.hmacDRBG({ hash: this.hash, pers: options.pers, entropy: options.entropy || elliptic.rand(this.hash.hmacStrength), nonce: this.n.toArray() }); var bytes = this.n.byteLength(); var ns2 = this.n.sub(new BN(2)); do { var priv = new BN(drbg.generate(bytes)); if (priv.cmp(ns2) > 0) continue; priv.iaddn(1); return this.keyFromPrivate(priv); } while (true); }; EC.prototype._truncateToN = function truncateToN(msg, truncOnly) { var delta = msg.byteLength() * 8 - this.n.bitLength(); if (delta > 0) msg = msg.ushrn(delta); if (!truncOnly && msg.cmp(this.n) >= 0) return msg.sub(this.n); else return msg; }; EC.prototype.sign = function sign(msg, key, enc, options) { if (typeof enc === 'object') { options = enc; enc = null; } if (!options) options = {}; key = this.keyFromPrivate(key, enc); msg = this._truncateToN(new BN(msg, 16)); // Zero-extend key to provide enough entropy var bytes = this.n.byteLength(); var bkey = key.getPrivate().toArray('be', bytes); // Zero-extend nonce to have the same byte size as N var nonce = msg.toArray('be', bytes); // Instantiate Hmac_DRBG var drbg = new elliptic.hmacDRBG({ hash: this.hash, entropy: bkey, nonce: nonce, pers: options.pers, persEnc: options.persEnc }); // Number of bytes to generate var ns1 = this.n.sub(new BN(1)); for (var iter = 0; true; iter++) { var k = options.k ? options.k(iter) : new BN(drbg.generate(this.n.byteLength())); k = this._truncateToN(k, true); if (k.cmpn(1) <= 0 || k.cmp(ns1) >= 0) continue; var kp = this.g.mul(k); if (kp.isInfinity()) continue; var kpX = kp.getX(); var r = kpX.umod(this.n); if (r.cmpn(0) === 0) continue; var s = k.invm(this.n).mul(r.mul(key.getPrivate()).iadd(msg)); s = s.umod(this.n); if (s.cmpn(0) === 0) continue; var recoveryParam = (kp.getY().isOdd() ? 1 : 0) | (kpX.cmp(r) !== 0 ? 2 : 0); // Use complement of `s`, if it is > `n / 2` if (options.canonical && s.cmp(this.nh) > 0) { s = this.n.sub(s); recoveryParam ^= 1; } return new Signature({ r: r, s: s, recoveryParam: recoveryParam }); } }; EC.prototype.verify = function verify(msg, signature, key, enc) { msg = this._truncateToN(new BN(msg, 16)); key = this.keyFromPublic(key, enc); signature = new Signature(signature, 'hex'); // Perform primitive values validation var r = signature.r; var s = signature.s; if (r.cmpn(1) < 0 || r.cmp(this.n) >= 0) return false; if (s.cmpn(1) < 0 || s.cmp(this.n) >= 0) return false; // Validate signature var sinv = s.invm(this.n); var u1 = sinv.mul(msg).umod(this.n); var u2 = sinv.mul(r).umod(this.n); var p = this.g.mulAdd(u1, key.getPublic(), u2); if (p.isInfinity()) return false; return p.getX().umod(this.n).cmp(r) === 0; }; EC.prototype.recoverPubKey = function(msg, signature, j, enc) { assert((3 & j) === j, 'The recovery param is more than two bits'); signature = new Signature(signature, enc); var n = this.n; var e = new BN(msg); var r = signature.r; var s = signature.s; // A set LSB signifies that the y-coordinate is odd var isYOdd = j & 1; var isSecondKey = j >> 1; if (r.cmp(this.curve.p.umod(this.curve.n)) >= 0 && isSecondKey) throw new Error('Unable to find sencond key candinate'); // 1.1. Let x = r + jn. if (isSecondKey) r = this.curve.pointFromX(r.add(this.curve.n), isYOdd); else r = this.curve.pointFromX(r, isYOdd); var eNeg = n.sub(e); // 1.6.1 Compute Q = r^-1 (sR - eG) // Q = r^-1 (sR + -eG) var rInv = signature.r.invm(n); return this.g.mulAdd(eNeg, r, s).mul(rInv); }; EC.prototype.getKeyRecoveryParam = function(e, signature, Q, enc) { signature = new Signature(signature, enc); if (signature.recoveryParam !== null) return signature.recoveryParam; for (var i = 0; i < 4; i++) { var Qprime; try { Qprime = this.recoverPubKey(e, signature, i); } catch (e) { continue; } if (Qprime.eq(Q)) return i; } throw new Error('Unable to find valid recovery factor'); }; },{"../../elliptic":125,"./key":133,"./signature":134,"bn.js":29}],133:[function(require,module,exports){ 'use strict'; var BN = require('bn.js'); function KeyPair(ec, options) { this.ec = ec; this.priv = null; this.pub = null; // KeyPair(ec, { priv: ..., pub: ... }) if (options.priv) this._importPrivate(options.priv, options.privEnc); if (options.pub) this._importPublic(options.pub, options.pubEnc); } module.exports = KeyPair; KeyPair.fromPublic = function fromPublic(ec, pub, enc) { if (pub instanceof KeyPair) return pub; return new KeyPair(ec, { pub: pub, pubEnc: enc }); }; KeyPair.fromPrivate = function fromPrivate(ec, priv, enc) { if (priv instanceof KeyPair) return priv; return new KeyPair(ec, { priv: priv, privEnc: enc }); }; KeyPair.prototype.validate = function validate() { var pub = this.getPublic(); if (pub.isInfinity()) return { result: false, reason: 'Invalid public key' }; if (!pub.validate()) return { result: false, reason: 'Public key is not a point' }; if (!pub.mul(this.ec.curve.n).isInfinity()) return { result: false, reason: 'Public key * N != O' }; return { result: true, reason: null }; }; KeyPair.prototype.getPublic = function getPublic(compact, enc) { // compact is optional argument if (typeof compact === 'string') { enc = compact; compact = null; } if (!this.pub) this.pub = this.ec.g.mul(this.priv); if (!enc) return this.pub; return this.pub.encode(enc, compact); }; KeyPair.prototype.getPrivate = function getPrivate(enc) { if (enc === 'hex') return this.priv.toString(16, 2); else return this.priv; }; KeyPair.prototype._importPrivate = function _importPrivate(key, enc) { this.priv = new BN(key, enc || 16); // Ensure that the priv won't be bigger than n, otherwise we may fail // in fixed multiplication method this.priv = this.priv.umod(this.ec.curve.n); }; KeyPair.prototype._importPublic = function _importPublic(key, enc) { if (key.x || key.y) { this.pub = this.ec.curve.point(key.x, key.y); return; } this.pub = this.ec.curve.decodePoint(key, enc); }; // ECDH KeyPair.prototype.derive = function derive(pub) { return pub.mul(this.priv).getX(); }; // ECDSA KeyPair.prototype.sign = function sign(msg, enc, options) { return this.ec.sign(msg, this, enc, options); }; KeyPair.prototype.verify = function verify(msg, signature) { return this.ec.verify(msg, signature, this); }; KeyPair.prototype.inspect = function inspect() { return ''; }; },{"bn.js":29}],134:[function(require,module,exports){ 'use strict'; var BN = require('bn.js'); var elliptic = require('../../elliptic'); var utils = elliptic.utils; var assert = utils.assert; function Signature(options, enc) { if (options instanceof Signature) return options; if (this._importDER(options, enc)) return; assert(options.r && options.s, 'Signature without r or s'); this.r = new BN(options.r, 16); this.s = new BN(options.s, 16); if (options.recoveryParam === undefined) this.recoveryParam = null; else this.recoveryParam = options.recoveryParam; } module.exports = Signature; function Position() { this.place = 0; } function getLength(buf, p) { var initial = buf[p.place++]; if (!(initial & 0x80)) { return initial; } var octetLen = initial & 0xf; var val = 0; for (var i = 0, off = p.place; i < octetLen; i++, off++) { val <<= 8; val |= buf[off]; } p.place = off; return val; } function rmPadding(buf) { var i = 0; var len = buf.length - 1; while (!buf[i] && !(buf[i + 1] & 0x80) && i < len) { i++; } if (i === 0) { return buf; } return buf.slice(i); } Signature.prototype._importDER = function _importDER(data, enc) { data = utils.toArray(data, enc); var p = new Position(); if (data[p.place++] !== 0x30) { return false; } var len = getLength(data, p); if ((len + p.place) !== data.length) { return false; } if (data[p.place++] !== 0x02) { return false; } var rlen = getLength(data, p); var r = data.slice(p.place, rlen + p.place); p.place += rlen; if (data[p.place++] !== 0x02) { return false; } var slen = getLength(data, p); if (data.length !== slen + p.place) { return false; } var s = data.slice(p.place, slen + p.place); if (r[0] === 0 && (r[1] & 0x80)) { r = r.slice(1); } if (s[0] === 0 && (s[1] & 0x80)) { s = s.slice(1); } this.r = new BN(r); this.s = new BN(s); this.recoveryParam = null; return true; }; function constructLength(arr, len) { if (len < 0x80) { arr.push(len); return; } var octets = 1 + (Math.log(len) / Math.LN2 >>> 3); arr.push(octets | 0x80); while (--octets) { arr.push((len >>> (octets << 3)) & 0xff); } arr.push(len); } Signature.prototype.toDER = function toDER(enc) { var r = this.r.toArray(); var s = this.s.toArray(); // Pad values if (r[0] & 0x80) r = [ 0 ].concat(r); // Pad values if (s[0] & 0x80) s = [ 0 ].concat(s); r = rmPadding(r); s = rmPadding(s); while (!s[0] && !(s[1] & 0x80)) { s = s.slice(1); } var arr = [ 0x02 ]; constructLength(arr, r.length); arr = arr.concat(r); arr.push(0x02); constructLength(arr, s.length); var backHalf = arr.concat(s); var res = [ 0x30 ]; constructLength(res, backHalf.length); res = res.concat(backHalf); return utils.encode(res, enc); }; },{"../../elliptic":125,"bn.js":29}],135:[function(require,module,exports){ 'use strict'; var hash = require('hash.js'); var elliptic = require('../../elliptic'); var utils = elliptic.utils; var assert = utils.assert; var parseBytes = utils.parseBytes; var KeyPair = require('./key'); var Signature = require('./signature'); function EDDSA(curve) { assert(curve === 'ed25519', 'only tested with ed25519 so far'); if (!(this instanceof EDDSA)) return new EDDSA(curve); var curve = elliptic.curves[curve].curve; this.curve = curve; this.g = curve.g; this.g.precompute(curve.n.bitLength() + 1); this.pointClass = curve.point().constructor; this.encodingLength = Math.ceil(curve.n.bitLength() / 8); this.hash = hash.sha512; } module.exports = EDDSA; /** * @param {Array|String} message - message bytes * @param {Array|String|KeyPair} secret - secret bytes or a keypair * @returns {Signature} - signature */ EDDSA.prototype.sign = function sign(message, secret) { message = parseBytes(message); var key = this.keyFromSecret(secret); var r = this.hashInt(key.messagePrefix(), message); var R = this.g.mul(r); var Rencoded = this.encodePoint(R); var s_ = this.hashInt(Rencoded, key.pubBytes(), message) .mul(key.priv()); var S = r.add(s_).umod(this.curve.n); return this.makeSignature({ R: R, S: S, Rencoded: Rencoded }); }; /** * @param {Array} message - message bytes * @param {Array|String|Signature} sig - sig bytes * @param {Array|String|Point|KeyPair} pub - public key * @returns {Boolean} - true if public key matches sig of message */ EDDSA.prototype.verify = function verify(message, sig, pub) { message = parseBytes(message); sig = this.makeSignature(sig); var key = this.keyFromPublic(pub); var h = this.hashInt(sig.Rencoded(), key.pubBytes(), message); var SG = this.g.mul(sig.S()); var RplusAh = sig.R().add(key.pub().mul(h)); return RplusAh.eq(SG); }; EDDSA.prototype.hashInt = function hashInt() { var hash = this.hash(); for (var i = 0; i < arguments.length; i++) hash.update(arguments[i]); return utils.intFromLE(hash.digest()).umod(this.curve.n); }; EDDSA.prototype.keyFromPublic = function keyFromPublic(pub) { return KeyPair.fromPublic(this, pub); }; EDDSA.prototype.keyFromSecret = function keyFromSecret(secret) { return KeyPair.fromSecret(this, secret); }; EDDSA.prototype.makeSignature = function makeSignature(sig) { if (sig instanceof Signature) return sig; return new Signature(this, sig); }; /** * * https://tools.ietf.org/html/draft-josefsson-eddsa-ed25519-03#section-5.2 * * EDDSA defines methods for encoding and decoding points and integers. These are * helper convenience methods, that pass along to utility functions implied * parameters. * */ EDDSA.prototype.encodePoint = function encodePoint(point) { var enc = point.getY().toArray('le', this.encodingLength); enc[this.encodingLength - 1] |= point.getX().isOdd() ? 0x80 : 0; return enc; }; EDDSA.prototype.decodePoint = function decodePoint(bytes) { bytes = utils.parseBytes(bytes); var lastIx = bytes.length - 1; var normed = bytes.slice(0, lastIx).concat(bytes[lastIx] & ~0x80); var xIsOdd = (bytes[lastIx] & 0x80) !== 0; var y = utils.intFromLE(normed); return this.curve.pointFromY(y, xIsOdd); }; EDDSA.prototype.encodeInt = function encodeInt(num) { return num.toArray('le', this.encodingLength); }; EDDSA.prototype.decodeInt = function decodeInt(bytes) { return utils.intFromLE(bytes); }; EDDSA.prototype.isPoint = function isPoint(val) { return val instanceof this.pointClass; }; },{"../../elliptic":125,"./key":136,"./signature":137,"hash.js":155}],136:[function(require,module,exports){ 'use strict'; var elliptic = require('../../elliptic'); var utils = elliptic.utils; var assert = utils.assert; var parseBytes = utils.parseBytes; var cachedProperty = utils.cachedProperty; /** * @param {EDDSA} eddsa - instance * @param {Object} params - public/private key parameters * * @param {Array} [params.secret] - secret seed bytes * @param {Point} [params.pub] - public key point (aka `A` in eddsa terms) * @param {Array} [params.pub] - public key point encoded as bytes * */ function KeyPair(eddsa, params) { this.eddsa = eddsa; this._secret = parseBytes(params.secret); if (eddsa.isPoint(params.pub)) this._pub = params.pub; else this._pubBytes = parseBytes(params.pub); } KeyPair.fromPublic = function fromPublic(eddsa, pub) { if (pub instanceof KeyPair) return pub; return new KeyPair(eddsa, { pub: pub }); }; KeyPair.fromSecret = function fromSecret(eddsa, secret) { if (secret instanceof KeyPair) return secret; return new KeyPair(eddsa, { secret: secret }); }; KeyPair.prototype.secret = function secret() { return this._secret; }; cachedProperty(KeyPair, function pubBytes() { return this.eddsa.encodePoint(this.pub()); }); cachedProperty(KeyPair, function pub() { if (this._pubBytes) return this.eddsa.decodePoint(this._pubBytes); return this.eddsa.g.mul(this.priv()); }); cachedProperty(KeyPair, function privBytes() { var eddsa = this.eddsa; var hash = this.hash(); var lastIx = eddsa.encodingLength - 1; var a = hash.slice(0, eddsa.encodingLength); a[0] &= 248; a[lastIx] &= 127; a[lastIx] |= 64; return a; }); cachedProperty(KeyPair, function priv() { return this.eddsa.decodeInt(this.privBytes()); }); cachedProperty(KeyPair, function hash() { return this.eddsa.hash().update(this.secret()).digest(); }); cachedProperty(KeyPair, function messagePrefix() { return this.hash().slice(this.eddsa.encodingLength); }); KeyPair.prototype.sign = function sign(message) { assert(this._secret, 'KeyPair can only verify'); return this.eddsa.sign(message, this); }; KeyPair.prototype.verify = function verify(message, sig) { return this.eddsa.verify(message, sig, this); }; KeyPair.prototype.getSecret = function getSecret(enc) { assert(this._secret, 'KeyPair is public only'); return utils.encode(this.secret(), enc); }; KeyPair.prototype.getPublic = function getPublic(enc) { return utils.encode(this.pubBytes(), enc); }; module.exports = KeyPair; },{"../../elliptic":125}],137:[function(require,module,exports){ 'use strict'; var BN = require('bn.js'); var elliptic = require('../../elliptic'); var utils = elliptic.utils; var assert = utils.assert; var cachedProperty = utils.cachedProperty; var parseBytes = utils.parseBytes; /** * @param {EDDSA} eddsa - eddsa instance * @param {Array|Object} sig - * @param {Array|Point} [sig.R] - R point as Point or bytes * @param {Array|bn} [sig.S] - S scalar as bn or bytes * @param {Array} [sig.Rencoded] - R point encoded * @param {Array} [sig.Sencoded] - S scalar encoded */ function Signature(eddsa, sig) { this.eddsa = eddsa; if (typeof sig !== 'object') sig = parseBytes(sig); if (Array.isArray(sig)) { sig = { R: sig.slice(0, eddsa.encodingLength), S: sig.slice(eddsa.encodingLength) }; } assert(sig.R && sig.S, 'Signature without R or S'); if (eddsa.isPoint(sig.R)) this._R = sig.R; if (sig.S instanceof BN) this._S = sig.S; this._Rencoded = Array.isArray(sig.R) ? sig.R : sig.Rencoded; this._Sencoded = Array.isArray(sig.S) ? sig.S : sig.Sencoded; } cachedProperty(Signature, function S() { return this.eddsa.decodeInt(this.Sencoded()); }); cachedProperty(Signature, function R() { return this.eddsa.decodePoint(this.Rencoded()); }); cachedProperty(Signature, function Rencoded() { return this.eddsa.encodePoint(this.R()); }); cachedProperty(Signature, function Sencoded() { return this.eddsa.encodeInt(this.S()); }); Signature.prototype.toBytes = function toBytes() { return this.Rencoded().concat(this.Sencoded()); }; Signature.prototype.toHex = function toHex() { return utils.encode(this.toBytes(), 'hex').toUpperCase(); }; module.exports = Signature; },{"../../elliptic":125,"bn.js":29}],138:[function(require,module,exports){ 'use strict'; var hash = require('hash.js'); var elliptic = require('../elliptic'); var utils = elliptic.utils; var assert = utils.assert; function HmacDRBG(options) { if (!(this instanceof HmacDRBG)) return new HmacDRBG(options); this.hash = options.hash; this.predResist = !!options.predResist; this.outLen = this.hash.outSize; this.minEntropy = options.minEntropy || this.hash.hmacStrength; this.reseed = null; this.reseedInterval = null; this.K = null; this.V = null; var entropy = utils.toArray(options.entropy, options.entropyEnc); var nonce = utils.toArray(options.nonce, options.nonceEnc); var pers = utils.toArray(options.pers, options.persEnc); assert(entropy.length >= (this.minEntropy / 8), 'Not enough entropy. Minimum is: ' + this.minEntropy + ' bits'); this._init(entropy, nonce, pers); } module.exports = HmacDRBG; HmacDRBG.prototype._init = function init(entropy, nonce, pers) { var seed = entropy.concat(nonce).concat(pers); this.K = new Array(this.outLen / 8); this.V = new Array(this.outLen / 8); for (var i = 0; i < this.V.length; i++) { this.K[i] = 0x00; this.V[i] = 0x01; } this._update(seed); this.reseed = 1; this.reseedInterval = 0x1000000000000; // 2^48 }; HmacDRBG.prototype._hmac = function hmac() { return new hash.hmac(this.hash, this.K); }; HmacDRBG.prototype._update = function update(seed) { var kmac = this._hmac() .update(this.V) .update([ 0x00 ]); if (seed) kmac = kmac.update(seed); this.K = kmac.digest(); this.V = this._hmac().update(this.V).digest(); if (!seed) return; this.K = this._hmac() .update(this.V) .update([ 0x01 ]) .update(seed) .digest(); this.V = this._hmac().update(this.V).digest(); }; HmacDRBG.prototype.reseed = function reseed(entropy, entropyEnc, add, addEnc) { // Optional entropy enc if (typeof entropyEnc !== 'string') { addEnc = add; add = entropyEnc; entropyEnc = null; } entropy = utils.toBuffer(entropy, entropyEnc); add = utils.toBuffer(add, addEnc); assert(entropy.length >= (this.minEntropy / 8), 'Not enough entropy. Minimum is: ' + this.minEntropy + ' bits'); this._update(entropy.concat(add || [])); this.reseed = 1; }; HmacDRBG.prototype.generate = function generate(len, enc, add, addEnc) { if (this.reseed > this.reseedInterval) throw new Error('Reseed is required'); // Optional encoding if (typeof enc !== 'string') { addEnc = add; add = enc; enc = null; } // Optional additional data if (add) { add = utils.toArray(add, addEnc); this._update(add); } var temp = []; while (temp.length < len) { this.V = this._hmac().update(this.V).digest(); temp = temp.concat(this.V); } var res = temp.slice(0, len); this._update(add); this.reseed++; return utils.encode(res, enc); }; },{"../elliptic":125,"hash.js":155}],139:[function(require,module,exports){ module.exports = { doubles: { step: 4, points: [ [ 'e60fce93b59e9ec53011aabc21c23e97b2a31369b87a5ae9c44ee89e2a6dec0a', 'f7e3507399e595929db99f34f57937101296891e44d23f0be1f32cce69616821' ], [ '8282263212c609d9ea2a6e3e172de238d8c39cabd5ac1ca10646e23fd5f51508', '11f8a8098557dfe45e8256e830b60ace62d613ac2f7b17bed31b6eaff6e26caf' ], [ '175e159f728b865a72f99cc6c6fc846de0b93833fd2222ed73fce5b551e5b739', 'd3506e0d9e3c79eba4ef97a51ff71f5eacb5955add24345c6efa6ffee9fed695' ], [ '363d90d447b00c9c99ceac05b6262ee053441c7e55552ffe526bad8f83ff4640', '4e273adfc732221953b445397f3363145b9a89008199ecb62003c7f3bee9de9' ], [ '8b4b5f165df3c2be8c6244b5b745638843e4a781a15bcd1b69f79a55dffdf80c', '4aad0a6f68d308b4b3fbd7813ab0da04f9e336546162ee56b3eff0c65fd4fd36' ], [ '723cbaa6e5db996d6bf771c00bd548c7b700dbffa6c0e77bcb6115925232fcda', '96e867b5595cc498a921137488824d6e2660a0653779494801dc069d9eb39f5f' ], [ 'eebfa4d493bebf98ba5feec812c2d3b50947961237a919839a533eca0e7dd7fa', '5d9a8ca3970ef0f269ee7edaf178089d9ae4cdc3a711f712ddfd4fdae1de8999' ], [ '100f44da696e71672791d0a09b7bde459f1215a29b3c03bfefd7835b39a48db0', 'cdd9e13192a00b772ec8f3300c090666b7ff4a18ff5195ac0fbd5cd62bc65a09' ], [ 'e1031be262c7ed1b1dc9227a4a04c017a77f8d4464f3b3852c8acde6e534fd2d', '9d7061928940405e6bb6a4176597535af292dd419e1ced79a44f18f29456a00d' ], [ 'feea6cae46d55b530ac2839f143bd7ec5cf8b266a41d6af52d5e688d9094696d', 'e57c6b6c97dce1bab06e4e12bf3ecd5c981c8957cc41442d3155debf18090088' ], [ 'da67a91d91049cdcb367be4be6ffca3cfeed657d808583de33fa978bc1ec6cb1', '9bacaa35481642bc41f463f7ec9780e5dec7adc508f740a17e9ea8e27a68be1d' ], [ '53904faa0b334cdda6e000935ef22151ec08d0f7bb11069f57545ccc1a37b7c0', '5bc087d0bc80106d88c9eccac20d3c1c13999981e14434699dcb096b022771c8' ], [ '8e7bcd0bd35983a7719cca7764ca906779b53a043a9b8bcaeff959f43ad86047', '10b7770b2a3da4b3940310420ca9514579e88e2e47fd68b3ea10047e8460372a' ], [ '385eed34c1cdff21e6d0818689b81bde71a7f4f18397e6690a841e1599c43862', '283bebc3e8ea23f56701de19e9ebf4576b304eec2086dc8cc0458fe5542e5453' ], [ '6f9d9b803ecf191637c73a4413dfa180fddf84a5947fbc9c606ed86c3fac3a7', '7c80c68e603059ba69b8e2a30e45c4d47ea4dd2f5c281002d86890603a842160' ], [ '3322d401243c4e2582a2147c104d6ecbf774d163db0f5e5313b7e0e742d0e6bd', '56e70797e9664ef5bfb019bc4ddaf9b72805f63ea2873af624f3a2e96c28b2a0' ], [ '85672c7d2de0b7da2bd1770d89665868741b3f9af7643397721d74d28134ab83', '7c481b9b5b43b2eb6374049bfa62c2e5e77f17fcc5298f44c8e3094f790313a6' ], [ '948bf809b1988a46b06c9f1919413b10f9226c60f668832ffd959af60c82a0a', '53a562856dcb6646dc6b74c5d1c3418c6d4dff08c97cd2bed4cb7f88d8c8e589' ], [ '6260ce7f461801c34f067ce0f02873a8f1b0e44dfc69752accecd819f38fd8e8', 'bc2da82b6fa5b571a7f09049776a1ef7ecd292238051c198c1a84e95b2b4ae17' ], [ 'e5037de0afc1d8d43d8348414bbf4103043ec8f575bfdc432953cc8d2037fa2d', '4571534baa94d3b5f9f98d09fb990bddbd5f5b03ec481f10e0e5dc841d755bda' ], [ 'e06372b0f4a207adf5ea905e8f1771b4e7e8dbd1c6a6c5b725866a0ae4fce725', '7a908974bce18cfe12a27bb2ad5a488cd7484a7787104870b27034f94eee31dd' ], [ '213c7a715cd5d45358d0bbf9dc0ce02204b10bdde2a3f58540ad6908d0559754', '4b6dad0b5ae462507013ad06245ba190bb4850f5f36a7eeddff2c27534b458f2' ], [ '4e7c272a7af4b34e8dbb9352a5419a87e2838c70adc62cddf0cc3a3b08fbd53c', '17749c766c9d0b18e16fd09f6def681b530b9614bff7dd33e0b3941817dcaae6' ], [ 'fea74e3dbe778b1b10f238ad61686aa5c76e3db2be43057632427e2840fb27b6', '6e0568db9b0b13297cf674deccb6af93126b596b973f7b77701d3db7f23cb96f' ], [ '76e64113f677cf0e10a2570d599968d31544e179b760432952c02a4417bdde39', 'c90ddf8dee4e95cf577066d70681f0d35e2a33d2b56d2032b4b1752d1901ac01' ], [ 'c738c56b03b2abe1e8281baa743f8f9a8f7cc643df26cbee3ab150242bcbb891', '893fb578951ad2537f718f2eacbfbbbb82314eef7880cfe917e735d9699a84c3' ], [ 'd895626548b65b81e264c7637c972877d1d72e5f3a925014372e9f6588f6c14b', 'febfaa38f2bc7eae728ec60818c340eb03428d632bb067e179363ed75d7d991f' ], [ 'b8da94032a957518eb0f6433571e8761ceffc73693e84edd49150a564f676e03', '2804dfa44805a1e4d7c99cc9762808b092cc584d95ff3b511488e4e74efdf6e7' ], [ 'e80fea14441fb33a7d8adab9475d7fab2019effb5156a792f1a11778e3c0df5d', 'eed1de7f638e00771e89768ca3ca94472d155e80af322ea9fcb4291b6ac9ec78' ], [ 'a301697bdfcd704313ba48e51d567543f2a182031efd6915ddc07bbcc4e16070', '7370f91cfb67e4f5081809fa25d40f9b1735dbf7c0a11a130c0d1a041e177ea1' ], [ '90ad85b389d6b936463f9d0512678de208cc330b11307fffab7ac63e3fb04ed4', 'e507a3620a38261affdcbd9427222b839aefabe1582894d991d4d48cb6ef150' ], [ '8f68b9d2f63b5f339239c1ad981f162ee88c5678723ea3351b7b444c9ec4c0da', '662a9f2dba063986de1d90c2b6be215dbbea2cfe95510bfdf23cbf79501fff82' ], [ 'e4f3fb0176af85d65ff99ff9198c36091f48e86503681e3e6686fd5053231e11', '1e63633ad0ef4f1c1661a6d0ea02b7286cc7e74ec951d1c9822c38576feb73bc' ], [ '8c00fa9b18ebf331eb961537a45a4266c7034f2f0d4e1d0716fb6eae20eae29e', 'efa47267fea521a1a9dc343a3736c974c2fadafa81e36c54e7d2a4c66702414b' ], [ 'e7a26ce69dd4829f3e10cec0a9e98ed3143d084f308b92c0997fddfc60cb3e41', '2a758e300fa7984b471b006a1aafbb18d0a6b2c0420e83e20e8a9421cf2cfd51' ], [ 'b6459e0ee3662ec8d23540c223bcbdc571cbcb967d79424f3cf29eb3de6b80ef', '67c876d06f3e06de1dadf16e5661db3c4b3ae6d48e35b2ff30bf0b61a71ba45' ], [ 'd68a80c8280bb840793234aa118f06231d6f1fc67e73c5a5deda0f5b496943e8', 'db8ba9fff4b586d00c4b1f9177b0e28b5b0e7b8f7845295a294c84266b133120' ], [ '324aed7df65c804252dc0270907a30b09612aeb973449cea4095980fc28d3d5d', '648a365774b61f2ff130c0c35aec1f4f19213b0c7e332843967224af96ab7c84' ], [ '4df9c14919cde61f6d51dfdbe5fee5dceec4143ba8d1ca888e8bd373fd054c96', '35ec51092d8728050974c23a1d85d4b5d506cdc288490192ebac06cad10d5d' ], [ '9c3919a84a474870faed8a9c1cc66021523489054d7f0308cbfc99c8ac1f98cd', 'ddb84f0f4a4ddd57584f044bf260e641905326f76c64c8e6be7e5e03d4fc599d' ], [ '6057170b1dd12fdf8de05f281d8e06bb91e1493a8b91d4cc5a21382120a959e5', '9a1af0b26a6a4807add9a2daf71df262465152bc3ee24c65e899be932385a2a8' ], [ 'a576df8e23a08411421439a4518da31880cef0fba7d4df12b1a6973eecb94266', '40a6bf20e76640b2c92b97afe58cd82c432e10a7f514d9f3ee8be11ae1b28ec8' ], [ '7778a78c28dec3e30a05fe9629de8c38bb30d1f5cf9a3a208f763889be58ad71', '34626d9ab5a5b22ff7098e12f2ff580087b38411ff24ac563b513fc1fd9f43ac' ], [ '928955ee637a84463729fd30e7afd2ed5f96274e5ad7e5cb09eda9c06d903ac', 'c25621003d3f42a827b78a13093a95eeac3d26efa8a8d83fc5180e935bcd091f' ], [ '85d0fef3ec6db109399064f3a0e3b2855645b4a907ad354527aae75163d82751', '1f03648413a38c0be29d496e582cf5663e8751e96877331582c237a24eb1f962' ], [ 'ff2b0dce97eece97c1c9b6041798b85dfdfb6d8882da20308f5404824526087e', '493d13fef524ba188af4c4dc54d07936c7b7ed6fb90e2ceb2c951e01f0c29907' ], [ '827fbbe4b1e880ea9ed2b2e6301b212b57f1ee148cd6dd28780e5e2cf856e241', 'c60f9c923c727b0b71bef2c67d1d12687ff7a63186903166d605b68baec293ec' ], [ 'eaa649f21f51bdbae7be4ae34ce6e5217a58fdce7f47f9aa7f3b58fa2120e2b3', 'be3279ed5bbbb03ac69a80f89879aa5a01a6b965f13f7e59d47a5305ba5ad93d' ], [ 'e4a42d43c5cf169d9391df6decf42ee541b6d8f0c9a137401e23632dda34d24f', '4d9f92e716d1c73526fc99ccfb8ad34ce886eedfa8d8e4f13a7f7131deba9414' ], [ '1ec80fef360cbdd954160fadab352b6b92b53576a88fea4947173b9d4300bf19', 'aeefe93756b5340d2f3a4958a7abbf5e0146e77f6295a07b671cdc1cc107cefd' ], [ '146a778c04670c2f91b00af4680dfa8bce3490717d58ba889ddb5928366642be', 'b318e0ec3354028add669827f9d4b2870aaa971d2f7e5ed1d0b297483d83efd0' ], [ 'fa50c0f61d22e5f07e3acebb1aa07b128d0012209a28b9776d76a8793180eef9', '6b84c6922397eba9b72cd2872281a68a5e683293a57a213b38cd8d7d3f4f2811' ], [ 'da1d61d0ca721a11b1a5bf6b7d88e8421a288ab5d5bba5220e53d32b5f067ec2', '8157f55a7c99306c79c0766161c91e2966a73899d279b48a655fba0f1ad836f1' ], [ 'a8e282ff0c9706907215ff98e8fd416615311de0446f1e062a73b0610d064e13', '7f97355b8db81c09abfb7f3c5b2515888b679a3e50dd6bd6cef7c73111f4cc0c' ], [ '174a53b9c9a285872d39e56e6913cab15d59b1fa512508c022f382de8319497c', 'ccc9dc37abfc9c1657b4155f2c47f9e6646b3a1d8cb9854383da13ac079afa73' ], [ '959396981943785c3d3e57edf5018cdbe039e730e4918b3d884fdff09475b7ba', '2e7e552888c331dd8ba0386a4b9cd6849c653f64c8709385e9b8abf87524f2fd' ], [ 'd2a63a50ae401e56d645a1153b109a8fcca0a43d561fba2dbb51340c9d82b151', 'e82d86fb6443fcb7565aee58b2948220a70f750af484ca52d4142174dcf89405' ], [ '64587e2335471eb890ee7896d7cfdc866bacbdbd3839317b3436f9b45617e073', 'd99fcdd5bf6902e2ae96dd6447c299a185b90a39133aeab358299e5e9faf6589' ], [ '8481bde0e4e4d885b3a546d3e549de042f0aa6cea250e7fd358d6c86dd45e458', '38ee7b8cba5404dd84a25bf39cecb2ca900a79c42b262e556d64b1b59779057e' ], [ '13464a57a78102aa62b6979ae817f4637ffcfed3c4b1ce30bcd6303f6caf666b', '69be159004614580ef7e433453ccb0ca48f300a81d0942e13f495a907f6ecc27' ], [ 'bc4a9df5b713fe2e9aef430bcc1dc97a0cd9ccede2f28588cada3a0d2d83f366', 'd3a81ca6e785c06383937adf4b798caa6e8a9fbfa547b16d758d666581f33c1' ], [ '8c28a97bf8298bc0d23d8c749452a32e694b65e30a9472a3954ab30fe5324caa', '40a30463a3305193378fedf31f7cc0eb7ae784f0451cb9459e71dc73cbef9482' ], [ '8ea9666139527a8c1dd94ce4f071fd23c8b350c5a4bb33748c4ba111faccae0', '620efabbc8ee2782e24e7c0cfb95c5d735b783be9cf0f8e955af34a30e62b945' ], [ 'dd3625faef5ba06074669716bbd3788d89bdde815959968092f76cc4eb9a9787', '7a188fa3520e30d461da2501045731ca941461982883395937f68d00c644a573' ], [ 'f710d79d9eb962297e4f6232b40e8f7feb2bc63814614d692c12de752408221e', 'ea98e67232d3b3295d3b535532115ccac8612c721851617526ae47a9c77bfc82' ] ] }, naf: { wnd: 7, points: [ [ 'f9308a019258c31049344f85f89d5229b531c845836f99b08601f113bce036f9', '388f7b0f632de8140fe337e62a37f3566500a99934c2231b6cb9fd7584b8e672' ], [ '2f8bde4d1a07209355b4a7250a5c5128e88b84bddc619ab7cba8d569b240efe4', 'd8ac222636e5e3d6d4dba9dda6c9c426f788271bab0d6840dca87d3aa6ac62d6' ], [ '5cbdf0646e5db4eaa398f365f2ea7a0e3d419b7e0330e39ce92bddedcac4f9bc', '6aebca40ba255960a3178d6d861a54dba813d0b813fde7b5a5082628087264da' ], [ 'acd484e2f0c7f65309ad178a9f559abde09796974c57e714c35f110dfc27ccbe', 'cc338921b0a7d9fd64380971763b61e9add888a4375f8e0f05cc262ac64f9c37' ], [ '774ae7f858a9411e5ef4246b70c65aac5649980be5c17891bbec17895da008cb', 'd984a032eb6b5e190243dd56d7b7b365372db1e2dff9d6a8301d74c9c953c61b' ], [ 'f28773c2d975288bc7d1d205c3748651b075fbc6610e58cddeeddf8f19405aa8', 'ab0902e8d880a89758212eb65cdaf473a1a06da521fa91f29b5cb52db03ed81' ], [ 'd7924d4f7d43ea965a465ae3095ff41131e5946f3c85f79e44adbcf8e27e080e', '581e2872a86c72a683842ec228cc6defea40af2bd896d3a5c504dc9ff6a26b58' ], [ 'defdea4cdb677750a420fee807eacf21eb9898ae79b9768766e4faa04a2d4a34', '4211ab0694635168e997b0ead2a93daeced1f4a04a95c0f6cfb199f69e56eb77' ], [ '2b4ea0a797a443d293ef5cff444f4979f06acfebd7e86d277475656138385b6c', '85e89bc037945d93b343083b5a1c86131a01f60c50269763b570c854e5c09b7a' ], [ '352bbf4a4cdd12564f93fa332ce333301d9ad40271f8107181340aef25be59d5', '321eb4075348f534d59c18259dda3e1f4a1b3b2e71b1039c67bd3d8bcf81998c' ], [ '2fa2104d6b38d11b0230010559879124e42ab8dfeff5ff29dc9cdadd4ecacc3f', '2de1068295dd865b64569335bd5dd80181d70ecfc882648423ba76b532b7d67' ], [ '9248279b09b4d68dab21a9b066edda83263c3d84e09572e269ca0cd7f5453714', '73016f7bf234aade5d1aa71bdea2b1ff3fc0de2a887912ffe54a32ce97cb3402' ], [ 'daed4f2be3a8bf278e70132fb0beb7522f570e144bf615c07e996d443dee8729', 'a69dce4a7d6c98e8d4a1aca87ef8d7003f83c230f3afa726ab40e52290be1c55' ], [ 'c44d12c7065d812e8acf28d7cbb19f9011ecd9e9fdf281b0e6a3b5e87d22e7db', '2119a460ce326cdc76c45926c982fdac0e106e861edf61c5a039063f0e0e6482' ], [ '6a245bf6dc698504c89a20cfded60853152b695336c28063b61c65cbd269e6b4', 'e022cf42c2bd4a708b3f5126f16a24ad8b33ba48d0423b6efd5e6348100d8a82' ], [ '1697ffa6fd9de627c077e3d2fe541084ce13300b0bec1146f95ae57f0d0bd6a5', 'b9c398f186806f5d27561506e4557433a2cf15009e498ae7adee9d63d01b2396' ], [ '605bdb019981718b986d0f07e834cb0d9deb8360ffb7f61df982345ef27a7479', '2972d2de4f8d20681a78d93ec96fe23c26bfae84fb14db43b01e1e9056b8c49' ], [ '62d14dab4150bf497402fdc45a215e10dcb01c354959b10cfe31c7e9d87ff33d', '80fc06bd8cc5b01098088a1950eed0db01aa132967ab472235f5642483b25eaf' ], [ '80c60ad0040f27dade5b4b06c408e56b2c50e9f56b9b8b425e555c2f86308b6f', '1c38303f1cc5c30f26e66bad7fe72f70a65eed4cbe7024eb1aa01f56430bd57a' ], [ '7a9375ad6167ad54aa74c6348cc54d344cc5dc9487d847049d5eabb0fa03c8fb', 'd0e3fa9eca8726909559e0d79269046bdc59ea10c70ce2b02d499ec224dc7f7' ], [ 'd528ecd9b696b54c907a9ed045447a79bb408ec39b68df504bb51f459bc3ffc9', 'eecf41253136e5f99966f21881fd656ebc4345405c520dbc063465b521409933' ], [ '49370a4b5f43412ea25f514e8ecdad05266115e4a7ecb1387231808f8b45963', '758f3f41afd6ed428b3081b0512fd62a54c3f3afbb5b6764b653052a12949c9a' ], [ '77f230936ee88cbbd73df930d64702ef881d811e0e1498e2f1c13eb1fc345d74', '958ef42a7886b6400a08266e9ba1b37896c95330d97077cbbe8eb3c7671c60d6' ], [ 'f2dac991cc4ce4b9ea44887e5c7c0bce58c80074ab9d4dbaeb28531b7739f530', 'e0dedc9b3b2f8dad4da1f32dec2531df9eb5fbeb0598e4fd1a117dba703a3c37' ], [ '463b3d9f662621fb1b4be8fbbe2520125a216cdfc9dae3debcba4850c690d45b', '5ed430d78c296c3543114306dd8622d7c622e27c970a1de31cb377b01af7307e' ], [ 'f16f804244e46e2a09232d4aff3b59976b98fac14328a2d1a32496b49998f247', 'cedabd9b82203f7e13d206fcdf4e33d92a6c53c26e5cce26d6579962c4e31df6' ], [ 'caf754272dc84563b0352b7a14311af55d245315ace27c65369e15f7151d41d1', 'cb474660ef35f5f2a41b643fa5e460575f4fa9b7962232a5c32f908318a04476' ], [ '2600ca4b282cb986f85d0f1709979d8b44a09c07cb86d7c124497bc86f082120', '4119b88753c15bd6a693b03fcddbb45d5ac6be74ab5f0ef44b0be9475a7e4b40' ], [ '7635ca72d7e8432c338ec53cd12220bc01c48685e24f7dc8c602a7746998e435', '91b649609489d613d1d5e590f78e6d74ecfc061d57048bad9e76f302c5b9c61' ], [ '754e3239f325570cdbbf4a87deee8a66b7f2b33479d468fbc1a50743bf56cc18', '673fb86e5bda30fb3cd0ed304ea49a023ee33d0197a695d0c5d98093c536683' ], [ 'e3e6bd1071a1e96aff57859c82d570f0330800661d1c952f9fe2694691d9b9e8', '59c9e0bba394e76f40c0aa58379a3cb6a5a2283993e90c4167002af4920e37f5' ], [ '186b483d056a033826ae73d88f732985c4ccb1f32ba35f4b4cc47fdcf04aa6eb', '3b952d32c67cf77e2e17446e204180ab21fb8090895138b4a4a797f86e80888b' ], [ 'df9d70a6b9876ce544c98561f4be4f725442e6d2b737d9c91a8321724ce0963f', '55eb2dafd84d6ccd5f862b785dc39d4ab157222720ef9da217b8c45cf2ba2417' ], [ '5edd5cc23c51e87a497ca815d5dce0f8ab52554f849ed8995de64c5f34ce7143', 'efae9c8dbc14130661e8cec030c89ad0c13c66c0d17a2905cdc706ab7399a868' ], [ '290798c2b6476830da12fe02287e9e777aa3fba1c355b17a722d362f84614fba', 'e38da76dcd440621988d00bcf79af25d5b29c094db2a23146d003afd41943e7a' ], [ 'af3c423a95d9f5b3054754efa150ac39cd29552fe360257362dfdecef4053b45', 'f98a3fd831eb2b749a93b0e6f35cfb40c8cd5aa667a15581bc2feded498fd9c6' ], [ '766dbb24d134e745cccaa28c99bf274906bb66b26dcf98df8d2fed50d884249a', '744b1152eacbe5e38dcc887980da38b897584a65fa06cedd2c924f97cbac5996' ], [ '59dbf46f8c94759ba21277c33784f41645f7b44f6c596a58ce92e666191abe3e', 'c534ad44175fbc300f4ea6ce648309a042ce739a7919798cd85e216c4a307f6e' ], [ 'f13ada95103c4537305e691e74e9a4a8dd647e711a95e73cb62dc6018cfd87b8', 'e13817b44ee14de663bf4bc808341f326949e21a6a75c2570778419bdaf5733d' ], [ '7754b4fa0e8aced06d4167a2c59cca4cda1869c06ebadfb6488550015a88522c', '30e93e864e669d82224b967c3020b8fa8d1e4e350b6cbcc537a48b57841163a2' ], [ '948dcadf5990e048aa3874d46abef9d701858f95de8041d2a6828c99e2262519', 'e491a42537f6e597d5d28a3224b1bc25df9154efbd2ef1d2cbba2cae5347d57e' ], [ '7962414450c76c1689c7b48f8202ec37fb224cf5ac0bfa1570328a8a3d7c77ab', '100b610ec4ffb4760d5c1fc133ef6f6b12507a051f04ac5760afa5b29db83437' ], [ '3514087834964b54b15b160644d915485a16977225b8847bb0dd085137ec47ca', 'ef0afbb2056205448e1652c48e8127fc6039e77c15c2378b7e7d15a0de293311' ], [ 'd3cc30ad6b483e4bc79ce2c9dd8bc54993e947eb8df787b442943d3f7b527eaf', '8b378a22d827278d89c5e9be8f9508ae3c2ad46290358630afb34db04eede0a4' ], [ '1624d84780732860ce1c78fcbfefe08b2b29823db913f6493975ba0ff4847610', '68651cf9b6da903e0914448c6cd9d4ca896878f5282be4c8cc06e2a404078575' ], [ '733ce80da955a8a26902c95633e62a985192474b5af207da6df7b4fd5fc61cd4', 'f5435a2bd2badf7d485a4d8b8db9fcce3e1ef8e0201e4578c54673bc1dc5ea1d' ], [ '15d9441254945064cf1a1c33bbd3b49f8966c5092171e699ef258dfab81c045c', 'd56eb30b69463e7234f5137b73b84177434800bacebfc685fc37bbe9efe4070d' ], [ 'a1d0fcf2ec9de675b612136e5ce70d271c21417c9d2b8aaaac138599d0717940', 'edd77f50bcb5a3cab2e90737309667f2641462a54070f3d519212d39c197a629' ], [ 'e22fbe15c0af8ccc5780c0735f84dbe9a790badee8245c06c7ca37331cb36980', 'a855babad5cd60c88b430a69f53a1a7a38289154964799be43d06d77d31da06' ], [ '311091dd9860e8e20ee13473c1155f5f69635e394704eaa74009452246cfa9b3', '66db656f87d1f04fffd1f04788c06830871ec5a64feee685bd80f0b1286d8374' ], [ '34c1fd04d301be89b31c0442d3e6ac24883928b45a9340781867d4232ec2dbdf', '9414685e97b1b5954bd46f730174136d57f1ceeb487443dc5321857ba73abee' ], [ 'f219ea5d6b54701c1c14de5b557eb42a8d13f3abbcd08affcc2a5e6b049b8d63', '4cb95957e83d40b0f73af4544cccf6b1f4b08d3c07b27fb8d8c2962a400766d1' ], [ 'd7b8740f74a8fbaab1f683db8f45de26543a5490bca627087236912469a0b448', 'fa77968128d9c92ee1010f337ad4717eff15db5ed3c049b3411e0315eaa4593b' ], [ '32d31c222f8f6f0ef86f7c98d3a3335ead5bcd32abdd94289fe4d3091aa824bf', '5f3032f5892156e39ccd3d7915b9e1da2e6dac9e6f26e961118d14b8462e1661' ], [ '7461f371914ab32671045a155d9831ea8793d77cd59592c4340f86cbc18347b5', '8ec0ba238b96bec0cbdddcae0aa442542eee1ff50c986ea6b39847b3cc092ff6' ], [ 'ee079adb1df1860074356a25aa38206a6d716b2c3e67453d287698bad7b2b2d6', '8dc2412aafe3be5c4c5f37e0ecc5f9f6a446989af04c4e25ebaac479ec1c8c1e' ], [ '16ec93e447ec83f0467b18302ee620f7e65de331874c9dc72bfd8616ba9da6b5', '5e4631150e62fb40d0e8c2a7ca5804a39d58186a50e497139626778e25b0674d' ], [ 'eaa5f980c245f6f038978290afa70b6bd8855897f98b6aa485b96065d537bd99', 'f65f5d3e292c2e0819a528391c994624d784869d7e6ea67fb18041024edc07dc' ], [ '78c9407544ac132692ee1910a02439958ae04877151342ea96c4b6b35a49f51', 'f3e0319169eb9b85d5404795539a5e68fa1fbd583c064d2462b675f194a3ddb4' ], [ '494f4be219a1a77016dcd838431aea0001cdc8ae7a6fc688726578d9702857a5', '42242a969283a5f339ba7f075e36ba2af925ce30d767ed6e55f4b031880d562c' ], [ 'a598a8030da6d86c6bc7f2f5144ea549d28211ea58faa70ebf4c1e665c1fe9b5', '204b5d6f84822c307e4b4a7140737aec23fc63b65b35f86a10026dbd2d864e6b' ], [ 'c41916365abb2b5d09192f5f2dbeafec208f020f12570a184dbadc3e58595997', '4f14351d0087efa49d245b328984989d5caf9450f34bfc0ed16e96b58fa9913' ], [ '841d6063a586fa475a724604da03bc5b92a2e0d2e0a36acfe4c73a5514742881', '73867f59c0659e81904f9a1c7543698e62562d6744c169ce7a36de01a8d6154' ], [ '5e95bb399a6971d376026947f89bde2f282b33810928be4ded112ac4d70e20d5', '39f23f366809085beebfc71181313775a99c9aed7d8ba38b161384c746012865' ], [ '36e4641a53948fd476c39f8a99fd974e5ec07564b5315d8bf99471bca0ef2f66', 'd2424b1b1abe4eb8164227b085c9aa9456ea13493fd563e06fd51cf5694c78fc' ], [ '336581ea7bfbbb290c191a2f507a41cf5643842170e914faeab27c2c579f726', 'ead12168595fe1be99252129b6e56b3391f7ab1410cd1e0ef3dcdcabd2fda224' ], [ '8ab89816dadfd6b6a1f2634fcf00ec8403781025ed6890c4849742706bd43ede', '6fdcef09f2f6d0a044e654aef624136f503d459c3e89845858a47a9129cdd24e' ], [ '1e33f1a746c9c5778133344d9299fcaa20b0938e8acff2544bb40284b8c5fb94', '60660257dd11b3aa9c8ed618d24edff2306d320f1d03010e33a7d2057f3b3b6' ], [ '85b7c1dcb3cec1b7ee7f30ded79dd20a0ed1f4cc18cbcfcfa410361fd8f08f31', '3d98a9cdd026dd43f39048f25a8847f4fcafad1895d7a633c6fed3c35e999511' ], [ '29df9fbd8d9e46509275f4b125d6d45d7fbe9a3b878a7af872a2800661ac5f51', 'b4c4fe99c775a606e2d8862179139ffda61dc861c019e55cd2876eb2a27d84b' ], [ 'a0b1cae06b0a847a3fea6e671aaf8adfdfe58ca2f768105c8082b2e449fce252', 'ae434102edde0958ec4b19d917a6a28e6b72da1834aff0e650f049503a296cf2' ], [ '4e8ceafb9b3e9a136dc7ff67e840295b499dfb3b2133e4ba113f2e4c0e121e5', 'cf2174118c8b6d7a4b48f6d534ce5c79422c086a63460502b827ce62a326683c' ], [ 'd24a44e047e19b6f5afb81c7ca2f69080a5076689a010919f42725c2b789a33b', '6fb8d5591b466f8fc63db50f1c0f1c69013f996887b8244d2cdec417afea8fa3' ], [ 'ea01606a7a6c9cdd249fdfcfacb99584001edd28abbab77b5104e98e8e3b35d4', '322af4908c7312b0cfbfe369f7a7b3cdb7d4494bc2823700cfd652188a3ea98d' ], [ 'af8addbf2b661c8a6c6328655eb96651252007d8c5ea31be4ad196de8ce2131f', '6749e67c029b85f52a034eafd096836b2520818680e26ac8f3dfbcdb71749700' ], [ 'e3ae1974566ca06cc516d47e0fb165a674a3dabcfca15e722f0e3450f45889', '2aeabe7e4531510116217f07bf4d07300de97e4874f81f533420a72eeb0bd6a4' ], [ '591ee355313d99721cf6993ffed1e3e301993ff3ed258802075ea8ced397e246', 'b0ea558a113c30bea60fc4775460c7901ff0b053d25ca2bdeee98f1a4be5d196' ], [ '11396d55fda54c49f19aa97318d8da61fa8584e47b084945077cf03255b52984', '998c74a8cd45ac01289d5833a7beb4744ff536b01b257be4c5767bea93ea57a4' ], [ '3c5d2a1ba39c5a1790000738c9e0c40b8dcdfd5468754b6405540157e017aa7a', 'b2284279995a34e2f9d4de7396fc18b80f9b8b9fdd270f6661f79ca4c81bd257' ], [ 'cc8704b8a60a0defa3a99a7299f2e9c3fbc395afb04ac078425ef8a1793cc030', 'bdd46039feed17881d1e0862db347f8cf395b74fc4bcdc4e940b74e3ac1f1b13' ], [ 'c533e4f7ea8555aacd9777ac5cad29b97dd4defccc53ee7ea204119b2889b197', '6f0a256bc5efdf429a2fb6242f1a43a2d9b925bb4a4b3a26bb8e0f45eb596096' ], [ 'c14f8f2ccb27d6f109f6d08d03cc96a69ba8c34eec07bbcf566d48e33da6593', 'c359d6923bb398f7fd4473e16fe1c28475b740dd098075e6c0e8649113dc3a38' ], [ 'a6cbc3046bc6a450bac24789fa17115a4c9739ed75f8f21ce441f72e0b90e6ef', '21ae7f4680e889bb130619e2c0f95a360ceb573c70603139862afd617fa9b9f' ], [ '347d6d9a02c48927ebfb86c1359b1caf130a3c0267d11ce6344b39f99d43cc38', '60ea7f61a353524d1c987f6ecec92f086d565ab687870cb12689ff1e31c74448' ], [ 'da6545d2181db8d983f7dcb375ef5866d47c67b1bf31c8cf855ef7437b72656a', '49b96715ab6878a79e78f07ce5680c5d6673051b4935bd897fea824b77dc208a' ], [ 'c40747cc9d012cb1a13b8148309c6de7ec25d6945d657146b9d5994b8feb1111', '5ca560753be2a12fc6de6caf2cb489565db936156b9514e1bb5e83037e0fa2d4' ], [ '4e42c8ec82c99798ccf3a610be870e78338c7f713348bd34c8203ef4037f3502', '7571d74ee5e0fb92a7a8b33a07783341a5492144cc54bcc40a94473693606437' ], [ '3775ab7089bc6af823aba2e1af70b236d251cadb0c86743287522a1b3b0dedea', 'be52d107bcfa09d8bcb9736a828cfa7fac8db17bf7a76a2c42ad961409018cf7' ], [ 'cee31cbf7e34ec379d94fb814d3d775ad954595d1314ba8846959e3e82f74e26', '8fd64a14c06b589c26b947ae2bcf6bfa0149ef0be14ed4d80f448a01c43b1c6d' ], [ 'b4f9eaea09b6917619f6ea6a4eb5464efddb58fd45b1ebefcdc1a01d08b47986', '39e5c9925b5a54b07433a4f18c61726f8bb131c012ca542eb24a8ac07200682a' ], [ 'd4263dfc3d2df923a0179a48966d30ce84e2515afc3dccc1b77907792ebcc60e', '62dfaf07a0f78feb30e30d6295853ce189e127760ad6cf7fae164e122a208d54' ], [ '48457524820fa65a4f8d35eb6930857c0032acc0a4a2de422233eeda897612c4', '25a748ab367979d98733c38a1fa1c2e7dc6cc07db2d60a9ae7a76aaa49bd0f77' ], [ 'dfeeef1881101f2cb11644f3a2afdfc2045e19919152923f367a1767c11cceda', 'ecfb7056cf1de042f9420bab396793c0c390bde74b4bbdff16a83ae09a9a7517' ], [ '6d7ef6b17543f8373c573f44e1f389835d89bcbc6062ced36c82df83b8fae859', 'cd450ec335438986dfefa10c57fea9bcc521a0959b2d80bbf74b190dca712d10' ], [ 'e75605d59102a5a2684500d3b991f2e3f3c88b93225547035af25af66e04541f', 'f5c54754a8f71ee540b9b48728473e314f729ac5308b06938360990e2bfad125' ], [ 'eb98660f4c4dfaa06a2be453d5020bc99a0c2e60abe388457dd43fefb1ed620c', '6cb9a8876d9cb8520609af3add26cd20a0a7cd8a9411131ce85f44100099223e' ], [ '13e87b027d8514d35939f2e6892b19922154596941888336dc3563e3b8dba942', 'fef5a3c68059a6dec5d624114bf1e91aac2b9da568d6abeb2570d55646b8adf1' ], [ 'ee163026e9fd6fe017c38f06a5be6fc125424b371ce2708e7bf4491691e5764a', '1acb250f255dd61c43d94ccc670d0f58f49ae3fa15b96623e5430da0ad6c62b2' ], [ 'b268f5ef9ad51e4d78de3a750c2dc89b1e626d43505867999932e5db33af3d80', '5f310d4b3c99b9ebb19f77d41c1dee018cf0d34fd4191614003e945a1216e423' ], [ 'ff07f3118a9df035e9fad85eb6c7bfe42b02f01ca99ceea3bf7ffdba93c4750d', '438136d603e858a3a5c440c38eccbaddc1d2942114e2eddd4740d098ced1f0d8' ], [ '8d8b9855c7c052a34146fd20ffb658bea4b9f69e0d825ebec16e8c3ce2b526a1', 'cdb559eedc2d79f926baf44fb84ea4d44bcf50fee51d7ceb30e2e7f463036758' ], [ '52db0b5384dfbf05bfa9d472d7ae26dfe4b851ceca91b1eba54263180da32b63', 'c3b997d050ee5d423ebaf66a6db9f57b3180c902875679de924b69d84a7b375' ], [ 'e62f9490d3d51da6395efd24e80919cc7d0f29c3f3fa48c6fff543becbd43352', '6d89ad7ba4876b0b22c2ca280c682862f342c8591f1daf5170e07bfd9ccafa7d' ], [ '7f30ea2476b399b4957509c88f77d0191afa2ff5cb7b14fd6d8e7d65aaab1193', 'ca5ef7d4b231c94c3b15389a5f6311e9daff7bb67b103e9880ef4bff637acaec' ], [ '5098ff1e1d9f14fb46a210fada6c903fef0fb7b4a1dd1d9ac60a0361800b7a00', '9731141d81fc8f8084d37c6e7542006b3ee1b40d60dfe5362a5b132fd17ddc0' ], [ '32b78c7de9ee512a72895be6b9cbefa6e2f3c4ccce445c96b9f2c81e2778ad58', 'ee1849f513df71e32efc3896ee28260c73bb80547ae2275ba497237794c8753c' ], [ 'e2cb74fddc8e9fbcd076eef2a7c72b0ce37d50f08269dfc074b581550547a4f7', 'd3aa2ed71c9dd2247a62df062736eb0baddea9e36122d2be8641abcb005cc4a4' ], [ '8438447566d4d7bedadc299496ab357426009a35f235cb141be0d99cd10ae3a8', 'c4e1020916980a4da5d01ac5e6ad330734ef0d7906631c4f2390426b2edd791f' ], [ '4162d488b89402039b584c6fc6c308870587d9c46f660b878ab65c82c711d67e', '67163e903236289f776f22c25fb8a3afc1732f2b84b4e95dbda47ae5a0852649' ], [ '3fad3fa84caf0f34f0f89bfd2dcf54fc175d767aec3e50684f3ba4a4bf5f683d', 'cd1bc7cb6cc407bb2f0ca647c718a730cf71872e7d0d2a53fa20efcdfe61826' ], [ '674f2600a3007a00568c1a7ce05d0816c1fb84bf1370798f1c69532faeb1a86b', '299d21f9413f33b3edf43b257004580b70db57da0b182259e09eecc69e0d38a5' ], [ 'd32f4da54ade74abb81b815ad1fb3b263d82d6c692714bcff87d29bd5ee9f08f', 'f9429e738b8e53b968e99016c059707782e14f4535359d582fc416910b3eea87' ], [ '30e4e670435385556e593657135845d36fbb6931f72b08cb1ed954f1e3ce3ff6', '462f9bce619898638499350113bbc9b10a878d35da70740dc695a559eb88db7b' ], [ 'be2062003c51cc3004682904330e4dee7f3dcd10b01e580bf1971b04d4cad297', '62188bc49d61e5428573d48a74e1c655b1c61090905682a0d5558ed72dccb9bc' ], [ '93144423ace3451ed29e0fb9ac2af211cb6e84a601df5993c419859fff5df04a', '7c10dfb164c3425f5c71a3f9d7992038f1065224f72bb9d1d902a6d13037b47c' ], [ 'b015f8044f5fcbdcf21ca26d6c34fb8197829205c7b7d2a7cb66418c157b112c', 'ab8c1e086d04e813744a655b2df8d5f83b3cdc6faa3088c1d3aea1454e3a1d5f' ], [ 'd5e9e1da649d97d89e4868117a465a3a4f8a18de57a140d36b3f2af341a21b52', '4cb04437f391ed73111a13cc1d4dd0db1693465c2240480d8955e8592f27447a' ], [ 'd3ae41047dd7ca065dbf8ed77b992439983005cd72e16d6f996a5316d36966bb', 'bd1aeb21ad22ebb22a10f0303417c6d964f8cdd7df0aca614b10dc14d125ac46' ], [ '463e2763d885f958fc66cdd22800f0a487197d0a82e377b49f80af87c897b065', 'bfefacdb0e5d0fd7df3a311a94de062b26b80c61fbc97508b79992671ef7ca7f' ], [ '7985fdfd127c0567c6f53ec1bb63ec3158e597c40bfe747c83cddfc910641917', '603c12daf3d9862ef2b25fe1de289aed24ed291e0ec6708703a5bd567f32ed03' ], [ '74a1ad6b5f76e39db2dd249410eac7f99e74c59cb83d2d0ed5ff1543da7703e9', 'cc6157ef18c9c63cd6193d83631bbea0093e0968942e8c33d5737fd790e0db08' ], [ '30682a50703375f602d416664ba19b7fc9bab42c72747463a71d0896b22f6da3', '553e04f6b018b4fa6c8f39e7f311d3176290d0e0f19ca73f17714d9977a22ff8' ], [ '9e2158f0d7c0d5f26c3791efefa79597654e7a2b2464f52b1ee6c1347769ef57', '712fcdd1b9053f09003a3481fa7762e9ffd7c8ef35a38509e2fbf2629008373' ], [ '176e26989a43c9cfeba4029c202538c28172e566e3c4fce7322857f3be327d66', 'ed8cc9d04b29eb877d270b4878dc43c19aefd31f4eee09ee7b47834c1fa4b1c3' ], [ '75d46efea3771e6e68abb89a13ad747ecf1892393dfc4f1b7004788c50374da8', '9852390a99507679fd0b86fd2b39a868d7efc22151346e1a3ca4726586a6bed8' ], [ '809a20c67d64900ffb698c4c825f6d5f2310fb0451c869345b7319f645605721', '9e994980d9917e22b76b061927fa04143d096ccc54963e6a5ebfa5f3f8e286c1' ], [ '1b38903a43f7f114ed4500b4eac7083fdefece1cf29c63528d563446f972c180', '4036edc931a60ae889353f77fd53de4a2708b26b6f5da72ad3394119daf408f9' ] ] } }; },{}],140:[function(require,module,exports){ 'use strict'; var utils = exports; var BN = require('bn.js'); utils.assert = function assert(val, msg) { if (!val) throw new Error(msg || 'Assertion failed'); }; function toArray(msg, enc) { if (Array.isArray(msg)) return msg.slice(); if (!msg) return []; var res = []; if (typeof msg !== 'string') { for (var i = 0; i < msg.length; i++) res[i] = msg[i] | 0; return res; } if (!enc) { for (var i = 0; i < msg.length; i++) { var c = msg.charCodeAt(i); var hi = c >> 8; var lo = c & 0xff; if (hi) res.push(hi, lo); else res.push(lo); } } else if (enc === 'hex') { msg = msg.replace(/[^a-z0-9]+/ig, ''); if (msg.length % 2 !== 0) msg = '0' + msg; for (var i = 0; i < msg.length; i += 2) res.push(parseInt(msg[i] + msg[i + 1], 16)); } return res; } utils.toArray = toArray; function zero2(word) { if (word.length === 1) return '0' + word; else return word; } utils.zero2 = zero2; function toHex(msg) { var res = ''; for (var i = 0; i < msg.length; i++) res += zero2(msg[i].toString(16)); return res; } utils.toHex = toHex; utils.encode = function encode(arr, enc) { if (enc === 'hex') return toHex(arr); else return arr; }; // Represent num in a w-NAF form function getNAF(num, w) { var naf = []; var ws = 1 << (w + 1); var k = num.clone(); while (k.cmpn(1) >= 0) { var z; if (k.isOdd()) { var mod = k.andln(ws - 1); if (mod > (ws >> 1) - 1) z = (ws >> 1) - mod; else z = mod; k.isubn(z); } else { z = 0; } naf.push(z); // Optimization, shift by word if possible var shift = (k.cmpn(0) !== 0 && k.andln(ws - 1) === 0) ? (w + 1) : 1; for (var i = 1; i < shift; i++) naf.push(0); k.iushrn(shift); } return naf; } utils.getNAF = getNAF; // Represent k1, k2 in a Joint Sparse Form function getJSF(k1, k2) { var jsf = [ [], [] ]; k1 = k1.clone(); k2 = k2.clone(); var d1 = 0; var d2 = 0; while (k1.cmpn(-d1) > 0 || k2.cmpn(-d2) > 0) { // First phase var m14 = (k1.andln(3) + d1) & 3; var m24 = (k2.andln(3) + d2) & 3; if (m14 === 3) m14 = -1; if (m24 === 3) m24 = -1; var u1; if ((m14 & 1) === 0) { u1 = 0; } else { var m8 = (k1.andln(7) + d1) & 7; if ((m8 === 3 || m8 === 5) && m24 === 2) u1 = -m14; else u1 = m14; } jsf[0].push(u1); var u2; if ((m24 & 1) === 0) { u2 = 0; } else { var m8 = (k2.andln(7) + d2) & 7; if ((m8 === 3 || m8 === 5) && m14 === 2) u2 = -m24; else u2 = m24; } jsf[1].push(u2); // Second phase if (2 * d1 === u1 + 1) d1 = 1 - d1; if (2 * d2 === u2 + 1) d2 = 1 - d2; k1.iushrn(1); k2.iushrn(1); } return jsf; } utils.getJSF = getJSF; function cachedProperty(obj, computer) { var name = computer.name; var key = '_' + name; obj.prototype[name] = function cachedProperty() { return this[key] !== undefined ? this[key] : this[key] = computer.call(this); }; } utils.cachedProperty = cachedProperty; function parseBytes(bytes) { return typeof bytes === 'string' ? utils.toArray(bytes, 'hex') : bytes; } utils.parseBytes = parseBytes; function intFromLE(bytes) { return new BN(bytes, 'hex', 'le'); } utils.intFromLE = intFromLE; },{"bn.js":29}],141:[function(require,module,exports){ module.exports={ "_args": [ [ "elliptic@^6.0.0", "/Users/joran/Documents/development/patchdeck/node_modules/browserify-sign" ] ], "_from": "elliptic@>=6.0.0 <7.0.0", "_id": "elliptic@6.2.3", "_inCache": true, "_installable": true, "_location": "/elliptic", "_nodeVersion": "5.4.1", "_npmUser": { "email": "fedor@indutny.com", "name": "indutny" }, "_npmVersion": "3.3.12", "_phantomChildren": {}, "_requested": { "name": "elliptic", "raw": "elliptic@^6.0.0", "rawSpec": "^6.0.0", "scope": null, "spec": ">=6.0.0 <7.0.0", "type": "range" }, "_requiredBy": [ "/browserify-sign", "/create-ecdh" ], "_resolved": "https://registry.npmjs.org/elliptic/-/elliptic-6.2.3.tgz", "_shasum": "18e46d7306b0951275a2d42063270a14b74ebe99", "_shrinkwrap": null, "_spec": "elliptic@^6.0.0", "_where": "/Users/joran/Documents/development/patchdeck/node_modules/browserify-sign", "author": { "email": "fedor@indutny.com", "name": "Fedor Indutny" }, "bugs": { "url": "https://github.com/indutny/elliptic/issues" }, "dependencies": { "bn.js": "^4.0.0", "brorand": "^1.0.1", "hash.js": "^1.0.0", "inherits": "^2.0.1" }, "description": "EC cryptography", "devDependencies": { "coveralls": "^2.11.3", "istanbul": "^0.4.2", "jscs": "^2.9.0", "jshint": "^2.6.0", "mocha": "^2.1.0" }, "directories": {}, "dist": { "shasum": "18e46d7306b0951275a2d42063270a14b74ebe99", "tarball": "https://registry.npmjs.org/elliptic/-/elliptic-6.2.3.tgz" }, "files": [ "lib" ], "gitHead": "c32f20b22b420eb6af3c6dda28963deb7facf823", "homepage": "https://github.com/indutny/elliptic", "keywords": [ "Cryptography", "EC", "Elliptic", "curve" ], "license": "MIT", "main": "lib/elliptic.js", "maintainers": [ { "name": "indutny", "email": "fedor@indutny.com" } ], "name": "elliptic", "optionalDependencies": {}, "readme": "ERROR: No README data found!", "repository": { "type": "git", "url": "git+ssh://git@github.com/indutny/elliptic.git" }, "scripts": { "coverage": "npm run unit --coverage", "coveralls": "npm run coverage && cat ./coverage/lcov.info | coveralls", "jscs": "jscs benchmarks/*.js lib/*.js lib/**/*.js lib/**/**/*.js test/*.js", "jshint": "jscs benchmarks/*.js lib/*.js lib/**/*.js lib/**/**/*.js test/*.js", "lint": "npm run jscs && npm run jshint", "test": "npm run lint && npm run unit", "unit": "istanbul test _mocha --reporter=spec test/*-test.js" }, "version": "6.2.3" } },{}],142:[function(require,module,exports){ var prr = require('prr') function init (type, message, cause) { prr(this, { type : type , name : type // can be passed just a 'cause' , cause : typeof message != 'string' ? message : cause , message : !!message && typeof message != 'string' ? message.message : message }, 'ewr') } // generic prototype, not intended to be actually used - helpful for `instanceof` function CustomError (message, cause) { Error.call(this) if (Error.captureStackTrace) Error.captureStackTrace(this, arguments.callee) init.call(this, 'CustomError', message, cause) } CustomError.prototype = new Error() function createError (errno, type, proto) { var err = function (message, cause) { init.call(this, type, message, cause) //TODO: the specificity here is stupid, errno should be available everywhere if (type == 'FilesystemError') { this.code = this.cause.code this.path = this.cause.path this.errno = this.cause.errno this.message = (errno.errno[this.cause.errno] ? errno.errno[this.cause.errno].description : this.cause.message) + (this.cause.path ? ' [' + this.cause.path + ']' : '') } Error.call(this) if (Error.captureStackTrace) Error.captureStackTrace(this, arguments.callee) } err.prototype = !!proto ? new proto() : new CustomError() return err } module.exports = function (errno) { var ce = function (type, proto) { return createError(errno, type, proto) } return { CustomError : CustomError , FilesystemError : ce('FilesystemError') , createError : ce } } },{"prr":296}],143:[function(require,module,exports){ var all = module.exports.all = [ { errno: -2, code: 'ENOENT', description: 'no such file or directory' }, { errno: -1, code: 'UNKNOWN', description: 'unknown error' }, { errno: 0, code: 'OK', description: 'success' }, { errno: 1, code: 'EOF', description: 'end of file' }, { errno: 2, code: 'EADDRINFO', description: 'getaddrinfo error' }, { errno: 3, code: 'EACCES', description: 'permission denied' }, { errno: 4, code: 'EAGAIN', description: 'resource temporarily unavailable' }, { errno: 5, code: 'EADDRINUSE', description: 'address already in use' }, { errno: 6, code: 'EADDRNOTAVAIL', description: 'address not available' }, { errno: 7, code: 'EAFNOSUPPORT', description: 'address family not supported' }, { errno: 8, code: 'EALREADY', description: 'connection already in progress' }, { errno: 9, code: 'EBADF', description: 'bad file descriptor' }, { errno: 10, code: 'EBUSY', description: 'resource busy or locked' }, { errno: 11, code: 'ECONNABORTED', description: 'software caused connection abort' }, { errno: 12, code: 'ECONNREFUSED', description: 'connection refused' }, { errno: 13, code: 'ECONNRESET', description: 'connection reset by peer' }, { errno: 14, code: 'EDESTADDRREQ', description: 'destination address required' }, { errno: 15, code: 'EFAULT', description: 'bad address in system call argument' }, { errno: 16, code: 'EHOSTUNREACH', description: 'host is unreachable' }, { errno: 17, code: 'EINTR', description: 'interrupted system call' }, { errno: 18, code: 'EINVAL', description: 'invalid argument' }, { errno: 19, code: 'EISCONN', description: 'socket is already connected' }, { errno: 20, code: 'EMFILE', description: 'too many open files' }, { errno: 21, code: 'EMSGSIZE', description: 'message too long' }, { errno: 22, code: 'ENETDOWN', description: 'network is down' }, { errno: 23, code: 'ENETUNREACH', description: 'network is unreachable' }, { errno: 24, code: 'ENFILE', description: 'file table overflow' }, { errno: 25, code: 'ENOBUFS', description: 'no buffer space available' }, { errno: 26, code: 'ENOMEM', description: 'not enough memory' }, { errno: 27, code: 'ENOTDIR', description: 'not a directory' }, { errno: 28, code: 'EISDIR', description: 'illegal operation on a directory' }, { errno: 29, code: 'ENONET', description: 'machine is not on the network' }, { errno: 31, code: 'ENOTCONN', description: 'socket is not connected' }, { errno: 32, code: 'ENOTSOCK', description: 'socket operation on non-socket' }, { errno: 33, code: 'ENOTSUP', description: 'operation not supported on socket' }, { errno: 34, code: 'ENOENT', description: 'no such file or directory' }, { errno: 35, code: 'ENOSYS', description: 'function not implemented' }, { errno: 36, code: 'EPIPE', description: 'broken pipe' }, { errno: 37, code: 'EPROTO', description: 'protocol error' }, { errno: 38, code: 'EPROTONOSUPPORT', description: 'protocol not supported' }, { errno: 39, code: 'EPROTOTYPE', description: 'protocol wrong type for socket' }, { errno: 40, code: 'ETIMEDOUT', description: 'connection timed out' }, { errno: 41, code: 'ECHARSET', description: 'invalid Unicode character' }, { errno: 42, code: 'EAIFAMNOSUPPORT', description: 'address family for hostname not supported' }, { errno: 44, code: 'EAISERVICE', description: 'servname not supported for ai_socktype' }, { errno: 45, code: 'EAISOCKTYPE', description: 'ai_socktype not supported' }, { errno: 46, code: 'ESHUTDOWN', description: 'cannot send after transport endpoint shutdown' }, { errno: 47, code: 'EEXIST', description: 'file already exists' }, { errno: 48, code: 'ESRCH', description: 'no such process' }, { errno: 49, code: 'ENAMETOOLONG', description: 'name too long' }, { errno: 50, code: 'EPERM', description: 'operation not permitted' }, { errno: 51, code: 'ELOOP', description: 'too many symbolic links encountered' }, { errno: 52, code: 'EXDEV', description: 'cross-device link not permitted' }, { errno: 53, code: 'ENOTEMPTY', description: 'directory not empty' }, { errno: 54, code: 'ENOSPC', description: 'no space left on device' }, { errno: 55, code: 'EIO', description: 'i/o error' }, { errno: 56, code: 'EROFS', description: 'read-only file system' }, { errno: 57, code: 'ENODEV', description: 'no such device' }, { errno: 58, code: 'ESPIPE', description: 'invalid seek' }, { errno: 59, code: 'ECANCELED', description: 'operation canceled' } ] module.exports.errno = {} module.exports.code = {} all.forEach(function (error) { module.exports.errno[error.errno] = error module.exports.code[error.code] = error }) module.exports.custom = require('./custom')(module.exports) module.exports.create = module.exports.custom.createError },{"./custom":142}],144:[function(require,module,exports){ // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. function EventEmitter() { this._events = this._events || {}; this._maxListeners = this._maxListeners || undefined; } module.exports = EventEmitter; // Backwards-compat with node 0.10.x EventEmitter.EventEmitter = EventEmitter; EventEmitter.prototype._events = undefined; EventEmitter.prototype._maxListeners = undefined; // By default EventEmitters will print a warning if more than 10 listeners are // added to it. This is a useful default which helps finding memory leaks. EventEmitter.defaultMaxListeners = 10; // Obviously not all Emitters should be limited to 10. This function allows // that to be increased. Set to zero for unlimited. EventEmitter.prototype.setMaxListeners = function(n) { if (!isNumber(n) || n < 0 || isNaN(n)) throw TypeError('n must be a positive number'); this._maxListeners = n; return this; }; EventEmitter.prototype.emit = function(type) { var er, handler, len, args, i, listeners; if (!this._events) this._events = {}; // If there is no 'error' event listener then throw. if (type === 'error') { if (!this._events.error || (isObject(this._events.error) && !this._events.error.length)) { er = arguments[1]; if (er instanceof Error) { throw er; // Unhandled 'error' event } throw TypeError('Uncaught, unspecified "error" event.'); } } handler = this._events[type]; if (isUndefined(handler)) return false; if (isFunction(handler)) { switch (arguments.length) { // fast cases case 1: handler.call(this); break; case 2: handler.call(this, arguments[1]); break; case 3: handler.call(this, arguments[1], arguments[2]); break; // slower default: args = Array.prototype.slice.call(arguments, 1); handler.apply(this, args); } } else if (isObject(handler)) { args = Array.prototype.slice.call(arguments, 1); listeners = handler.slice(); len = listeners.length; for (i = 0; i < len; i++) listeners[i].apply(this, args); } return true; }; EventEmitter.prototype.addListener = function(type, listener) { var m; if (!isFunction(listener)) throw TypeError('listener must be a function'); if (!this._events) this._events = {}; // To avoid recursion in the case that type === "newListener"! Before // adding it to the listeners, first emit "newListener". if (this._events.newListener) this.emit('newListener', type, isFunction(listener.listener) ? listener.listener : listener); if (!this._events[type]) // Optimize the case of one listener. Don't need the extra array object. this._events[type] = listener; else if (isObject(this._events[type])) // If we've already got an array, just append. this._events[type].push(listener); else // Adding the second element, need to change to array. this._events[type] = [this._events[type], listener]; // Check for listener leak if (isObject(this._events[type]) && !this._events[type].warned) { if (!isUndefined(this._maxListeners)) { m = this._maxListeners; } else { m = EventEmitter.defaultMaxListeners; } if (m && m > 0 && this._events[type].length > m) { this._events[type].warned = true; console.error('(node) warning: possible EventEmitter memory ' + 'leak detected. %d listeners added. ' + 'Use emitter.setMaxListeners() to increase limit.', this._events[type].length); if (typeof console.trace === 'function') { // not supported in IE 10 console.trace(); } } } return this; }; EventEmitter.prototype.on = EventEmitter.prototype.addListener; EventEmitter.prototype.once = function(type, listener) { if (!isFunction(listener)) throw TypeError('listener must be a function'); var fired = false; function g() { this.removeListener(type, g); if (!fired) { fired = true; listener.apply(this, arguments); } } g.listener = listener; this.on(type, g); return this; }; // emits a 'removeListener' event iff the listener was removed EventEmitter.prototype.removeListener = function(type, listener) { var list, position, length, i; if (!isFunction(listener)) throw TypeError('listener must be a function'); if (!this._events || !this._events[type]) return this; list = this._events[type]; length = list.length; position = -1; if (list === listener || (isFunction(list.listener) && list.listener === listener)) { delete this._events[type]; if (this._events.removeListener) this.emit('removeListener', type, listener); } else if (isObject(list)) { for (i = length; i-- > 0;) { if (list[i] === listener || (list[i].listener && list[i].listener === listener)) { position = i; break; } } if (position < 0) return this; if (list.length === 1) { list.length = 0; delete this._events[type]; } else { list.splice(position, 1); } if (this._events.removeListener) this.emit('removeListener', type, listener); } return this; }; EventEmitter.prototype.removeAllListeners = function(type) { var key, listeners; if (!this._events) return this; // not listening for removeListener, no need to emit if (!this._events.removeListener) { if (arguments.length === 0) this._events = {}; else if (this._events[type]) delete this._events[type]; return this; } // emit removeListener for all listeners on all events if (arguments.length === 0) { for (key in this._events) { if (key === 'removeListener') continue; this.removeAllListeners(key); } this.removeAllListeners('removeListener'); this._events = {}; return this; } listeners = this._events[type]; if (isFunction(listeners)) { this.removeListener(type, listeners); } else if (listeners) { // LIFO order while (listeners.length) this.removeListener(type, listeners[listeners.length - 1]); } delete this._events[type]; return this; }; EventEmitter.prototype.listeners = function(type) { var ret; if (!this._events || !this._events[type]) ret = []; else if (isFunction(this._events[type])) ret = [this._events[type]]; else ret = this._events[type].slice(); return ret; }; EventEmitter.prototype.listenerCount = function(type) { if (this._events) { var evlistener = this._events[type]; if (isFunction(evlistener)) return 1; else if (evlistener) return evlistener.length; } return 0; }; EventEmitter.listenerCount = function(emitter, type) { return emitter.listenerCount(type); }; function isFunction(arg) { return typeof arg === 'function'; } function isNumber(arg) { return typeof arg === 'number'; } function isObject(arg) { return typeof arg === 'object' && arg !== null; } function isUndefined(arg) { return arg === void 0; } },{}],145:[function(require,module,exports){ (function (Buffer){ var md5 = require('create-hash/md5') module.exports = EVP_BytesToKey function EVP_BytesToKey (password, salt, keyLen, ivLen) { if (!Buffer.isBuffer(password)) { password = new Buffer(password, 'binary') } if (salt && !Buffer.isBuffer(salt)) { salt = new Buffer(salt, 'binary') } keyLen = keyLen / 8 ivLen = ivLen || 0 var ki = 0 var ii = 0 var key = new Buffer(keyLen) var iv = new Buffer(ivLen) var addmd = 0 var md_buf var i var bufs = [] while (true) { if (addmd++ > 0) { bufs.push(md_buf) } bufs.push(password) if (salt) { bufs.push(salt) } md_buf = md5(Buffer.concat(bufs)) bufs = [] i = 0 if (keyLen > 0) { while (true) { if (keyLen === 0) { break } if (i === md_buf.length) { break } key[ki++] = md_buf[i] keyLen-- i++ } } if (ivLen > 0 && i !== md_buf.length) { while (true) { if (ivLen === 0) { break } if (i === md_buf.length) { break } iv[ii++] = md_buf[i] ivLen-- i++ } } if (keyLen === 0 && ivLen === 0) { break } } for (i = 0; i < md_buf.length; i++) { md_buf[i] = 0 } return { key: key, iv: iv } } }).call(this,require("buffer").Buffer) },{"buffer":61,"create-hash/md5":108}],146:[function(require,module,exports){ function getStack(err) { return err.stack.substring(err.name.length + 3 + err.message.length) .split('\n') } function removePrefix (a, b) { return a.filter(function (e) { return !~b.indexOf(e) }) } var explain = module.exports = function (err, message) { var _err = new Error(message) var stack = removePrefix(getStack(_err).slice(1), getStack(err)).join('\n') _err.stack = _err.name + ': ' + _err.message + '\n' + stack + '\n ' + err.stack return _err } },{}],147:[function(require,module,exports){ /** * Extend an object with another. * * @param {Object, ...} src, ... * @return {Object} merged * @api private */ module.exports = function(src) { var objs = [].slice.call(arguments, 1), obj; for (var i = 0, len = objs.length; i < len; i++) { obj = objs[i]; for (var prop in obj) { src[prop] = obj[prop]; } } return src; } },{}],148:[function(require,module,exports){ 'use strict'; var hasOwn = Object.prototype.hasOwnProperty; var toStr = Object.prototype.toString; var isArray = function isArray(arr) { if (typeof Array.isArray === 'function') { return Array.isArray(arr); } return toStr.call(arr) === '[object Array]'; }; var isPlainObject = function isPlainObject(obj) { if (!obj || toStr.call(obj) !== '[object Object]') { return false; } var hasOwnConstructor = hasOwn.call(obj, 'constructor'); var hasIsPrototypeOf = obj.constructor && obj.constructor.prototype && hasOwn.call(obj.constructor.prototype, 'isPrototypeOf'); // Not own constructor property must be Object if (obj.constructor && !hasOwnConstructor && !hasIsPrototypeOf) { return false; } // Own properties are enumerated firstly, so to speed up, // if last one is own, then all properties are own. var key; for (key in obj) {/**/} return typeof key === 'undefined' || hasOwn.call(obj, key); }; module.exports = function extend() { var options, name, src, copy, copyIsArray, clone, target = arguments[0], i = 1, length = arguments.length, deep = false; // Handle a deep copy situation if (typeof target === 'boolean') { deep = target; target = arguments[1] || {}; // skip the boolean and the target i = 2; } else if ((typeof target !== 'object' && typeof target !== 'function') || target == null) { target = {}; } for (; i < length; ++i) { options = arguments[i]; // Only deal with non-null/undefined values if (options != null) { // Extend the base object for (name in options) { src = target[name]; copy = options[name]; // Prevent never-ending loop if (target !== copy) { // Recurse if we're merging plain objects or arrays if (deep && copy && (isPlainObject(copy) || (copyIsArray = isArray(copy)))) { if (copyIsArray) { copyIsArray = false; clone = src && isArray(src) ? src : []; } else { clone = src && isPlainObject(src) ? src : {}; } // Never move original objects, clone them target[name] = extend(deep, clone, copy); // Don't bring in undefined values } else if (typeof copy !== 'undefined') { target[name] = copy; } } } } } // Return the modified object return target; }; },{}],149:[function(require,module,exports){ (function (process,global){ var LIMIT = process.maxTickDepth / 2 , factory = function () { var count = 0 return function (callback) { if (count >= LIMIT){ global.setImmediate(callback) count = 0 } else process.nextTick(callback) count++ } } module.exports = global.setImmediate ? factory : function () { return process.nextTick } }).call(this,require('_process'),typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) },{"_process":295}],150:[function(require,module,exports){ (function (process){ exports.alphasort = alphasort exports.alphasorti = alphasorti exports.setopts = setopts exports.ownProp = ownProp exports.makeAbs = makeAbs exports.finish = finish exports.mark = mark exports.isIgnored = isIgnored exports.childrenIgnored = childrenIgnored function ownProp (obj, field) { return Object.prototype.hasOwnProperty.call(obj, field) } var path = require("path") var minimatch = require("minimatch") var isAbsolute = require("path-is-absolute") var Minimatch = minimatch.Minimatch function alphasorti (a, b) { return a.toLowerCase().localeCompare(b.toLowerCase()) } function alphasort (a, b) { return a.localeCompare(b) } function setupIgnores (self, options) { self.ignore = options.ignore || [] if (!Array.isArray(self.ignore)) self.ignore = [self.ignore] if (self.ignore.length) { self.ignore = self.ignore.map(ignoreMap) } } // ignore patterns are always in dot:true mode. function ignoreMap (pattern) { var gmatcher = null if (pattern.slice(-3) === '/**') { var gpattern = pattern.replace(/(\/\*\*)+$/, '') gmatcher = new Minimatch(gpattern, { dot: true }) } return { matcher: new Minimatch(pattern, { dot: true }), gmatcher: gmatcher } } function setopts (self, pattern, options) { if (!options) options = {} // base-matching: just use globstar for that. if (options.matchBase && -1 === pattern.indexOf("/")) { if (options.noglobstar) { throw new Error("base matching requires globstar") } pattern = "**/" + pattern } self.silent = !!options.silent self.pattern = pattern self.strict = options.strict !== false self.realpath = !!options.realpath self.realpathCache = options.realpathCache || Object.create(null) self.follow = !!options.follow self.dot = !!options.dot self.mark = !!options.mark self.nodir = !!options.nodir if (self.nodir) self.mark = true self.sync = !!options.sync self.nounique = !!options.nounique self.nonull = !!options.nonull self.nosort = !!options.nosort self.nocase = !!options.nocase self.stat = !!options.stat self.noprocess = !!options.noprocess self.maxLength = options.maxLength || Infinity self.cache = options.cache || Object.create(null) self.statCache = options.statCache || Object.create(null) self.symlinks = options.symlinks || Object.create(null) setupIgnores(self, options) self.changedCwd = false var cwd = process.cwd() if (!ownProp(options, "cwd")) self.cwd = cwd else { self.cwd = options.cwd self.changedCwd = path.resolve(options.cwd) !== cwd } self.root = options.root || path.resolve(self.cwd, "/") self.root = path.resolve(self.root) if (process.platform === "win32") self.root = self.root.replace(/\\/g, "/") self.nomount = !!options.nomount // disable comments and negation in Minimatch. // Note that they are not supported in Glob itself anyway. options.nonegate = true options.nocomment = true self.minimatch = new Minimatch(pattern, options) self.options = self.minimatch.options } function finish (self) { var nou = self.nounique var all = nou ? [] : Object.create(null) for (var i = 0, l = self.matches.length; i < l; i ++) { var matches = self.matches[i] if (!matches || Object.keys(matches).length === 0) { if (self.nonull) { // do like the shell, and spit out the literal glob var literal = self.minimatch.globSet[i] if (nou) all.push(literal) else all[literal] = true } } else { // had matches var m = Object.keys(matches) if (nou) all.push.apply(all, m) else m.forEach(function (m) { all[m] = true }) } } if (!nou) all = Object.keys(all) if (!self.nosort) all = all.sort(self.nocase ? alphasorti : alphasort) // at *some* point we statted all of these if (self.mark) { for (var i = 0; i < all.length; i++) { all[i] = self._mark(all[i]) } if (self.nodir) { all = all.filter(function (e) { return !(/\/$/.test(e)) }) } } if (self.ignore.length) all = all.filter(function(m) { return !isIgnored(self, m) }) self.found = all } function mark (self, p) { var abs = makeAbs(self, p) var c = self.cache[abs] var m = p if (c) { var isDir = c === 'DIR' || Array.isArray(c) var slash = p.slice(-1) === '/' if (isDir && !slash) m += '/' else if (!isDir && slash) m = m.slice(0, -1) if (m !== p) { var mabs = makeAbs(self, m) self.statCache[mabs] = self.statCache[abs] self.cache[mabs] = self.cache[abs] } } return m } // lotta situps... function makeAbs (self, f) { var abs = f if (f.charAt(0) === '/') { abs = path.join(self.root, f) } else if (isAbsolute(f) || f === '') { abs = f } else if (self.changedCwd) { abs = path.resolve(self.cwd, f) } else { abs = path.resolve(f) } return abs } // Return true, if pattern ends with globstar '**', for the accompanying parent directory. // Ex:- If node_modules/** is the pattern, add 'node_modules' to ignore list along with it's contents function isIgnored (self, path) { if (!self.ignore.length) return false return self.ignore.some(function(item) { return item.matcher.match(path) || !!(item.gmatcher && item.gmatcher.match(path)) }) } function childrenIgnored (self, path) { if (!self.ignore.length) return false return self.ignore.some(function(item) { return !!(item.gmatcher && item.gmatcher.match(path)) }) } }).call(this,require('_process')) },{"_process":295,"minimatch":247,"path":290,"path-is-absolute":291}],151:[function(require,module,exports){ (function (process){ // Approach: // // 1. Get the minimatch set // 2. For each pattern in the set, PROCESS(pattern, false) // 3. Store matches per-set, then uniq them // // PROCESS(pattern, inGlobStar) // Get the first [n] items from pattern that are all strings // Join these together. This is PREFIX. // If there is no more remaining, then stat(PREFIX) and // add to matches if it succeeds. END. // // If inGlobStar and PREFIX is symlink and points to dir // set ENTRIES = [] // else readdir(PREFIX) as ENTRIES // If fail, END // // with ENTRIES // If pattern[n] is GLOBSTAR // // handle the case where the globstar match is empty // // by pruning it out, and testing the resulting pattern // PROCESS(pattern[0..n] + pattern[n+1 .. $], false) // // handle other cases. // for ENTRY in ENTRIES (not dotfiles) // // attach globstar + tail onto the entry // // Mark that this entry is a globstar match // PROCESS(pattern[0..n] + ENTRY + pattern[n .. $], true) // // else // not globstar // for ENTRY in ENTRIES (not dotfiles, unless pattern[n] is dot) // Test ENTRY against pattern[n] // If fails, continue // If passes, PROCESS(pattern[0..n] + item + pattern[n+1 .. $]) // // Caveat: // Cache all stats and readdirs results to minimize syscall. Since all // we ever care about is existence and directory-ness, we can just keep // `true` for files, and [children,...] for directories, or `false` for // things that don't exist. module.exports = glob var fs = require('fs') var minimatch = require('minimatch') var Minimatch = minimatch.Minimatch var inherits = require('inherits') var EE = require('events').EventEmitter var path = require('path') var assert = require('assert') var isAbsolute = require('path-is-absolute') var globSync = require('./sync.js') var common = require('./common.js') var alphasort = common.alphasort var alphasorti = common.alphasorti var setopts = common.setopts var ownProp = common.ownProp var inflight = require('inflight') var util = require('util') var childrenIgnored = common.childrenIgnored var isIgnored = common.isIgnored var once = require('once') function glob (pattern, options, cb) { if (typeof options === 'function') cb = options, options = {} if (!options) options = {} if (options.sync) { if (cb) throw new TypeError('callback provided to sync glob') return globSync(pattern, options) } return new Glob(pattern, options, cb) } glob.sync = globSync var GlobSync = glob.GlobSync = globSync.GlobSync // old api surface glob.glob = glob function extend (origin, add) { if (add === null || typeof add !== 'object') { return origin } var keys = Object.keys(add) var i = keys.length while (i--) { origin[keys[i]] = add[keys[i]] } return origin } glob.hasMagic = function (pattern, options_) { var options = extend({}, options_) options.noprocess = true var g = new Glob(pattern, options) var set = g.minimatch.set if (set.length > 1) return true for (var j = 0; j < set[0].length; j++) { if (typeof set[0][j] !== 'string') return true } return false } glob.Glob = Glob inherits(Glob, EE) function Glob (pattern, options, cb) { if (typeof options === 'function') { cb = options options = null } if (options && options.sync) { if (cb) throw new TypeError('callback provided to sync glob') return new GlobSync(pattern, options) } if (!(this instanceof Glob)) return new Glob(pattern, options, cb) setopts(this, pattern, options) this._didRealPath = false // process each pattern in the minimatch set var n = this.minimatch.set.length // The matches are stored as {: true,...} so that // duplicates are automagically pruned. // Later, we do an Object.keys() on these. // Keep them as a list so we can fill in when nonull is set. this.matches = new Array(n) if (typeof cb === 'function') { cb = once(cb) this.on('error', cb) this.on('end', function (matches) { cb(null, matches) }) } var self = this var n = this.minimatch.set.length this._processing = 0 this.matches = new Array(n) this._emitQueue = [] this._processQueue = [] this.paused = false if (this.noprocess) return this if (n === 0) return done() for (var i = 0; i < n; i ++) { this._process(this.minimatch.set[i], i, false, done) } function done () { --self._processing if (self._processing <= 0) self._finish() } } Glob.prototype._finish = function () { assert(this instanceof Glob) if (this.aborted) return if (this.realpath && !this._didRealpath) return this._realpath() common.finish(this) this.emit('end', this.found) } Glob.prototype._realpath = function () { if (this._didRealpath) return this._didRealpath = true var n = this.matches.length if (n === 0) return this._finish() var self = this for (var i = 0; i < this.matches.length; i++) this._realpathSet(i, next) function next () { if (--n === 0) self._finish() } } Glob.prototype._realpathSet = function (index, cb) { var matchset = this.matches[index] if (!matchset) return cb() var found = Object.keys(matchset) var self = this var n = found.length if (n === 0) return cb() var set = this.matches[index] = Object.create(null) found.forEach(function (p, i) { // If there's a problem with the stat, then it means that // one or more of the links in the realpath couldn't be // resolved. just return the abs value in that case. p = self._makeAbs(p) fs.realpath(p, self.realpathCache, function (er, real) { if (!er) set[real] = true else if (er.syscall === 'stat') set[p] = true else self.emit('error', er) // srsly wtf right here if (--n === 0) { self.matches[index] = set cb() } }) }) } Glob.prototype._mark = function (p) { return common.mark(this, p) } Glob.prototype._makeAbs = function (f) { return common.makeAbs(this, f) } Glob.prototype.abort = function () { this.aborted = true this.emit('abort') } Glob.prototype.pause = function () { if (!this.paused) { this.paused = true this.emit('pause') } } Glob.prototype.resume = function () { if (this.paused) { this.emit('resume') this.paused = false if (this._emitQueue.length) { var eq = this._emitQueue.slice(0) this._emitQueue.length = 0 for (var i = 0; i < eq.length; i ++) { var e = eq[i] this._emitMatch(e[0], e[1]) } } if (this._processQueue.length) { var pq = this._processQueue.slice(0) this._processQueue.length = 0 for (var i = 0; i < pq.length; i ++) { var p = pq[i] this._processing-- this._process(p[0], p[1], p[2], p[3]) } } } } Glob.prototype._process = function (pattern, index, inGlobStar, cb) { assert(this instanceof Glob) assert(typeof cb === 'function') if (this.aborted) return this._processing++ if (this.paused) { this._processQueue.push([pattern, index, inGlobStar, cb]) return } //console.error('PROCESS %d', this._processing, pattern) // Get the first [n] parts of pattern that are all strings. var n = 0 while (typeof pattern[n] === 'string') { n ++ } // now n is the index of the first one that is *not* a string. // see if there's anything else var prefix switch (n) { // if not, then this is rather simple case pattern.length: this._processSimple(pattern.join('/'), index, cb) return case 0: // pattern *starts* with some non-trivial item. // going to readdir(cwd), but not include the prefix in matches. prefix = null break default: // pattern has some string bits in the front. // whatever it starts with, whether that's 'absolute' like /foo/bar, // or 'relative' like '../baz' prefix = pattern.slice(0, n).join('/') break } var remain = pattern.slice(n) // get the list of entries. var read if (prefix === null) read = '.' else if (isAbsolute(prefix) || isAbsolute(pattern.join('/'))) { if (!prefix || !isAbsolute(prefix)) prefix = '/' + prefix read = prefix } else read = prefix var abs = this._makeAbs(read) //if ignored, skip _processing if (childrenIgnored(this, read)) return cb() var isGlobStar = remain[0] === minimatch.GLOBSTAR if (isGlobStar) this._processGlobStar(prefix, read, abs, remain, index, inGlobStar, cb) else this._processReaddir(prefix, read, abs, remain, index, inGlobStar, cb) } Glob.prototype._processReaddir = function (prefix, read, abs, remain, index, inGlobStar, cb) { var self = this this._readdir(abs, inGlobStar, function (er, entries) { return self._processReaddir2(prefix, read, abs, remain, index, inGlobStar, entries, cb) }) } Glob.prototype._processReaddir2 = function (prefix, read, abs, remain, index, inGlobStar, entries, cb) { // if the abs isn't a dir, then nothing can match! if (!entries) return cb() // It will only match dot entries if it starts with a dot, or if // dot is set. Stuff like @(.foo|.bar) isn't allowed. var pn = remain[0] var negate = !!this.minimatch.negate var rawGlob = pn._glob var dotOk = this.dot || rawGlob.charAt(0) === '.' var matchedEntries = [] for (var i = 0; i < entries.length; i++) { var e = entries[i] if (e.charAt(0) !== '.' || dotOk) { var m if (negate && !prefix) { m = !e.match(pn) } else { m = e.match(pn) } if (m) matchedEntries.push(e) } } //console.error('prd2', prefix, entries, remain[0]._glob, matchedEntries) var len = matchedEntries.length // If there are no matched entries, then nothing matches. if (len === 0) return cb() // if this is the last remaining pattern bit, then no need for // an additional stat *unless* the user has specified mark or // stat explicitly. We know they exist, since readdir returned // them. if (remain.length === 1 && !this.mark && !this.stat) { if (!this.matches[index]) this.matches[index] = Object.create(null) for (var i = 0; i < len; i ++) { var e = matchedEntries[i] if (prefix) { if (prefix !== '/') e = prefix + '/' + e else e = prefix + e } if (e.charAt(0) === '/' && !this.nomount) { e = path.join(this.root, e) } this._emitMatch(index, e) } // This was the last one, and no stats were needed return cb() } // now test all matched entries as stand-ins for that part // of the pattern. remain.shift() for (var i = 0; i < len; i ++) { var e = matchedEntries[i] var newPattern if (prefix) { if (prefix !== '/') e = prefix + '/' + e else e = prefix + e } this._process([e].concat(remain), index, inGlobStar, cb) } cb() } Glob.prototype._emitMatch = function (index, e) { if (this.aborted) return if (this.matches[index][e]) return if (isIgnored(this, e)) return if (this.paused) { this._emitQueue.push([index, e]) return } var abs = this._makeAbs(e) if (this.nodir) { var c = this.cache[abs] if (c === 'DIR' || Array.isArray(c)) return } if (this.mark) e = this._mark(e) this.matches[index][e] = true var st = this.statCache[abs] if (st) this.emit('stat', e, st) this.emit('match', e) } Glob.prototype._readdirInGlobStar = function (abs, cb) { if (this.aborted) return // follow all symlinked directories forever // just proceed as if this is a non-globstar situation if (this.follow) return this._readdir(abs, false, cb) var lstatkey = 'lstat\0' + abs var self = this var lstatcb = inflight(lstatkey, lstatcb_) if (lstatcb) fs.lstat(abs, lstatcb) function lstatcb_ (er, lstat) { if (er) return cb() var isSym = lstat.isSymbolicLink() self.symlinks[abs] = isSym // If it's not a symlink or a dir, then it's definitely a regular file. // don't bother doing a readdir in that case. if (!isSym && !lstat.isDirectory()) { self.cache[abs] = 'FILE' cb() } else self._readdir(abs, false, cb) } } Glob.prototype._readdir = function (abs, inGlobStar, cb) { if (this.aborted) return cb = inflight('readdir\0'+abs+'\0'+inGlobStar, cb) if (!cb) return //console.error('RD %j %j', +inGlobStar, abs) if (inGlobStar && !ownProp(this.symlinks, abs)) return this._readdirInGlobStar(abs, cb) if (ownProp(this.cache, abs)) { var c = this.cache[abs] if (!c || c === 'FILE') return cb() if (Array.isArray(c)) return cb(null, c) } var self = this fs.readdir(abs, readdirCb(this, abs, cb)) } function readdirCb (self, abs, cb) { return function (er, entries) { if (er) self._readdirError(abs, er, cb) else self._readdirEntries(abs, entries, cb) } } Glob.prototype._readdirEntries = function (abs, entries, cb) { if (this.aborted) return // if we haven't asked to stat everything, then just // assume that everything in there exists, so we can avoid // having to stat it a second time. if (!this.mark && !this.stat) { for (var i = 0; i < entries.length; i ++) { var e = entries[i] if (abs === '/') e = abs + e else e = abs + '/' + e this.cache[e] = true } } this.cache[abs] = entries return cb(null, entries) } Glob.prototype._readdirError = function (f, er, cb) { if (this.aborted) return // handle errors, and cache the information switch (er.code) { case 'ENOTSUP': // https://github.com/isaacs/node-glob/issues/205 case 'ENOTDIR': // totally normal. means it *does* exist. this.cache[this._makeAbs(f)] = 'FILE' break case 'ENOENT': // not terribly unusual case 'ELOOP': case 'ENAMETOOLONG': case 'UNKNOWN': this.cache[this._makeAbs(f)] = false break default: // some unusual error. Treat as failure. this.cache[this._makeAbs(f)] = false if (this.strict) { this.emit('error', er) // If the error is handled, then we abort // if not, we threw out of here this.abort() } if (!this.silent) console.error('glob error', er) break } return cb() } Glob.prototype._processGlobStar = function (prefix, read, abs, remain, index, inGlobStar, cb) { var self = this this._readdir(abs, inGlobStar, function (er, entries) { self._processGlobStar2(prefix, read, abs, remain, index, inGlobStar, entries, cb) }) } Glob.prototype._processGlobStar2 = function (prefix, read, abs, remain, index, inGlobStar, entries, cb) { //console.error('pgs2', prefix, remain[0], entries) // no entries means not a dir, so it can never have matches // foo.txt/** doesn't match foo.txt if (!entries) return cb() // test without the globstar, and with every child both below // and replacing the globstar. var remainWithoutGlobStar = remain.slice(1) var gspref = prefix ? [ prefix ] : [] var noGlobStar = gspref.concat(remainWithoutGlobStar) // the noGlobStar pattern exits the inGlobStar state this._process(noGlobStar, index, false, cb) var isSym = this.symlinks[abs] var len = entries.length // If it's a symlink, and we're in a globstar, then stop if (isSym && inGlobStar) return cb() for (var i = 0; i < len; i++) { var e = entries[i] if (e.charAt(0) === '.' && !this.dot) continue // these two cases enter the inGlobStar state var instead = gspref.concat(entries[i], remainWithoutGlobStar) this._process(instead, index, true, cb) var below = gspref.concat(entries[i], remain) this._process(below, index, true, cb) } cb() } Glob.prototype._processSimple = function (prefix, index, cb) { // XXX review this. Shouldn't it be doing the mounting etc // before doing stat? kinda weird? var self = this this._stat(prefix, function (er, exists) { self._processSimple2(prefix, index, er, exists, cb) }) } Glob.prototype._processSimple2 = function (prefix, index, er, exists, cb) { //console.error('ps2', prefix, exists) if (!this.matches[index]) this.matches[index] = Object.create(null) // If it doesn't exist, then just mark the lack of results if (!exists) return cb() if (prefix && isAbsolute(prefix) && !this.nomount) { var trail = /[\/\\]$/.test(prefix) if (prefix.charAt(0) === '/') { prefix = path.join(this.root, prefix) } else { prefix = path.resolve(this.root, prefix) if (trail) prefix += '/' } } if (process.platform === 'win32') prefix = prefix.replace(/\\/g, '/') // Mark this as a match this._emitMatch(index, prefix) cb() } // Returns either 'DIR', 'FILE', or false Glob.prototype._stat = function (f, cb) { var abs = this._makeAbs(f) var needDir = f.slice(-1) === '/' if (f.length > this.maxLength) return cb() if (!this.stat && ownProp(this.cache, abs)) { var c = this.cache[abs] if (Array.isArray(c)) c = 'DIR' // It exists, but maybe not how we need it if (!needDir || c === 'DIR') return cb(null, c) if (needDir && c === 'FILE') return cb() // otherwise we have to stat, because maybe c=true // if we know it exists, but not what it is. } var exists var stat = this.statCache[abs] if (stat !== undefined) { if (stat === false) return cb(null, stat) else { var type = stat.isDirectory() ? 'DIR' : 'FILE' if (needDir && type === 'FILE') return cb() else return cb(null, type, stat) } } var self = this var statcb = inflight('stat\0' + abs, lstatcb_) if (statcb) fs.lstat(abs, statcb) function lstatcb_ (er, lstat) { if (lstat && lstat.isSymbolicLink()) { // If it's a symlink, then treat it as the target, unless // the target does not exist, then treat it as a file. return fs.stat(abs, function (er, stat) { if (er) self._stat2(f, abs, null, lstat, cb) else self._stat2(f, abs, er, stat, cb) }) } else { self._stat2(f, abs, er, lstat, cb) } } } Glob.prototype._stat2 = function (f, abs, er, stat, cb) { if (er) { this.statCache[abs] = false return cb() } var needDir = f.slice(-1) === '/' this.statCache[abs] = stat if (abs.slice(-1) === '/' && !stat.isDirectory()) return cb(null, false, stat) var c = stat.isDirectory() ? 'DIR' : 'FILE' this.cache[abs] = this.cache[abs] || c if (needDir && c !== 'DIR') return cb() return cb(null, c, stat) } }).call(this,require('_process')) },{"./common.js":150,"./sync.js":152,"_process":295,"assert":15,"events":144,"fs":58,"inflight":166,"inherits":167,"minimatch":247,"once":278,"path":290,"path-is-absolute":291,"util":636}],152:[function(require,module,exports){ (function (process){ module.exports = globSync globSync.GlobSync = GlobSync var fs = require('fs') var minimatch = require('minimatch') var Minimatch = minimatch.Minimatch var Glob = require('./glob.js').Glob var util = require('util') var path = require('path') var assert = require('assert') var isAbsolute = require('path-is-absolute') var common = require('./common.js') var alphasort = common.alphasort var alphasorti = common.alphasorti var setopts = common.setopts var ownProp = common.ownProp var childrenIgnored = common.childrenIgnored function globSync (pattern, options) { if (typeof options === 'function' || arguments.length === 3) throw new TypeError('callback provided to sync glob\n'+ 'See: https://github.com/isaacs/node-glob/issues/167') return new GlobSync(pattern, options).found } function GlobSync (pattern, options) { if (!pattern) throw new Error('must provide pattern') if (typeof options === 'function' || arguments.length === 3) throw new TypeError('callback provided to sync glob\n'+ 'See: https://github.com/isaacs/node-glob/issues/167') if (!(this instanceof GlobSync)) return new GlobSync(pattern, options) setopts(this, pattern, options) if (this.noprocess) return this var n = this.minimatch.set.length this.matches = new Array(n) for (var i = 0; i < n; i ++) { this._process(this.minimatch.set[i], i, false) } this._finish() } GlobSync.prototype._finish = function () { assert(this instanceof GlobSync) if (this.realpath) { var self = this this.matches.forEach(function (matchset, index) { var set = self.matches[index] = Object.create(null) for (var p in matchset) { try { p = self._makeAbs(p) var real = fs.realpathSync(p, self.realpathCache) set[real] = true } catch (er) { if (er.syscall === 'stat') set[self._makeAbs(p)] = true else throw er } } }) } common.finish(this) } GlobSync.prototype._process = function (pattern, index, inGlobStar) { assert(this instanceof GlobSync) // Get the first [n] parts of pattern that are all strings. var n = 0 while (typeof pattern[n] === 'string') { n ++ } // now n is the index of the first one that is *not* a string. // See if there's anything else var prefix switch (n) { // if not, then this is rather simple case pattern.length: this._processSimple(pattern.join('/'), index) return case 0: // pattern *starts* with some non-trivial item. // going to readdir(cwd), but not include the prefix in matches. prefix = null break default: // pattern has some string bits in the front. // whatever it starts with, whether that's 'absolute' like /foo/bar, // or 'relative' like '../baz' prefix = pattern.slice(0, n).join('/') break } var remain = pattern.slice(n) // get the list of entries. var read if (prefix === null) read = '.' else if (isAbsolute(prefix) || isAbsolute(pattern.join('/'))) { if (!prefix || !isAbsolute(prefix)) prefix = '/' + prefix read = prefix } else read = prefix var abs = this._makeAbs(read) //if ignored, skip processing if (childrenIgnored(this, read)) return var isGlobStar = remain[0] === minimatch.GLOBSTAR if (isGlobStar) this._processGlobStar(prefix, read, abs, remain, index, inGlobStar) else this._processReaddir(prefix, read, abs, remain, index, inGlobStar) } GlobSync.prototype._processReaddir = function (prefix, read, abs, remain, index, inGlobStar) { var entries = this._readdir(abs, inGlobStar) // if the abs isn't a dir, then nothing can match! if (!entries) return // It will only match dot entries if it starts with a dot, or if // dot is set. Stuff like @(.foo|.bar) isn't allowed. var pn = remain[0] var negate = !!this.minimatch.negate var rawGlob = pn._glob var dotOk = this.dot || rawGlob.charAt(0) === '.' var matchedEntries = [] for (var i = 0; i < entries.length; i++) { var e = entries[i] if (e.charAt(0) !== '.' || dotOk) { var m if (negate && !prefix) { m = !e.match(pn) } else { m = e.match(pn) } if (m) matchedEntries.push(e) } } var len = matchedEntries.length // If there are no matched entries, then nothing matches. if (len === 0) return // if this is the last remaining pattern bit, then no need for // an additional stat *unless* the user has specified mark or // stat explicitly. We know they exist, since readdir returned // them. if (remain.length === 1 && !this.mark && !this.stat) { if (!this.matches[index]) this.matches[index] = Object.create(null) for (var i = 0; i < len; i ++) { var e = matchedEntries[i] if (prefix) { if (prefix.slice(-1) !== '/') e = prefix + '/' + e else e = prefix + e } if (e.charAt(0) === '/' && !this.nomount) { e = path.join(this.root, e) } this.matches[index][e] = true } // This was the last one, and no stats were needed return } // now test all matched entries as stand-ins for that part // of the pattern. remain.shift() for (var i = 0; i < len; i ++) { var e = matchedEntries[i] var newPattern if (prefix) newPattern = [prefix, e] else newPattern = [e] this._process(newPattern.concat(remain), index, inGlobStar) } } GlobSync.prototype._emitMatch = function (index, e) { var abs = this._makeAbs(e) if (this.mark) e = this._mark(e) if (this.matches[index][e]) return if (this.nodir) { var c = this.cache[this._makeAbs(e)] if (c === 'DIR' || Array.isArray(c)) return } this.matches[index][e] = true if (this.stat) this._stat(e) } GlobSync.prototype._readdirInGlobStar = function (abs) { // follow all symlinked directories forever // just proceed as if this is a non-globstar situation if (this.follow) return this._readdir(abs, false) var entries var lstat var stat try { lstat = fs.lstatSync(abs) } catch (er) { // lstat failed, doesn't exist return null } var isSym = lstat.isSymbolicLink() this.symlinks[abs] = isSym // If it's not a symlink or a dir, then it's definitely a regular file. // don't bother doing a readdir in that case. if (!isSym && !lstat.isDirectory()) this.cache[abs] = 'FILE' else entries = this._readdir(abs, false) return entries } GlobSync.prototype._readdir = function (abs, inGlobStar) { var entries if (inGlobStar && !ownProp(this.symlinks, abs)) return this._readdirInGlobStar(abs) if (ownProp(this.cache, abs)) { var c = this.cache[abs] if (!c || c === 'FILE') return null if (Array.isArray(c)) return c } try { return this._readdirEntries(abs, fs.readdirSync(abs)) } catch (er) { this._readdirError(abs, er) return null } } GlobSync.prototype._readdirEntries = function (abs, entries) { // if we haven't asked to stat everything, then just // assume that everything in there exists, so we can avoid // having to stat it a second time. if (!this.mark && !this.stat) { for (var i = 0; i < entries.length; i ++) { var e = entries[i] if (abs === '/') e = abs + e else e = abs + '/' + e this.cache[e] = true } } this.cache[abs] = entries // mark and cache dir-ness return entries } GlobSync.prototype._readdirError = function (f, er) { // handle errors, and cache the information switch (er.code) { case 'ENOTSUP': // https://github.com/isaacs/node-glob/issues/205 case 'ENOTDIR': // totally normal. means it *does* exist. this.cache[this._makeAbs(f)] = 'FILE' break case 'ENOENT': // not terribly unusual case 'ELOOP': case 'ENAMETOOLONG': case 'UNKNOWN': this.cache[this._makeAbs(f)] = false break default: // some unusual error. Treat as failure. this.cache[this._makeAbs(f)] = false if (this.strict) throw er if (!this.silent) console.error('glob error', er) break } } GlobSync.prototype._processGlobStar = function (prefix, read, abs, remain, index, inGlobStar) { var entries = this._readdir(abs, inGlobStar) // no entries means not a dir, so it can never have matches // foo.txt/** doesn't match foo.txt if (!entries) return // test without the globstar, and with every child both below // and replacing the globstar. var remainWithoutGlobStar = remain.slice(1) var gspref = prefix ? [ prefix ] : [] var noGlobStar = gspref.concat(remainWithoutGlobStar) // the noGlobStar pattern exits the inGlobStar state this._process(noGlobStar, index, false) var len = entries.length var isSym = this.symlinks[abs] // If it's a symlink, and we're in a globstar, then stop if (isSym && inGlobStar) return for (var i = 0; i < len; i++) { var e = entries[i] if (e.charAt(0) === '.' && !this.dot) continue // these two cases enter the inGlobStar state var instead = gspref.concat(entries[i], remainWithoutGlobStar) this._process(instead, index, true) var below = gspref.concat(entries[i], remain) this._process(below, index, true) } } GlobSync.prototype._processSimple = function (prefix, index) { // XXX review this. Shouldn't it be doing the mounting etc // before doing stat? kinda weird? var exists = this._stat(prefix) if (!this.matches[index]) this.matches[index] = Object.create(null) // If it doesn't exist, then just mark the lack of results if (!exists) return if (prefix && isAbsolute(prefix) && !this.nomount) { var trail = /[\/\\]$/.test(prefix) if (prefix.charAt(0) === '/') { prefix = path.join(this.root, prefix) } else { prefix = path.resolve(this.root, prefix) if (trail) prefix += '/' } } if (process.platform === 'win32') prefix = prefix.replace(/\\/g, '/') // Mark this as a match this.matches[index][prefix] = true } // Returns either 'DIR', 'FILE', or false GlobSync.prototype._stat = function (f) { var abs = this._makeAbs(f) var needDir = f.slice(-1) === '/' if (f.length > this.maxLength) return false if (!this.stat && ownProp(this.cache, abs)) { var c = this.cache[abs] if (Array.isArray(c)) c = 'DIR' // It exists, but maybe not how we need it if (!needDir || c === 'DIR') return c if (needDir && c === 'FILE') return false // otherwise we have to stat, because maybe c=true // if we know it exists, but not what it is. } var exists var stat = this.statCache[abs] if (!stat) { var lstat try { lstat = fs.lstatSync(abs) } catch (er) { return false } if (lstat.isSymbolicLink()) { try { stat = fs.statSync(abs) } catch (er) { stat = lstat } } else { stat = lstat } } this.statCache[abs] = stat var c = stat.isDirectory() ? 'DIR' : 'FILE' this.cache[abs] = this.cache[abs] || c if (needDir && c !== 'DIR') return false return c } GlobSync.prototype._mark = function (p) { return common.mark(this, p) } GlobSync.prototype._makeAbs = function (f) { return common.makeAbs(this, f) } }).call(this,require('_process')) },{"./common.js":150,"./glob.js":151,"_process":295,"assert":15,"fs":58,"minimatch":247,"path":290,"path-is-absolute":291,"util":636}],153:[function(require,module,exports){ 'use strict'; // // Algorithms // // probably move these to another file when there get to be lots of them. function count(obj) { var c = 0 for(var k in obj) c++ return c } function widthTraverse (graph, reachable, start, depth, hops, max, iter) { if(!start) throw new Error('Graphmitter#traverse: start must be provided') var nodes = 1 reachable[start] = reachable[start] == null ? 0 : reachable[start] var queue = [{key: start, hops: depth}] iter = iter || function () {} var abort = false while(queue.length && (!max || nodes < max) && !abort) { var o = queue.shift() var h = o.hops var n = graph.nodes[o.key] if(n && (!hops || (h + 1 <= hops))) for(var k in n.edges) { // If we have already been to this node by a shorter path, // then skip this node (this only happens when processing // a realtime edge) if(!(reachable[k] != null && reachable[k] < h + 1)) { if(false === iter(o.key, k, h + 1, reachable[k])) return reachable reachable[k] = h + 1 nodes ++ queue.push({key: k, hops: h + 1}) } } } return reachable } exports.traverse = function (opts, onEach) { var self = this var maxHops = opts.hops || 3 var maxNodes = opts.max || 150 var reachable = {} opts.each = onEach = onEach || opts.each widthTraverse( this, reachable, opts.start, 0, //initial hops opts.hops, //max hops opts.max, //max nodes opts.old !== false && onEach ) if(!onEach || opts.live === false) return reachable function onEdge (from, to) { //if this edge is part of the initial setd if(reachable[from] != null && reachable[from] < maxHops) { //edges to new nodes. var h = reachable[from] + 1 var _h = reachable[to] if(_h == null) onEach(from, to, reachable[to] = h, _h) else if(Math.min(h, _h) != _h) onEach(from, to, reachable[to] = Math.min(h, _h), _h) if(h <= maxHops && h != _h) { //also add other nodes that are now reachable. widthTraverse(self, reachable, to, h, maxHops, maxNodes, onEach) } } } this.on('edge', onEdge) return function () { self.removeListener('edge', onEdge) } } // page rank. I adapted the algorithm to use // forward links instead of backward links which means // we only have to traverse the graph one time. exports.rank = function (opts) { opts = opts || {} var ranks = {}, links = {}, _ranks = {} var N = count(this.nodes) var iterations = opts.iterations || 1 var damping = opts.damping || 0.85 var init = (1 - damping) / N //initialize this.each(function (k, n) { ranks[k] = 1/N; _ranks[k] = init links[k] = count(n.edges) }) while(iterations --> 0) { //iteration this.each(function (j, n) { var r = damping*(ranks[j]/links[j]) n.each(function (k) { _ranks[k] += r }) }) //reset for(var k in ranks) ranks[k] = init var __ranks = ranks ranks = _ranks _ranks = __ranks } return ranks } //find the shortest path between two nodes. //if there was no path within max hops, return null. //convert a spanning tree to an array. function toArray (span, root) { if(!span[root]) return null var a = [root] while(span[root]) a.push(root = span[root]) return a.reverse() } exports.path = function (opts) { var reverse = {} if(opts.source == opts.dest) return [opts.source] opts.start = opts.source opts.live = false opts.each = function (f, t, h) { reverse[t] = f } this.traverse(opts) return toArray(reverse, opts.dest) } },{}],154:[function(require,module,exports){ var EventEmitter = require('events').EventEmitter var inherits = require('util').inherits inherits(Graphmitter, EventEmitter) module.exports = Graphmitter function each(obj, iter) { for(var k in obj) iter(k, obj[k]) } // // Node / Vertice // function Node () { this.edges = {} } var nproto = Node.prototype //returns the old data for this edge.. nproto.edge = function (to, data) { var _data = this.edges[to] this.edges[to] = (data == null ? true : data) return _data } nproto.has = function (to) { return this.edges[to] } //also returns the old data for this edge.. nproto.del = function (to, data) { var _data = this.edges[to] delete this.edges[to] return _data } nproto.each = function (iter) { each(this.edges, iter) return this } // // the whole graph // function Graphmitter () { if(!(this instanceof Graphmitter)) return new Graphmitter() this.nodes = {} } var proto = Graphmitter.prototype proto.hasNode = function (n) { return !!this.nodes[n] } proto.hasEdge = function (f, t) { return this.hasNode(f) && !!this.nodes[f].edges[t] != null } proto.node = function (n) { return this.nodes[n] = this.nodes[n] || new Node(n) } proto.get = function (f, t) { if(t == null) return this.nodes[f] return this.hasNode(f) ? this.nodes[f].edges[t] : null } proto.edge = function (from, to, data) { data = (data == null ? true : data) var f = this.node(from) this.node(to) var _data = f.edge(to, data) if(_data !== data) this.emit('edge', from, to, data, _data) return this } proto.del = function (from, to) { var data = this.node(from).del(to) if (typeof data !== 'undefined') this.emit('del', from, to, data) return this } proto.each = function (iter) { each(this.nodes, iter) return this } proto.eachEdge = function (iter) { each(this.nodes, function (from, n) { each(n.edges, function (to, data) { iter(from, to, data) }) }) return this } //get a random node proto.random = function () { var keys = Object.keys(this.nodes) return keys[~~(keys.length*Math.random())] } //add another subgraph proto.add = function (g2) { var g1 = this g2.eachEdge(function (from, to, data) { g1.edge(from, to, data) }) return this } proto.toJSON = function (iter) { var g = {} this.each(function (k, v) { var e = {} v.each(function (k, v) { e[k] = v }) g[k] = e }) return g } // // graph generators // Graphmitter.random = function (nodes, edges, prefix) { prefix = prefix || '#' if(isNaN(+nodes)) throw new Error('nodes must be a number') if(isNaN(+edges)) throw new Error('edges must be a number') var n = 0, g = new Graphmitter() function rand(n) { return prefix+~~(Math.random()*n) } for(var i = 0; i < nodes; i++) g.node(prefix+i) for(var i = 0; i < edges; i++) { var a = rand(nodes), b = rand(nodes) g.edge(a, b).edge(b, a) } return g } var algorithms = require('./algorithms') for(var k in algorithms) proto[k] = algorithms[k] },{"./algorithms":153,"events":144,"util":636}],155:[function(require,module,exports){ var hash = exports; hash.utils = require('./hash/utils'); hash.common = require('./hash/common'); hash.sha = require('./hash/sha'); hash.ripemd = require('./hash/ripemd'); hash.hmac = require('./hash/hmac'); // Proxy hash functions to the main object hash.sha1 = hash.sha.sha1; hash.sha256 = hash.sha.sha256; hash.sha224 = hash.sha.sha224; hash.sha384 = hash.sha.sha384; hash.sha512 = hash.sha.sha512; hash.ripemd160 = hash.ripemd.ripemd160; },{"./hash/common":156,"./hash/hmac":157,"./hash/ripemd":158,"./hash/sha":159,"./hash/utils":160}],156:[function(require,module,exports){ var hash = require('../hash'); var utils = hash.utils; var assert = utils.assert; function BlockHash() { this.pending = null; this.pendingTotal = 0; this.blockSize = this.constructor.blockSize; this.outSize = this.constructor.outSize; this.hmacStrength = this.constructor.hmacStrength; this.padLength = this.constructor.padLength / 8; this.endian = 'big'; this._delta8 = this.blockSize / 8; this._delta32 = this.blockSize / 32; } exports.BlockHash = BlockHash; BlockHash.prototype.update = function update(msg, enc) { // Convert message to array, pad it, and join into 32bit blocks msg = utils.toArray(msg, enc); if (!this.pending) this.pending = msg; else this.pending = this.pending.concat(msg); this.pendingTotal += msg.length; // Enough data, try updating if (this.pending.length >= this._delta8) { msg = this.pending; // Process pending data in blocks var r = msg.length % this._delta8; this.pending = msg.slice(msg.length - r, msg.length); if (this.pending.length === 0) this.pending = null; msg = utils.join32(msg, 0, msg.length - r, this.endian); for (var i = 0; i < msg.length; i += this._delta32) this._update(msg, i, i + this._delta32); } return this; }; BlockHash.prototype.digest = function digest(enc) { this.update(this._pad()); assert(this.pending === null); return this._digest(enc); }; BlockHash.prototype._pad = function pad() { var len = this.pendingTotal; var bytes = this._delta8; var k = bytes - ((len + this.padLength) % bytes); var res = new Array(k + this.padLength); res[0] = 0x80; for (var i = 1; i < k; i++) res[i] = 0; // Append length len <<= 3; if (this.endian === 'big') { for (var t = 8; t < this.padLength; t++) res[i++] = 0; res[i++] = 0; res[i++] = 0; res[i++] = 0; res[i++] = 0; res[i++] = (len >>> 24) & 0xff; res[i++] = (len >>> 16) & 0xff; res[i++] = (len >>> 8) & 0xff; res[i++] = len & 0xff; } else { res[i++] = len & 0xff; res[i++] = (len >>> 8) & 0xff; res[i++] = (len >>> 16) & 0xff; res[i++] = (len >>> 24) & 0xff; res[i++] = 0; res[i++] = 0; res[i++] = 0; res[i++] = 0; for (var t = 8; t < this.padLength; t++) res[i++] = 0; } return res; }; },{"../hash":155}],157:[function(require,module,exports){ var hmac = exports; var hash = require('../hash'); var utils = hash.utils; var assert = utils.assert; function Hmac(hash, key, enc) { if (!(this instanceof Hmac)) return new Hmac(hash, key, enc); this.Hash = hash; this.blockSize = hash.blockSize / 8; this.outSize = hash.outSize / 8; this.inner = null; this.outer = null; this._init(utils.toArray(key, enc)); } module.exports = Hmac; Hmac.prototype._init = function init(key) { // Shorten key, if needed if (key.length > this.blockSize) key = new this.Hash().update(key).digest(); assert(key.length <= this.blockSize); // Add padding to key for (var i = key.length; i < this.blockSize; i++) key.push(0); for (var i = 0; i < key.length; i++) key[i] ^= 0x36; this.inner = new this.Hash().update(key); // 0x36 ^ 0x5c = 0x6a for (var i = 0; i < key.length; i++) key[i] ^= 0x6a; this.outer = new this.Hash().update(key); }; Hmac.prototype.update = function update(msg, enc) { this.inner.update(msg, enc); return this; }; Hmac.prototype.digest = function digest(enc) { this.outer.update(this.inner.digest()); return this.outer.digest(enc); }; },{"../hash":155}],158:[function(require,module,exports){ var hash = require('../hash'); var utils = hash.utils; var rotl32 = utils.rotl32; var sum32 = utils.sum32; var sum32_3 = utils.sum32_3; var sum32_4 = utils.sum32_4; var BlockHash = hash.common.BlockHash; function RIPEMD160() { if (!(this instanceof RIPEMD160)) return new RIPEMD160(); BlockHash.call(this); this.h = [ 0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476, 0xc3d2e1f0 ]; this.endian = 'little'; } utils.inherits(RIPEMD160, BlockHash); exports.ripemd160 = RIPEMD160; RIPEMD160.blockSize = 512; RIPEMD160.outSize = 160; RIPEMD160.hmacStrength = 192; RIPEMD160.padLength = 64; RIPEMD160.prototype._update = function update(msg, start) { var A = this.h[0]; var B = this.h[1]; var C = this.h[2]; var D = this.h[3]; var E = this.h[4]; var Ah = A; var Bh = B; var Ch = C; var Dh = D; var Eh = E; for (var j = 0; j < 80; j++) { var T = sum32( rotl32( sum32_4(A, f(j, B, C, D), msg[r[j] + start], K(j)), s[j]), E); A = E; E = D; D = rotl32(C, 10); C = B; B = T; T = sum32( rotl32( sum32_4(Ah, f(79 - j, Bh, Ch, Dh), msg[rh[j] + start], Kh(j)), sh[j]), Eh); Ah = Eh; Eh = Dh; Dh = rotl32(Ch, 10); Ch = Bh; Bh = T; } T = sum32_3(this.h[1], C, Dh); this.h[1] = sum32_3(this.h[2], D, Eh); this.h[2] = sum32_3(this.h[3], E, Ah); this.h[3] = sum32_3(this.h[4], A, Bh); this.h[4] = sum32_3(this.h[0], B, Ch); this.h[0] = T; }; RIPEMD160.prototype._digest = function digest(enc) { if (enc === 'hex') return utils.toHex32(this.h, 'little'); else return utils.split32(this.h, 'little'); }; function f(j, x, y, z) { if (j <= 15) return x ^ y ^ z; else if (j <= 31) return (x & y) | ((~x) & z); else if (j <= 47) return (x | (~y)) ^ z; else if (j <= 63) return (x & z) | (y & (~z)); else return x ^ (y | (~z)); } function K(j) { if (j <= 15) return 0x00000000; else if (j <= 31) return 0x5a827999; else if (j <= 47) return 0x6ed9eba1; else if (j <= 63) return 0x8f1bbcdc; else return 0xa953fd4e; } function Kh(j) { if (j <= 15) return 0x50a28be6; else if (j <= 31) return 0x5c4dd124; else if (j <= 47) return 0x6d703ef3; else if (j <= 63) return 0x7a6d76e9; else return 0x00000000; } var r = [ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8, 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12, 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2, 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13 ]; var rh = [ 5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12, 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2, 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13, 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14, 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11 ]; var s = [ 11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8, 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12, 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5, 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12, 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6 ]; var sh = [ 8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6, 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11, 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5, 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8, 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11 ]; },{"../hash":155}],159:[function(require,module,exports){ var hash = require('../hash'); var utils = hash.utils; var assert = utils.assert; var rotr32 = utils.rotr32; var rotl32 = utils.rotl32; var sum32 = utils.sum32; var sum32_4 = utils.sum32_4; var sum32_5 = utils.sum32_5; var rotr64_hi = utils.rotr64_hi; var rotr64_lo = utils.rotr64_lo; var shr64_hi = utils.shr64_hi; var shr64_lo = utils.shr64_lo; var sum64 = utils.sum64; var sum64_hi = utils.sum64_hi; var sum64_lo = utils.sum64_lo; var sum64_4_hi = utils.sum64_4_hi; var sum64_4_lo = utils.sum64_4_lo; var sum64_5_hi = utils.sum64_5_hi; var sum64_5_lo = utils.sum64_5_lo; var BlockHash = hash.common.BlockHash; var sha256_K = [ 0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5, 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5, 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3, 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174, 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc, 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da, 0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7, 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967, 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13, 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85, 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3, 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070, 0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5, 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3, 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208, 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2 ]; var sha512_K = [ 0x428a2f98, 0xd728ae22, 0x71374491, 0x23ef65cd, 0xb5c0fbcf, 0xec4d3b2f, 0xe9b5dba5, 0x8189dbbc, 0x3956c25b, 0xf348b538, 0x59f111f1, 0xb605d019, 0x923f82a4, 0xaf194f9b, 0xab1c5ed5, 0xda6d8118, 0xd807aa98, 0xa3030242, 0x12835b01, 0x45706fbe, 0x243185be, 0x4ee4b28c, 0x550c7dc3, 0xd5ffb4e2, 0x72be5d74, 0xf27b896f, 0x80deb1fe, 0x3b1696b1, 0x9bdc06a7, 0x25c71235, 0xc19bf174, 0xcf692694, 0xe49b69c1, 0x9ef14ad2, 0xefbe4786, 0x384f25e3, 0x0fc19dc6, 0x8b8cd5b5, 0x240ca1cc, 0x77ac9c65, 0x2de92c6f, 0x592b0275, 0x4a7484aa, 0x6ea6e483, 0x5cb0a9dc, 0xbd41fbd4, 0x76f988da, 0x831153b5, 0x983e5152, 0xee66dfab, 0xa831c66d, 0x2db43210, 0xb00327c8, 0x98fb213f, 0xbf597fc7, 0xbeef0ee4, 0xc6e00bf3, 0x3da88fc2, 0xd5a79147, 0x930aa725, 0x06ca6351, 0xe003826f, 0x14292967, 0x0a0e6e70, 0x27b70a85, 0x46d22ffc, 0x2e1b2138, 0x5c26c926, 0x4d2c6dfc, 0x5ac42aed, 0x53380d13, 0x9d95b3df, 0x650a7354, 0x8baf63de, 0x766a0abb, 0x3c77b2a8, 0x81c2c92e, 0x47edaee6, 0x92722c85, 0x1482353b, 0xa2bfe8a1, 0x4cf10364, 0xa81a664b, 0xbc423001, 0xc24b8b70, 0xd0f89791, 0xc76c51a3, 0x0654be30, 0xd192e819, 0xd6ef5218, 0xd6990624, 0x5565a910, 0xf40e3585, 0x5771202a, 0x106aa070, 0x32bbd1b8, 0x19a4c116, 0xb8d2d0c8, 0x1e376c08, 0x5141ab53, 0x2748774c, 0xdf8eeb99, 0x34b0bcb5, 0xe19b48a8, 0x391c0cb3, 0xc5c95a63, 0x4ed8aa4a, 0xe3418acb, 0x5b9cca4f, 0x7763e373, 0x682e6ff3, 0xd6b2b8a3, 0x748f82ee, 0x5defb2fc, 0x78a5636f, 0x43172f60, 0x84c87814, 0xa1f0ab72, 0x8cc70208, 0x1a6439ec, 0x90befffa, 0x23631e28, 0xa4506ceb, 0xde82bde9, 0xbef9a3f7, 0xb2c67915, 0xc67178f2, 0xe372532b, 0xca273ece, 0xea26619c, 0xd186b8c7, 0x21c0c207, 0xeada7dd6, 0xcde0eb1e, 0xf57d4f7f, 0xee6ed178, 0x06f067aa, 0x72176fba, 0x0a637dc5, 0xa2c898a6, 0x113f9804, 0xbef90dae, 0x1b710b35, 0x131c471b, 0x28db77f5, 0x23047d84, 0x32caab7b, 0x40c72493, 0x3c9ebe0a, 0x15c9bebc, 0x431d67c4, 0x9c100d4c, 0x4cc5d4be, 0xcb3e42b6, 0x597f299c, 0xfc657e2a, 0x5fcb6fab, 0x3ad6faec, 0x6c44198c, 0x4a475817 ]; var sha1_K = [ 0x5A827999, 0x6ED9EBA1, 0x8F1BBCDC, 0xCA62C1D6 ]; function SHA256() { if (!(this instanceof SHA256)) return new SHA256(); BlockHash.call(this); this.h = [ 0x6a09e667, 0xbb67ae85, 0x3c6ef372, 0xa54ff53a, 0x510e527f, 0x9b05688c, 0x1f83d9ab, 0x5be0cd19 ]; this.k = sha256_K; this.W = new Array(64); } utils.inherits(SHA256, BlockHash); exports.sha256 = SHA256; SHA256.blockSize = 512; SHA256.outSize = 256; SHA256.hmacStrength = 192; SHA256.padLength = 64; SHA256.prototype._update = function _update(msg, start) { var W = this.W; for (var i = 0; i < 16; i++) W[i] = msg[start + i]; for (; i < W.length; i++) W[i] = sum32_4(g1_256(W[i - 2]), W[i - 7], g0_256(W[i - 15]), W[i - 16]); var a = this.h[0]; var b = this.h[1]; var c = this.h[2]; var d = this.h[3]; var e = this.h[4]; var f = this.h[5]; var g = this.h[6]; var h = this.h[7]; assert(this.k.length === W.length); for (var i = 0; i < W.length; i++) { var T1 = sum32_5(h, s1_256(e), ch32(e, f, g), this.k[i], W[i]); var T2 = sum32(s0_256(a), maj32(a, b, c)); h = g; g = f; f = e; e = sum32(d, T1); d = c; c = b; b = a; a = sum32(T1, T2); } this.h[0] = sum32(this.h[0], a); this.h[1] = sum32(this.h[1], b); this.h[2] = sum32(this.h[2], c); this.h[3] = sum32(this.h[3], d); this.h[4] = sum32(this.h[4], e); this.h[5] = sum32(this.h[5], f); this.h[6] = sum32(this.h[6], g); this.h[7] = sum32(this.h[7], h); }; SHA256.prototype._digest = function digest(enc) { if (enc === 'hex') return utils.toHex32(this.h, 'big'); else return utils.split32(this.h, 'big'); }; function SHA224() { if (!(this instanceof SHA224)) return new SHA224(); SHA256.call(this); this.h = [ 0xc1059ed8, 0x367cd507, 0x3070dd17, 0xf70e5939, 0xffc00b31, 0x68581511, 0x64f98fa7, 0xbefa4fa4 ]; } utils.inherits(SHA224, SHA256); exports.sha224 = SHA224; SHA224.blockSize = 512; SHA224.outSize = 224; SHA224.hmacStrength = 192; SHA224.padLength = 64; SHA224.prototype._digest = function digest(enc) { // Just truncate output if (enc === 'hex') return utils.toHex32(this.h.slice(0, 7), 'big'); else return utils.split32(this.h.slice(0, 7), 'big'); }; function SHA512() { if (!(this instanceof SHA512)) return new SHA512(); BlockHash.call(this); this.h = [ 0x6a09e667, 0xf3bcc908, 0xbb67ae85, 0x84caa73b, 0x3c6ef372, 0xfe94f82b, 0xa54ff53a, 0x5f1d36f1, 0x510e527f, 0xade682d1, 0x9b05688c, 0x2b3e6c1f, 0x1f83d9ab, 0xfb41bd6b, 0x5be0cd19, 0x137e2179 ]; this.k = sha512_K; this.W = new Array(160); } utils.inherits(SHA512, BlockHash); exports.sha512 = SHA512; SHA512.blockSize = 1024; SHA512.outSize = 512; SHA512.hmacStrength = 192; SHA512.padLength = 128; SHA512.prototype._prepareBlock = function _prepareBlock(msg, start) { var W = this.W; // 32 x 32bit words for (var i = 0; i < 32; i++) W[i] = msg[start + i]; for (; i < W.length; i += 2) { var c0_hi = g1_512_hi(W[i - 4], W[i - 3]); // i - 2 var c0_lo = g1_512_lo(W[i - 4], W[i - 3]); var c1_hi = W[i - 14]; // i - 7 var c1_lo = W[i - 13]; var c2_hi = g0_512_hi(W[i - 30], W[i - 29]); // i - 15 var c2_lo = g0_512_lo(W[i - 30], W[i - 29]); var c3_hi = W[i - 32]; // i - 16 var c3_lo = W[i - 31]; W[i] = sum64_4_hi(c0_hi, c0_lo, c1_hi, c1_lo, c2_hi, c2_lo, c3_hi, c3_lo); W[i + 1] = sum64_4_lo(c0_hi, c0_lo, c1_hi, c1_lo, c2_hi, c2_lo, c3_hi, c3_lo); } }; SHA512.prototype._update = function _update(msg, start) { this._prepareBlock(msg, start); var W = this.W; var ah = this.h[0]; var al = this.h[1]; var bh = this.h[2]; var bl = this.h[3]; var ch = this.h[4]; var cl = this.h[5]; var dh = this.h[6]; var dl = this.h[7]; var eh = this.h[8]; var el = this.h[9]; var fh = this.h[10]; var fl = this.h[11]; var gh = this.h[12]; var gl = this.h[13]; var hh = this.h[14]; var hl = this.h[15]; assert(this.k.length === W.length); for (var i = 0; i < W.length; i += 2) { var c0_hi = hh; var c0_lo = hl; var c1_hi = s1_512_hi(eh, el); var c1_lo = s1_512_lo(eh, el); var c2_hi = ch64_hi(eh, el, fh, fl, gh, gl); var c2_lo = ch64_lo(eh, el, fh, fl, gh, gl); var c3_hi = this.k[i]; var c3_lo = this.k[i + 1]; var c4_hi = W[i]; var c4_lo = W[i + 1]; var T1_hi = sum64_5_hi(c0_hi, c0_lo, c1_hi, c1_lo, c2_hi, c2_lo, c3_hi, c3_lo, c4_hi, c4_lo); var T1_lo = sum64_5_lo(c0_hi, c0_lo, c1_hi, c1_lo, c2_hi, c2_lo, c3_hi, c3_lo, c4_hi, c4_lo); var c0_hi = s0_512_hi(ah, al); var c0_lo = s0_512_lo(ah, al); var c1_hi = maj64_hi(ah, al, bh, bl, ch, cl); var c1_lo = maj64_lo(ah, al, bh, bl, ch, cl); var T2_hi = sum64_hi(c0_hi, c0_lo, c1_hi, c1_lo); var T2_lo = sum64_lo(c0_hi, c0_lo, c1_hi, c1_lo); hh = gh; hl = gl; gh = fh; gl = fl; fh = eh; fl = el; eh = sum64_hi(dh, dl, T1_hi, T1_lo); el = sum64_lo(dl, dl, T1_hi, T1_lo); dh = ch; dl = cl; ch = bh; cl = bl; bh = ah; bl = al; ah = sum64_hi(T1_hi, T1_lo, T2_hi, T2_lo); al = sum64_lo(T1_hi, T1_lo, T2_hi, T2_lo); } sum64(this.h, 0, ah, al); sum64(this.h, 2, bh, bl); sum64(this.h, 4, ch, cl); sum64(this.h, 6, dh, dl); sum64(this.h, 8, eh, el); sum64(this.h, 10, fh, fl); sum64(this.h, 12, gh, gl); sum64(this.h, 14, hh, hl); }; SHA512.prototype._digest = function digest(enc) { if (enc === 'hex') return utils.toHex32(this.h, 'big'); else return utils.split32(this.h, 'big'); }; function SHA384() { if (!(this instanceof SHA384)) return new SHA384(); SHA512.call(this); this.h = [ 0xcbbb9d5d, 0xc1059ed8, 0x629a292a, 0x367cd507, 0x9159015a, 0x3070dd17, 0x152fecd8, 0xf70e5939, 0x67332667, 0xffc00b31, 0x8eb44a87, 0x68581511, 0xdb0c2e0d, 0x64f98fa7, 0x47b5481d, 0xbefa4fa4 ]; } utils.inherits(SHA384, SHA512); exports.sha384 = SHA384; SHA384.blockSize = 1024; SHA384.outSize = 384; SHA384.hmacStrength = 192; SHA384.padLength = 128; SHA384.prototype._digest = function digest(enc) { if (enc === 'hex') return utils.toHex32(this.h.slice(0, 12), 'big'); else return utils.split32(this.h.slice(0, 12), 'big'); }; function SHA1() { if (!(this instanceof SHA1)) return new SHA1(); BlockHash.call(this); this.h = [ 0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476, 0xc3d2e1f0 ]; this.W = new Array(80); } utils.inherits(SHA1, BlockHash); exports.sha1 = SHA1; SHA1.blockSize = 512; SHA1.outSize = 160; SHA1.hmacStrength = 80; SHA1.padLength = 64; SHA1.prototype._update = function _update(msg, start) { var W = this.W; for (var i = 0; i < 16; i++) W[i] = msg[start + i]; for(; i < W.length; i++) W[i] = rotl32(W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16], 1); var a = this.h[0]; var b = this.h[1]; var c = this.h[2]; var d = this.h[3]; var e = this.h[4]; for (var i = 0; i < W.length; i++) { var s = ~~(i / 20); var t = sum32_5(rotl32(a, 5), ft_1(s, b, c, d), e, W[i], sha1_K[s]); e = d; d = c; c = rotl32(b, 30); b = a; a = t; } this.h[0] = sum32(this.h[0], a); this.h[1] = sum32(this.h[1], b); this.h[2] = sum32(this.h[2], c); this.h[3] = sum32(this.h[3], d); this.h[4] = sum32(this.h[4], e); }; SHA1.prototype._digest = function digest(enc) { if (enc === 'hex') return utils.toHex32(this.h, 'big'); else return utils.split32(this.h, 'big'); }; function ch32(x, y, z) { return (x & y) ^ ((~x) & z); } function maj32(x, y, z) { return (x & y) ^ (x & z) ^ (y & z); } function p32(x, y, z) { return x ^ y ^ z; } function s0_256(x) { return rotr32(x, 2) ^ rotr32(x, 13) ^ rotr32(x, 22); } function s1_256(x) { return rotr32(x, 6) ^ rotr32(x, 11) ^ rotr32(x, 25); } function g0_256(x) { return rotr32(x, 7) ^ rotr32(x, 18) ^ (x >>> 3); } function g1_256(x) { return rotr32(x, 17) ^ rotr32(x, 19) ^ (x >>> 10); } function ft_1(s, x, y, z) { if (s === 0) return ch32(x, y, z); if (s === 1 || s === 3) return p32(x, y, z); if (s === 2) return maj32(x, y, z); } function ch64_hi(xh, xl, yh, yl, zh, zl) { var r = (xh & yh) ^ ((~xh) & zh); if (r < 0) r += 0x100000000; return r; } function ch64_lo(xh, xl, yh, yl, zh, zl) { var r = (xl & yl) ^ ((~xl) & zl); if (r < 0) r += 0x100000000; return r; } function maj64_hi(xh, xl, yh, yl, zh, zl) { var r = (xh & yh) ^ (xh & zh) ^ (yh & zh); if (r < 0) r += 0x100000000; return r; } function maj64_lo(xh, xl, yh, yl, zh, zl) { var r = (xl & yl) ^ (xl & zl) ^ (yl & zl); if (r < 0) r += 0x100000000; return r; } function s0_512_hi(xh, xl) { var c0_hi = rotr64_hi(xh, xl, 28); var c1_hi = rotr64_hi(xl, xh, 2); // 34 var c2_hi = rotr64_hi(xl, xh, 7); // 39 var r = c0_hi ^ c1_hi ^ c2_hi; if (r < 0) r += 0x100000000; return r; } function s0_512_lo(xh, xl) { var c0_lo = rotr64_lo(xh, xl, 28); var c1_lo = rotr64_lo(xl, xh, 2); // 34 var c2_lo = rotr64_lo(xl, xh, 7); // 39 var r = c0_lo ^ c1_lo ^ c2_lo; if (r < 0) r += 0x100000000; return r; } function s1_512_hi(xh, xl) { var c0_hi = rotr64_hi(xh, xl, 14); var c1_hi = rotr64_hi(xh, xl, 18); var c2_hi = rotr64_hi(xl, xh, 9); // 41 var r = c0_hi ^ c1_hi ^ c2_hi; if (r < 0) r += 0x100000000; return r; } function s1_512_lo(xh, xl) { var c0_lo = rotr64_lo(xh, xl, 14); var c1_lo = rotr64_lo(xh, xl, 18); var c2_lo = rotr64_lo(xl, xh, 9); // 41 var r = c0_lo ^ c1_lo ^ c2_lo; if (r < 0) r += 0x100000000; return r; } function g0_512_hi(xh, xl) { var c0_hi = rotr64_hi(xh, xl, 1); var c1_hi = rotr64_hi(xh, xl, 8); var c2_hi = shr64_hi(xh, xl, 7); var r = c0_hi ^ c1_hi ^ c2_hi; if (r < 0) r += 0x100000000; return r; } function g0_512_lo(xh, xl) { var c0_lo = rotr64_lo(xh, xl, 1); var c1_lo = rotr64_lo(xh, xl, 8); var c2_lo = shr64_lo(xh, xl, 7); var r = c0_lo ^ c1_lo ^ c2_lo; if (r < 0) r += 0x100000000; return r; } function g1_512_hi(xh, xl) { var c0_hi = rotr64_hi(xh, xl, 19); var c1_hi = rotr64_hi(xl, xh, 29); // 61 var c2_hi = shr64_hi(xh, xl, 6); var r = c0_hi ^ c1_hi ^ c2_hi; if (r < 0) r += 0x100000000; return r; } function g1_512_lo(xh, xl) { var c0_lo = rotr64_lo(xh, xl, 19); var c1_lo = rotr64_lo(xl, xh, 29); // 61 var c2_lo = shr64_lo(xh, xl, 6); var r = c0_lo ^ c1_lo ^ c2_lo; if (r < 0) r += 0x100000000; return r; } },{"../hash":155}],160:[function(require,module,exports){ var utils = exports; var inherits = require('inherits'); function toArray(msg, enc) { if (Array.isArray(msg)) return msg.slice(); if (!msg) return []; var res = []; if (typeof msg === 'string') { if (!enc) { for (var i = 0; i < msg.length; i++) { var c = msg.charCodeAt(i); var hi = c >> 8; var lo = c & 0xff; if (hi) res.push(hi, lo); else res.push(lo); } } else if (enc === 'hex') { msg = msg.replace(/[^a-z0-9]+/ig, ''); if (msg.length % 2 !== 0) msg = '0' + msg; for (var i = 0; i < msg.length; i += 2) res.push(parseInt(msg[i] + msg[i + 1], 16)); } } else { for (var i = 0; i < msg.length; i++) res[i] = msg[i] | 0; } return res; } utils.toArray = toArray; function toHex(msg) { var res = ''; for (var i = 0; i < msg.length; i++) res += zero2(msg[i].toString(16)); return res; } utils.toHex = toHex; function htonl(w) { var res = (w >>> 24) | ((w >>> 8) & 0xff00) | ((w << 8) & 0xff0000) | ((w & 0xff) << 24); return res >>> 0; } utils.htonl = htonl; function toHex32(msg, endian) { var res = ''; for (var i = 0; i < msg.length; i++) { var w = msg[i]; if (endian === 'little') w = htonl(w); res += zero8(w.toString(16)); } return res; } utils.toHex32 = toHex32; function zero2(word) { if (word.length === 1) return '0' + word; else return word; } utils.zero2 = zero2; function zero8(word) { if (word.length === 7) return '0' + word; else if (word.length === 6) return '00' + word; else if (word.length === 5) return '000' + word; else if (word.length === 4) return '0000' + word; else if (word.length === 3) return '00000' + word; else if (word.length === 2) return '000000' + word; else if (word.length === 1) return '0000000' + word; else return word; } utils.zero8 = zero8; function join32(msg, start, end, endian) { var len = end - start; assert(len % 4 === 0); var res = new Array(len / 4); for (var i = 0, k = start; i < res.length; i++, k += 4) { var w; if (endian === 'big') w = (msg[k] << 24) | (msg[k + 1] << 16) | (msg[k + 2] << 8) | msg[k + 3]; else w = (msg[k + 3] << 24) | (msg[k + 2] << 16) | (msg[k + 1] << 8) | msg[k]; res[i] = w >>> 0; } return res; } utils.join32 = join32; function split32(msg, endian) { var res = new Array(msg.length * 4); for (var i = 0, k = 0; i < msg.length; i++, k += 4) { var m = msg[i]; if (endian === 'big') { res[k] = m >>> 24; res[k + 1] = (m >>> 16) & 0xff; res[k + 2] = (m >>> 8) & 0xff; res[k + 3] = m & 0xff; } else { res[k + 3] = m >>> 24; res[k + 2] = (m >>> 16) & 0xff; res[k + 1] = (m >>> 8) & 0xff; res[k] = m & 0xff; } } return res; } utils.split32 = split32; function rotr32(w, b) { return (w >>> b) | (w << (32 - b)); } utils.rotr32 = rotr32; function rotl32(w, b) { return (w << b) | (w >>> (32 - b)); } utils.rotl32 = rotl32; function sum32(a, b) { return (a + b) >>> 0; } utils.sum32 = sum32; function sum32_3(a, b, c) { return (a + b + c) >>> 0; } utils.sum32_3 = sum32_3; function sum32_4(a, b, c, d) { return (a + b + c + d) >>> 0; } utils.sum32_4 = sum32_4; function sum32_5(a, b, c, d, e) { return (a + b + c + d + e) >>> 0; } utils.sum32_5 = sum32_5; function assert(cond, msg) { if (!cond) throw new Error(msg || 'Assertion failed'); } utils.assert = assert; utils.inherits = inherits; function sum64(buf, pos, ah, al) { var bh = buf[pos]; var bl = buf[pos + 1]; var lo = (al + bl) >>> 0; var hi = (lo < al ? 1 : 0) + ah + bh; buf[pos] = hi >>> 0; buf[pos + 1] = lo; } exports.sum64 = sum64; function sum64_hi(ah, al, bh, bl) { var lo = (al + bl) >>> 0; var hi = (lo < al ? 1 : 0) + ah + bh; return hi >>> 0; }; exports.sum64_hi = sum64_hi; function sum64_lo(ah, al, bh, bl) { var lo = al + bl; return lo >>> 0; }; exports.sum64_lo = sum64_lo; function sum64_4_hi(ah, al, bh, bl, ch, cl, dh, dl) { var carry = 0; var lo = al; lo = (lo + bl) >>> 0; carry += lo < al ? 1 : 0; lo = (lo + cl) >>> 0; carry += lo < cl ? 1 : 0; lo = (lo + dl) >>> 0; carry += lo < dl ? 1 : 0; var hi = ah + bh + ch + dh + carry; return hi >>> 0; }; exports.sum64_4_hi = sum64_4_hi; function sum64_4_lo(ah, al, bh, bl, ch, cl, dh, dl) { var lo = al + bl + cl + dl; return lo >>> 0; }; exports.sum64_4_lo = sum64_4_lo; function sum64_5_hi(ah, al, bh, bl, ch, cl, dh, dl, eh, el) { var carry = 0; var lo = al; lo = (lo + bl) >>> 0; carry += lo < al ? 1 : 0; lo = (lo + cl) >>> 0; carry += lo < cl ? 1 : 0; lo = (lo + dl) >>> 0; carry += lo < dl ? 1 : 0; lo = (lo + el) >>> 0; carry += lo < el ? 1 : 0; var hi = ah + bh + ch + dh + eh + carry; return hi >>> 0; }; exports.sum64_5_hi = sum64_5_hi; function sum64_5_lo(ah, al, bh, bl, ch, cl, dh, dl, eh, el) { var lo = al + bl + cl + dl + el; return lo >>> 0; }; exports.sum64_5_lo = sum64_5_lo; function rotr64_hi(ah, al, num) { var r = (al << (32 - num)) | (ah >>> num); return r >>> 0; }; exports.rotr64_hi = rotr64_hi; function rotr64_lo(ah, al, num) { var r = (ah << (32 - num)) | (al >>> num); return r >>> 0; }; exports.rotr64_lo = rotr64_lo; function shr64_hi(ah, al, num) { return ah >>> num; }; exports.shr64_hi = shr64_hi; function shr64_lo(ah, al, num) { var r = (ah << (32 - num)) | (al >>> num); return r >>> 0; }; exports.shr64_lo = shr64_lo; },{"inherits":167}],161:[function(require,module,exports){ (function (Buffer){ 'use strict'; var zeroBuffer = new Buffer(128) zeroBuffer.fill(0) module.exports = Hmac function Hmac (createHash, blocksize, key) { if(!(this instanceof Hmac)) return new Hmac(createHash, blocksize, key) this._opad = opad this._createHash = createHash if(blocksize !== 128 && blocksize !== 64) throw new Error('blocksize must be either 64 for or 128 , but was:'+blocksize) key = this._key = !Buffer.isBuffer(key) ? new Buffer(key) : key if(key.length > blocksize) { key = this._createHash().update(key).digest() } else if(key.length < blocksize) { key = Buffer.concat([key, zeroBuffer], blocksize) } var ipad = this._ipad = new Buffer(blocksize) var opad = this._opad = new Buffer(blocksize) for(var i = 0; i < blocksize; i++) { ipad[i] = key[i] ^ 0x36 opad[i] = key[i] ^ 0x5C } this._hash = this._createHash().update(ipad) } Hmac.prototype.update = function (data, enc) { this._hash.update(data, enc) return this } Hmac.prototype.digest = function (enc) { var h = this._hash.digest() return this._createHash().update(this._opad).update(h).digest(enc) } }).call(this,require("buffer").Buffer) },{"buffer":61}],162:[function(require,module,exports){ function wrap (fn, hook) { return function () { return hook.call(this, fn, [].slice.call(arguments)) } } module.exports = function hookable(fn) { function hooked () { return fn.apply(this, [].slice.call(arguments)) } hooked.hook = function (hook) { fn = wrap(fn, hook) return this } return hooked } },{}],163:[function(require,module,exports){ exports.read = function (buffer, offset, isLE, mLen, nBytes) { var e, m var eLen = nBytes * 8 - mLen - 1 var eMax = (1 << eLen) - 1 var eBias = eMax >> 1 var nBits = -7 var i = isLE ? (nBytes - 1) : 0 var d = isLE ? -1 : 1 var s = buffer[offset + i] i += d e = s & ((1 << (-nBits)) - 1) s >>= (-nBits) nBits += eLen for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {} m = e & ((1 << (-nBits)) - 1) e >>= (-nBits) nBits += mLen for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {} if (e === 0) { e = 1 - eBias } else if (e === eMax) { return m ? NaN : ((s ? -1 : 1) * Infinity) } else { m = m + Math.pow(2, mLen) e = e - eBias } return (s ? -1 : 1) * m * Math.pow(2, e - mLen) } exports.write = function (buffer, value, offset, isLE, mLen, nBytes) { var e, m, c var eLen = nBytes * 8 - mLen - 1 var eMax = (1 << eLen) - 1 var eBias = eMax >> 1 var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0) var i = isLE ? 0 : (nBytes - 1) var d = isLE ? 1 : -1 var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0 value = Math.abs(value) if (isNaN(value) || value === Infinity) { m = isNaN(value) ? 1 : 0 e = eMax } else { e = Math.floor(Math.log(value) / Math.LN2) if (value * (c = Math.pow(2, -e)) < 1) { e-- c *= 2 } if (e + eBias >= 1) { value += rt / c } else { value += rt * Math.pow(2, 1 - eBias) } if (value * c >= 2) { e++ c /= 2 } if (e + eBias >= eMax) { m = 0 e = eMax } else if (e + eBias >= 1) { m = (value * c - 1) * Math.pow(2, mLen) e = e + eBias } else { m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen) e = 0 } } for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {} e = (e << mLen) | m eLen += mLen for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {} buffer[offset + i - d] |= s * 128 } },{}],164:[function(require,module,exports){ module.exports = function (buf) { var len = buf.length, i for(i = len - 1; buf[i] === 255; i--) buf[i] = 0 if(~i) buf[i] = buf[i] + 1 return buf } },{}],165:[function(require,module,exports){ var indexOf = [].indexOf; module.exports = function(arr, obj){ if (indexOf) return arr.indexOf(obj); for (var i = 0; i < arr.length; ++i) { if (arr[i] === obj) return i; } return -1; }; },{}],166:[function(require,module,exports){ (function (process){ var wrappy = require('wrappy') var reqs = Object.create(null) var once = require('once') module.exports = wrappy(inflight) function inflight (key, cb) { if (reqs[key]) { reqs[key].push(cb) return null } else { reqs[key] = [cb] return makeres(key) } } function makeres (key) { return once(function RES () { var cbs = reqs[key] var len = cbs.length var args = slice(arguments) for (var i = 0; i < len; i++) { cbs[i].apply(null, args) } if (cbs.length > len) { // added more in the interim. // de-zalgo, just in case, but don't call again. cbs.splice(0, len) process.nextTick(function () { RES.apply(null, args) }) } else { delete reqs[key] } }) } function slice (args) { var length = args.length var array = [] for (var i = 0; i < length; i++) array[i] = args[i] return array } }).call(this,require('_process')) },{"_process":295,"once":278,"wrappy":641}],167:[function(require,module,exports){ if (typeof Object.create === 'function') { // implementation from standard node.js 'util' module module.exports = function inherits(ctor, superCtor) { ctor.super_ = superCtor ctor.prototype = Object.create(superCtor.prototype, { constructor: { value: ctor, enumerable: false, writable: true, configurable: true } }); }; } else { // old school shim for old browsers module.exports = function inherits(ctor, superCtor) { ctor.super_ = superCtor var TempCtor = function () {} TempCtor.prototype = superCtor.prototype ctor.prototype = new TempCtor() ctor.prototype.constructor = ctor } } },{}],168:[function(require,module,exports){ 'use strict'; var v4 = '(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])(?:\\.(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])){3}'; var v6 = '(?:(?:[0-9a-fA-F:]){1,4}(?:(?::(?:[0-9a-fA-F]){1,4}|:)){2,7})+'; var ip = module.exports = function (opts) { opts = opts || {}; return opts.exact ? new RegExp('(?:^' + v4 + '$)|(?:^' + v6 + '$)') : new RegExp('(?:' + v4 + ')|(?:' + v6 + ')', 'g'); }; ip.v4 = function (opts) { opts = opts || {}; return opts.exact ? new RegExp('^' + v4 + '$') : new RegExp(v4, 'g'); }; ip.v6 = function (opts) { opts = opts || {}; return opts.exact ? new RegExp('^' + v6 + '$') : new RegExp(v6, 'g'); }; },{}],169:[function(require,module,exports){ var ip = exports, Buffer = require('buffer').Buffer, os = require('os'); ip.toBuffer = function toBuffer(ip, buff, offset) { offset = ~~offset; var result; if (/^(\d{1,3}\.){3,3}\d{1,3}$/.test(ip)) { result = buff || new Buffer(offset + 4); ip.split(/\./g).map(function(byte) { result[offset++] = parseInt(byte, 10) & 0xff; }); } else if (/^[a-f0-9:]+$/.test(ip)) { var s = ip.split(/::/g, 2), head = (s[0] || '').split(/:/g, 8), tail = (s[1] || '').split(/:/g, 8); if (tail.length === 0) { // xxxx:: while (head.length < 8) head.push('0000'); } else if (head.length === 0) { // ::xxxx while (tail.length < 8) tail.unshift('0000'); } else { // xxxx::xxxx while (head.length + tail.length < 8) head.push('0000'); } result = buff || new Buffer(offset + 16); head.concat(tail).map(function(word) { word = parseInt(word, 16); result[offset++] = (word >> 8) & 0xff; result[offset++] = word & 0xff; }); } else { throw Error('Invalid ip address: ' + ip); } return result; }; ip.toString = function toString(buff, offset, length) { offset = ~~offset; length = length || (buff.length - offset); var result = []; if (length === 4) { // IPv4 for (var i = 0; i < length; i++) { result.push(buff[offset + i]); } result = result.join('.'); } else if (length === 16) { // IPv6 for (var i = 0; i < length; i += 2) { result.push(buff.readUInt16BE(offset + i).toString(16)); } result = result.join(':'); result = result.replace(/(^|:)0(:0)*:0(:|$)/, '$1::$3'); result = result.replace(/:{3,4}/, '::'); } return result; }; ip.fromPrefixLen = function fromPrefixLen(prefixlen, family) { if (prefixlen > 32) { family = 'ipv6'; } else { family = _normalizeFamily(family); } var len = 4; if (family === 'ipv6') { len = 16; } var buff = new Buffer(len); for (var i = 0, n = buff.length; i < n; ++i) { var bits = 8; if (prefixlen < 8) { bits = prefixlen; } prefixlen -= bits; buff[i] = ~(0xff >> bits); } return ip.toString(buff); }; ip.mask = function mask(addr, mask) { addr = ip.toBuffer(addr); mask = ip.toBuffer(mask); var result = new Buffer(Math.max(addr.length, mask.length)); // Same protocol - do bitwise and if (addr.length === mask.length) { for (var i = 0; i < addr.length; i++) { result[i] = addr[i] & mask[i]; } } else if (mask.length === 4) { // IPv6 address and IPv4 mask // (Mask low bits) for (var i = 0; i < mask.length; i++) { result[i] = addr[addr.length - 4 + i] & mask[i]; } } else { // IPv6 mask and IPv4 addr for (var i = 0; i < result.length - 6; i++) { result[i] = 0; } // ::ffff:ipv4 result[10] = 0xff; result[11] = 0xff; for (var i = 0; i < addr.length; i++) { result[i + 12] = addr[i] & mask[i + 12]; } } return ip.toString(result); }; ip.cidr = function cidr(cidrString) { var cidrParts = cidrString.split('/'); if (cidrParts.length != 2) throw new Error('invalid CIDR subnet: ' + addr); var addr = cidrParts[0]; var mask = ip.fromPrefixLen(parseInt(cidrParts[1], 10)); return ip.mask(addr, mask); } ip.subnet = function subnet(addr, mask) { var networkAddress = ip.toLong(ip.mask(addr, mask)); // Calculate the mask's length. var maskBuffer = ip.toBuffer(mask); var maskLength = 0; for (var i = 0; i < maskBuffer.length; i++) { if (maskBuffer[i] == 0xff) { maskLength += 8; } else { var octet = maskBuffer[i] & 0xff; while (octet) { octet = (octet << 1) & 0xff; maskLength++; } } } var numberOfAddresses = Math.pow(2, 32 - maskLength); return { networkAddress: ip.fromLong(networkAddress), firstAddress: numberOfAddresses <= 2 ? ip.fromLong(networkAddress) : ip.fromLong(networkAddress + 1), lastAddress: numberOfAddresses <= 2 ? ip.fromLong(networkAddress + numberOfAddresses - 1) : ip.fromLong(networkAddress + numberOfAddresses - 2), broadcastAddress: ip.fromLong(networkAddress + numberOfAddresses - 1), subnetMask: mask, subnetMaskLength: maskLength, numHosts: numberOfAddresses <= 2 ? numberOfAddresses : numberOfAddresses - 2, length: numberOfAddresses }; } ip.cidrSubnet = function cidrSubnet(cidrString) { var cidrParts = cidrString.split('/'); if (cidrParts.length !== 2) throw new Error('invalid CIDR subnet: ' + addr); var addr = cidrParts[0]; var mask = ip.fromPrefixLen(parseInt(cidrParts[1], 10)); return ip.subnet(addr, mask); } ip.not = function not(addr) { var buff = ip.toBuffer(addr); for (var i = 0; i < buff.length; i++) { buff[i] = 0xff ^ buff[i]; } return ip.toString(buff); }; ip.or = function or(a, b) { a = ip.toBuffer(a); b = ip.toBuffer(b); // same protocol if (a.length == b.length) { for (var i = 0; i < a.length; ++i) { a[i] |= b[i]; } return ip.toString(a); // mixed protocols } else { var buff = a; var other = b; if (b.length > a.length) { buff = b; other = a; } var offset = buff.length - other.length; for (var i = offset; i < buff.length; ++i) { buff[i] |= other[i - offset]; } return ip.toString(buff); } }; ip.isEqual = function isEqual(a, b) { a = ip.toBuffer(a); b = ip.toBuffer(b); // Same protocol if (a.length === b.length) { for (var i = 0; i < a.length; i++) { if (a[i] !== b[i]) return false; } return true; } // Swap if (b.length === 4) { var t = b; b = a; a = t; } // a - IPv4, b - IPv6 for (var i = 0; i < 10; i++) { if (b[i] !== 0) return false; } var word = b.readUInt16BE(10); if (word !== 0 && word !== 0xffff) return false; for (var i = 0; i < 4; i++) { if (a[i] !== b[i + 12]) return false; } return true; }; ip.isPrivate = function isPrivate(addr) { return addr.match(/^10\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})/) != null || addr.match(/^192\.168\.([0-9]{1,3})\.([0-9]{1,3})/) != null || addr.match( /^172\.(1[6-9]|2\d|30|31)\.([0-9]{1,3})\.([0-9]{1,3})/) != null || addr.match(/^127\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})/) != null || addr.match(/^169\.254\.([0-9]{1,3})\.([0-9]{1,3})/) != null || addr.match(/^fc00:/) != null || addr.match(/^fe80:/) != null || addr.match(/^::1$/) != null || addr.match(/^::$/) != null; }; ip.isPublic = function isPublic(addr) { return !ip.isPrivate(addr); } ip.isLoopback = function isLoopback(addr) { return /^127\.0\.0\.1$/.test(addr) || /^fe80::1$/.test(addr) || /^::1$/.test(addr) || /^::$/.test(addr); }; ip.loopback = function loopback(family) { // // Default to `ipv4` // family = _normalizeFamily(family); if (family !== 'ipv4' && family !== 'ipv6') { throw new Error('family must be ipv4 or ipv6'); } return family === 'ipv4' ? '127.0.0.1' : 'fe80::1'; }; // // ### function address (name, family) // #### @name {string|'public'|'private'} **Optional** Name or security // of the network interface. // #### @family {ipv4|ipv6} **Optional** IP family of the address (defaults // to ipv4). // // Returns the address for the network interface on the current system with // the specified `name`: // * String: First `family` address of the interface. // If not found see `undefined`. // * 'public': the first public ip address of family. // * 'private': the first private ip address of family. // * undefined: First address with `ipv4` or loopback addres `127.0.0.1`. // ip.address = function address(name, family) { var interfaces = os.networkInterfaces(), all; // // Default to `ipv4` // family = _normalizeFamily(family); // // If a specific network interface has been named, // return the address. // if (name && !~['public', 'private'].indexOf(name)) { return interfaces[name].filter(function (details) { details.family = details.family.toLowerCase(); return details.family === family; })[0].address; } var all = Object.keys(interfaces).map(function (nic) { // // Note: name will only be `public` or `private` // when this is called. // var addresses = interfaces[nic].filter(function (details) { details.family = details.family.toLowerCase(); if (details.family !== family || ip.isLoopback(details.address)) { return false; } else if (!name) { return true; } return name === 'public' ? !ip.isPrivate(details.address) : ip.isPrivate(details.address) }); return addresses.length ? addresses[0].address : undefined; }).filter(Boolean); return !all.length ? ip.loopback(family) : all[0]; }; ip.toLong = function toInt(ip){ var ipl=0; ip.split('.').forEach(function( octet ) { ipl<<=8; ipl+=parseInt(octet); }); return(ipl >>>0); }; ip.fromLong = function fromInt(ipl){ return ( (ipl>>>24) +'.' + (ipl>>16 & 255) +'.' + (ipl>>8 & 255) +'.' + (ipl & 255) ); }; function _normalizeFamily(family) { return family ? family.toLowerCase() : 'ipv4'; } },{"buffer":61,"os":279}],170:[function(require,module,exports){ /** * Determine if an object is Buffer * * Author: Feross Aboukhadijeh * License: MIT * * `npm install is-buffer` */ module.exports = function (obj) { return !!(obj != null && (obj._isBuffer || // For Safari 5-7 (missing Object.prototype.constructor) (obj.constructor && typeof obj.constructor.isBuffer === 'function' && obj.constructor.isBuffer(obj)) )) } },{}],171:[function(require,module,exports){ (function(root) { function isValidDomain(v) { if (!v) return false; var re = /^(?!:\/\/)([a-zA-Z0-9-]+\.){0,5}[a-zA-Z0-9-][a-zA-Z0-9-]+\.[a-zA-Z]{2,64}?$/gi; return re.test(v); } if (typeof exports !== 'undefined') { if (typeof module !== 'undefined' && module.exports) { exports = module.exports = isValidDomain; } exports.isValidDomain = isValidDomain; } else if (typeof define === 'function' && define.amd) { define([], function() { return isValidDomain; }); } else { root.isValidDomain = isValidDomain; } })(this); },{}],172:[function(require,module,exports){ module.exports = Array.isArray || function (arr) { return Object.prototype.toString.call(arr) == '[object Array]'; }; },{}],173:[function(require,module,exports){ var encodings = require('./lib/encodings'); module.exports = Codec; function Codec(opts){ this.opts = opts || {}; this.encodings = encodings; } Codec.prototype._encoding = function(encoding){ if (typeof encoding == 'string') encoding = encodings[encoding]; if (!encoding) encoding = encodings.id; return encoding; }; Codec.prototype._keyEncoding = function(opts, batchOpts){ return this._encoding(batchOpts && batchOpts.keyEncoding || opts && opts.keyEncoding || this.opts.keyEncoding); }; Codec.prototype._valueEncoding = function(opts, batchOpts){ return this._encoding( batchOpts && (batchOpts.valueEncoding || batchOpts.encoding) || opts && (opts.valueEncoding || opts.encoding) || (this.opts.valueEncoding || this.opts.encoding)); }; Codec.prototype.encodeKey = function(key, opts, batchOpts){ return this._keyEncoding(opts, batchOpts).encode(key); }; Codec.prototype.encodeValue = function(value, opts, batchOpts){ return this._valueEncoding(opts, batchOpts).encode(value); }; Codec.prototype.decodeKey = function(key, opts){ return this._keyEncoding(opts).decode(key); }; Codec.prototype.decodeValue = function(value, opts){ return this._valueEncoding(opts).decode(value); }; Codec.prototype.encodeBatch = function(ops, opts){ var self = this; return ops.map(function(_op){ var op = { type: _op.type, key: self.encodeKey(_op.key, opts, _op) }; if (self.keyAsBuffer(opts, _op)) op.keyEncoding = 'binary'; if (_op.prefix) op.prefix = _op.prefix; if ('value' in _op) { op.value = self.encodeValue(_op.value, opts, _op); if (self.valueAsBuffer(opts, _op)) op.valueEncoding = 'binary'; } return op; }); }; var ltgtKeys = ['lt', 'gt', 'lte', 'gte', 'start', 'end']; Codec.prototype.encodeLtgt = function(ltgt){ var self = this; var ret = {}; Object.keys(ltgt).forEach(function(key){ ret[key] = ltgtKeys.indexOf(key) > -1 ? self.encodeKey(ltgt[key], ltgt) : ltgt[key] }); return ret; }; Codec.prototype.createStreamDecoder = function(opts){ var self = this; if (opts.keys && opts.values) { return function(key, value){ return { key: self.decodeKey(key, opts), value: self.decodeValue(value, opts) }; }; } else if (opts.keys) { return function(key) { return self.decodeKey(key, opts); }; } else if (opts.values) { return function(_, value){ return self.decodeValue(value, opts); } } else { return function(){}; } }; Codec.prototype.keyAsBuffer = function(opts){ return this._keyEncoding(opts).buffer; }; Codec.prototype.valueAsBuffer = function(opts){ return this._valueEncoding(opts).buffer; }; },{"./lib/encodings":174}],174:[function(require,module,exports){ (function (Buffer){ exports.utf8 = exports['utf-8'] = { encode: function(data){ return isBinary(data) ? data : String(data); }, decode: identity, buffer: false, type: 'utf8' }; exports.json = { encode: JSON.stringify, decode: JSON.parse, buffer: false, type: 'json' }; exports.binary = { encode: function(data){ return isBinary(data) ? data : new Buffer(data); }, decode: identity, buffer: true, type: 'binary' }; exports.id = { encode: function(data){ return data; }, decode: function(data){ return data; }, buffer: false, type: 'id' }; var bufferEncodings = [ 'hex', 'ascii', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le' ]; bufferEncodings.forEach(function(type){ exports[type] = { encode: function(data){ return isBinary(data) ? data : new Buffer(data, type); }, decode: function(buffer){ return buffer.toString(type); }, buffer: true, type: type }; }); function identity(value){ return value; } function isBinary(data){ return data === undefined || data === null || Buffer.isBuffer(data); } }).call(this,require("buffer").Buffer) },{"buffer":61}],175:[function(require,module,exports){ /* Copyright (c) 2012-2015 LevelUP contributors * See list at * MIT License * */ var createError = require('errno').create , LevelUPError = createError('LevelUPError') , NotFoundError = createError('NotFoundError', LevelUPError) NotFoundError.prototype.notFound = true NotFoundError.prototype.status = 404 module.exports = { LevelUPError : LevelUPError , InitializationError : createError('InitializationError', LevelUPError) , OpenError : createError('OpenError', LevelUPError) , ReadError : createError('ReadError', LevelUPError) , WriteError : createError('WriteError', LevelUPError) , NotFoundError : NotFoundError , EncodingError : createError('EncodingError', LevelUPError) } },{"errno":143}],176:[function(require,module,exports){ var inherits = require('inherits'); var Readable = require('readable-stream').Readable; var extend = require('xtend'); var EncodingError = require('level-errors').EncodingError; module.exports = ReadStream; inherits(ReadStream, Readable); function ReadStream(iterator, options){ if (!(this instanceof ReadStream)) return new ReadStream(iterator, options); Readable.call(this, extend(options, { objectMode: true })); this._iterator = iterator; this._destroyed = false; this._decoder = null; if (options && options.decoder) this._decoder = options.decoder; this.on('end', this._cleanup.bind(this)); } ReadStream.prototype._read = function(){ var self = this; if (this._destroyed) return; this._iterator.next(function(err, key, value){ if (self._destroyed) return; if (err) return self.emit('error', err); if (key === undefined && value === undefined) { self.push(null); } else { if (!self._decoder) return self.push({ key: key, value: value }); try { var value = self._decoder(key, value); } catch (err) { self.emit('error', new EncodingError(err)); self.push(null); return; } self.push(value); } }); }; ReadStream.prototype.destroy = ReadStream.prototype._cleanup = function(){ var self = this; if (this._destroyed) return; this._destroyed = true; this._iterator.end(function(err){ if (err) return self.emit('error', err); self.emit('close'); }); }; },{"inherits":167,"level-errors":175,"readable-stream":410,"xtend":177}],177:[function(require,module,exports){ module.exports = extend var hasOwnProperty = Object.prototype.hasOwnProperty; function extend() { var target = {} for (var i = 0; i < arguments.length; i++) { var source = arguments[i] for (var key in source) { if (hasOwnProperty.call(source, key)) { target[key] = source[key] } } } return target } },{}],178:[function(require,module,exports){ var pl = require('pull-level') var pull = require('pull-stream') module.exports = function (db, update, get) { var waiting = [], ready = false pull( pl.read(db, { onSync: function () { ready = true while(waiting.length) { waiting.shift()() } }, live: true }), pull.drain(update) ) function call (opts, cb) { var value try { value = get(opts) } catch (err) { return cb(err) } cb(null, value) } return function (opts, cb) { if(!cb) cb = opts, opts = null if(ready) call(opts, cb) else waiting.push(function () { call(opts, cb) }) } } },{"pull-level":344,"pull-stream":179}],179:[function(require,module,exports){ var sources = require('./sources') var sinks = require('./sinks') var throughs = require('./throughs') var u = require('pull-core') function isFunction (fun) { return 'function' === typeof fun } function isReader (fun) { return fun && (fun.type === "Through" || fun.length === 1) } var exports = module.exports = function pull () { var args = [].slice.call(arguments) if(isReader(args[0])) return function (read) { args.unshift(read) return pull.apply(null, args) } var read = args.shift() //if the first function is a duplex stream, //pipe from the source. if(isFunction(read.source)) read = read.source function next () { var s = args.shift() if(null == s) return next() if(isFunction(s)) return s return function (read) { s.sink(read) //this supports pipeing through a duplex stream //pull(a, b, a) "telephone style". //if this stream is in the a (first & last position) //s.source will have already been used, but this should never be called //so that is okay. return s.source } } while(args.length) read = next() (read) return read } for(var k in sources) exports[k] = u.Source(sources[k]) for(var k in throughs) exports[k] = u.Through(throughs[k]) for(var k in sinks) exports[k] = u.Sink(sinks[k]) var maybe = require('./maybe')(exports) for(var k in maybe) exports[k] = maybe[k] exports.Duplex = exports.Through = exports.pipeable = u.Through exports.Source = exports.pipeableSource = u.Source exports.Sink = exports.pipeableSink = u.Sink },{"./maybe":180,"./sinks":181,"./sources":182,"./throughs":183,"pull-core":306}],180:[function(require,module,exports){ var u = require('pull-core') var prop = u.prop var id = u.id var maybeSink = u.maybeSink module.exports = function (pull) { var exports = {} var drain = pull.drain var find = exports.find = function (test, cb) { return maybeSink(function (cb) { var ended = false if(!cb) cb = test, test = id else test = prop(test) || id return drain(function (data) { if(test(data)) { ended = true cb(null, data) return false } }, function (err) { if(ended) return //already called back cb(err === true ? null : err, null) }) }, cb) } var reduce = exports.reduce = function (reduce, acc, cb) { return maybeSink(function (cb) { return drain(function (data) { acc = reduce(acc, data) }, function (err) { cb(err, acc) }) }, cb) } var collect = exports.collect = exports.writeArray = function (cb) { return reduce(function (arr, item) { arr.push(item) return arr }, [], cb) } var concat = exports.concat = function (cb) { return reduce(function (a, b) { return a + b }, '', cb) } return exports } },{"pull-core":306}],181:[function(require,module,exports){ var drain = exports.drain = function (read, op, done) { ;(function next() { var loop = true, cbed = false while(loop) { cbed = false read(null, function (end, data) { cbed = true if(end) { loop = false if(done) done(end === true ? null : end) else if(end && end !== true) throw end } else if(op && false === op(data)) { loop = false read(true, done || function () {}) } else if(!loop){ next() } }) if(!cbed) { loop = false return } } })() } var onEnd = exports.onEnd = function (read, done) { return drain(read, null, done) } var log = exports.log = function (read, done) { return drain(read, function (data) { console.log(data) }, done) } },{}],182:[function(require,module,exports){ var keys = exports.keys = function (object) { return values(Object.keys(object)) } var once = exports.once = function (value) { return function (abort, cb) { if(abort) return cb(abort) if(value != null) { var _value = value; value = null cb(null, _value) } else cb(true) } } var values = exports.values = exports.readArray = function (array) { if(!array) return function (abort, cb) { return cb(abort || true) } if(!Array.isArray(array)) array = Object.keys(array).map(function (k) { return array[k] }) var i = 0 return function (end, cb) { if(end) return cb && cb(end) cb(i >= array.length || null, array[i++]) } } var count = exports.count = function (max) { var i = 0; max = max || Infinity return function (end, cb) { if(end) return cb && cb(end) if(i > max) return cb(true) cb(null, i++) } } var infinite = exports.infinite = function (generate) { generate = generate || Math.random return function (end, cb) { if(end) return cb && cb(end) return cb(null, generate()) } } var defer = exports.defer = function () { var _read, cbs = [], _end var read = function (end, cb) { if(!_read) { _end = end cbs.push(cb) } else _read(end, cb) } read.resolve = function (read) { if(_read) throw new Error('already resolved') _read = read if(!_read) throw new Error('no read cannot resolve!' + _read) while(cbs.length) _read(_end, cbs.shift()) } read.abort = function(err) { read.resolve(function (_, cb) { cb(err || true) }) } return read } var empty = exports.empty = function () { return function (abort, cb) { cb(true) } } var error = exports.error = function (err) { return function (abort, cb) { cb(err) } } var depthFirst = exports.depthFirst = function (start, createStream) { var reads = [] reads.unshift(once(start)) return function next (end, cb) { if(!reads.length) return cb(true) reads[0](end, function (end, data) { if(end) { //if this stream has ended, go to the next queue reads.shift() return next(null, cb) } reads.unshift(createStream(data)) cb(end, data) }) } } //width first is just like depth first, //but push each new stream onto the end of the queue var widthFirst = exports.widthFirst = function (start, createStream) { var reads = [] reads.push(once(start)) return function next (end, cb) { if(!reads.length) return cb(true) reads[0](end, function (end, data) { if(end) { reads.shift() return next(null, cb) } reads.push(createStream(data)) cb(end, data) }) } } //this came out different to the first (strm) //attempt at leafFirst, but it's still a valid //topological sort. var leafFirst = exports.leafFirst = function (start, createStream) { var reads = [] var output = [] reads.push(once(start)) return function next (end, cb) { reads[0](end, function (end, data) { if(end) { reads.shift() if(!output.length) return cb(true) return cb(null, output.shift()) } reads.unshift(createStream(data)) output.unshift(data) next(null, cb) }) } } },{}],183:[function(require,module,exports){ (function (process){ var u = require('pull-core') var sources = require('./sources') var sinks = require('./sinks') var prop = u.prop var id = u.id var tester = u.tester var map = exports.map = function (read, map) { map = prop(map) || id return function (abort, cb) { read(abort, function (end, data) { try { data = !end ? map(data) : null } catch (err) { return read(err, function () { return cb(err) }) } cb(end, data) }) } } var asyncMap = exports.asyncMap = function (read, map) { if(!map) return read return function (end, cb) { if(end) return read(end, cb) //abort read(null, function (end, data) { if(end) return cb(end, data) map(data, cb) }) } } var paraMap = exports.paraMap = function (read, map, width) { if(!map) return read var ended = false, queue = [], _cb function drain () { if(!_cb) return var cb = _cb _cb = null if(queue.length) return cb(null, queue.shift()) else if(ended && !n) return cb(ended) _cb = cb } function pull () { read(null, function (end, data) { if(end) { ended = end return drain() } n++ map(data, function (err, data) { n-- queue.push(data) drain() }) if(n < width && !ended) pull() }) } var n = 0 return function (end, cb) { if(end) return read(end, cb) //abort //continue to read while there are less than 3 maps in flight _cb = cb if(queue.length || ended) pull(), drain() else pull() } return highWaterMark(asyncMap(read, map), width) } var filter = exports.filter = function (read, test) { //regexp test = tester(test) return function next (end, cb) { var sync, loop = true while(loop) { loop = false sync = true read(end, function (end, data) { if(!end && !test(data)) return sync ? loop = true : next(end, cb) cb(end, data) }) sync = false } } } var filterNot = exports.filterNot = function (read, test) { test = tester(test) return filter(read, function (e) { return !test(e) }) } var through = exports.through = function (read, op, onEnd) { var a = false function once (abort) { if(a || !onEnd) return a = true onEnd(abort === true ? null : abort) } return function (end, cb) { if(end) once(end) return read(end, function (end, data) { if(!end) op && op(data) else once(end) cb(end, data) }) } } var take = exports.take = function (read, test) { var ended = false if('number' === typeof test) { var n = test; test = function () { return n -- } } return function (end, cb) { if(ended) return cb(ended) if(ended = end) return read(ended, cb) read(null, function (end, data) { if(ended = ended || end) return cb(ended) if(!test(data)) { ended = true read(true, function (end, data) { cb(ended, data) }) } else cb(null, data) }) } } var unique = exports.unique = function (read, field, invert) { field = prop(field) || id var seen = {} return filter(read, function (data) { var key = field(data) if(seen[key]) return !!invert //false, by default else seen[key] = true return !invert //true by default }) } var nonUnique = exports.nonUnique = function (read, field) { return unique(read, field, true) } var group = exports.group = function (read, size) { var ended; size = size || 5 var queue = [] return function (end, cb) { //this means that the upstream is sending an error. if(end) return read(ended = end, cb) //this means that we read an end before. if(ended) return cb(ended) read(null, function next(end, data) { if(ended = ended || end) { if(!queue.length) return cb(ended) var _queue = queue; queue = [] return cb(null, _queue) } queue.push(data) if(queue.length < size) return read(null, next) var _queue = queue; queue = [] cb(null, _queue) }) } } var flatten = exports.flatten = function (read) { var _read return function (abort, cb) { if(_read) nextChunk() else nextStream() function nextChunk () { _read(null, function (end, data) { if(end) nextStream() else cb(null, data) }) } function nextStream () { read(null, function (end, stream) { if(end) return cb(end) if(Array.isArray(stream) || stream && 'object' === typeof stream) stream = sources.values(stream) else if('function' != typeof stream) throw new Error('expected stream of streams') _read = stream nextChunk() }) } } } var prepend = exports.prepend = function (read, head) { return function (abort, cb) { if(head !== null) { if(abort) return read(abort, cb) var _head = head head = null cb(null, _head) } else { read(abort, cb) } } } //var drainIf = exports.drainIf = function (op, done) { // sinks.drain( //} var _reduce = exports._reduce = function (read, reduce, initial) { return function (close, cb) { if(close) return read(close, cb) if(ended) return cb(ended) sinks.drain(function (item) { initial = reduce(initial, item) }, function (err, data) { ended = err || true if(!err) cb(null, initial) else cb(ended) }) (read) } } var nextTick = process.nextTick var highWaterMark = exports.highWaterMark = function (read, highWaterMark) { var buffer = [], waiting = [], ended, ending, reading = false highWaterMark = highWaterMark || 10 function readAhead () { while(waiting.length && (buffer.length || ended)) waiting.shift()(ended, ended ? null : buffer.shift()) if (!buffer.length && ending) ended = ending; } function next () { if(ended || ending || reading || buffer.length >= highWaterMark) return reading = true return read(ended || ending, function (end, data) { reading = false ending = ending || end if(data != null) buffer.push(data) next(); readAhead() }) } process.nextTick(next) return function (end, cb) { ended = ended || end waiting.push(cb) next(); readAhead() } } var flatMap = exports.flatMap = function (read, mapper) { mapper = mapper || id var queue = [], ended return function (abort, cb) { if(queue.length) return cb(null, queue.shift()) else if(ended) return cb(ended) read(abort, function next (end, data) { if(end) ended = end else { var add = mapper(data) while(add && add.length) queue.push(add.shift()) } if(queue.length) cb(null, queue.shift()) else if(ended) cb(ended) else read(null, next) }) } } }).call(this,require('_process')) },{"./sinks":181,"./sources":182,"_process":295,"pull-core":306}],184:[function(require,module,exports){ const levelup = require('levelup') function packager (leveldown) { function Level (location, options, callback) { if (typeof options === 'function') callback = options if (!(typeof options === 'object' && options !== null)) options = {} options.db = leveldown return levelup(location, options, callback) } [ 'destroy', 'repair' ].forEach(function (m) { if (typeof leveldown[m] === 'function') { Level[m] = function (location, callback) { leveldown[m](location, callback || function () {}) } } }) return Level } module.exports = packager },{"levelup":193}],185:[function(require,module,exports){ (function (process){ /* Copyright (c) 2013 Rod Vagg, MIT License */ function AbstractChainedBatch (db) { this._db = db this._operations = [] this._written = false } AbstractChainedBatch.prototype._checkWritten = function () { if (this._written) throw new Error('write() already called on this batch') } AbstractChainedBatch.prototype.put = function (key, value) { this._checkWritten() var err = this._db._checkKey(key, 'key', this._db._isBuffer) if (err) throw err if (!this._db._isBuffer(key)) key = String(key) if (!this._db._isBuffer(value)) value = String(value) if (typeof this._put == 'function' ) this._put(key, value) else this._operations.push({ type: 'put', key: key, value: value }) return this } AbstractChainedBatch.prototype.del = function (key) { this._checkWritten() var err = this._db._checkKey(key, 'key', this._db._isBuffer) if (err) throw err if (!this._db._isBuffer(key)) key = String(key) if (typeof this._del == 'function' ) this._del(key) else this._operations.push({ type: 'del', key: key }) return this } AbstractChainedBatch.prototype.clear = function () { this._checkWritten() this._operations = [] if (typeof this._clear == 'function' ) this._clear() return this } AbstractChainedBatch.prototype.write = function (options, callback) { this._checkWritten() if (typeof options == 'function') callback = options if (typeof callback != 'function') throw new Error('write() requires a callback argument') if (typeof options != 'object') options = {} this._written = true if (typeof this._write == 'function' ) return this._write(callback) if (typeof this._db._batch == 'function') return this._db._batch(this._operations, options, callback) process.nextTick(callback) } module.exports = AbstractChainedBatch }).call(this,require('_process')) },{"_process":295}],186:[function(require,module,exports){ (function (process){ /* Copyright (c) 2013 Rod Vagg, MIT License */ function AbstractIterator (db) { this.db = db this._ended = false this._nexting = false } AbstractIterator.prototype.next = function (callback) { var self = this if (typeof callback != 'function') throw new Error('next() requires a callback argument') if (self._ended) return callback(new Error('cannot call next() after end()')) if (self._nexting) return callback(new Error('cannot call next() before previous next() has completed')) self._nexting = true if (typeof self._next == 'function') { return self._next(function () { self._nexting = false callback.apply(null, arguments) }) } process.nextTick(function () { self._nexting = false callback() }) } AbstractIterator.prototype.end = function (callback) { if (typeof callback != 'function') throw new Error('end() requires a callback argument') if (this._ended) return callback(new Error('end() already called on iterator')) this._ended = true if (typeof this._end == 'function') return this._end(callback) process.nextTick(callback) } module.exports = AbstractIterator }).call(this,require('_process')) },{"_process":295}],187:[function(require,module,exports){ (function (Buffer,process){ /* Copyright (c) 2013 Rod Vagg, MIT License */ var xtend = require('xtend') , AbstractIterator = require('./abstract-iterator') , AbstractChainedBatch = require('./abstract-chained-batch') function AbstractLevelDOWN (location) { if (!arguments.length || location === undefined) throw new Error('constructor requires at least a location argument') if (typeof location != 'string') throw new Error('constructor requires a location string argument') this.location = location this.status = 'new' } AbstractLevelDOWN.prototype.open = function (options, callback) { var self = this , oldStatus = this.status if (typeof options == 'function') callback = options if (typeof callback != 'function') throw new Error('open() requires a callback argument') if (typeof options != 'object') options = {} options.createIfMissing = options.createIfMissing != false options.errorIfExists = !!options.errorIfExists if (typeof this._open == 'function') { this.status = 'opening' this._open(options, function (err) { if (err) { self.status = oldStatus return callback(err) } self.status = 'open' callback() }) } else { this.status = 'open' process.nextTick(callback) } } AbstractLevelDOWN.prototype.close = function (callback) { var self = this , oldStatus = this.status if (typeof callback != 'function') throw new Error('close() requires a callback argument') if (typeof this._close == 'function') { this.status = 'closing' this._close(function (err) { if (err) { self.status = oldStatus return callback(err) } self.status = 'closed' callback() }) } else { this.status = 'closed' process.nextTick(callback) } } AbstractLevelDOWN.prototype.get = function (key, options, callback) { var err if (typeof options == 'function') callback = options if (typeof callback != 'function') throw new Error('get() requires a callback argument') if (err = this._checkKey(key, 'key', this._isBuffer)) return callback(err) if (!this._isBuffer(key)) key = String(key) if (typeof options != 'object') options = {} options.asBuffer = options.asBuffer != false if (typeof this._get == 'function') return this._get(key, options, callback) process.nextTick(function () { callback(new Error('NotFound')) }) } AbstractLevelDOWN.prototype.put = function (key, value, options, callback) { var err if (typeof options == 'function') callback = options if (typeof callback != 'function') throw new Error('put() requires a callback argument') if (err = this._checkKey(key, 'key', this._isBuffer)) return callback(err) if (!this._isBuffer(key)) key = String(key) // coerce value to string in node, don't touch it in browser // (indexeddb can store any JS type) if (value != null && !this._isBuffer(value) && !process.browser) value = String(value) if (typeof options != 'object') options = {} if (typeof this._put == 'function') return this._put(key, value, options, callback) process.nextTick(callback) } AbstractLevelDOWN.prototype.del = function (key, options, callback) { var err if (typeof options == 'function') callback = options if (typeof callback != 'function') throw new Error('del() requires a callback argument') if (err = this._checkKey(key, 'key', this._isBuffer)) return callback(err) if (!this._isBuffer(key)) key = String(key) if (typeof options != 'object') options = {} if (typeof this._del == 'function') return this._del(key, options, callback) process.nextTick(callback) } AbstractLevelDOWN.prototype.batch = function (array, options, callback) { if (!arguments.length) return this._chainedBatch() if (typeof options == 'function') callback = options if (typeof array == 'function') callback = array if (typeof callback != 'function') throw new Error('batch(array) requires a callback argument') if (!Array.isArray(array)) return callback(new Error('batch(array) requires an array argument')) if (!options || typeof options != 'object') options = {} var i = 0 , l = array.length , e , err for (; i < l; i++) { e = array[i] if (typeof e != 'object') continue if (err = this._checkKey(e.type, 'type', this._isBuffer)) return callback(err) if (err = this._checkKey(e.key, 'key', this._isBuffer)) return callback(err) } if (typeof this._batch == 'function') return this._batch(array, options, callback) process.nextTick(callback) } //TODO: remove from here, not a necessary primitive AbstractLevelDOWN.prototype.approximateSize = function (start, end, callback) { if ( start == null || end == null || typeof start == 'function' || typeof end == 'function') { throw new Error('approximateSize() requires valid `start`, `end` and `callback` arguments') } if (typeof callback != 'function') throw new Error('approximateSize() requires a callback argument') if (!this._isBuffer(start)) start = String(start) if (!this._isBuffer(end)) end = String(end) if (typeof this._approximateSize == 'function') return this._approximateSize(start, end, callback) process.nextTick(function () { callback(null, 0) }) } AbstractLevelDOWN.prototype._setupIteratorOptions = function (options) { var self = this options = xtend(options) ;[ 'start', 'end', 'gt', 'gte', 'lt', 'lte' ].forEach(function (o) { if (options[o] && self._isBuffer(options[o]) && options[o].length === 0) delete options[o] }) options.reverse = !!options.reverse options.keys = options.keys != false options.values = options.values != false options.limit = 'limit' in options ? options.limit : -1 options.keyAsBuffer = options.keyAsBuffer != false options.valueAsBuffer = options.valueAsBuffer != false return options } AbstractLevelDOWN.prototype.iterator = function (options) { if (typeof options != 'object') options = {} options = this._setupIteratorOptions(options) if (typeof this._iterator == 'function') return this._iterator(options) return new AbstractIterator(this) } AbstractLevelDOWN.prototype._chainedBatch = function () { return new AbstractChainedBatch(this) } AbstractLevelDOWN.prototype._isBuffer = function (obj) { return Buffer.isBuffer(obj) } AbstractLevelDOWN.prototype._checkKey = function (obj, type) { if (obj === null || obj === undefined) return new Error(type + ' cannot be `null` or `undefined`') if (this._isBuffer(obj)) { if (obj.length === 0) return new Error(type + ' cannot be an empty Buffer') } else if (String(obj) === '') return new Error(type + ' cannot be an empty String') } module.exports = AbstractLevelDOWN }).call(this,{"isBuffer":require("../../../is-buffer/index.js")},require('_process')) },{"../../../is-buffer/index.js":170,"./abstract-chained-batch":185,"./abstract-iterator":186,"_process":295,"xtend":197}],188:[function(require,module,exports){ exports.AbstractLevelDOWN = require('./abstract-leveldown') exports.AbstractIterator = require('./abstract-iterator') exports.AbstractChainedBatch = require('./abstract-chained-batch') exports.isLevelDOWN = require('./is-leveldown') },{"./abstract-chained-batch":185,"./abstract-iterator":186,"./abstract-leveldown":187,"./is-leveldown":189}],189:[function(require,module,exports){ var AbstractLevelDOWN = require('./abstract-leveldown') function isLevelDOWN (db) { if (!db || typeof db !== 'object') return false return Object.keys(AbstractLevelDOWN.prototype).filter(function (name) { // TODO remove approximateSize check when method is gone return name[0] != '_' && name != 'approximateSize' }).every(function (name) { return typeof db[name] == 'function' }) } module.exports = isLevelDOWN },{"./abstract-leveldown":187}],190:[function(require,module,exports){ var util = require('util') , AbstractIterator = require('abstract-leveldown').AbstractIterator function DeferredIterator (options) { AbstractIterator.call(this, options) this._options = options this._iterator = null this._operations = [] } util.inherits(DeferredIterator, AbstractIterator) DeferredIterator.prototype.setDb = function (db) { var it = this._iterator = db.iterator(this._options) this._operations.forEach(function (op) { it[op.method].apply(it, op.args) }) } DeferredIterator.prototype._operation = function (method, args) { if (this._iterator) return this._iterator[method].apply(this._iterator, args) this._operations.push({ method: method, args: args }) } 'next end'.split(' ').forEach(function (m) { DeferredIterator.prototype['_' + m] = function () { this._operation(m, arguments) } }) module.exports = DeferredIterator; },{"abstract-leveldown":188,"util":636}],191:[function(require,module,exports){ (function (Buffer,process){ var util = require('util') , AbstractLevelDOWN = require('abstract-leveldown').AbstractLevelDOWN , DeferredIterator = require('./deferred-iterator') function DeferredLevelDOWN (location) { AbstractLevelDOWN.call(this, typeof location == 'string' ? location : '') // optional location, who cares? this._db = undefined this._operations = [] this._iterators = [] } util.inherits(DeferredLevelDOWN, AbstractLevelDOWN) // called by LevelUP when we have a real DB to take its place DeferredLevelDOWN.prototype.setDb = function (db) { this._db = db this._operations.forEach(function (op) { db[op.method].apply(db, op.args) }) this._iterators.forEach(function (it) { it.setDb(db) }) } DeferredLevelDOWN.prototype._open = function (options, callback) { return process.nextTick(callback) } // queue a new deferred operation DeferredLevelDOWN.prototype._operation = function (method, args) { if (this._db) return this._db[method].apply(this._db, args) this._operations.push({ method: method, args: args }) } // deferrables 'put get del batch approximateSize'.split(' ').forEach(function (m) { DeferredLevelDOWN.prototype['_' + m] = function () { this._operation(m, arguments) } }) DeferredLevelDOWN.prototype._isBuffer = function (obj) { return Buffer.isBuffer(obj) } DeferredLevelDOWN.prototype._iterator = function (options) { if (this._db) return this._db.iterator.apply(this._db, arguments) var it = new DeferredIterator(options) this._iterators.push(it) return it } module.exports = DeferredLevelDOWN module.exports.DeferredIterator = DeferredIterator }).call(this,{"isBuffer":require("../../../is-buffer/index.js")},require('_process')) },{"../../../is-buffer/index.js":170,"./deferred-iterator":190,"_process":295,"abstract-leveldown":188,"util":636}],192:[function(require,module,exports){ /* Copyright (c) 2012-2015 LevelUP contributors * See list at * MIT License * */ var util = require('./util') , WriteError = require('level-errors').WriteError , getOptions = util.getOptions , dispatchError = util.dispatchError function Batch (levelup, codec) { this._levelup = levelup this._codec = codec this.batch = levelup.db.batch() this.ops = [] this.length = 0 } Batch.prototype.put = function (key_, value_, options) { options = getOptions(options) var key = this._codec.encodeKey(key_, options) , value = this._codec.encodeValue(value_, options) try { this.batch.put(key, value) } catch (e) { throw new WriteError(e) } this.ops.push({ type : 'put', key : key, value : value }) this.length++ return this } Batch.prototype.del = function (key_, options) { options = getOptions(options) var key = this._codec.encodeKey(key_, options) try { this.batch.del(key) } catch (err) { throw new WriteError(err) } this.ops.push({ type : 'del', key : key }) this.length++ return this } Batch.prototype.clear = function () { try { this.batch.clear() } catch (err) { throw new WriteError(err) } this.ops = [] this.length = 0 return this } Batch.prototype.write = function (callback) { var levelup = this._levelup , ops = this.ops try { this.batch.write(function (err) { if (err) return dispatchError(levelup, new WriteError(err), callback) levelup.emit('batch', ops) if (callback) callback() }) } catch (err) { throw new WriteError(err) } } module.exports = Batch },{"./util":194,"level-errors":175}],193:[function(require,module,exports){ (function (process){ /* Copyright (c) 2012-2015 LevelUP contributors * See list at * MIT License * */ var EventEmitter = require('events').EventEmitter , inherits = require('util').inherits , deprecate = require('util').deprecate , extend = require('xtend') , prr = require('prr') , DeferredLevelDOWN = require('deferred-leveldown') , IteratorStream = require('level-iterator-stream') , errors = require('level-errors') , WriteError = errors.WriteError , ReadError = errors.ReadError , NotFoundError = errors.NotFoundError , OpenError = errors.OpenError , EncodingError = errors.EncodingError , InitializationError = errors.InitializationError , util = require('./util') , Batch = require('./batch') , Codec = require('level-codec') , getOptions = util.getOptions , defaultOptions = util.defaultOptions , getLevelDOWN = util.getLevelDOWN , dispatchError = util.dispatchError , isDefined = util.isDefined function getCallback (options, callback) { return typeof options == 'function' ? options : callback } // Possible LevelUP#_status values: // - 'new' - newly created, not opened or closed // - 'opening' - waiting for the database to be opened, post open() // - 'open' - successfully opened the database, available for use // - 'closing' - waiting for the database to be closed, post close() // - 'closed' - database has been successfully closed, should not be // used except for another open() operation function LevelUP (location, options, callback) { if (!(this instanceof LevelUP)) return new LevelUP(location, options, callback) var error EventEmitter.call(this) this.setMaxListeners(Infinity) if (typeof location == 'function') { options = typeof options == 'object' ? options : {} options.db = location location = null } else if (typeof location == 'object' && typeof location.db == 'function') { options = location location = null } if (typeof options == 'function') { callback = options options = {} } if ((!options || typeof options.db != 'function') && typeof location != 'string') { error = new InitializationError( 'Must provide a location for the database') if (callback) { return process.nextTick(function () { callback(error) }) } throw error } options = getOptions(options) this.options = extend(defaultOptions, options) this._codec = new Codec(this.options) this._status = 'new' // set this.location as enumerable but not configurable or writable prr(this, 'location', location, 'e') this.open(callback) } inherits(LevelUP, EventEmitter) LevelUP.prototype.open = function (callback) { var self = this , dbFactory , db if (this.isOpen()) { if (callback) process.nextTick(function () { callback(null, self) }) return this } if (this._isOpening()) { return callback && this.once( 'open' , function () { callback(null, self) } ) } this.emit('opening') this._status = 'opening' this.db = new DeferredLevelDOWN(this.location) dbFactory = this.options.db || getLevelDOWN() db = dbFactory(this.location) db.open(this.options, function (err) { if (err) { return dispatchError(self, new OpenError(err), callback) } else { self.db.setDb(db) self.db = db self._status = 'open' if (callback) callback(null, self) self.emit('open') self.emit('ready') } }) } LevelUP.prototype.close = function (callback) { var self = this if (this.isOpen()) { this._status = 'closing' this.db.close(function () { self._status = 'closed' self.emit('closed') if (callback) callback.apply(null, arguments) }) this.emit('closing') this.db = new DeferredLevelDOWN(this.location) } else if (this._status == 'closed' && callback) { return process.nextTick(callback) } else if (this._status == 'closing' && callback) { this.once('closed', callback) } else if (this._isOpening()) { this.once('open', function () { self.close(callback) }) } } LevelUP.prototype.isOpen = function () { return this._status == 'open' } LevelUP.prototype._isOpening = function () { return this._status == 'opening' } LevelUP.prototype.isClosed = function () { return (/^clos/).test(this._status) } function maybeError(db, options, callback) { if (!db._isOpening() && !db.isOpen()) { dispatchError( db , new ReadError('Database is not open') , callback ) return true } } function writeError (db, message, callback) { dispatchError( db , new WriteError(message) , callback ) } function readError (db, message, callback) { dispatchError( db , new ReadError(message) , callback ) } LevelUP.prototype.get = function (key_, options, callback) { var self = this , key callback = getCallback(options, callback) if (maybeError(this, options, callback)) return if (key_ === null || key_ === undefined || 'function' !== typeof callback) return readError(this , 'get() requires key and callback arguments', callback) options = util.getOptions(options) key = this._codec.encodeKey(key_, options) options.asBuffer = this._codec.valueAsBuffer(options) this.db.get(key, options, function (err, value) { if (err) { if ((/notfound/i).test(err) || err.notFound) { err = new NotFoundError( 'Key not found in database [' + key_ + ']', err) } else { err = new ReadError(err) } return dispatchError(self, err, callback) } if (callback) { try { value = self._codec.decodeValue(value, options) } catch (e) { return callback(new EncodingError(e)) } callback(null, value) } }) } LevelUP.prototype.put = function (key_, value_, options, callback) { var self = this , key , value callback = getCallback(options, callback) if (key_ === null || key_ === undefined) return writeError(this, 'put() requires a key argument', callback) if (maybeError(this, options, callback)) return options = getOptions(options) key = this._codec.encodeKey(key_, options) value = this._codec.encodeValue(value_, options) this.db.put(key, value, options, function (err) { if (err) { return dispatchError(self, new WriteError(err), callback) } else { self.emit('put', key_, value_) if (callback) callback() } }) } LevelUP.prototype.del = function (key_, options, callback) { var self = this , key callback = getCallback(options, callback) if (key_ === null || key_ === undefined) return writeError(this, 'del() requires a key argument', callback) if (maybeError(this, options, callback)) return options = getOptions(options) key = this._codec.encodeKey(key_, options) this.db.del(key, options, function (err) { if (err) { return dispatchError(self, new WriteError(err), callback) } else { self.emit('del', key_) if (callback) callback() } }) } LevelUP.prototype.batch = function (arr_, options, callback) { var self = this , keyEnc , valueEnc , arr if (!arguments.length) return new Batch(this, this._codec) callback = getCallback(options, callback) if (!Array.isArray(arr_)) return writeError(this, 'batch() requires an array argument', callback) if (maybeError(this, options, callback)) return options = getOptions(options) arr = self._codec.encodeBatch(arr_, options) arr = arr.map(function (op) { if (!op.type && op.key !== undefined && op.value !== undefined) op.type = 'put' return op }) this.db.batch(arr, options, function (err) { if (err) { return dispatchError(self, new WriteError(err), callback) } else { self.emit('batch', arr_) if (callback) callback() } }) } LevelUP.prototype.approximateSize = deprecate(function (start_, end_, options, callback) { var self = this , start , end callback = getCallback(options, callback) options = getOptions(options) if (start_ === null || start_ === undefined || end_ === null || end_ === undefined || 'function' !== typeof callback) return readError(this, 'approximateSize() requires start, end and callback arguments', callback) start = this._codec.encodeKey(start_, options) end = this._codec.encodeKey(end_, options) this.db.approximateSize(start, end, function (err, size) { if (err) { return dispatchError(self, new OpenError(err), callback) } else if (callback) { callback(null, size) } }) }, 'db.approximateSize() is deprecated. Use db.db.approximateSize() instead') LevelUP.prototype.readStream = LevelUP.prototype.createReadStream = function (options) { options = extend( {keys: true, values: true}, this.options, options) options.keyEncoding = options.keyEncoding options.valueEncoding = options.valueEncoding options = this._codec.encodeLtgt(options); options.keyAsBuffer = this._codec.keyAsBuffer(options) options.valueAsBuffer = this._codec.valueAsBuffer(options) if ('number' !== typeof options.limit) options.limit = -1 return new IteratorStream(this.db.iterator(options), extend(options, { decoder: this._codec.createStreamDecoder(options) })) } LevelUP.prototype.keyStream = LevelUP.prototype.createKeyStream = function (options) { return this.createReadStream(extend(options, { keys: true, values: false })) } LevelUP.prototype.valueStream = LevelUP.prototype.createValueStream = function (options) { return this.createReadStream(extend(options, { keys: false, values: true })) } LevelUP.prototype.toString = function () { return 'LevelUP' } function utilStatic (name) { return function (location, callback) { getLevelDOWN()[name](location, callback || function () {}) } } module.exports = LevelUP module.exports.errors = require('level-errors') module.exports.destroy = deprecate( utilStatic('destroy') , 'levelup.destroy() is deprecated. Use leveldown.destroy() instead' ) module.exports.repair = deprecate( utilStatic('repair') , 'levelup.repair() is deprecated. Use leveldown.repair() instead' ) }).call(this,require('_process')) },{"./batch":192,"./util":194,"_process":295,"deferred-leveldown":191,"events":144,"level-codec":173,"level-errors":175,"level-iterator-stream":176,"prr":196,"util":636,"xtend":197}],194:[function(require,module,exports){ /* Copyright (c) 2012-2015 LevelUP contributors * See list at * MIT License * */ var extend = require('xtend') , LevelUPError = require('level-errors').LevelUPError , format = require('util').format , defaultOptions = { createIfMissing : true , errorIfExists : false , keyEncoding : 'utf8' , valueEncoding : 'utf8' , compression : true } , leveldown function getOptions (options) { if (typeof options == 'string') options = { valueEncoding: options } if (typeof options != 'object') options = {} return options } function getLevelDOWN () { if (leveldown) return leveldown var requiredVersion = require('../package.json').devDependencies.leveldown , leveldownVersion try { leveldownVersion = require('leveldown/package').version } catch (e) { throw requireError(e) } if (!require('semver').satisfies(leveldownVersion, requiredVersion)) { throw new LevelUPError( 'Installed version of LevelDOWN (' + leveldownVersion + ') does not match required version (' + requiredVersion + ')' ) } try { return leveldown = require('leveldown') } catch (e) { throw requireError(e) } } function requireError (e) { var template = 'Failed to require LevelDOWN (%s). Try `npm install leveldown` if it\'s missing' return new LevelUPError(format(template, e.message)) } function dispatchError (db, error, callback) { typeof callback == 'function' ? callback(error) : db.emit('error', error) } function isDefined (v) { return typeof v !== 'undefined' } module.exports = { defaultOptions : defaultOptions , getOptions : getOptions , getLevelDOWN : getLevelDOWN , dispatchError : dispatchError , isDefined : isDefined } },{"../package.json":195,"level-errors":175,"leveldown":33,"leveldown/package":33,"semver":33,"util":636,"xtend":197}],195:[function(require,module,exports){ module.exports={ "_args": [ [ "levelup@~1.3.0", "/Users/joran/Documents/development/patchdeck/node_modules/level-packager" ] ], "_from": "levelup@>=1.3.0 <1.4.0", "_id": "levelup@1.3.1", "_inCache": true, "_installable": true, "_location": "/level-packager/levelup", "_nodeVersion": "4.2.2", "_npmUser": { "email": "ralphtheninja@riseup.net", "name": "ralphtheninja" }, "_npmVersion": "3.5.0", "_phantomChildren": {}, "_requested": { "name": "levelup", "raw": "levelup@~1.3.0", "rawSpec": "~1.3.0", "scope": null, "spec": ">=1.3.0 <1.4.0", "type": "range" }, "_requiredBy": [ "/level-packager" ], "_resolved": "https://registry.npmjs.org/levelup/-/levelup-1.3.1.tgz", "_shasum": "8030758bb1b1dafdb71bfb55fff0caa2740cb846", "_shrinkwrap": null, "_spec": "levelup@~1.3.0", "_where": "/Users/joran/Documents/development/patchdeck/node_modules/level-packager", "browser": { "leveldown": false, "leveldown/package": false, "semver": false }, "bugs": { "url": "https://github.com/level/levelup/issues" }, "contributors": [ { "name": "Julian Gruber", "email": "julian@juliangruber.com", "url": "https://github.com/juliangruber" }, { "name": "Rod Vagg", "email": "r@va.gg", "url": "https://github.com/rvagg" }, { "name": "Jake Verbaten", "email": "raynos2@gmail.com", "url": "https://github.com/raynos" }, { "name": "Dominic Tarr", "email": "dominic.tarr@gmail.com", "url": "https://github.com/dominictarr" }, { "name": "Max Ogden", "email": "max@maxogden.com", "url": "https://github.com/maxogden" }, { "name": "Lars-Magnus Skog", "email": "ralphtheninja@riseup.net", "url": "https://github.com/ralphtheninja" }, { "name": "David Björklund", "email": "david.bjorklund@gmail.com", "url": "https://github.com/kesla" }, { "name": "John Chesley", "email": "john@chesl.es", "url": "https://github.com/chesles/" }, { "name": "Paolo Fragomeni", "email": "paolo@async.ly", "url": "https://github.com/hij1nx" }, { "name": "Anton Whalley", "email": "anton.whalley@nearform.com", "url": "https://github.com/No9" }, { "name": "Matteo Collina", "email": "matteo.collina@gmail.com", "url": "https://github.com/mcollina" }, { "name": "Pedro Teixeira", "email": "pedro.teixeira@gmail.com", "url": "https://github.com/pgte" }, { "name": "James Halliday", "email": "mail@substack.net", "url": "https://github.com/substack" }, { "name": "Jarrett Cruger", "email": "jcrugzz@gmail.com", "url": "https://github.com/jcrugzz" } ], "dependencies": { "deferred-leveldown": "~1.2.1", "level-codec": "~6.1.0", "level-errors": "~1.0.3", "level-iterator-stream": "~1.3.0", "prr": "~1.0.1", "semver": "~5.1.0", "xtend": "~4.0.0" }, "description": "Fast & simple storage - a Node.js-style LevelDB wrapper", "devDependencies": { "async": "~1.5.0", "bustermove": "~1.0.0", "delayed": "~1.0.1", "faucet": "~0.0.1", "leveldown": "^1.1.0", "memdown": "~1.1.0", "msgpack-js": "~0.3.0", "referee": "~1.2.0", "rimraf": "~2.4.3", "slow-stream": "0.0.4", "tap": "~2.3.1", "tape": "~4.2.1" }, "directories": {}, "dist": { "shasum": "8030758bb1b1dafdb71bfb55fff0caa2740cb846", "tarball": "https://registry.npmjs.org/levelup/-/levelup-1.3.1.tgz" }, "gitHead": "40bd66872974140c79a74d9411b992ddffa926a4", "homepage": "https://github.com/level/levelup", "keywords": [ "database", "db", "json", "leveldb", "storage", "store", "stream" ], "license": "MIT", "main": "lib/levelup.js", "maintainers": [ { "name": "rvagg", "email": "rod@vagg.org" }, { "name": "ralphtheninja", "email": "ralphtheninja@riseup.net" }, { "name": "juliangruber", "email": "julian@juliangruber.com" } ], "name": "levelup", "optionalDependencies": {}, "readme": "ERROR: No README data found!", "repository": { "type": "git", "url": "git+https://github.com/level/levelup.git" }, "scripts": { "test": "tape test/*-test.js | faucet" }, "version": "1.3.1" } },{}],196:[function(require,module,exports){ /*! * prr * (c) 2013 Rod Vagg * https://github.com/rvagg/prr * License: MIT */ (function (name, context, definition) { if (typeof module != 'undefined' && module.exports) module.exports = definition() else context[name] = definition() })('prr', this, function() { var setProperty = typeof Object.defineProperty == 'function' ? function (obj, key, options) { Object.defineProperty(obj, key, options) return obj } : function (obj, key, options) { // < es5 obj[key] = options.value return obj } , makeOptions = function (value, options) { var oo = typeof options == 'object' , os = !oo && typeof options == 'string' , op = function (p) { return oo ? !!options[p] : os ? options.indexOf(p[0]) > -1 : false } return { enumerable : op('enumerable') , configurable : op('configurable') , writable : op('writable') , value : value } } , prr = function (obj, key, value, options) { var k options = makeOptions(value, options) if (typeof key == 'object') { for (k in key) { if (Object.hasOwnProperty.call(key, k)) { options.value = key[k] setProperty(obj, k, options) } } return obj } return setProperty(obj, key, options) } return prr }) },{}],197:[function(require,module,exports){ arguments[4][177][0].apply(exports,arguments) },{"dup":177}],198:[function(require,module,exports){ (function (Buffer){ var sr = require('string-range') var defined = require('defined') var beq = require('buffer-equal') function eq (a, b) { if (Buffer.isBuffer(a) && Buffer.isBuffer(b)) { return beq(a, b) } else return a === b } module.exports = function post (db, opts, each) { if(!each) each = opts, opts = {} if('function' === typeof db.post) return db.post(opts, each) var encode = (opts && opts.keyEncoding && opts.keyEncoding.encode) || (db.options && db.options.keyEncoding && db.options.keyEncoding.encode) || function (x) { return x } var min = defined(opts.min, opts.gt, opts.gte, opts.start) var max = defined(opts.max, opts.lt, opts.lte, opts.end) var copts = {} if (min !== undefined) copts.min = encode(min) if (max !== undefined) copts.max = encode(max) var checker = sr.checker(copts) function cmp (key) { var ek = encode(key) if (opts.gt && eq(ek, copts.min)) return false if (opts.lt && eq(ek, copts.max)) return false return checker(ek) } function onPut (key, val) { if(cmp(key)) each({type: 'put', key: key, value: val}) } function onDel (key, val) { if(cmp(key)) each({type: 'del', key: key, value: val}) } function onBatch (ary) { ary.forEach(function (op) { if(cmp(op.key)) each(op) }) } db.on('put', onPut) db.on('del', onDel) db.on('batch', onBatch) return function () { db.removeListener('put', onPut) db.removeListener('del', onPut) db.removeListener('batch', onPut) } } }).call(this,{"isBuffer":require("../is-buffer/index.js")}) },{"../is-buffer/index.js":170,"buffer-equal":59,"defined":112,"string-range":615}],199:[function(require,module,exports){ module.exports = require('level-packager')(require('leveldown')) },{"level-packager":184,"leveldown":202}],200:[function(require,module,exports){ const util = require('util') , AbstractChainedBatch = require('abstract-leveldown').AbstractChainedBatch function ChainedBatch (db) { AbstractChainedBatch.call(this, db) this.binding = db.binding.batch() } ChainedBatch.prototype._put = function (key, value) { this.binding.put(key, value) } ChainedBatch.prototype._del = function (key) { this.binding.del(key) } ChainedBatch.prototype._clear = function (key) { this.binding.clear(key) } ChainedBatch.prototype._write = function (options, callback) { this.binding.write(options, callback) } util.inherits(ChainedBatch, AbstractChainedBatch) module.exports = ChainedBatch },{"abstract-leveldown":206,"util":636}],201:[function(require,module,exports){ const util = require('util') , AbstractIterator = require('abstract-leveldown').AbstractIterator , fastFuture = require('fast-future') function Iterator (db, options) { AbstractIterator.call(this, db) this.binding = db.binding.iterator(options) this.cache = null this.finished = false this.fastFuture = fastFuture() } util.inherits(Iterator, AbstractIterator) Iterator.prototype.seek = function (key) { if (typeof key !== 'string') throw new Error('seek requires a string key') this.cache = null this.binding.seek(key) } Iterator.prototype._next = function (callback) { var that = this , key , value if (this.cache && this.cache.length) { key = this.cache.pop() value = this.cache.pop() this.fastFuture(function () { callback(null, key, value) }) } else if (this.finished) { this.fastFuture(function () { callback() }) } else { this.binding.next(function (err, array, finished) { if (err) return callback(err) that.cache = array that.finished = finished that._next(callback) }) } return this } Iterator.prototype._end = function (callback) { delete this.cache this.binding.end(callback) } module.exports = Iterator },{"abstract-leveldown":206,"fast-future":149,"util":636}],202:[function(require,module,exports){ const util = require('util') , AbstractLevelDOWN = require('abstract-leveldown').AbstractLevelDOWN , binding = require('bindings')('leveldown').leveldown , ChainedBatch = require('./chained-batch') , Iterator = require('./iterator') function LevelDOWN (location) { if (!(this instanceof LevelDOWN)) return new LevelDOWN(location) AbstractLevelDOWN.call(this, location) this.binding = binding(location) } util.inherits(LevelDOWN, AbstractLevelDOWN) LevelDOWN.prototype._open = function (options, callback) { this.binding.open(options, callback) } LevelDOWN.prototype._close = function (callback) { this.binding.close(callback) } LevelDOWN.prototype._put = function (key, value, options, callback) { this.binding.put(key, value, options, callback) } LevelDOWN.prototype._get = function (key, options, callback) { this.binding.get(key, options, callback) } LevelDOWN.prototype._del = function (key, options, callback) { this.binding.del(key, options, callback) } LevelDOWN.prototype._chainedBatch = function () { return new ChainedBatch(this) } LevelDOWN.prototype._batch = function (operations, options, callback) { return this.binding.batch(operations, options, callback) } LevelDOWN.prototype._approximateSize = function (start, end, callback) { this.binding.approximateSize(start, end, callback) } LevelDOWN.prototype.getProperty = function (property) { if (typeof property != 'string') throw new Error('getProperty() requires a valid `property` argument') return this.binding.getProperty(property) } LevelDOWN.prototype._iterator = function (options) { return new Iterator(this, options) } LevelDOWN.destroy = function (location, callback) { if (arguments.length < 2) throw new Error('destroy() requires `location` and `callback` arguments') if (typeof location != 'string') throw new Error('destroy() requires a location string argument') if (typeof callback != 'function') throw new Error('destroy() requires a callback function argument') binding.destroy(location, callback) } LevelDOWN.repair = function (location, callback) { if (arguments.length < 2) throw new Error('repair() requires `location` and `callback` arguments') if (typeof location != 'string') throw new Error('repair() requires a location string argument') if (typeof callback != 'function') throw new Error('repair() requires a callback function argument') binding.repair(location, callback) } module.exports = LevelDOWN },{"./chained-batch":200,"./iterator":201,"abstract-leveldown":206,"bindings":21,"util":636}],203:[function(require,module,exports){ (function (process){ /* Copyright (c) 2013 Rod Vagg, MIT License */ function AbstractChainedBatch (db) { this._db = db this._operations = [] this._written = false } AbstractChainedBatch.prototype._checkWritten = function () { if (this._written) throw new Error('write() already called on this batch') } AbstractChainedBatch.prototype.put = function (key, value) { this._checkWritten() var err = this._db._checkKey(key, 'key', this._db._isBuffer) if (err) throw err if (!this._db._isBuffer(key)) key = String(key) if (!this._db._isBuffer(value)) value = String(value) if (typeof this._put == 'function' ) this._put(key, value) else this._operations.push({ type: 'put', key: key, value: value }) return this } AbstractChainedBatch.prototype.del = function (key) { this._checkWritten() var err = this._db._checkKey(key, 'key', this._db._isBuffer) if (err) throw err if (!this._db._isBuffer(key)) key = String(key) if (typeof this._del == 'function' ) this._del(key) else this._operations.push({ type: 'del', key: key }) return this } AbstractChainedBatch.prototype.clear = function () { this._checkWritten() this._operations = [] if (typeof this._clear == 'function' ) this._clear() return this } AbstractChainedBatch.prototype.write = function (options, callback) { this._checkWritten() if (typeof options == 'function') callback = options if (typeof callback != 'function') throw new Error('write() requires a callback argument') if (typeof options != 'object') options = {} this._written = true if (typeof this._write == 'function' ) return this._write(callback) if (typeof this._db._batch == 'function') return this._db._batch(this._operations, options, callback) process.nextTick(callback) } module.exports = AbstractChainedBatch }).call(this,require('_process')) },{"_process":295}],204:[function(require,module,exports){ (function (process){ /* Copyright (c) 2013 Rod Vagg, MIT License */ function AbstractIterator (db) { this.db = db this._ended = false this._nexting = false } AbstractIterator.prototype.next = function (callback) { var self = this if (typeof callback != 'function') throw new Error('next() requires a callback argument') if (self._ended) return callback(new Error('cannot call next() after end()')) if (self._nexting) return callback(new Error('cannot call next() before previous next() has completed')) self._nexting = true if (typeof self._next == 'function') { return self._next(function () { self._nexting = false callback.apply(null, arguments) }) } process.nextTick(function () { self._nexting = false callback() }) } AbstractIterator.prototype.end = function (callback) { if (typeof callback != 'function') throw new Error('end() requires a callback argument') if (this._ended) return callback(new Error('end() already called on iterator')) this._ended = true if (typeof this._end == 'function') return this._end(callback) process.nextTick(callback) } module.exports = AbstractIterator }).call(this,require('_process')) },{"_process":295}],205:[function(require,module,exports){ (function (Buffer,process){ /* Copyright (c) 2013 Rod Vagg, MIT License */ var xtend = require('xtend') , AbstractIterator = require('./abstract-iterator') , AbstractChainedBatch = require('./abstract-chained-batch') function AbstractLevelDOWN (location) { if (!arguments.length || location === undefined) throw new Error('constructor requires at least a location argument') if (typeof location != 'string') throw new Error('constructor requires a location string argument') this.location = location this.status = 'new' } AbstractLevelDOWN.prototype.open = function (options, callback) { var self = this , oldStatus = this.status if (typeof options == 'function') callback = options if (typeof callback != 'function') throw new Error('open() requires a callback argument') if (typeof options != 'object') options = {} options.createIfMissing = options.createIfMissing != false options.errorIfExists = !!options.errorIfExists if (typeof this._open == 'function') { this.status = 'opening' this._open(options, function (err) { if (err) { self.status = oldStatus return callback(err) } self.status = 'open' callback() }) } else { this.status = 'open' process.nextTick(callback) } } AbstractLevelDOWN.prototype.close = function (callback) { var self = this , oldStatus = this.status if (typeof callback != 'function') throw new Error('close() requires a callback argument') if (typeof this._close == 'function') { this.status = 'closing' this._close(function (err) { if (err) { self.status = oldStatus return callback(err) } self.status = 'closed' callback() }) } else { this.status = 'closed' process.nextTick(callback) } } AbstractLevelDOWN.prototype.get = function (key, options, callback) { var err if (typeof options == 'function') callback = options if (typeof callback != 'function') throw new Error('get() requires a callback argument') if (err = this._checkKey(key, 'key', this._isBuffer)) return callback(err) if (!this._isBuffer(key)) key = String(key) if (typeof options != 'object') options = {} options.asBuffer = options.asBuffer != false if (typeof this._get == 'function') return this._get(key, options, callback) process.nextTick(function () { callback(new Error('NotFound')) }) } AbstractLevelDOWN.prototype.put = function (key, value, options, callback) { var err if (typeof options == 'function') callback = options if (typeof callback != 'function') throw new Error('put() requires a callback argument') if (err = this._checkKey(key, 'key', this._isBuffer)) return callback(err) if (!this._isBuffer(key)) key = String(key) // coerce value to string in node, don't touch it in browser // (indexeddb can store any JS type) if (value != null && !this._isBuffer(value) && !process.browser) value = String(value) if (typeof options != 'object') options = {} if (typeof this._put == 'function') return this._put(key, value, options, callback) process.nextTick(callback) } AbstractLevelDOWN.prototype.del = function (key, options, callback) { var err if (typeof options == 'function') callback = options if (typeof callback != 'function') throw new Error('del() requires a callback argument') if (err = this._checkKey(key, 'key', this._isBuffer)) return callback(err) if (!this._isBuffer(key)) key = String(key) if (typeof options != 'object') options = {} if (typeof this._del == 'function') return this._del(key, options, callback) process.nextTick(callback) } AbstractLevelDOWN.prototype.batch = function (array, options, callback) { if (!arguments.length) return this._chainedBatch() if (typeof options == 'function') callback = options if (typeof array == 'function') callback = array if (typeof callback != 'function') throw new Error('batch(array) requires a callback argument') if (!Array.isArray(array)) return callback(new Error('batch(array) requires an array argument')) if (!options || typeof options != 'object') options = {} var i = 0 , l = array.length , e , err for (; i < l; i++) { e = array[i] if (typeof e != 'object') continue if (err = this._checkKey(e.type, 'type', this._isBuffer)) return callback(err) if (err = this._checkKey(e.key, 'key', this._isBuffer)) return callback(err) } if (typeof this._batch == 'function') return this._batch(array, options, callback) process.nextTick(callback) } //TODO: remove from here, not a necessary primitive AbstractLevelDOWN.prototype.approximateSize = function (start, end, callback) { if ( start == null || end == null || typeof start == 'function' || typeof end == 'function') { throw new Error('approximateSize() requires valid `start`, `end` and `callback` arguments') } if (typeof callback != 'function') throw new Error('approximateSize() requires a callback argument') if (!this._isBuffer(start)) start = String(start) if (!this._isBuffer(end)) end = String(end) if (typeof this._approximateSize == 'function') return this._approximateSize(start, end, callback) process.nextTick(function () { callback(null, 0) }) } AbstractLevelDOWN.prototype._setupIteratorOptions = function (options) { var self = this options = xtend(options) ;[ 'start', 'end', 'gt', 'gte', 'lt', 'lte' ].forEach(function (o) { if (options[o] && self._isBuffer(options[o]) && options[o].length === 0) delete options[o] }) options.reverse = !!options.reverse options.keys = options.keys != false options.values = options.values != false options.limit = 'limit' in options ? options.limit : -1 options.keyAsBuffer = options.keyAsBuffer != false options.valueAsBuffer = options.valueAsBuffer != false return options } AbstractLevelDOWN.prototype.iterator = function (options) { if (typeof options != 'object') options = {} options = this._setupIteratorOptions(options) if (typeof this._iterator == 'function') return this._iterator(options) return new AbstractIterator(this) } AbstractLevelDOWN.prototype._chainedBatch = function () { return new AbstractChainedBatch(this) } AbstractLevelDOWN.prototype._isBuffer = function (obj) { return Buffer.isBuffer(obj) } AbstractLevelDOWN.prototype._checkKey = function (obj, type) { if (obj === null || obj === undefined) return new Error(type + ' cannot be `null` or `undefined`') if (this._isBuffer(obj)) { if (obj.length === 0) return new Error(type + ' cannot be an empty Buffer') } else if (String(obj) === '') return new Error(type + ' cannot be an empty String') } module.exports = AbstractLevelDOWN }).call(this,{"isBuffer":require("../../../is-buffer/index.js")},require('_process')) },{"../../../is-buffer/index.js":170,"./abstract-chained-batch":203,"./abstract-iterator":204,"_process":295,"xtend":208}],206:[function(require,module,exports){ arguments[4][188][0].apply(exports,arguments) },{"./abstract-chained-batch":203,"./abstract-iterator":204,"./abstract-leveldown":205,"./is-leveldown":207,"dup":188}],207:[function(require,module,exports){ arguments[4][189][0].apply(exports,arguments) },{"./abstract-leveldown":205,"dup":189}],208:[function(require,module,exports){ arguments[4][177][0].apply(exports,arguments) },{"dup":177}],209:[function(require,module,exports){ /* Copyright (c) 2012-2014 LevelUP contributors * See list at * MIT License * */ var encodings = require('./encodings') function getKeyEncoder (options, op) { var type = ((op && op.keyEncoding) || options.keyEncoding) || 'utf8' return encodings[type] || type } function getValueEncoder (options, op) { var type = (((op && (op.valueEncoding || op.encoding)) || options.valueEncoding || options.encoding)) || 'utf8' return encodings[type] || type } /* Encode a key. This method takes two options, because the leveldb instance has options, and this operation (a put, del, or batch) also has options that may override the leveldb's options. */ function encodeKey (key, options, op) { return getKeyEncoder(options, op).encode(key) } /* Encode a value. Takes 2 options, for the same reason as encodeKey */ function encodeValue (value, options, op) { return getValueEncoder(options, op).encode(value) } /* Decode an encoded key */ function decodeKey (key, options) { return getKeyEncoder(options).decode(key) } /* Decode an encoded value */ function decodeValue (value, options) { return getValueEncoder(options).decode(value) } /* check whether this value should be requested as a buffer (if false, then it will be a string) this allows an optimization in leveldown where leveldown retrives a string directly, and thus avoids a memory copy. */ function isValueAsBuffer (options, op) { return getValueEncoder(options, op).buffer } /* check whether a given key should be requested as a buffer. */ function isKeyAsBuffer (options, op) { return getKeyEncoder(options, op).buffer } module.exports = { encodeKey : encodeKey , encodeValue : encodeValue , isValueAsBuffer : isValueAsBuffer , isKeyAsBuffer : isKeyAsBuffer , decodeValue : decodeValue , decodeKey : decodeKey } },{"./encodings":210}],210:[function(require,module,exports){ (function (Buffer){ /* Copyright (c) 2012-2014 LevelUP contributors * See list at * MIT License * */ var encodingNames = [ 'hex' , 'utf8' , 'utf-8' , 'ascii' , 'binary' , 'base64' , 'ucs2' , 'ucs-2' , 'utf16le' , 'utf-16le' ] module.exports = (function () { function isBinary (data) { return data === undefined || data === null || Buffer.isBuffer(data) } var encodings = {} encodings.utf8 = encodings['utf-8'] = { encode : function (data) { return isBinary(data) ? data : String(data) } , decode : function (data) { return data } , buffer : false , type : 'utf8' } encodings.json = { encode : JSON.stringify , decode : JSON.parse , buffer : false , type : 'json' } encodings.binary = { encode : function (data) { return isBinary(data) ? data : new Buffer(data) } , decode : function (data) { return data } , buffer : true , type : 'binary' } encodingNames.forEach(function (type) { if (encodings[type]) return encodings[type] = { encode : function (data) { return isBinary(data) ? data : new Buffer(data, type) } , decode : function (buffer) { return buffer.toString(type) } , buffer : true , type : type // useful for debugging purposes } }) return encodings })() }).call(this,require("buffer").Buffer) },{"buffer":61}],211:[function(require,module,exports){ /* Copyright (c) 2012-2014 LevelUP contributors * See list at * MIT License * */ var createError = require('errno').create , LevelUPError = createError('LevelUPError') , NotFoundError = createError('NotFoundError', LevelUPError) NotFoundError.prototype.notFound = true NotFoundError.prototype.status = 404 module.exports = { LevelUPError : LevelUPError , InitializationError : createError('InitializationError', LevelUPError) , OpenError : createError('OpenError', LevelUPError) , ReadError : createError('ReadError', LevelUPError) , WriteError : createError('WriteError', LevelUPError) , NotFoundError : NotFoundError , EncodingError : createError('EncodingError', LevelUPError) } },{"errno":143}],212:[function(require,module,exports){ /* Copyright (c) 2012-2014 LevelUP contributors * See list at * MIT License */ // NOTE: we are fixed to readable-stream@1.0.x for now // for pure Streams2 across Node versions var Readable = require('readable-stream').Readable , inherits = require('util').inherits , extend = require('xtend') , EncodingError = require('./errors').EncodingError , util = require('./util') function ReadStream (options, makeData) { if (!(this instanceof ReadStream)) return new ReadStream(options, makeData) Readable.call(this, { objectMode: true, highWaterMark: options.highWaterMark }) // purely to keep `db` around until we're done so it's not GCed if the user doesn't keep a ref this._waiting = false this._options = options this._makeData = makeData } inherits(ReadStream, Readable) ReadStream.prototype.setIterator = function (it) { var self = this this._iterator = it if(this._destroyed) return it.end(function () {}) if(this._waiting) { this._waiting = false return this._read() } return this } ReadStream.prototype._read = function read () { var self = this if (self._destroyed) return if(!self._iterator) return this._waiting = true self._iterator.next(function(err, key, value) { if (err || (key === undefined && value === undefined)) { if (!err && !self._destroyed) self.push(null) return self._cleanup(err) } try { value = self._makeData(key, value) } catch (e) { return self._cleanup(new EncodingError(e)) } if (!self._destroyed) self.push(value) }) } ReadStream.prototype._cleanup = function (err) { if (this._destroyed) return this._destroyed = true var self = this if (err) self.emit('error', err) if (self._iterator) { self._iterator.end(function () { self._iterator = null self.emit('close') }) } else { self.emit('close') } } ReadStream.prototype.destroy = function () { this._cleanup() } ReadStream.prototype.toString = function () { return 'LevelUP.ReadStream' } module.exports = ReadStream },{"./errors":211,"./util":213,"readable-stream":219,"util":636,"xtend":220}],213:[function(require,module,exports){ /* Copyright (c) 2012-2014 LevelUP contributors * See list at * MIT License * */ var extend = require('xtend') , LevelUPError = require('./errors').LevelUPError , encodings = require('./encodings') , defaultOptions = { createIfMissing : true , errorIfExists : false , keyEncoding : 'utf8' , valueEncoding : 'utf8' , compression : true } , leveldown , encodingOpts = (function () { var eo = {} for(var e in encodings) eo[e] = {valueEncoding: encodings[e]} return eo }()) function copy (srcdb, dstdb, callback) { srcdb.readStream() .pipe(dstdb.writeStream()) .on('close', callback ? callback : function () {}) .on('error', callback ? callback : function (err) { throw err }) } function getOptions (levelup, options) { var s = typeof options == 'string' // just an encoding if (!s && options && options.encoding && !options.valueEncoding) options.valueEncoding = options.encoding return extend( (levelup && levelup.options) || {} , s ? encodingOpts[options] || encodingOpts[defaultOptions.valueEncoding] : options ) } function getLevelDOWN () { if (leveldown) return leveldown var requiredVersion = require('../package.json').devDependencies.leveldown , missingLevelDOWNError = 'Could not locate LevelDOWN, try `npm install leveldown`' , leveldownVersion try { leveldownVersion = require('leveldown/package').version } catch (e) { throw new LevelUPError(missingLevelDOWNError) } if (!require('semver').satisfies(leveldownVersion, requiredVersion)) { throw new LevelUPError( 'Installed version of LevelDOWN (' + leveldownVersion + ') does not match required version (' + requiredVersion + ')' ) } try { return leveldown = require('leveldown') } catch (e) { throw new LevelUPError(missingLevelDOWNError) } } function dispatchError (levelup, error, callback) { return typeof callback == 'function' ? callback(error) : levelup.emit('error', error) } function isDefined (v) { return typeof v !== 'undefined' } module.exports = { defaultOptions : defaultOptions , copy : copy , getOptions : getOptions , getLevelDOWN : getLevelDOWN , dispatchError : dispatchError , isDefined : isDefined } },{"../package.json":221,"./encodings":210,"./errors":211,"leveldown":33,"leveldown/package":33,"semver":33,"xtend":220}],214:[function(require,module,exports){ (function (process){ // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. // a duplex stream is just a stream that is both readable and writable. // Since JS doesn't have multiple prototypal inheritance, this class // prototypally inherits from Readable, and then parasitically from // Writable. module.exports = Duplex; /**/ var objectKeys = Object.keys || function (obj) { var keys = []; for (var key in obj) keys.push(key); return keys; } /**/ /**/ var util = require('core-util-is'); util.inherits = require('inherits'); /**/ var Readable = require('./_stream_readable'); var Writable = require('./_stream_writable'); util.inherits(Duplex, Readable); forEach(objectKeys(Writable.prototype), function(method) { if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method]; }); function Duplex(options) { if (!(this instanceof Duplex)) return new Duplex(options); Readable.call(this, options); Writable.call(this, options); if (options && options.readable === false) this.readable = false; if (options && options.writable === false) this.writable = false; this.allowHalfOpen = true; if (options && options.allowHalfOpen === false) this.allowHalfOpen = false; this.once('end', onend); } // the no-half-open enforcer function onend() { // if we allow half-open state, or if the writable side ended, // then we're ok. if (this.allowHalfOpen || this._writableState.ended) return; // no more data can be written. // But allow more writes to happen in this tick. process.nextTick(this.end.bind(this)); } function forEach (xs, f) { for (var i = 0, l = xs.length; i < l; i++) { f(xs[i], i); } } }).call(this,require('_process')) },{"./_stream_readable":216,"./_stream_writable":218,"_process":295,"core-util-is":104,"inherits":167}],215:[function(require,module,exports){ // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. // a passthrough stream. // basically just the most minimal sort of Transform stream. // Every written chunk gets output as-is. module.exports = PassThrough; var Transform = require('./_stream_transform'); /**/ var util = require('core-util-is'); util.inherits = require('inherits'); /**/ util.inherits(PassThrough, Transform); function PassThrough(options) { if (!(this instanceof PassThrough)) return new PassThrough(options); Transform.call(this, options); } PassThrough.prototype._transform = function(chunk, encoding, cb) { cb(null, chunk); }; },{"./_stream_transform":217,"core-util-is":104,"inherits":167}],216:[function(require,module,exports){ (function (process){ // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. module.exports = Readable; /**/ var isArray = require('isarray'); /**/ /**/ var Buffer = require('buffer').Buffer; /**/ Readable.ReadableState = ReadableState; var EE = require('events').EventEmitter; /**/ if (!EE.listenerCount) EE.listenerCount = function(emitter, type) { return emitter.listeners(type).length; }; /**/ var Stream = require('stream'); /**/ var util = require('core-util-is'); util.inherits = require('inherits'); /**/ var StringDecoder; util.inherits(Readable, Stream); function ReadableState(options, stream) { options = options || {}; // the point at which it stops calling _read() to fill the buffer // Note: 0 is a valid value, means "don't call _read preemptively ever" var hwm = options.highWaterMark; this.highWaterMark = (hwm || hwm === 0) ? hwm : 16 * 1024; // cast to ints. this.highWaterMark = ~~this.highWaterMark; this.buffer = []; this.length = 0; this.pipes = null; this.pipesCount = 0; this.flowing = false; this.ended = false; this.endEmitted = false; this.reading = false; // In streams that never have any data, and do push(null) right away, // the consumer can miss the 'end' event if they do some I/O before // consuming the stream. So, we don't emit('end') until some reading // happens. this.calledRead = false; // a flag to be able to tell if the onwrite cb is called immediately, // or on a later tick. We set this to true at first, becuase any // actions that shouldn't happen until "later" should generally also // not happen before the first write call. this.sync = true; // whenever we return null, then we set a flag to say // that we're awaiting a 'readable' event emission. this.needReadable = false; this.emittedReadable = false; this.readableListening = false; // object stream flag. Used to make read(n) ignore n and to // make all the buffer merging and length checks go away this.objectMode = !!options.objectMode; // Crypto is kind of old and crusty. Historically, its default string // encoding is 'binary' so we have to make this configurable. // Everything else in the universe uses 'utf8', though. this.defaultEncoding = options.defaultEncoding || 'utf8'; // when piping, we only care about 'readable' events that happen // after read()ing all the bytes and not getting any pushback. this.ranOut = false; // the number of writers that are awaiting a drain event in .pipe()s this.awaitDrain = 0; // if true, a maybeReadMore has been scheduled this.readingMore = false; this.decoder = null; this.encoding = null; if (options.encoding) { if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder; this.decoder = new StringDecoder(options.encoding); this.encoding = options.encoding; } } function Readable(options) { if (!(this instanceof Readable)) return new Readable(options); this._readableState = new ReadableState(options, this); // legacy this.readable = true; Stream.call(this); } // Manually shove something into the read() buffer. // This returns true if the highWaterMark has not been hit yet, // similar to how Writable.write() returns true if you should // write() some more. Readable.prototype.push = function(chunk, encoding) { var state = this._readableState; if (typeof chunk === 'string' && !state.objectMode) { encoding = encoding || state.defaultEncoding; if (encoding !== state.encoding) { chunk = new Buffer(chunk, encoding); encoding = ''; } } return readableAddChunk(this, state, chunk, encoding, false); }; // Unshift should *always* be something directly out of read() Readable.prototype.unshift = function(chunk) { var state = this._readableState; return readableAddChunk(this, state, chunk, '', true); }; function readableAddChunk(stream, state, chunk, encoding, addToFront) { var er = chunkInvalid(state, chunk); if (er) { stream.emit('error', er); } else if (chunk === null || chunk === undefined) { state.reading = false; if (!state.ended) onEofChunk(stream, state); } else if (state.objectMode || chunk && chunk.length > 0) { if (state.ended && !addToFront) { var e = new Error('stream.push() after EOF'); stream.emit('error', e); } else if (state.endEmitted && addToFront) { var e = new Error('stream.unshift() after end event'); stream.emit('error', e); } else { if (state.decoder && !addToFront && !encoding) chunk = state.decoder.write(chunk); // update the buffer info. state.length += state.objectMode ? 1 : chunk.length; if (addToFront) { state.buffer.unshift(chunk); } else { state.reading = false; state.buffer.push(chunk); } if (state.needReadable) emitReadable(stream); maybeReadMore(stream, state); } } else if (!addToFront) { state.reading = false; } return needMoreData(state); } // if it's past the high water mark, we can push in some more. // Also, if we have no data yet, we can stand some // more bytes. This is to work around cases where hwm=0, // such as the repl. Also, if the push() triggered a // readable event, and the user called read(largeNumber) such that // needReadable was set, then we ought to push more, so that another // 'readable' event will be triggered. function needMoreData(state) { return !state.ended && (state.needReadable || state.length < state.highWaterMark || state.length === 0); } // backwards compatibility. Readable.prototype.setEncoding = function(enc) { if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder; this._readableState.decoder = new StringDecoder(enc); this._readableState.encoding = enc; }; // Don't raise the hwm > 128MB var MAX_HWM = 0x800000; function roundUpToNextPowerOf2(n) { if (n >= MAX_HWM) { n = MAX_HWM; } else { // Get the next highest power of 2 n--; for (var p = 1; p < 32; p <<= 1) n |= n >> p; n++; } return n; } function howMuchToRead(n, state) { if (state.length === 0 && state.ended) return 0; if (state.objectMode) return n === 0 ? 0 : 1; if (n === null || isNaN(n)) { // only flow one buffer at a time if (state.flowing && state.buffer.length) return state.buffer[0].length; else return state.length; } if (n <= 0) return 0; // If we're asking for more than the target buffer level, // then raise the water mark. Bump up to the next highest // power of 2, to prevent increasing it excessively in tiny // amounts. if (n > state.highWaterMark) state.highWaterMark = roundUpToNextPowerOf2(n); // don't have that much. return null, unless we've ended. if (n > state.length) { if (!state.ended) { state.needReadable = true; return 0; } else return state.length; } return n; } // you can override either this method, or the async _read(n) below. Readable.prototype.read = function(n) { var state = this._readableState; state.calledRead = true; var nOrig = n; var ret; if (typeof n !== 'number' || n > 0) state.emittedReadable = false; // if we're doing read(0) to trigger a readable event, but we // already have a bunch of data in the buffer, then just trigger // the 'readable' event and move on. if (n === 0 && state.needReadable && (state.length >= state.highWaterMark || state.ended)) { emitReadable(this); return null; } n = howMuchToRead(n, state); // if we've ended, and we're now clear, then finish it up. if (n === 0 && state.ended) { ret = null; // In cases where the decoder did not receive enough data // to produce a full chunk, then immediately received an // EOF, state.buffer will contain [, ]. // howMuchToRead will see this and coerce the amount to // read to zero (because it's looking at the length of the // first in state.buffer), and we'll end up here. // // This can only happen via state.decoder -- no other venue // exists for pushing a zero-length chunk into state.buffer // and triggering this behavior. In this case, we return our // remaining data and end the stream, if appropriate. if (state.length > 0 && state.decoder) { ret = fromList(n, state); state.length -= ret.length; } if (state.length === 0) endReadable(this); return ret; } // All the actual chunk generation logic needs to be // *below* the call to _read. The reason is that in certain // synthetic stream cases, such as passthrough streams, _read // may be a completely synchronous operation which may change // the state of the read buffer, providing enough data when // before there was *not* enough. // // So, the steps are: // 1. Figure out what the state of things will be after we do // a read from the buffer. // // 2. If that resulting state will trigger a _read, then call _read. // Note that this may be asynchronous, or synchronous. Yes, it is // deeply ugly to write APIs this way, but that still doesn't mean // that the Readable class should behave improperly, as streams are // designed to be sync/async agnostic. // Take note if the _read call is sync or async (ie, if the read call // has returned yet), so that we know whether or not it's safe to emit // 'readable' etc. // // 3. Actually pull the requested chunks out of the buffer and return. // if we need a readable event, then we need to do some reading. var doRead = state.needReadable; // if we currently have less than the highWaterMark, then also read some if (state.length - n <= state.highWaterMark) doRead = true; // however, if we've ended, then there's no point, and if we're already // reading, then it's unnecessary. if (state.ended || state.reading) doRead = false; if (doRead) { state.reading = true; state.sync = true; // if the length is currently zero, then we *need* a readable event. if (state.length === 0) state.needReadable = true; // call internal read method this._read(state.highWaterMark); state.sync = false; } // If _read called its callback synchronously, then `reading` // will be false, and we need to re-evaluate how much data we // can return to the user. if (doRead && !state.reading) n = howMuchToRead(nOrig, state); if (n > 0) ret = fromList(n, state); else ret = null; if (ret === null) { state.needReadable = true; n = 0; } state.length -= n; // If we have nothing in the buffer, then we want to know // as soon as we *do* get something into the buffer. if (state.length === 0 && !state.ended) state.needReadable = true; // If we happened to read() exactly the remaining amount in the // buffer, and the EOF has been seen at this point, then make sure // that we emit 'end' on the very next tick. if (state.ended && !state.endEmitted && state.length === 0) endReadable(this); return ret; }; function chunkInvalid(state, chunk) { var er = null; if (!Buffer.isBuffer(chunk) && 'string' !== typeof chunk && chunk !== null && chunk !== undefined && !state.objectMode) { er = new TypeError('Invalid non-string/buffer chunk'); } return er; } function onEofChunk(stream, state) { if (state.decoder && !state.ended) { var chunk = state.decoder.end(); if (chunk && chunk.length) { state.buffer.push(chunk); state.length += state.objectMode ? 1 : chunk.length; } } state.ended = true; // if we've ended and we have some data left, then emit // 'readable' now to make sure it gets picked up. if (state.length > 0) emitReadable(stream); else endReadable(stream); } // Don't emit readable right away in sync mode, because this can trigger // another read() call => stack overflow. This way, it might trigger // a nextTick recursion warning, but that's not so bad. function emitReadable(stream) { var state = stream._readableState; state.needReadable = false; if (state.emittedReadable) return; state.emittedReadable = true; if (state.sync) process.nextTick(function() { emitReadable_(stream); }); else emitReadable_(stream); } function emitReadable_(stream) { stream.emit('readable'); } // at this point, the user has presumably seen the 'readable' event, // and called read() to consume some data. that may have triggered // in turn another _read(n) call, in which case reading = true if // it's in progress. // However, if we're not ended, or reading, and the length < hwm, // then go ahead and try to read some more preemptively. function maybeReadMore(stream, state) { if (!state.readingMore) { state.readingMore = true; process.nextTick(function() { maybeReadMore_(stream, state); }); } } function maybeReadMore_(stream, state) { var len = state.length; while (!state.reading && !state.flowing && !state.ended && state.length < state.highWaterMark) { stream.read(0); if (len === state.length) // didn't get any data, stop spinning. break; else len = state.length; } state.readingMore = false; } // abstract method. to be overridden in specific implementation classes. // call cb(er, data) where data is <= n in length. // for virtual (non-string, non-buffer) streams, "length" is somewhat // arbitrary, and perhaps not very meaningful. Readable.prototype._read = function(n) { this.emit('error', new Error('not implemented')); }; Readable.prototype.pipe = function(dest, pipeOpts) { var src = this; var state = this._readableState; switch (state.pipesCount) { case 0: state.pipes = dest; break; case 1: state.pipes = [state.pipes, dest]; break; default: state.pipes.push(dest); break; } state.pipesCount += 1; var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr; var endFn = doEnd ? onend : cleanup; if (state.endEmitted) process.nextTick(endFn); else src.once('end', endFn); dest.on('unpipe', onunpipe); function onunpipe(readable) { if (readable !== src) return; cleanup(); } function onend() { dest.end(); } // when the dest drains, it reduces the awaitDrain counter // on the source. This would be more elegant with a .once() // handler in flow(), but adding and removing repeatedly is // too slow. var ondrain = pipeOnDrain(src); dest.on('drain', ondrain); function cleanup() { // cleanup event handlers once the pipe is broken dest.removeListener('close', onclose); dest.removeListener('finish', onfinish); dest.removeListener('drain', ondrain); dest.removeListener('error', onerror); dest.removeListener('unpipe', onunpipe); src.removeListener('end', onend); src.removeListener('end', cleanup); // if the reader is waiting for a drain event from this // specific writer, then it would cause it to never start // flowing again. // So, if this is awaiting a drain, then we just call it now. // If we don't know, then assume that we are waiting for one. if (!dest._writableState || dest._writableState.needDrain) ondrain(); } // if the dest has an error, then stop piping into it. // however, don't suppress the throwing behavior for this. function onerror(er) { unpipe(); dest.removeListener('error', onerror); if (EE.listenerCount(dest, 'error') === 0) dest.emit('error', er); } // This is a brutally ugly hack to make sure that our error handler // is attached before any userland ones. NEVER DO THIS. if (!dest._events || !dest._events.error) dest.on('error', onerror); else if (isArray(dest._events.error)) dest._events.error.unshift(onerror); else dest._events.error = [onerror, dest._events.error]; // Both close and finish should trigger unpipe, but only once. function onclose() { dest.removeListener('finish', onfinish); unpipe(); } dest.once('close', onclose); function onfinish() { dest.removeListener('close', onclose); unpipe(); } dest.once('finish', onfinish); function unpipe() { src.unpipe(dest); } // tell the dest that it's being piped to dest.emit('pipe', src); // start the flow if it hasn't been started already. if (!state.flowing) { // the handler that waits for readable events after all // the data gets sucked out in flow. // This would be easier to follow with a .once() handler // in flow(), but that is too slow. this.on('readable', pipeOnReadable); state.flowing = true; process.nextTick(function() { flow(src); }); } return dest; }; function pipeOnDrain(src) { return function() { var dest = this; var state = src._readableState; state.awaitDrain--; if (state.awaitDrain === 0) flow(src); }; } function flow(src) { var state = src._readableState; var chunk; state.awaitDrain = 0; function write(dest, i, list) { var written = dest.write(chunk); if (false === written) { state.awaitDrain++; } } while (state.pipesCount && null !== (chunk = src.read())) { if (state.pipesCount === 1) write(state.pipes, 0, null); else forEach(state.pipes, write); src.emit('data', chunk); // if anyone needs a drain, then we have to wait for that. if (state.awaitDrain > 0) return; } // if every destination was unpiped, either before entering this // function, or in the while loop, then stop flowing. // // NB: This is a pretty rare edge case. if (state.pipesCount === 0) { state.flowing = false; // if there were data event listeners added, then switch to old mode. if (EE.listenerCount(src, 'data') > 0) emitDataEvents(src); return; } // at this point, no one needed a drain, so we just ran out of data // on the next readable event, start it over again. state.ranOut = true; } function pipeOnReadable() { if (this._readableState.ranOut) { this._readableState.ranOut = false; flow(this); } } Readable.prototype.unpipe = function(dest) { var state = this._readableState; // if we're not piping anywhere, then do nothing. if (state.pipesCount === 0) return this; // just one destination. most common case. if (state.pipesCount === 1) { // passed in one, but it's not the right one. if (dest && dest !== state.pipes) return this; if (!dest) dest = state.pipes; // got a match. state.pipes = null; state.pipesCount = 0; this.removeListener('readable', pipeOnReadable); state.flowing = false; if (dest) dest.emit('unpipe', this); return this; } // slow case. multiple pipe destinations. if (!dest) { // remove all. var dests = state.pipes; var len = state.pipesCount; state.pipes = null; state.pipesCount = 0; this.removeListener('readable', pipeOnReadable); state.flowing = false; for (var i = 0; i < len; i++) dests[i].emit('unpipe', this); return this; } // try to find the right one. var i = indexOf(state.pipes, dest); if (i === -1) return this; state.pipes.splice(i, 1); state.pipesCount -= 1; if (state.pipesCount === 1) state.pipes = state.pipes[0]; dest.emit('unpipe', this); return this; }; // set up data events if they are asked for // Ensure readable listeners eventually get something Readable.prototype.on = function(ev, fn) { var res = Stream.prototype.on.call(this, ev, fn); if (ev === 'data' && !this._readableState.flowing) emitDataEvents(this); if (ev === 'readable' && this.readable) { var state = this._readableState; if (!state.readableListening) { state.readableListening = true; state.emittedReadable = false; state.needReadable = true; if (!state.reading) { this.read(0); } else if (state.length) { emitReadable(this, state); } } } return res; }; Readable.prototype.addListener = Readable.prototype.on; // pause() and resume() are remnants of the legacy readable stream API // If the user uses them, then switch into old mode. Readable.prototype.resume = function() { emitDataEvents(this); this.read(0); this.emit('resume'); }; Readable.prototype.pause = function() { emitDataEvents(this, true); this.emit('pause'); }; function emitDataEvents(stream, startPaused) { var state = stream._readableState; if (state.flowing) { // https://github.com/isaacs/readable-stream/issues/16 throw new Error('Cannot switch to old mode now.'); } var paused = startPaused || false; var readable = false; // convert to an old-style stream. stream.readable = true; stream.pipe = Stream.prototype.pipe; stream.on = stream.addListener = Stream.prototype.on; stream.on('readable', function() { readable = true; var c; while (!paused && (null !== (c = stream.read()))) stream.emit('data', c); if (c === null) { readable = false; stream._readableState.needReadable = true; } }); stream.pause = function() { paused = true; this.emit('pause'); }; stream.resume = function() { paused = false; if (readable) process.nextTick(function() { stream.emit('readable'); }); else this.read(0); this.emit('resume'); }; // now make it start, just in case it hadn't already. stream.emit('readable'); } // wrap an old-style stream as the async data source. // This is *not* part of the readable stream interface. // It is an ugly unfortunate mess of history. Readable.prototype.wrap = function(stream) { var state = this._readableState; var paused = false; var self = this; stream.on('end', function() { if (state.decoder && !state.ended) { var chunk = state.decoder.end(); if (chunk && chunk.length) self.push(chunk); } self.push(null); }); stream.on('data', function(chunk) { if (state.decoder) chunk = state.decoder.write(chunk); // don't skip over falsy values in objectMode //if (state.objectMode && util.isNullOrUndefined(chunk)) if (state.objectMode && (chunk === null || chunk === undefined)) return; else if (!state.objectMode && (!chunk || !chunk.length)) return; var ret = self.push(chunk); if (!ret) { paused = true; stream.pause(); } }); // proxy all the other methods. // important when wrapping filters and duplexes. for (var i in stream) { if (typeof stream[i] === 'function' && typeof this[i] === 'undefined') { this[i] = function(method) { return function() { return stream[method].apply(stream, arguments); }}(i); } } // proxy certain important events. var events = ['error', 'close', 'destroy', 'pause', 'resume']; forEach(events, function(ev) { stream.on(ev, self.emit.bind(self, ev)); }); // when we try to consume some more bytes, simply unpause the // underlying stream. self._read = function(n) { if (paused) { paused = false; stream.resume(); } }; return self; }; // exposed for testing purposes only. Readable._fromList = fromList; // Pluck off n bytes from an array of buffers. // Length is the combined lengths of all the buffers in the list. function fromList(n, state) { var list = state.buffer; var length = state.length; var stringMode = !!state.decoder; var objectMode = !!state.objectMode; var ret; // nothing in the list, definitely empty. if (list.length === 0) return null; if (length === 0) ret = null; else if (objectMode) ret = list.shift(); else if (!n || n >= length) { // read it all, truncate the array. if (stringMode) ret = list.join(''); else ret = Buffer.concat(list, length); list.length = 0; } else { // read just some of it. if (n < list[0].length) { // just take a part of the first list item. // slice is the same for buffers and strings. var buf = list[0]; ret = buf.slice(0, n); list[0] = buf.slice(n); } else if (n === list[0].length) { // first list is a perfect match ret = list.shift(); } else { // complex case. // we have enough to cover it, but it spans past the first buffer. if (stringMode) ret = ''; else ret = new Buffer(n); var c = 0; for (var i = 0, l = list.length; i < l && c < n; i++) { var buf = list[0]; var cpy = Math.min(n - c, buf.length); if (stringMode) ret += buf.slice(0, cpy); else buf.copy(ret, c, 0, cpy); if (cpy < buf.length) list[0] = buf.slice(cpy); else list.shift(); c += cpy; } } } return ret; } function endReadable(stream) { var state = stream._readableState; // If we get here before consuming all the bytes, then that is a // bug in node. Should never happen. if (state.length > 0) throw new Error('endReadable called on non-empty stream'); if (!state.endEmitted && state.calledRead) { state.ended = true; process.nextTick(function() { // Check that we didn't get one last unshift. if (!state.endEmitted && state.length === 0) { state.endEmitted = true; stream.readable = false; stream.emit('end'); } }); } } function forEach (xs, f) { for (var i = 0, l = xs.length; i < l; i++) { f(xs[i], i); } } function indexOf (xs, x) { for (var i = 0, l = xs.length; i < l; i++) { if (xs[i] === x) return i; } return -1; } }).call(this,require('_process')) },{"_process":295,"buffer":61,"core-util-is":104,"events":144,"inherits":167,"isarray":172,"stream":576,"string_decoder/":616}],217:[function(require,module,exports){ // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. // a transform stream is a readable/writable stream where you do // something with the data. Sometimes it's called a "filter", // but that's not a great name for it, since that implies a thing where // some bits pass through, and others are simply ignored. (That would // be a valid example of a transform, of course.) // // While the output is causally related to the input, it's not a // necessarily symmetric or synchronous transformation. For example, // a zlib stream might take multiple plain-text writes(), and then // emit a single compressed chunk some time in the future. // // Here's how this works: // // The Transform stream has all the aspects of the readable and writable // stream classes. When you write(chunk), that calls _write(chunk,cb) // internally, and returns false if there's a lot of pending writes // buffered up. When you call read(), that calls _read(n) until // there's enough pending readable data buffered up. // // In a transform stream, the written data is placed in a buffer. When // _read(n) is called, it transforms the queued up data, calling the // buffered _write cb's as it consumes chunks. If consuming a single // written chunk would result in multiple output chunks, then the first // outputted bit calls the readcb, and subsequent chunks just go into // the read buffer, and will cause it to emit 'readable' if necessary. // // This way, back-pressure is actually determined by the reading side, // since _read has to be called to start processing a new chunk. However, // a pathological inflate type of transform can cause excessive buffering // here. For example, imagine a stream where every byte of input is // interpreted as an integer from 0-255, and then results in that many // bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in // 1kb of data being output. In this case, you could write a very small // amount of input, and end up with a very large amount of output. In // such a pathological inflating mechanism, there'd be no way to tell // the system to stop doing the transform. A single 4MB write could // cause the system to run out of memory. // // However, even in such a pathological case, only a single written chunk // would be consumed, and then the rest would wait (un-transformed) until // the results of the previous transformed chunk were consumed. module.exports = Transform; var Duplex = require('./_stream_duplex'); /**/ var util = require('core-util-is'); util.inherits = require('inherits'); /**/ util.inherits(Transform, Duplex); function TransformState(options, stream) { this.afterTransform = function(er, data) { return afterTransform(stream, er, data); }; this.needTransform = false; this.transforming = false; this.writecb = null; this.writechunk = null; } function afterTransform(stream, er, data) { var ts = stream._transformState; ts.transforming = false; var cb = ts.writecb; if (!cb) return stream.emit('error', new Error('no writecb in Transform class')); ts.writechunk = null; ts.writecb = null; if (data !== null && data !== undefined) stream.push(data); if (cb) cb(er); var rs = stream._readableState; rs.reading = false; if (rs.needReadable || rs.length < rs.highWaterMark) { stream._read(rs.highWaterMark); } } function Transform(options) { if (!(this instanceof Transform)) return new Transform(options); Duplex.call(this, options); var ts = this._transformState = new TransformState(options, this); // when the writable side finishes, then flush out anything remaining. var stream = this; // start out asking for a readable event once data is transformed. this._readableState.needReadable = true; // we have implemented the _read method, and done the other things // that Readable wants before the first _read call, so unset the // sync guard flag. this._readableState.sync = false; this.once('finish', function() { if ('function' === typeof this._flush) this._flush(function(er) { done(stream, er); }); else done(stream); }); } Transform.prototype.push = function(chunk, encoding) { this._transformState.needTransform = false; return Duplex.prototype.push.call(this, chunk, encoding); }; // This is the part where you do stuff! // override this function in implementation classes. // 'chunk' is an input chunk. // // Call `push(newChunk)` to pass along transformed output // to the readable side. You may call 'push' zero or more times. // // Call `cb(err)` when you are done with this chunk. If you pass // an error, then that'll put the hurt on the whole operation. If you // never call cb(), then you'll never get another chunk. Transform.prototype._transform = function(chunk, encoding, cb) { throw new Error('not implemented'); }; Transform.prototype._write = function(chunk, encoding, cb) { var ts = this._transformState; ts.writecb = cb; ts.writechunk = chunk; ts.writeencoding = encoding; if (!ts.transforming) { var rs = this._readableState; if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark); } }; // Doesn't matter what the args are here. // _transform does all the work. // That we got here means that the readable side wants more data. Transform.prototype._read = function(n) { var ts = this._transformState; if (ts.writechunk !== null && ts.writecb && !ts.transforming) { ts.transforming = true; this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform); } else { // mark that we need a transform, so that any data that comes in // will get processed, now that we've asked for it. ts.needTransform = true; } }; function done(stream, er) { if (er) return stream.emit('error', er); // if there's nothing in the write buffer, then that means // that nothing more will ever be provided var ws = stream._writableState; var rs = stream._readableState; var ts = stream._transformState; if (ws.length) throw new Error('calling transform done when ws.length != 0'); if (ts.transforming) throw new Error('calling transform done when still transforming'); return stream.push(null); } },{"./_stream_duplex":214,"core-util-is":104,"inherits":167}],218:[function(require,module,exports){ (function (process){ // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. // A bit simpler than readable streams. // Implement an async ._write(chunk, cb), and it'll handle all // the drain event emission and buffering. module.exports = Writable; /**/ var Buffer = require('buffer').Buffer; /**/ Writable.WritableState = WritableState; /**/ var util = require('core-util-is'); util.inherits = require('inherits'); /**/ var Stream = require('stream'); util.inherits(Writable, Stream); function WriteReq(chunk, encoding, cb) { this.chunk = chunk; this.encoding = encoding; this.callback = cb; } function WritableState(options, stream) { options = options || {}; // the point at which write() starts returning false // Note: 0 is a valid value, means that we always return false if // the entire buffer is not flushed immediately on write() var hwm = options.highWaterMark; this.highWaterMark = (hwm || hwm === 0) ? hwm : 16 * 1024; // object stream flag to indicate whether or not this stream // contains buffers or objects. this.objectMode = !!options.objectMode; // cast to ints. this.highWaterMark = ~~this.highWaterMark; this.needDrain = false; // at the start of calling end() this.ending = false; // when end() has been called, and returned this.ended = false; // when 'finish' is emitted this.finished = false; // should we decode strings into buffers before passing to _write? // this is here so that some node-core streams can optimize string // handling at a lower level. var noDecode = options.decodeStrings === false; this.decodeStrings = !noDecode; // Crypto is kind of old and crusty. Historically, its default string // encoding is 'binary' so we have to make this configurable. // Everything else in the universe uses 'utf8', though. this.defaultEncoding = options.defaultEncoding || 'utf8'; // not an actual buffer we keep track of, but a measurement // of how much we're waiting to get pushed to some underlying // socket or file. this.length = 0; // a flag to see when we're in the middle of a write. this.writing = false; // a flag to be able to tell if the onwrite cb is called immediately, // or on a later tick. We set this to true at first, becuase any // actions that shouldn't happen until "later" should generally also // not happen before the first write call. this.sync = true; // a flag to know if we're processing previously buffered items, which // may call the _write() callback in the same tick, so that we don't // end up in an overlapped onwrite situation. this.bufferProcessing = false; // the callback that's passed to _write(chunk,cb) this.onwrite = function(er) { onwrite(stream, er); }; // the callback that the user supplies to write(chunk,encoding,cb) this.writecb = null; // the amount that is being written when _write is called. this.writelen = 0; this.buffer = []; // True if the error was already emitted and should not be thrown again this.errorEmitted = false; } function Writable(options) { var Duplex = require('./_stream_duplex'); // Writable ctor is applied to Duplexes, though they're not // instanceof Writable, they're instanceof Readable. if (!(this instanceof Writable) && !(this instanceof Duplex)) return new Writable(options); this._writableState = new WritableState(options, this); // legacy. this.writable = true; Stream.call(this); } // Otherwise people can pipe Writable streams, which is just wrong. Writable.prototype.pipe = function() { this.emit('error', new Error('Cannot pipe. Not readable.')); }; function writeAfterEnd(stream, state, cb) { var er = new Error('write after end'); // TODO: defer error events consistently everywhere, not just the cb stream.emit('error', er); process.nextTick(function() { cb(er); }); } // If we get something that is not a buffer, string, null, or undefined, // and we're not in objectMode, then that's an error. // Otherwise stream chunks are all considered to be of length=1, and the // watermarks determine how many objects to keep in the buffer, rather than // how many bytes or characters. function validChunk(stream, state, chunk, cb) { var valid = true; if (!Buffer.isBuffer(chunk) && 'string' !== typeof chunk && chunk !== null && chunk !== undefined && !state.objectMode) { var er = new TypeError('Invalid non-string/buffer chunk'); stream.emit('error', er); process.nextTick(function() { cb(er); }); valid = false; } return valid; } Writable.prototype.write = function(chunk, encoding, cb) { var state = this._writableState; var ret = false; if (typeof encoding === 'function') { cb = encoding; encoding = null; } if (Buffer.isBuffer(chunk)) encoding = 'buffer'; else if (!encoding) encoding = state.defaultEncoding; if (typeof cb !== 'function') cb = function() {}; if (state.ended) writeAfterEnd(this, state, cb); else if (validChunk(this, state, chunk, cb)) ret = writeOrBuffer(this, state, chunk, encoding, cb); return ret; }; function decodeChunk(state, chunk, encoding) { if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') { chunk = new Buffer(chunk, encoding); } return chunk; } // if we're already writing something, then just put this // in the queue, and wait our turn. Otherwise, call _write // If we return false, then we need a drain event, so set that flag. function writeOrBuffer(stream, state, chunk, encoding, cb) { chunk = decodeChunk(state, chunk, encoding); if (Buffer.isBuffer(chunk)) encoding = 'buffer'; var len = state.objectMode ? 1 : chunk.length; state.length += len; var ret = state.length < state.highWaterMark; // we must ensure that previous needDrain will not be reset to false. if (!ret) state.needDrain = true; if (state.writing) state.buffer.push(new WriteReq(chunk, encoding, cb)); else doWrite(stream, state, len, chunk, encoding, cb); return ret; } function doWrite(stream, state, len, chunk, encoding, cb) { state.writelen = len; state.writecb = cb; state.writing = true; state.sync = true; stream._write(chunk, encoding, state.onwrite); state.sync = false; } function onwriteError(stream, state, sync, er, cb) { if (sync) process.nextTick(function() { cb(er); }); else cb(er); stream._writableState.errorEmitted = true; stream.emit('error', er); } function onwriteStateUpdate(state) { state.writing = false; state.writecb = null; state.length -= state.writelen; state.writelen = 0; } function onwrite(stream, er) { var state = stream._writableState; var sync = state.sync; var cb = state.writecb; onwriteStateUpdate(state); if (er) onwriteError(stream, state, sync, er, cb); else { // Check if we're actually ready to finish, but don't emit yet var finished = needFinish(stream, state); if (!finished && !state.bufferProcessing && state.buffer.length) clearBuffer(stream, state); if (sync) { process.nextTick(function() { afterWrite(stream, state, finished, cb); }); } else { afterWrite(stream, state, finished, cb); } } } function afterWrite(stream, state, finished, cb) { if (!finished) onwriteDrain(stream, state); cb(); if (finished) finishMaybe(stream, state); } // Must force callback to be called on nextTick, so that we don't // emit 'drain' before the write() consumer gets the 'false' return // value, and has a chance to attach a 'drain' listener. function onwriteDrain(stream, state) { if (state.length === 0 && state.needDrain) { state.needDrain = false; stream.emit('drain'); } } // if there's something in the buffer waiting, then process it function clearBuffer(stream, state) { state.bufferProcessing = true; for (var c = 0; c < state.buffer.length; c++) { var entry = state.buffer[c]; var chunk = entry.chunk; var encoding = entry.encoding; var cb = entry.callback; var len = state.objectMode ? 1 : chunk.length; doWrite(stream, state, len, chunk, encoding, cb); // if we didn't call the onwrite immediately, then // it means that we need to wait until it does. // also, that means that the chunk and cb are currently // being processed, so move the buffer counter past them. if (state.writing) { c++; break; } } state.bufferProcessing = false; if (c < state.buffer.length) state.buffer = state.buffer.slice(c); else state.buffer.length = 0; } Writable.prototype._write = function(chunk, encoding, cb) { cb(new Error('not implemented')); }; Writable.prototype.end = function(chunk, encoding, cb) { var state = this._writableState; if (typeof chunk === 'function') { cb = chunk; chunk = null; encoding = null; } else if (typeof encoding === 'function') { cb = encoding; encoding = null; } if (typeof chunk !== 'undefined' && chunk !== null) this.write(chunk, encoding); // ignore unnecessary end() calls. if (!state.ending && !state.finished) endWritable(this, state, cb); }; function needFinish(stream, state) { return (state.ending && state.length === 0 && !state.finished && !state.writing); } function finishMaybe(stream, state) { var need = needFinish(stream, state); if (need) { state.finished = true; stream.emit('finish'); } return need; } function endWritable(stream, state, cb) { state.ending = true; finishMaybe(stream, state); if (cb) { if (state.finished) process.nextTick(cb); else stream.once('finish', cb); } state.ended = true; } }).call(this,require('_process')) },{"./_stream_duplex":214,"_process":295,"buffer":61,"core-util-is":104,"inherits":167,"stream":576}],219:[function(require,module,exports){ (function (process){ var Stream = require('stream'); // hack to fix a circular dependency issue when used with browserify exports = module.exports = require('./lib/_stream_readable.js'); exports.Stream = Stream; exports.Readable = exports; exports.Writable = require('./lib/_stream_writable.js'); exports.Duplex = require('./lib/_stream_duplex.js'); exports.Transform = require('./lib/_stream_transform.js'); exports.PassThrough = require('./lib/_stream_passthrough.js'); if (!process.browser && process.env.READABLE_STREAM === 'disable') { module.exports = require('stream'); } }).call(this,require('_process')) },{"./lib/_stream_duplex.js":214,"./lib/_stream_passthrough.js":215,"./lib/_stream_readable.js":216,"./lib/_stream_transform.js":217,"./lib/_stream_writable.js":218,"_process":295,"stream":576}],220:[function(require,module,exports){ module.exports = extend function extend() { var target = {} for (var i = 0; i < arguments.length; i++) { var source = arguments[i] for (var key in source) { if (source.hasOwnProperty(key)) { target[key] = source[key] } } } return target } },{}],221:[function(require,module,exports){ module.exports={ "_args": [ [ "levelup@~0.19.0", "/Users/joran/Documents/development/patchdeck/node_modules/level-sublevel" ] ], "_from": "levelup@>=0.19.0 <0.20.0", "_id": "levelup@0.19.1", "_inCache": true, "_installable": true, "_location": "/levelup", "_nodeVersion": "5.5.0", "_npmUser": { "email": "ralphtheninja@riseup.net", "name": "ralphtheninja" }, "_npmVersion": "3.3.12", "_phantomChildren": { "core-util-is": "1.0.2", "inherits": "2.0.1", "isarray": "0.0.1", "string_decoder": "0.10.31" }, "_requested": { "name": "levelup", "raw": "levelup@~0.19.0", "rawSpec": "~0.19.0", "scope": null, "spec": ">=0.19.0 <0.20.0", "type": "range" }, "_requiredBy": [ "/level-sublevel", "/secure-scuttlebutt/level-sublevel" ], "_resolved": "https://registry.npmjs.org/levelup/-/levelup-0.19.1.tgz", "_shasum": "f3a6a7205272c4b5f35e412ff004a03a0aedf50b", "_shrinkwrap": null, "_spec": "levelup@~0.19.0", "_where": "/Users/joran/Documents/development/patchdeck/node_modules/level-sublevel", "browser": { "leveldown": false, "leveldown/package": false, "semver": false }, "bugs": { "url": "https://github.com/rvagg/node-levelup/issues" }, "contributors": [ { "name": "David Björklund", "email": "david.bjorklund@gmail.com", "url": "https://github.com/kesla" }, { "name": "Rod Vagg", "email": "r@va.gg", "url": "https://github.com/rvagg" }, { "name": "Jake Verbaten", "email": "raynos2@gmail.com", "url": "https://github.com/raynos" }, { "name": "Dominic Tarr", "email": "dominic.tarr@gmail.com", "url": "https://github.com/dominictarr" }, { "name": "Max Ogden", "email": "max@maxogden.com", "url": "https://github.com/maxogden" }, { "name": "Lars-Magnus Skog", "email": "lars.magnus.skog@gmail.com", "url": "https://github.com/ralphtheninja" }, { "name": "John Chesley", "email": "john@chesl.es", "url": "https://github.com/chesles/" }, { "name": "Julian Gruber", "email": "julian@juliangruber.com", "url": "https://github.com/juliangruber" }, { "name": "Paolo Fragomeni", "email": "paolo@async.ly", "url": "https://github.com/hij1nx" }, { "name": "Anton Whalley", "email": "anton.whalley@nearform.com", "url": "https://github.com/No9" }, { "name": "Matteo Collina", "email": "matteo.collina@gmail.com", "url": "https://github.com/mcollina" }, { "name": "Pedro Teixeira", "email": "pedro.teixeira@gmail.com", "url": "https://github.com/pgte" }, { "name": "James Halliday", "email": "mail@substack.net", "url": "https://github.com/substack" } ], "dependencies": { "bl": "~0.8.1", "deferred-leveldown": "~0.2.0", "errno": "~0.1.1", "prr": "~0.0.0", "readable-stream": "~1.0.26", "semver": "~5.1.0", "xtend": "~3.0.0" }, "description": "Fast & simple storage - a Node.js-style LevelDB wrapper", "devDependencies": { "async": "*", "boganipsum": "*", "bustermove": "~1.0.1", "delayed": "*", "du": "*", "fstream": "*", "leveldown": "~0.10.0", "memdown": "^0.11.0", "mkfiletree": "*", "msgpack-js": "*", "readfiletree": "*", "referee": "*", "rimraf": "*", "slow-stream": ">=0.0.4", "tap": "2.x.x", "tape": "4.x.x", "tar": "*" }, "directories": {}, "dist": { "shasum": "f3a6a7205272c4b5f35e412ff004a03a0aedf50b", "tarball": "https://registry.npmjs.org/levelup/-/levelup-0.19.1.tgz" }, "gitHead": "2847795d54c6eceb865e2c6b5157bccf68132c55", "homepage": "https://github.com/rvagg/node-levelup", "keywords": [ "database", "db", "json", "leveldb", "storage", "store", "stream" ], "license": "MIT", "main": "lib/levelup.js", "maintainers": [ { "name": "rvagg", "email": "rod@vagg.org" }, { "name": "ralphtheninja", "email": "ralphtheninja@riseup.net" }, { "name": "juliangruber", "email": "julian@juliangruber.com" } ], "name": "levelup", "optionalDependencies": {}, "readme": "ERROR: No README data found!", "repository": { "type": "git", "url": "git+https://github.com/rvagg/node-levelup.git" }, "scripts": { "alltests": "npm test && npm run-script functionaltests", "functionaltests": "node ./test/functional/fstream-test.js && node ./test/functional/binary-data-test.js && node ./test/functional/compat-test.js", "test": "tap test/*-test.js" }, "version": "0.19.1" } },{}],222:[function(require,module,exports){ (function (process){ (function (root, factory) { if (typeof process === "object" && typeof process.stdout === "undefined") { process.stderr = process.stdout = { write: function() { } }; } if (typeof define === "function" && define.amd) { define(["exports", "libsodium"], factory); } else if (typeof exports !== "undefined") { factory(exports, require("libsodium")); } else { var cb = root.sodium && root.sodium.onload; factory((root.sodium = {}), root.libsodium); if (typeof cb === "function") { cb(root.sodium); } } }(this, function (exports, libsodium) { "use strict"; Object.defineProperty(exports, '__esModule', { value: true }); var output_format = "uint8array"; libsodium._sodium_init(); // List of functions and constants defined in the wrapped libsodium function symbols() { return Object.keys(exports).sort(); } function increment(bytes) { if (! bytes instanceof Uint8Array) { throw new TypeError("Only Uint8Array instances can be incremented"); } var c = 1 << 8; for (var i = 0 | 0, j = bytes.length; i < j; i++) { c >>= 8; c += bytes[i]; bytes[i] = c & 0xff; } } function memzero(bytes) { if (! bytes instanceof Uint8Array) { throw new TypeError("Only Uint8Array instances can be wiped"); } for (var i = 0 | 0, j = bytes.length; i < j; i++) { bytes[i] = 0; } } function memcmp(b1, b2) { if (!(b1 instanceof Uint8Array && b2 instanceof Uint8Array)) { throw new TypeError("Only Uint8Array instances can be compared"); } if (b1.length !== b2.length) { throw new TypeError("Only instances of identical length can be compared"); } for (var d = 0 | 0, i = 0 | 0, j = b1.length; i < j; i++) { d |= b1[i] ^ b2[i]; } return d === 0; } function compare(b1, b2) { if (!(b1 instanceof Uint8Array && b2 instanceof Uint8Array)) { throw new TypeError("Only Uint8Array instances can be compared"); } if (b1.length !== b2.length) { throw new TypeError("Only instances of identical length can be compared"); } for (var gt = 0 | 0, eq = 1 | 1, i = b1.length; i-- > 0;) { gt |= ((b2[i] - b1[i]) >> 8) & eq; eq &= ((b2[i] ^ b1[i]) - 1) >> 8; } return (gt + gt + eq) - 1; } //--------------------------------------------------------------------------- // Codecs function from_string(str) { if (typeof TextEncoder === "function") { return new TextEncoder("utf-8").encode(str); } str = unescape(encodeURIComponent(str)); var bytes = new Uint8Array(str.length); for (var i = 0; i < str.length; i++) { bytes[i] = str.charCodeAt(i); } return bytes; } function to_string(bytes) { if (typeof TextDecoder === "function") { return new TextDecoder("utf-8", {fatal: true}).decode(bytes); } try { return decodeURIComponent(escape(String.fromCharCode.apply(null, bytes))); } catch (_) { throw new TypeError("The encoded data was not valid."); } } function from_hex(str) { if (!is_hex(str)) throw new TypeError("The provided string doesn't look like hex data"); var result = new Uint8Array(str.length / 2); for (var i = 0; i < str.length; i += 2) { result[i >>> 1] = parseInt(str.substr(i, 2), 16); } return result; } function to_hex(bytes) { var str = "", b, c, x; for (var i = 0; i < bytes.length; i++) { c = bytes[i] & 0xf; b = bytes[i] >>> 4; x = (87 + c + (((c - 10) >> 8) & ~38)) << 8 | (87 + b + (((b - 10) >> 8) & ~38)); str += String.fromCharCode(x & 0xff) + String.fromCharCode(x >>> 8); } return str; } function is_hex(str) { return (typeof str === "string" && /^[0-9a-f]+$/i.test(str) && str.length % 2 === 0); } function from_base64(sBase64, nBlocksSize) { function _b64ToUint6(nChr) { return nChr > 64 && nChr < 91 ? nChr - 65 : nChr > 96 && nChr < 123 ? nChr - 71 : nChr > 47 && nChr < 58 ? nChr + 4 : nChr === 43 ? 62 : nChr === 47 ? 63 : 0; } var sB64Enc = sBase64.replace(/[^A-Za-z0-9\+\/]/g, ""), nInLen = sB64Enc.length, nOutLen = nBlocksSize ? Math.ceil((nInLen * 3 + 1 >> 2) / nBlocksSize) * nBlocksSize : nInLen * 3 + 1 >> 2, taBytes = new Uint8Array(nOutLen); for (var nMod3, nMod4, nUint24 = 0, nOutIdx = 0, nInIdx = 0; nInIdx < nInLen; nInIdx++) { nMod4 = nInIdx & 3; nUint24 |= _b64ToUint6(sB64Enc.charCodeAt(nInIdx)) << 18 - 6 * nMod4; if (nMod4 === 3 || nInLen - nInIdx === 1) { for (nMod3 = 0; nMod3 < 3 && nOutIdx < nOutLen; nMod3++, nOutIdx++) { taBytes[nOutIdx] = nUint24 >>> (16 >>> nMod3 & 24) & 255; } nUint24 = 0; } } return taBytes; } function to_base64(aBytes, noNewLine) { function _uint6ToB64(nUint6) { return nUint6 < 26 ? nUint6 + 65 : nUint6 < 52 ? nUint6 + 71 : nUint6 < 62 ? nUint6 - 4 : nUint6 === 62 ? 43 : nUint6 === 63 ? 47 : 65; } if (typeof aBytes === "string") { throw new Exception("input has to be an array"); } var nMod3 = 2, sB64Enc = ""; for (var nLen = aBytes.length, nUint24 = 0, nIdx = 0; nIdx < nLen; nIdx++) { nMod3 = nIdx % 3; if (nIdx > 0 && (nIdx * 4 / 3) % 76 === 0 && !noNewLine) { sB64Enc += "\r\n"; } nUint24 |= aBytes[nIdx] << (16 >>> nMod3 & 24); if (nMod3 === 2 || aBytes.length - nIdx === 1) { sB64Enc += String.fromCharCode(_uint6ToB64(nUint24 >>> 18 & 63), _uint6ToB64(nUint24 >>> 12 & 63), _uint6ToB64(nUint24 >>> 6 & 63), _uint6ToB64(nUint24 & 63)); nUint24 = 0; } } return sB64Enc.substr(0, sB64Enc.length - 2 + nMod3) + (nMod3 === 2 ? "" : nMod3 === 1 ? "=" : "=="); } function output_formats() { return ["uint8array", "text", "hex", "base64"]; } function _format_output(output, optionalOutputFormat) { var selectedOutputFormat = optionalOutputFormat || output_format; if (!_is_output_format(selectedOutputFormat)) throw new Error(selectedOutputFormat + " output format is not available"); if (output instanceof AllocatedBuf) { if (selectedOutputFormat === "uint8array") return output.to_Uint8Array(); else if (selectedOutputFormat === "text") return libsodium.Pointer_stringify(output.address, output.length); else if (selectedOutputFormat === "hex") return to_hex(output.to_Uint8Array()); else if (selectedOutputFormat === "base64") return to_base64(output.to_Uint8Array()); else throw new Error("What is output format \"" + selectedOutputFormat + "\"?"); } else if (typeof output === "object") { //Composed output. Example : key pairs var props = Object.keys(output); var formattedOutput = {}; for (var i = 0; i < props.length; i++) { formattedOutput[props[i]] = _format_output(output[props[i]], selectedOutputFormat); } return formattedOutput; } else if (typeof output === "string") { return output; } else { throw new TypeError("Cannot format output"); } } function _is_output_format(format) { var formats = output_formats(); for (var i = 0; i < formats.length; i++) { if (formats[i] === format) return true; } return false; } function _check_output_format(format) { if (!format) { return; } else if (typeof format !== "string") { throw new TypeError("When defined, the output format must be a string"); } else if (!_is_output_format(format)) { throw new Error(format + " is not a supported output format"); } } //--------------------------------------------------------------------------- // Memory management // AllocatedBuf: address allocated using _malloc() + length function AllocatedBuf(length) { this.length = length; this.address = _malloc(length); } // Copy the content of a AllocatedBuf (_malloc()'d memory) into a Uint8Array AllocatedBuf.prototype.to_Uint8Array = function () { var result = new Uint8Array(this.length); result.set(libsodium.HEAPU8.subarray(this.address, this.address + this.length)); return result; }; // _malloc() a region and initialize it with the content of a Uint8Array function _to_allocated_buf_address(bytes) { var address = _malloc(bytes.length); libsodium.HEAPU8.set(bytes, address); return address; } function _malloc(length) { var result = libsodium._malloc(length); if (result === 0) { throw { message: "_malloc() failed", length: length }; } return result; } function _free(address) { libsodium._free(address); } function _free_all(addresses) { for (var i = 0; i < addresses.length; i++) { _free(addresses[i]); } } function _free_and_throw_error(address_pool, err) { _free_all(address_pool); throw new Error(err); } function _free_and_throw_type_error(address_pool, err) { _free_all(address_pool); throw new TypeError(err); } function _require_defined(address_pool, varValue, varName) { if (varValue == undefined) { _free_and_throw_type_error(address_pool, varName + " cannot be null or undefined"); } } function _any_to_Uint8Array(address_pool, varValue, varName) { _require_defined(address_pool, varValue, varName); if (varValue instanceof Uint8Array) { return varValue; } else if (typeof varValue === "string") { return from_string(varValue); } _free_and_throw_type_error(address_pool, "unsupported input type for " + varName); } function crypto_aead_chacha20poly1305_decrypt(secret_nonce, ciphertext, additional_data, public_nonce, key, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: secret_nonce (unsized_buf_optional) var secret_nonce_address = null, secret_nonce_length = 0; if (secret_nonce != undefined) { secret_nonce = _any_to_Uint8Array(address_pool, secret_nonce, "secret_nonce"); secret_nonce_address = _to_allocated_buf_address(secret_nonce); secret_nonce_length = secret_nonce.length; address_pool.push(secret_nonce_address); } // ---------- input: ciphertext (unsized_buf) ciphertext = _any_to_Uint8Array(address_pool, ciphertext, "ciphertext"); var ciphertext_address = _to_allocated_buf_address(ciphertext), ciphertext_length = ciphertext.length; address_pool.push(ciphertext_address); // ---------- input: additional_data (unsized_buf_optional) var additional_data_address = null, additional_data_length = 0; if (additional_data != undefined) { additional_data = _any_to_Uint8Array(address_pool, additional_data, "additional_data"); additional_data_address = _to_allocated_buf_address(additional_data); additional_data_length = additional_data.length; address_pool.push(additional_data_address); } // ---------- input: public_nonce (buf) public_nonce = _any_to_Uint8Array(address_pool, public_nonce, "public_nonce"); var public_nonce_address, public_nonce_length = (libsodium._crypto_aead_chacha20poly1305_npubbytes()) | 0; if (public_nonce.length !== public_nonce_length) { _free_and_throw_type_error(address_pool, "invalid public_nonce length"); } public_nonce_address = _to_allocated_buf_address(public_nonce); address_pool.push(public_nonce_address); // ---------- input: key (buf) key = _any_to_Uint8Array(address_pool, key, "key"); var key_address, key_length = (libsodium._crypto_aead_chacha20poly1305_keybytes()) | 0; if (key.length !== key_length) { _free_and_throw_type_error(address_pool, "invalid key length"); } key_address = _to_allocated_buf_address(key); address_pool.push(key_address); // ---------- output message (buf) var message_length = (ciphertext_length - libsodium._crypto_aead_chacha20poly1305_abytes()) | 0, message = new AllocatedBuf(message_length), message_address = message.address; address_pool.push(message_address); if ((libsodium._crypto_aead_chacha20poly1305_decrypt(message_address, null, secret_nonce_address, ciphertext_address, ciphertext_length, 0, additional_data_address, additional_data_length, 0, public_nonce_address, key_address)) === 0) { var ret = _format_output(message, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_aead_chacha20poly1305_encrypt(message, additional_data, secret_nonce, public_nonce, key, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: additional_data (unsized_buf_optional) var additional_data_address = null, additional_data_length = 0; if (additional_data != undefined) { additional_data = _any_to_Uint8Array(address_pool, additional_data, "additional_data"); additional_data_address = _to_allocated_buf_address(additional_data); additional_data_length = additional_data.length; address_pool.push(additional_data_address); } // ---------- input: secret_nonce (unsized_buf_optional) var secret_nonce_address = null, secret_nonce_length = 0; if (secret_nonce != undefined) { secret_nonce = _any_to_Uint8Array(address_pool, secret_nonce, "secret_nonce"); secret_nonce_address = _to_allocated_buf_address(secret_nonce); secret_nonce_length = secret_nonce.length; address_pool.push(secret_nonce_address); } // ---------- input: public_nonce (buf) public_nonce = _any_to_Uint8Array(address_pool, public_nonce, "public_nonce"); var public_nonce_address, public_nonce_length = (libsodium._crypto_aead_chacha20poly1305_npubbytes()) | 0; if (public_nonce.length !== public_nonce_length) { _free_and_throw_type_error(address_pool, "invalid public_nonce length"); } public_nonce_address = _to_allocated_buf_address(public_nonce); address_pool.push(public_nonce_address); // ---------- input: key (buf) key = _any_to_Uint8Array(address_pool, key, "key"); var key_address, key_length = (libsodium._crypto_aead_chacha20poly1305_keybytes()) | 0; if (key.length !== key_length) { _free_and_throw_type_error(address_pool, "invalid key length"); } key_address = _to_allocated_buf_address(key); address_pool.push(key_address); // ---------- output ciphertext (buf) var ciphertext_length = (message_length + libsodium._crypto_aead_chacha20poly1305_abytes()) | 0, ciphertext = new AllocatedBuf(ciphertext_length), ciphertext_address = ciphertext.address; address_pool.push(ciphertext_address); if ((libsodium._crypto_aead_chacha20poly1305_encrypt(ciphertext_address, null, message_address, message_length, 0, additional_data_address, additional_data_length, 0, secret_nonce_address, public_nonce_address, key_address)) === 0) { var ret = _format_output(ciphertext, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_aead_chacha20poly1305_ietf_decrypt(secret_nonce, ciphertext, additional_data, public_nonce, key, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: secret_nonce (unsized_buf_optional) var secret_nonce_address = null, secret_nonce_length = 0; if (secret_nonce != undefined) { secret_nonce = _any_to_Uint8Array(address_pool, secret_nonce, "secret_nonce"); secret_nonce_address = _to_allocated_buf_address(secret_nonce); secret_nonce_length = secret_nonce.length; address_pool.push(secret_nonce_address); } // ---------- input: ciphertext (unsized_buf) ciphertext = _any_to_Uint8Array(address_pool, ciphertext, "ciphertext"); var ciphertext_address = _to_allocated_buf_address(ciphertext), ciphertext_length = ciphertext.length; address_pool.push(ciphertext_address); // ---------- input: additional_data (unsized_buf_optional) var additional_data_address = null, additional_data_length = 0; if (additional_data != undefined) { additional_data = _any_to_Uint8Array(address_pool, additional_data, "additional_data"); additional_data_address = _to_allocated_buf_address(additional_data); additional_data_length = additional_data.length; address_pool.push(additional_data_address); } // ---------- input: public_nonce (buf) public_nonce = _any_to_Uint8Array(address_pool, public_nonce, "public_nonce"); var public_nonce_address, public_nonce_length = (libsodium._crypto_aead_chacha20poly1305_ietf_npubbytes()) | 0; if (public_nonce.length !== public_nonce_length) { _free_and_throw_type_error(address_pool, "invalid public_nonce length"); } public_nonce_address = _to_allocated_buf_address(public_nonce); address_pool.push(public_nonce_address); // ---------- input: key (buf) key = _any_to_Uint8Array(address_pool, key, "key"); var key_address, key_length = (libsodium._crypto_aead_chacha20poly1305_keybytes()) | 0; if (key.length !== key_length) { _free_and_throw_type_error(address_pool, "invalid key length"); } key_address = _to_allocated_buf_address(key); address_pool.push(key_address); // ---------- output message (buf) var message_length = (ciphertext_length - libsodium._crypto_aead_chacha20poly1305_abytes()) | 0, message = new AllocatedBuf(message_length), message_address = message.address; address_pool.push(message_address); if ((libsodium._crypto_aead_chacha20poly1305_ietf_decrypt(message_address, null, secret_nonce_address, ciphertext_address, ciphertext_length, 0, additional_data_address, additional_data_length, 0, public_nonce_address, key_address)) === 0) { var ret = _format_output(message, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_aead_chacha20poly1305_ietf_encrypt(message, additional_data, secret_nonce, public_nonce, key, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: additional_data (unsized_buf_optional) var additional_data_address = null, additional_data_length = 0; if (additional_data != undefined) { additional_data = _any_to_Uint8Array(address_pool, additional_data, "additional_data"); additional_data_address = _to_allocated_buf_address(additional_data); additional_data_length = additional_data.length; address_pool.push(additional_data_address); } // ---------- input: secret_nonce (unsized_buf_optional) var secret_nonce_address = null, secret_nonce_length = 0; if (secret_nonce != undefined) { secret_nonce = _any_to_Uint8Array(address_pool, secret_nonce, "secret_nonce"); secret_nonce_address = _to_allocated_buf_address(secret_nonce); secret_nonce_length = secret_nonce.length; address_pool.push(secret_nonce_address); } // ---------- input: public_nonce (buf) public_nonce = _any_to_Uint8Array(address_pool, public_nonce, "public_nonce"); var public_nonce_address, public_nonce_length = (libsodium._crypto_aead_chacha20poly1305_ietf_npubbytes()) | 0; if (public_nonce.length !== public_nonce_length) { _free_and_throw_type_error(address_pool, "invalid public_nonce length"); } public_nonce_address = _to_allocated_buf_address(public_nonce); address_pool.push(public_nonce_address); // ---------- input: key (buf) key = _any_to_Uint8Array(address_pool, key, "key"); var key_address, key_length = (libsodium._crypto_aead_chacha20poly1305_keybytes()) | 0; if (key.length !== key_length) { _free_and_throw_type_error(address_pool, "invalid key length"); } key_address = _to_allocated_buf_address(key); address_pool.push(key_address); // ---------- output ciphertext (buf) var ciphertext_length = (message_length + libsodium._crypto_aead_chacha20poly1305_abytes()) | 0, ciphertext = new AllocatedBuf(ciphertext_length), ciphertext_address = ciphertext.address; address_pool.push(ciphertext_address); if ((libsodium._crypto_aead_chacha20poly1305_ietf_encrypt(ciphertext_address, null, message_address, message_length, 0, additional_data_address, additional_data_length, 0, secret_nonce_address, public_nonce_address, key_address)) === 0) { var ret = _format_output(ciphertext, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_auth(message, key, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: key (buf) key = _any_to_Uint8Array(address_pool, key, "key"); var key_address, key_length = (libsodium._crypto_auth_keybytes()) | 0; if (key.length !== key_length) { _free_and_throw_type_error(address_pool, "invalid key length"); } key_address = _to_allocated_buf_address(key); address_pool.push(key_address); // ---------- output tag (buf) var tag_length = (libsodium._crypto_auth_bytes()) | 0, tag = new AllocatedBuf(tag_length), tag_address = tag.address; address_pool.push(tag_address); if ((libsodium._crypto_auth(tag_address, message_address, message_length, 0, key_address) | 0) === 0) { var ret = _format_output(tag, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_auth_hmacsha256(message, key, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: key (buf) key = _any_to_Uint8Array(address_pool, key, "key"); var key_address, key_length = (libsodium._crypto_auth_hmacsha256_keybytes()) | 0; if (key.length !== key_length) { _free_and_throw_type_error(address_pool, "invalid key length"); } key_address = _to_allocated_buf_address(key); address_pool.push(key_address); // ---------- output hash (buf) var hash_length = (libsodium._crypto_auth_hmacsha256_bytes()) | 0, hash = new AllocatedBuf(hash_length), hash_address = hash.address; address_pool.push(hash_address); if ((libsodium._crypto_auth_hmacsha256(hash_address, message_address, message_length, 0, key_address) | 0) === 0) { var ret = _format_output(hash, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_auth_hmacsha256_verify(tag, message, key) { var address_pool = []; // ---------- input: tag (buf) tag = _any_to_Uint8Array(address_pool, tag, "tag"); var tag_address, tag_length = (libsodium._crypto_auth_hmacsha256_bytes()) | 0; if (tag.length !== tag_length) { _free_and_throw_type_error(address_pool, "invalid tag length"); } tag_address = _to_allocated_buf_address(tag); address_pool.push(tag_address); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: key (buf) key = _any_to_Uint8Array(address_pool, key, "key"); var key_address, key_length = (libsodium._crypto_auth_hmacsha256_keybytes()) | 0; if (key.length !== key_length) { _free_and_throw_type_error(address_pool, "invalid key length"); } key_address = _to_allocated_buf_address(key); address_pool.push(key_address); var result = libsodium._crypto_auth_hmacsha256_verify(tag_address, message_address, message_length, 0, key_address) | 0; var ret = (result === 0); _free_all(address_pool); return ret; } function crypto_auth_hmacsha512(message, key, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: key (buf) key = _any_to_Uint8Array(address_pool, key, "key"); var key_address, key_length = (libsodium._crypto_auth_hmacsha512_keybytes()) | 0; if (key.length !== key_length) { _free_and_throw_type_error(address_pool, "invalid key length"); } key_address = _to_allocated_buf_address(key); address_pool.push(key_address); // ---------- output hash (buf) var hash_length = (libsodium._crypto_auth_hmacsha512_bytes()) | 0, hash = new AllocatedBuf(hash_length), hash_address = hash.address; address_pool.push(hash_address); if ((libsodium._crypto_auth_hmacsha512(hash_address, message_address, message_length, 0, key_address) | 0) === 0) { var ret = _format_output(hash, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_auth_hmacsha512_verify(tag, message, key) { var address_pool = []; // ---------- input: tag (buf) tag = _any_to_Uint8Array(address_pool, tag, "tag"); var tag_address, tag_length = (libsodium._crypto_auth_hmacsha512_bytes()) | 0; if (tag.length !== tag_length) { _free_and_throw_type_error(address_pool, "invalid tag length"); } tag_address = _to_allocated_buf_address(tag); address_pool.push(tag_address); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: key (buf) key = _any_to_Uint8Array(address_pool, key, "key"); var key_address, key_length = (libsodium._crypto_auth_hmacsha512_keybytes()) | 0; if (key.length !== key_length) { _free_and_throw_type_error(address_pool, "invalid key length"); } key_address = _to_allocated_buf_address(key); address_pool.push(key_address); var result = libsodium._crypto_auth_hmacsha512_verify(tag_address, message_address, message_length, 0, key_address) | 0; var ret = (result === 0); _free_all(address_pool); return ret; } function crypto_auth_verify(tag, message, key) { var address_pool = []; // ---------- input: tag (buf) tag = _any_to_Uint8Array(address_pool, tag, "tag"); var tag_address, tag_length = (libsodium._crypto_auth_bytes()) | 0; if (tag.length !== tag_length) { _free_and_throw_type_error(address_pool, "invalid tag length"); } tag_address = _to_allocated_buf_address(tag); address_pool.push(tag_address); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: key (buf) key = _any_to_Uint8Array(address_pool, key, "key"); var key_address, key_length = (libsodium._crypto_auth_keybytes()) | 0; if (key.length !== key_length) { _free_and_throw_type_error(address_pool, "invalid key length"); } key_address = _to_allocated_buf_address(key); address_pool.push(key_address); var result = libsodium._crypto_auth_verify(tag_address, message_address, message_length, 0, key_address) | 0; var ret = (result === 0); _free_all(address_pool); return ret; } function crypto_box_beforenm(publicKey, secretKey, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: publicKey (buf) publicKey = _any_to_Uint8Array(address_pool, publicKey, "publicKey"); var publicKey_address, publicKey_length = (libsodium._crypto_box_publickeybytes()) | 0; if (publicKey.length !== publicKey_length) { _free_and_throw_type_error(address_pool, "invalid publicKey length"); } publicKey_address = _to_allocated_buf_address(publicKey); address_pool.push(publicKey_address); // ---------- input: secretKey (buf) secretKey = _any_to_Uint8Array(address_pool, secretKey, "secretKey"); var secretKey_address, secretKey_length = (libsodium._crypto_box_secretkeybytes()) | 0; if (secretKey.length !== secretKey_length) { _free_and_throw_type_error(address_pool, "invalid secretKey length"); } secretKey_address = _to_allocated_buf_address(secretKey); address_pool.push(secretKey_address); // ---------- output sharedKey (buf) var sharedKey_length = (libsodium._crypto_box_beforenmbytes()) | 0, sharedKey = new AllocatedBuf(sharedKey_length), sharedKey_address = sharedKey.address; address_pool.push(sharedKey_address); if ((libsodium._crypto_box_beforenm(sharedKey_address, publicKey_address, secretKey_address) | 0) === 0) { var ret = _format_output(sharedKey, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_box_detached(message, nonce, publicKey, secretKey, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: nonce (buf) nonce = _any_to_Uint8Array(address_pool, nonce, "nonce"); var nonce_address, nonce_length = (libsodium._crypto_box_noncebytes()) | 0; if (nonce.length !== nonce_length) { _free_and_throw_type_error(address_pool, "invalid nonce length"); } nonce_address = _to_allocated_buf_address(nonce); address_pool.push(nonce_address); // ---------- input: publicKey (buf) publicKey = _any_to_Uint8Array(address_pool, publicKey, "publicKey"); var publicKey_address, publicKey_length = (libsodium._crypto_box_publickeybytes()) | 0; if (publicKey.length !== publicKey_length) { _free_and_throw_type_error(address_pool, "invalid publicKey length"); } publicKey_address = _to_allocated_buf_address(publicKey); address_pool.push(publicKey_address); // ---------- input: secretKey (buf) secretKey = _any_to_Uint8Array(address_pool, secretKey, "secretKey"); var secretKey_address, secretKey_length = (libsodium._crypto_box_secretkeybytes()) | 0; if (secretKey.length !== secretKey_length) { _free_and_throw_type_error(address_pool, "invalid secretKey length"); } secretKey_address = _to_allocated_buf_address(secretKey); address_pool.push(secretKey_address); // ---------- output ciphertext (buf) var ciphertext_length = (message_length) | 0, ciphertext = new AllocatedBuf(ciphertext_length), ciphertext_address = ciphertext.address; address_pool.push(ciphertext_address); // ---------- output mac (buf) var mac_length = (libsodium._crypto_box_macbytes()) | 0, mac = new AllocatedBuf(mac_length), mac_address = mac.address; address_pool.push(mac_address); if ((libsodium._crypto_box_detached(ciphertext_address, mac_address, message_address, message_length, 0, nonce_address, publicKey_address, secretKey_address) | 0) === 0) { var ret = _format_output({ciphertext: ciphertext, mac: mac}, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_box_easy(message, nonce, publicKey, secretKey, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: nonce (buf) nonce = _any_to_Uint8Array(address_pool, nonce, "nonce"); var nonce_address, nonce_length = (libsodium._crypto_box_noncebytes()) | 0; if (nonce.length !== nonce_length) { _free_and_throw_type_error(address_pool, "invalid nonce length"); } nonce_address = _to_allocated_buf_address(nonce); address_pool.push(nonce_address); // ---------- input: publicKey (buf) publicKey = _any_to_Uint8Array(address_pool, publicKey, "publicKey"); var publicKey_address, publicKey_length = (libsodium._crypto_box_publickeybytes()) | 0; if (publicKey.length !== publicKey_length) { _free_and_throw_type_error(address_pool, "invalid publicKey length"); } publicKey_address = _to_allocated_buf_address(publicKey); address_pool.push(publicKey_address); // ---------- input: secretKey (buf) secretKey = _any_to_Uint8Array(address_pool, secretKey, "secretKey"); var secretKey_address, secretKey_length = (libsodium._crypto_box_secretkeybytes()) | 0; if (secretKey.length !== secretKey_length) { _free_and_throw_type_error(address_pool, "invalid secretKey length"); } secretKey_address = _to_allocated_buf_address(secretKey); address_pool.push(secretKey_address); // ---------- output ciphertext (buf) var ciphertext_length = (message_length + libsodium._crypto_box_macbytes()) | 0, ciphertext = new AllocatedBuf(ciphertext_length), ciphertext_address = ciphertext.address; address_pool.push(ciphertext_address); if ((libsodium._crypto_box_easy(ciphertext_address, message_address, message_length, 0, nonce_address, publicKey_address, secretKey_address) | 0) === 0) { var ret = _format_output(ciphertext, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_box_easy_afternm(message, nonce, sharedKey, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: nonce (buf) nonce = _any_to_Uint8Array(address_pool, nonce, "nonce"); var nonce_address, nonce_length = (libsodium._crypto_box_noncebytes()) | 0; if (nonce.length !== nonce_length) { _free_and_throw_type_error(address_pool, "invalid nonce length"); } nonce_address = _to_allocated_buf_address(nonce); address_pool.push(nonce_address); // ---------- input: sharedKey (buf) sharedKey = _any_to_Uint8Array(address_pool, sharedKey, "sharedKey"); var sharedKey_address, sharedKey_length = (libsodium._crypto_box_beforenmbytes()) | 0; if (sharedKey.length !== sharedKey_length) { _free_and_throw_type_error(address_pool, "invalid sharedKey length"); } sharedKey_address = _to_allocated_buf_address(sharedKey); address_pool.push(sharedKey_address); // ---------- output ciphertext (buf) var ciphertext_length = (message_length + libsodium._crypto_box_macbytes()) | 0, ciphertext = new AllocatedBuf(ciphertext_length), ciphertext_address = ciphertext.address; address_pool.push(ciphertext_address); if ((libsodium._crypto_box_easy_afternm(ciphertext_address, message_address, message_length, 0, nonce_address, sharedKey_address) | 0) === 0) { var ret = _format_output(ciphertext, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_box_keypair(outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- output publicKey (buf) var publicKey_length = (libsodium._crypto_box_publickeybytes()) | 0, publicKey = new AllocatedBuf(publicKey_length), publicKey_address = publicKey.address; address_pool.push(publicKey_address); // ---------- output secretKey (buf) var secretKey_length = (libsodium._crypto_box_secretkeybytes()) | 0, secretKey = new AllocatedBuf(secretKey_length), secretKey_address = secretKey.address; address_pool.push(secretKey_address); if ((libsodium._crypto_box_keypair(publicKey_address, secretKey_address) | 0) === 0) { var ret = _format_output({publicKey: publicKey, privateKey: secretKey, keyType: "curve25519"}, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_box_open_detached(ciphertext, mac, nonce, publicKey, secretKey, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: ciphertext (unsized_buf) ciphertext = _any_to_Uint8Array(address_pool, ciphertext, "ciphertext"); var ciphertext_address = _to_allocated_buf_address(ciphertext), ciphertext_length = ciphertext.length; address_pool.push(ciphertext_address); // ---------- input: mac (buf) mac = _any_to_Uint8Array(address_pool, mac, "mac"); var mac_address, mac_length = (libsodium._crypto_box_macbytes()) | 0; if (mac.length !== mac_length) { _free_and_throw_type_error(address_pool, "invalid mac length"); } mac_address = _to_allocated_buf_address(mac); address_pool.push(mac_address); // ---------- input: nonce (buf) nonce = _any_to_Uint8Array(address_pool, nonce, "nonce"); var nonce_address, nonce_length = (libsodium._crypto_box_noncebytes()) | 0; if (nonce.length !== nonce_length) { _free_and_throw_type_error(address_pool, "invalid nonce length"); } nonce_address = _to_allocated_buf_address(nonce); address_pool.push(nonce_address); // ---------- input: publicKey (buf) publicKey = _any_to_Uint8Array(address_pool, publicKey, "publicKey"); var publicKey_address, publicKey_length = (libsodium._crypto_box_publickeybytes()) | 0; if (publicKey.length !== publicKey_length) { _free_and_throw_type_error(address_pool, "invalid publicKey length"); } publicKey_address = _to_allocated_buf_address(publicKey); address_pool.push(publicKey_address); // ---------- input: secretKey (buf) secretKey = _any_to_Uint8Array(address_pool, secretKey, "secretKey"); var secretKey_address, secretKey_length = (libsodium._crypto_box_secretkeybytes()) | 0; if (secretKey.length !== secretKey_length) { _free_and_throw_type_error(address_pool, "invalid secretKey length"); } secretKey_address = _to_allocated_buf_address(secretKey); address_pool.push(secretKey_address); // ---------- output plaintext (buf) var plaintext_length = (ciphertext_length) | 0, plaintext = new AllocatedBuf(plaintext_length), plaintext_address = plaintext.address; address_pool.push(plaintext_address); if ((libsodium._crypto_box_open_detached(plaintext_address, ciphertext_address, mac_address, ciphertext_length, 0, nonce_address, publicKey_address, secretKey_address) | 0) === 0) { var ret = _format_output(plaintext, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_box_open_easy(ciphertext, nonce, publicKey, secretKey, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: ciphertext (unsized_buf) ciphertext = _any_to_Uint8Array(address_pool, ciphertext, "ciphertext"); var ciphertext_address = _to_allocated_buf_address(ciphertext), ciphertext_length = ciphertext.length; address_pool.push(ciphertext_address); // ---------- input: nonce (buf) nonce = _any_to_Uint8Array(address_pool, nonce, "nonce"); var nonce_address, nonce_length = (libsodium._crypto_box_noncebytes()) | 0; if (nonce.length !== nonce_length) { _free_and_throw_type_error(address_pool, "invalid nonce length"); } nonce_address = _to_allocated_buf_address(nonce); address_pool.push(nonce_address); // ---------- input: publicKey (buf) publicKey = _any_to_Uint8Array(address_pool, publicKey, "publicKey"); var publicKey_address, publicKey_length = (libsodium._crypto_box_publickeybytes()) | 0; if (publicKey.length !== publicKey_length) { _free_and_throw_type_error(address_pool, "invalid publicKey length"); } publicKey_address = _to_allocated_buf_address(publicKey); address_pool.push(publicKey_address); // ---------- input: secretKey (buf) secretKey = _any_to_Uint8Array(address_pool, secretKey, "secretKey"); var secretKey_address, secretKey_length = (libsodium._crypto_box_secretkeybytes()) | 0; if (secretKey.length !== secretKey_length) { _free_and_throw_type_error(address_pool, "invalid secretKey length"); } secretKey_address = _to_allocated_buf_address(secretKey); address_pool.push(secretKey_address); // ---------- output plaintext (buf) var plaintext_length = (ciphertext_length - libsodium._crypto_box_macbytes()) | 0, plaintext = new AllocatedBuf(plaintext_length), plaintext_address = plaintext.address; address_pool.push(plaintext_address); if ((libsodium._crypto_box_open_easy(plaintext_address, ciphertext_address, ciphertext_length, 0, nonce_address, publicKey_address, secretKey_address) | 0) === 0) { var ret = _format_output(plaintext, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_box_open_easy_afternm(ciphertext, nonce, sharedKey, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: ciphertext (unsized_buf) ciphertext = _any_to_Uint8Array(address_pool, ciphertext, "ciphertext"); var ciphertext_address = _to_allocated_buf_address(ciphertext), ciphertext_length = ciphertext.length; address_pool.push(ciphertext_address); // ---------- input: nonce (buf) nonce = _any_to_Uint8Array(address_pool, nonce, "nonce"); var nonce_address, nonce_length = (libsodium._crypto_box_noncebytes()) | 0; if (nonce.length !== nonce_length) { _free_and_throw_type_error(address_pool, "invalid nonce length"); } nonce_address = _to_allocated_buf_address(nonce); address_pool.push(nonce_address); // ---------- input: sharedKey (buf) sharedKey = _any_to_Uint8Array(address_pool, sharedKey, "sharedKey"); var sharedKey_address, sharedKey_length = (libsodium._crypto_box_beforenmbytes()) | 0; if (sharedKey.length !== sharedKey_length) { _free_and_throw_type_error(address_pool, "invalid sharedKey length"); } sharedKey_address = _to_allocated_buf_address(sharedKey); address_pool.push(sharedKey_address); // ---------- output plaintext (buf) var plaintext_length = (ciphertext_length - libsodium._crypto_box_macbytes()) | 0, plaintext = new AllocatedBuf(plaintext_length), plaintext_address = plaintext.address; address_pool.push(plaintext_address); if ((libsodium._crypto_box_open_easy_afternm(plaintext_address, ciphertext_address, ciphertext_length, 0, nonce_address, sharedKey_address) | 0) === 0) { var ret = _format_output(plaintext, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_box_seal(message, publicKey, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: publicKey (buf) publicKey = _any_to_Uint8Array(address_pool, publicKey, "publicKey"); var publicKey_address, publicKey_length = (libsodium._crypto_box_publickeybytes()) | 0; if (publicKey.length !== publicKey_length) { _free_and_throw_type_error(address_pool, "invalid publicKey length"); } publicKey_address = _to_allocated_buf_address(publicKey); address_pool.push(publicKey_address); // ---------- output ciphertext (buf) var ciphertext_length = (message_length + libsodium._crypto_box_sealbytes()) | 0, ciphertext = new AllocatedBuf(ciphertext_length), ciphertext_address = ciphertext.address; address_pool.push(ciphertext_address); if ((libsodium._crypto_box_seal(ciphertext_address, message_address, message_length, 0, publicKey_address) | 0) === 0) { var ret = _format_output(ciphertext, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_box_seal_open(ciphertext, publicKey, secretKey, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: ciphertext (unsized_buf) ciphertext = _any_to_Uint8Array(address_pool, ciphertext, "ciphertext"); var ciphertext_address = _to_allocated_buf_address(ciphertext), ciphertext_length = ciphertext.length; address_pool.push(ciphertext_address); // ---------- input: publicKey (buf) publicKey = _any_to_Uint8Array(address_pool, publicKey, "publicKey"); var publicKey_address, publicKey_length = (libsodium._crypto_box_publickeybytes()) | 0; if (publicKey.length !== publicKey_length) { _free_and_throw_type_error(address_pool, "invalid publicKey length"); } publicKey_address = _to_allocated_buf_address(publicKey); address_pool.push(publicKey_address); // ---------- input: secretKey (buf) secretKey = _any_to_Uint8Array(address_pool, secretKey, "secretKey"); var secretKey_address, secretKey_length = (libsodium._crypto_box_secretkeybytes()) | 0; if (secretKey.length !== secretKey_length) { _free_and_throw_type_error(address_pool, "invalid secretKey length"); } secretKey_address = _to_allocated_buf_address(secretKey); address_pool.push(secretKey_address); // ---------- output plaintext (buf) var plaintext_length = (ciphertext_length - libsodium._crypto_box_sealbytes()) | 0, plaintext = new AllocatedBuf(plaintext_length), plaintext_address = plaintext.address; address_pool.push(plaintext_address); if ((libsodium._crypto_box_seal_open(plaintext_address, ciphertext_address, ciphertext_length, 0, publicKey_address, secretKey_address) | 0) === 0) { var ret = _format_output(plaintext, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_box_seed_keypair(seed, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: seed (buf) seed = _any_to_Uint8Array(address_pool, seed, "seed"); var seed_address, seed_length = (libsodium._crypto_box_seedbytes()) | 0; if (seed.length !== seed_length) { _free_and_throw_type_error(address_pool, "invalid seed length"); } seed_address = _to_allocated_buf_address(seed); address_pool.push(seed_address); // ---------- output publicKey (buf) var publicKey_length = (libsodium._crypto_box_publickeybytes()) | 0, publicKey = new AllocatedBuf(publicKey_length), publicKey_address = publicKey.address; address_pool.push(publicKey_address); // ---------- output privateKey (buf) var privateKey_length = (libsodium._crypto_box_secretkeybytes()) | 0, privateKey = new AllocatedBuf(privateKey_length), privateKey_address = privateKey.address; address_pool.push(privateKey_address); if ((libsodium._crypto_box_seed_keypair(publicKey_address, privateKey_address, seed_address) | 0) === 0) { var ret = _format_output({publicKey: publicKey, privateKey: privateKey}, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_generichash(hash_length, message, key, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: hash_length (uint) _require_defined(address_pool, hash_length, "hash_length"); if (!(typeof hash_length === "number" && (hash_length | 0) === hash_length) && (hash_length | 0) > 0) { _free_and_throw_type_error(address_pool, "hash_length must be an unsigned integer"); } // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: key (unsized_buf_optional) var key_address = null, key_length = 0; if (key != undefined) { key = _any_to_Uint8Array(address_pool, key, "key"); key_address = _to_allocated_buf_address(key); key_length = key.length; address_pool.push(key_address); } // ---------- output hash (buf) var hash_length = (hash_length) | 0, hash = new AllocatedBuf(hash_length), hash_address = hash.address; address_pool.push(hash_address); if ((libsodium._crypto_generichash(hash_address, hash_length, message_address, message_length, 0, key_address, key_length) | 0) === 0) { var ret = _format_output(hash, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_generichash_final(state_address, hash_length, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: state_address (generichash_state_address) _require_defined(address_pool, state_address, "state_address"); // ---------- input: hash_length (uint) _require_defined(address_pool, hash_length, "hash_length"); if (!(typeof hash_length === "number" && (hash_length | 0) === hash_length) && (hash_length | 0) > 0) { _free_and_throw_type_error(address_pool, "hash_length must be an unsigned integer"); } // ---------- output hash (buf) var hash_length = (hash_length) | 0, hash = new AllocatedBuf(hash_length), hash_address = hash.address; address_pool.push(hash_address); if ((libsodium._crypto_generichash_final(state_address, hash_address, hash_length) | 0) === 0) { var ret = (libsodium._free(state_address), _format_output(hash, outputFormat)); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_generichash_init(key, hash_length, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: key (unsized_buf_optional) var key_address = null, key_length = 0; if (key != undefined) { key = _any_to_Uint8Array(address_pool, key, "key"); key_address = _to_allocated_buf_address(key); key_length = key.length; address_pool.push(key_address); } // ---------- input: hash_length (uint) _require_defined(address_pool, hash_length, "hash_length"); if (!(typeof hash_length === "number" && (hash_length | 0) === hash_length) && (hash_length | 0) > 0) { _free_and_throw_type_error(address_pool, "hash_length must be an unsigned integer"); } // ---------- output state (generichash_state) var state_address = new AllocatedBuf(357).address; if ((libsodium._crypto_generichash_init(state_address, key_address, key_length, hash_length) | 0) === 0) { var ret = state_address; _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_generichash_update(state_address, message_chunk, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: state_address (generichash_state_address) _require_defined(address_pool, state_address, "state_address"); // ---------- input: message_chunk (unsized_buf) message_chunk = _any_to_Uint8Array(address_pool, message_chunk, "message_chunk"); var message_chunk_address = _to_allocated_buf_address(message_chunk), message_chunk_length = message_chunk.length; address_pool.push(message_chunk_address); if ((libsodium._crypto_generichash_update(state_address, message_chunk_address, message_chunk_length) | 0) === 0) { _free_all(address_pool); return; } _free_and_throw_error(address_pool); } function crypto_hash(message, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- output hash (buf) var hash_length = (libsodium._crypto_hash_bytes()) | 0, hash = new AllocatedBuf(hash_length), hash_address = hash.address; address_pool.push(hash_address); if ((libsodium._crypto_hash(hash_address, message_address, message_length, 0) | 0) === 0) { var ret = _format_output(hash, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_hash_sha256(message, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- output hash (buf) var hash_length = (libsodium._crypto_hash_sha256_bytes()) | 0, hash = new AllocatedBuf(hash_length), hash_address = hash.address; address_pool.push(hash_address); if ((libsodium._crypto_hash_sha256(hash_address, message_address, message_length, 0) | 0) === 0) { var ret = _format_output(hash, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_hash_sha512(message, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- output hash (buf) var hash_length = (libsodium._crypto_hash_sha512_bytes()) | 0, hash = new AllocatedBuf(hash_length), hash_address = hash.address; address_pool.push(hash_address); if ((libsodium._crypto_hash_sha512(hash_address, message_address, message_length, 0) | 0) === 0) { var ret = _format_output(hash, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_onetimeauth(message, key, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: key (buf) key = _any_to_Uint8Array(address_pool, key, "key"); var key_address, key_length = (libsodium._crypto_onetimeauth_keybytes()) | 0; if (key.length !== key_length) { _free_and_throw_type_error(address_pool, "invalid key length"); } key_address = _to_allocated_buf_address(key); address_pool.push(key_address); // ---------- output hash (buf) var hash_length = (libsodium._crypto_onetimeauth_bytes()) | 0, hash = new AllocatedBuf(hash_length), hash_address = hash.address; address_pool.push(hash_address); if ((libsodium._crypto_onetimeauth(hash_address, message_address, message_length, 0, key_address) | 0) === 0) { var ret = _format_output(hash, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_onetimeauth_final(state_address, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: state_address (onetimeauth_state_address) _require_defined(address_pool, state_address, "state_address"); // ---------- output hash (buf) var hash_length = (libsodium._crypto_onetimeauth_bytes()) | 0, hash = new AllocatedBuf(hash_length), hash_address = hash.address; address_pool.push(hash_address); if ((libsodium._crypto_onetimeauth_final(state_address, hash_address) | 0) === 0) { var ret = (libsodium._free(state_address), _format_output(hash, outputFormat)); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_onetimeauth_init(key, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: key (unsized_buf_optional) var key_address = null, key_length = 0; if (key != undefined) { key = _any_to_Uint8Array(address_pool, key, "key"); key_address = _to_allocated_buf_address(key); key_length = key.length; address_pool.push(key_address); } // ---------- output state (onetimeauth_state) var state_address = new AllocatedBuf(144).address; if ((libsodium._crypto_onetimeauth_init(state_address, key_address) | 0) === 0) { var ret = state_address; _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_onetimeauth_update(state_address, message_chunk, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: state_address (onetimeauth_state_address) _require_defined(address_pool, state_address, "state_address"); // ---------- input: message_chunk (unsized_buf) message_chunk = _any_to_Uint8Array(address_pool, message_chunk, "message_chunk"); var message_chunk_address = _to_allocated_buf_address(message_chunk), message_chunk_length = message_chunk.length; address_pool.push(message_chunk_address); if ((libsodium._crypto_onetimeauth_update(state_address, message_chunk_address, message_chunk_length) | 0) === 0) { _free_all(address_pool); return; } _free_and_throw_error(address_pool); } function crypto_onetimeauth_verify(hash, message, key) { var address_pool = []; // ---------- input: hash (buf) hash = _any_to_Uint8Array(address_pool, hash, "hash"); var hash_address, hash_length = (libsodium._crypto_onetimeauth_bytes()) | 0; if (hash.length !== hash_length) { _free_and_throw_type_error(address_pool, "invalid hash length"); } hash_address = _to_allocated_buf_address(hash); address_pool.push(hash_address); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: key (buf) key = _any_to_Uint8Array(address_pool, key, "key"); var key_address, key_length = (libsodium._crypto_onetimeauth_keybytes()) | 0; if (key.length !== key_length) { _free_and_throw_type_error(address_pool, "invalid key length"); } key_address = _to_allocated_buf_address(key); address_pool.push(key_address); var result = libsodium._crypto_onetimeauth_verify(hash_address, message_address, message_length, 0, key_address) | 0; var ret = (result === 0); _free_all(address_pool); return ret; } function crypto_pwhash_scryptsalsa208sha256(password, salt, opsLimit, memLimit, keyLength, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: password (unsized_buf) password = _any_to_Uint8Array(address_pool, password, "password"); var password_address = _to_allocated_buf_address(password), password_length = password.length; address_pool.push(password_address); // ---------- input: salt (buf) salt = _any_to_Uint8Array(address_pool, salt, "salt"); var salt_address, salt_length = (libsodium._crypto_pwhash_scryptsalsa208sha256_saltbytes()) | 0; if (salt.length !== salt_length) { _free_and_throw_type_error(address_pool, "invalid salt length"); } salt_address = _to_allocated_buf_address(salt); address_pool.push(salt_address); // ---------- input: opsLimit (uint) _require_defined(address_pool, opsLimit, "opsLimit"); if (!(typeof opsLimit === "number" && (opsLimit | 0) === opsLimit) && (opsLimit | 0) > 0) { _free_and_throw_type_error(address_pool, "opsLimit must be an unsigned integer"); } // ---------- input: memLimit (uint) _require_defined(address_pool, memLimit, "memLimit"); if (!(typeof memLimit === "number" && (memLimit | 0) === memLimit) && (memLimit | 0) > 0) { _free_and_throw_type_error(address_pool, "memLimit must be an unsigned integer"); } // ---------- input: keyLength (uint) _require_defined(address_pool, keyLength, "keyLength"); if (!(typeof keyLength === "number" && (keyLength | 0) === keyLength) && (keyLength | 0) > 0) { _free_and_throw_type_error(address_pool, "keyLength must be an unsigned integer"); } // ---------- output derivedKey (buf) var derivedKey_length = (keyLength) | 0, derivedKey = new AllocatedBuf(derivedKey_length), derivedKey_address = derivedKey.address; address_pool.push(derivedKey_address); if ((libsodium._crypto_pwhash_scryptsalsa208sha256(derivedKey_address, keyLength, 0, password_address, password_length, 0, salt_address, opsLimit, 0, memLimit) | 0) === 0) { var ret = _format_output(derivedKey, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_pwhash_scryptsalsa208sha256_ll(password, salt, opsLimit, r, p, keyLength, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: password (unsized_buf) password = _any_to_Uint8Array(address_pool, password, "password"); var password_address = _to_allocated_buf_address(password), password_length = password.length; address_pool.push(password_address); // ---------- input: salt (unsized_buf) salt = _any_to_Uint8Array(address_pool, salt, "salt"); var salt_address = _to_allocated_buf_address(salt), salt_length = salt.length; address_pool.push(salt_address); // ---------- input: opsLimit (uint) _require_defined(address_pool, opsLimit, "opsLimit"); if (!(typeof opsLimit === "number" && (opsLimit | 0) === opsLimit) && (opsLimit | 0) > 0) { _free_and_throw_type_error(address_pool, "opsLimit must be an unsigned integer"); } // ---------- input: r (uint) _require_defined(address_pool, r, "r"); if (!(typeof r === "number" && (r | 0) === r) && (r | 0) > 0) { _free_and_throw_type_error(address_pool, "r must be an unsigned integer"); } // ---------- input: p (uint) _require_defined(address_pool, p, "p"); if (!(typeof p === "number" && (p | 0) === p) && (p | 0) > 0) { _free_and_throw_type_error(address_pool, "p must be an unsigned integer"); } // ---------- input: keyLength (uint) _require_defined(address_pool, keyLength, "keyLength"); if (!(typeof keyLength === "number" && (keyLength | 0) === keyLength) && (keyLength | 0) > 0) { _free_and_throw_type_error(address_pool, "keyLength must be an unsigned integer"); } // ---------- output derivedKey (buf) var derivedKey_length = (keyLength) | 0, derivedKey = new AllocatedBuf(derivedKey_length), derivedKey_address = derivedKey.address; address_pool.push(derivedKey_address); if ((libsodium._crypto_pwhash_scryptsalsa208sha256_ll(password_address, password_length, salt_address, salt_length, opsLimit, 0, r, p, derivedKey_address, keyLength) | 0) === 0) { var ret = _format_output(derivedKey, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_pwhash_scryptsalsa208sha256_str(password, opsLimit, memLimit, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: password (unsized_buf) password = _any_to_Uint8Array(address_pool, password, "password"); var password_address = _to_allocated_buf_address(password), password_length = password.length; address_pool.push(password_address); // ---------- input: opsLimit (uint) _require_defined(address_pool, opsLimit, "opsLimit"); if (!(typeof opsLimit === "number" && (opsLimit | 0) === opsLimit) && (opsLimit | 0) > 0) { _free_and_throw_type_error(address_pool, "opsLimit must be an unsigned integer"); } // ---------- input: memLimit (uint) _require_defined(address_pool, memLimit, "memLimit"); if (!(typeof memLimit === "number" && (memLimit | 0) === memLimit) && (memLimit | 0) > 0) { _free_and_throw_type_error(address_pool, "memLimit must be an unsigned integer"); } // ---------- output hashed_password (buf) var hashed_password_length = (libsodium._crypto_pwhash_scryptsalsa208sha256_strbytes()) | 0, hashed_password = new AllocatedBuf(hashed_password_length), hashed_password_address = hashed_password.address; address_pool.push(hashed_password_address); if ((libsodium._crypto_pwhash_scryptsalsa208sha256_str(hashed_password_address, password_address, password_length, 0, opsLimit, 0, memLimit) | 0) === 0) { var ret = libsodium.Pointer_stringify(hashed_password_address); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_pwhash_scryptsalsa208sha256_str_verify(hashed_password, password, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: hashed_password (string) hashed_password = from_string(hashed_password + "\0"); var hashed_password_address = _to_allocated_buf_address(hashed_password), hashed_password_length = hashed_password.length - 1; address_pool.push(hashed_password_address); // ---------- input: password (unsized_buf) password = _any_to_Uint8Array(address_pool, password, "password"); var password_address = _to_allocated_buf_address(password), password_length = password.length; address_pool.push(password_address); var result = libsodium._crypto_pwhash_scryptsalsa208sha256_str_verify(hashed_password_address, password_address, password_length, 0) | 0; var ret = (result === 0); _free_all(address_pool); return ret; } function crypto_scalarmult(privateKey, publicKey, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: privateKey (buf) privateKey = _any_to_Uint8Array(address_pool, privateKey, "privateKey"); var privateKey_address, privateKey_length = (libsodium._crypto_scalarmult_scalarbytes()) | 0; if (privateKey.length !== privateKey_length) { _free_and_throw_type_error(address_pool, "invalid privateKey length"); } privateKey_address = _to_allocated_buf_address(privateKey); address_pool.push(privateKey_address); // ---------- input: publicKey (buf) publicKey = _any_to_Uint8Array(address_pool, publicKey, "publicKey"); var publicKey_address, publicKey_length = (libsodium._crypto_scalarmult_scalarbytes()) | 0; if (publicKey.length !== publicKey_length) { _free_and_throw_type_error(address_pool, "invalid publicKey length"); } publicKey_address = _to_allocated_buf_address(publicKey); address_pool.push(publicKey_address); // ---------- output sharedSecret (buf) var sharedSecret_length = (libsodium._crypto_scalarmult_bytes()) | 0, sharedSecret = new AllocatedBuf(sharedSecret_length), sharedSecret_address = sharedSecret.address; address_pool.push(sharedSecret_address); if ((libsodium._crypto_scalarmult(sharedSecret_address, privateKey_address, publicKey_address) | 0) === 0) { var ret = _format_output(sharedSecret, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_scalarmult_base(privateKey, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: privateKey (buf) privateKey = _any_to_Uint8Array(address_pool, privateKey, "privateKey"); var privateKey_address, privateKey_length = (libsodium._crypto_scalarmult_scalarbytes()) | 0; if (privateKey.length !== privateKey_length) { _free_and_throw_type_error(address_pool, "invalid privateKey length"); } privateKey_address = _to_allocated_buf_address(privateKey); address_pool.push(privateKey_address); // ---------- output publicKey (buf) var publicKey_length = (libsodium._crypto_scalarmult_scalarbytes()) | 0, publicKey = new AllocatedBuf(publicKey_length), publicKey_address = publicKey.address; address_pool.push(publicKey_address); if ((libsodium._crypto_scalarmult_base(publicKey_address, privateKey_address) | 0) === 0) { var ret = _format_output(publicKey, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_secretbox_detached(message, nonce, key, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: nonce (buf) nonce = _any_to_Uint8Array(address_pool, nonce, "nonce"); var nonce_address, nonce_length = (libsodium._crypto_secretbox_noncebytes()) | 0; if (nonce.length !== nonce_length) { _free_and_throw_type_error(address_pool, "invalid nonce length"); } nonce_address = _to_allocated_buf_address(nonce); address_pool.push(nonce_address); // ---------- input: key (buf) key = _any_to_Uint8Array(address_pool, key, "key"); var key_address, key_length = (libsodium._crypto_secretbox_keybytes()) | 0; if (key.length !== key_length) { _free_and_throw_type_error(address_pool, "invalid key length"); } key_address = _to_allocated_buf_address(key); address_pool.push(key_address); // ---------- output cipher (buf) var cipher_length = (message_length) | 0, cipher = new AllocatedBuf(cipher_length), cipher_address = cipher.address; address_pool.push(cipher_address); // ---------- output mac (buf) var mac_length = (libsodium._crypto_secretbox_macbytes()) | 0, mac = new AllocatedBuf(mac_length), mac_address = mac.address; address_pool.push(mac_address); if ((libsodium._crypto_secretbox_detached(cipher_address, mac_address, message_address, message_length, 0, nonce_address, key_address) | 0) === 0) { var ret = _format_output({mac: mac, cipher: cipher}, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_secretbox_easy(message, nonce, key, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: nonce (buf) nonce = _any_to_Uint8Array(address_pool, nonce, "nonce"); var nonce_address, nonce_length = (libsodium._crypto_secretbox_noncebytes()) | 0; if (nonce.length !== nonce_length) { _free_and_throw_type_error(address_pool, "invalid nonce length"); } nonce_address = _to_allocated_buf_address(nonce); address_pool.push(nonce_address); // ---------- input: key (buf) key = _any_to_Uint8Array(address_pool, key, "key"); var key_address, key_length = (libsodium._crypto_secretbox_keybytes()) | 0; if (key.length !== key_length) { _free_and_throw_type_error(address_pool, "invalid key length"); } key_address = _to_allocated_buf_address(key); address_pool.push(key_address); // ---------- output cipher (buf) var cipher_length = (message_length + libsodium._crypto_secretbox_macbytes()) | 0, cipher = new AllocatedBuf(cipher_length), cipher_address = cipher.address; address_pool.push(cipher_address); if ((libsodium._crypto_secretbox_easy(cipher_address, message_address, message_length, 0, nonce_address, key_address) | 0) === 0) { var ret = _format_output(cipher, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_secretbox_open_detached(ciphertext, mac, nonce, key, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: ciphertext (unsized_buf) ciphertext = _any_to_Uint8Array(address_pool, ciphertext, "ciphertext"); var ciphertext_address = _to_allocated_buf_address(ciphertext), ciphertext_length = ciphertext.length; address_pool.push(ciphertext_address); // ---------- input: mac (buf) mac = _any_to_Uint8Array(address_pool, mac, "mac"); var mac_address, mac_length = (libsodium._crypto_secretbox_macbytes()) | 0; if (mac.length !== mac_length) { _free_and_throw_type_error(address_pool, "invalid mac length"); } mac_address = _to_allocated_buf_address(mac); address_pool.push(mac_address); // ---------- input: nonce (buf) nonce = _any_to_Uint8Array(address_pool, nonce, "nonce"); var nonce_address, nonce_length = (libsodium._crypto_secretbox_noncebytes()) | 0; if (nonce.length !== nonce_length) { _free_and_throw_type_error(address_pool, "invalid nonce length"); } nonce_address = _to_allocated_buf_address(nonce); address_pool.push(nonce_address); // ---------- input: key (buf) key = _any_to_Uint8Array(address_pool, key, "key"); var key_address, key_length = (libsodium._crypto_secretbox_keybytes()) | 0; if (key.length !== key_length) { _free_and_throw_type_error(address_pool, "invalid key length"); } key_address = _to_allocated_buf_address(key); address_pool.push(key_address); // ---------- output message (buf) var message_length = (ciphertext_length) | 0, message = new AllocatedBuf(message_length), message_address = message.address; address_pool.push(message_address); if ((libsodium._crypto_secretbox_open_detached(message_address, ciphertext_address, mac_address, ciphertext_length, 0, nonce_address, key_address) | 0) === 0) { var ret = _format_output(message, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_secretbox_open_easy(ciphertext, nonce, key, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: ciphertext (unsized_buf) ciphertext = _any_to_Uint8Array(address_pool, ciphertext, "ciphertext"); var ciphertext_address = _to_allocated_buf_address(ciphertext), ciphertext_length = ciphertext.length; address_pool.push(ciphertext_address); // ---------- input: nonce (buf) nonce = _any_to_Uint8Array(address_pool, nonce, "nonce"); var nonce_address, nonce_length = (libsodium._crypto_secretbox_noncebytes()) | 0; if (nonce.length !== nonce_length) { _free_and_throw_type_error(address_pool, "invalid nonce length"); } nonce_address = _to_allocated_buf_address(nonce); address_pool.push(nonce_address); // ---------- input: key (buf) key = _any_to_Uint8Array(address_pool, key, "key"); var key_address, key_length = (libsodium._crypto_secretbox_keybytes()) | 0; if (key.length !== key_length) { _free_and_throw_type_error(address_pool, "invalid key length"); } key_address = _to_allocated_buf_address(key); address_pool.push(key_address); // ---------- output message (buf) var message_length = (ciphertext_length - libsodium._crypto_secretbox_macbytes()) | 0, message = new AllocatedBuf(message_length), message_address = message.address; address_pool.push(message_address); if ((libsodium._crypto_secretbox_open_easy(message_address, ciphertext_address, ciphertext_length, 0, nonce_address, key_address) | 0) === 0) { var ret = _format_output(message, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_shorthash(message, key, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: key (buf) key = _any_to_Uint8Array(address_pool, key, "key"); var key_address, key_length = (libsodium._crypto_shorthash_keybytes()) | 0; if (key.length !== key_length) { _free_and_throw_type_error(address_pool, "invalid key length"); } key_address = _to_allocated_buf_address(key); address_pool.push(key_address); // ---------- output hash (buf) var hash_length = (libsodium._crypto_shorthash_bytes()) | 0, hash = new AllocatedBuf(hash_length), hash_address = hash.address; address_pool.push(hash_address); if ((libsodium._crypto_shorthash(hash_address, message_address, message_length, 0, key_address) | 0) === 0) { var ret = _format_output(hash, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_sign(message, privateKey, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: privateKey (buf) privateKey = _any_to_Uint8Array(address_pool, privateKey, "privateKey"); var privateKey_address, privateKey_length = (libsodium._crypto_sign_secretkeybytes()) | 0; if (privateKey.length !== privateKey_length) { _free_and_throw_type_error(address_pool, "invalid privateKey length"); } privateKey_address = _to_allocated_buf_address(privateKey); address_pool.push(privateKey_address); // ---------- output signature (buf) var signature_length = (message.length + libsodium._crypto_sign_bytes()) | 0, signature = new AllocatedBuf(signature_length), signature_address = signature.address; address_pool.push(signature_address); if ((libsodium._crypto_sign(signature_address, null, message_address, message_length, 0, privateKey_address) | 0) === 0) { var ret = _format_output(signature, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_sign_detached(message, privateKey, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: privateKey (buf) privateKey = _any_to_Uint8Array(address_pool, privateKey, "privateKey"); var privateKey_address, privateKey_length = (libsodium._crypto_sign_secretkeybytes()) | 0; if (privateKey.length !== privateKey_length) { _free_and_throw_type_error(address_pool, "invalid privateKey length"); } privateKey_address = _to_allocated_buf_address(privateKey); address_pool.push(privateKey_address); // ---------- output signature (buf) var signature_length = (libsodium._crypto_sign_bytes()) | 0, signature = new AllocatedBuf(signature_length), signature_address = signature.address; address_pool.push(signature_address); if ((libsodium._crypto_sign_detached(signature_address, null, message_address, message_length, 0, privateKey_address) | 0) === 0) { var ret = _format_output(signature, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_sign_ed25519_pk_to_curve25519(edPk, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: edPk (buf) edPk = _any_to_Uint8Array(address_pool, edPk, "edPk"); var edPk_address, edPk_length = (libsodium._crypto_sign_publickeybytes()) | 0; if (edPk.length !== edPk_length) { _free_and_throw_type_error(address_pool, "invalid edPk length"); } edPk_address = _to_allocated_buf_address(edPk); address_pool.push(edPk_address); // ---------- output cPk (buf) var cPk_length = (libsodium._crypto_scalarmult_scalarbytes()) | 0, cPk = new AllocatedBuf(cPk_length), cPk_address = cPk.address; address_pool.push(cPk_address); if ((libsodium._crypto_sign_ed25519_pk_to_curve25519(cPk_address, edPk_address) | 0) === 0) { var ret = _format_output(cPk, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_sign_ed25519_sk_to_curve25519(edSk, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: edSk (buf) edSk = _any_to_Uint8Array(address_pool, edSk, "edSk"); var edSk_address, edSk_length = (libsodium._crypto_sign_secretkeybytes()) | 0; if (edSk.length !== edSk_length) { _free_and_throw_type_error(address_pool, "invalid edSk length"); } edSk_address = _to_allocated_buf_address(edSk); address_pool.push(edSk_address); // ---------- output cSk (buf) var cSk_length = (libsodium._crypto_scalarmult_scalarbytes()) | 0, cSk = new AllocatedBuf(cSk_length), cSk_address = cSk.address; address_pool.push(cSk_address); if ((libsodium._crypto_sign_ed25519_sk_to_curve25519(cSk_address, edSk_address) | 0) === 0) { var ret = _format_output(cSk, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_sign_ed25519_sk_to_pk(privateKey, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: privateKey (buf) privateKey = _any_to_Uint8Array(address_pool, privateKey, "privateKey"); var privateKey_address, privateKey_length = (libsodium._crypto_sign_secretkeybytes()) | 0; if (privateKey.length !== privateKey_length) { _free_and_throw_type_error(address_pool, "invalid privateKey length"); } privateKey_address = _to_allocated_buf_address(privateKey); address_pool.push(privateKey_address); // ---------- output publicKey (buf) var publicKey_length = (libsodium._crypto_sign_publickeybytes()) | 0, publicKey = new AllocatedBuf(publicKey_length), publicKey_address = publicKey.address; address_pool.push(publicKey_address); if ((libsodium._crypto_sign_ed25519_sk_to_pk(publicKey_address, privateKey_address) | 0) === 0) { var ret = _format_output(publicKey, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_sign_ed25519_sk_to_seed(privateKey, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: privateKey (buf) privateKey = _any_to_Uint8Array(address_pool, privateKey, "privateKey"); var privateKey_address, privateKey_length = (libsodium._crypto_sign_secretkeybytes()) | 0; if (privateKey.length !== privateKey_length) { _free_and_throw_type_error(address_pool, "invalid privateKey length"); } privateKey_address = _to_allocated_buf_address(privateKey); address_pool.push(privateKey_address); // ---------- output seed (buf) var seed_length = (libsodium._crypto_sign_seedbytes()) | 0, seed = new AllocatedBuf(seed_length), seed_address = seed.address; address_pool.push(seed_address); if ((libsodium._crypto_sign_ed25519_sk_to_seed(seed_address, privateKey_address) | 0) === 0) { var ret = _format_output(seed, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_sign_keypair(outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- output publicKey (buf) var publicKey_length = (libsodium._crypto_sign_publickeybytes()) | 0, publicKey = new AllocatedBuf(publicKey_length), publicKey_address = publicKey.address; address_pool.push(publicKey_address); // ---------- output privateKey (buf) var privateKey_length = (libsodium._crypto_sign_secretkeybytes()) | 0, privateKey = new AllocatedBuf(privateKey_length), privateKey_address = privateKey.address; address_pool.push(privateKey_address); if ((libsodium._crypto_sign_keypair(publicKey_address, privateKey_address) | 0) === 0) { var ret = _format_output({publicKey: publicKey, privateKey: privateKey, keyType: 'ed25519'}, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_sign_open(signedMessage, publicKey, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: signedMessage (unsized_buf) signedMessage = _any_to_Uint8Array(address_pool, signedMessage, "signedMessage"); var signedMessage_address = _to_allocated_buf_address(signedMessage), signedMessage_length = signedMessage.length; address_pool.push(signedMessage_address); // ---------- input: publicKey (buf) publicKey = _any_to_Uint8Array(address_pool, publicKey, "publicKey"); var publicKey_address, publicKey_length = (libsodium._crypto_sign_publickeybytes()) | 0; if (publicKey.length !== publicKey_length) { _free_and_throw_type_error(address_pool, "invalid publicKey length"); } publicKey_address = _to_allocated_buf_address(publicKey); address_pool.push(publicKey_address); // ---------- output message (buf) var message_length = (signedMessage_length - libsodium._crypto_sign_bytes()) | 0, message = new AllocatedBuf(message_length), message_address = message.address; address_pool.push(message_address); if ((libsodium._crypto_sign_open(message_address, null, signedMessage_address, signedMessage_length, 0, publicKey_address) | 0) === 0) { var ret = _format_output(message, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_sign_seed_keypair(seed, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: seed (buf) seed = _any_to_Uint8Array(address_pool, seed, "seed"); var seed_address, seed_length = (libsodium._crypto_sign_seedbytes()) | 0; if (seed.length !== seed_length) { _free_and_throw_type_error(address_pool, "invalid seed length"); } seed_address = _to_allocated_buf_address(seed); address_pool.push(seed_address); // ---------- output publicKey (buf) var publicKey_length = (libsodium._crypto_sign_publickeybytes()) | 0, publicKey = new AllocatedBuf(publicKey_length), publicKey_address = publicKey.address; address_pool.push(publicKey_address); // ---------- output privateKey (buf) var privateKey_length = (libsodium._crypto_sign_secretkeybytes()) | 0, privateKey = new AllocatedBuf(privateKey_length), privateKey_address = privateKey.address; address_pool.push(privateKey_address); if ((libsodium._crypto_sign_seed_keypair(publicKey_address, privateKey_address, seed_address) | 0) === 0) { var ret = _format_output({publicKey: publicKey, privateKey: privateKey, keyType: "ed25519"}, outputFormat); _free_all(address_pool); return ret; } _free_and_throw_error(address_pool); } function crypto_sign_verify_detached(signature, message, publicKey) { var address_pool = []; // ---------- input: signature (buf) signature = _any_to_Uint8Array(address_pool, signature, "signature"); var signature_address, signature_length = (libsodium._crypto_sign_bytes()) | 0; if (signature.length !== signature_length) { _free_and_throw_type_error(address_pool, "invalid signature length"); } signature_address = _to_allocated_buf_address(signature); address_pool.push(signature_address); // ---------- input: message (unsized_buf) message = _any_to_Uint8Array(address_pool, message, "message"); var message_address = _to_allocated_buf_address(message), message_length = message.length; address_pool.push(message_address); // ---------- input: publicKey (buf) publicKey = _any_to_Uint8Array(address_pool, publicKey, "publicKey"); var publicKey_address, publicKey_length = (libsodium._crypto_sign_publickeybytes()) | 0; if (publicKey.length !== publicKey_length) { _free_and_throw_type_error(address_pool, "invalid publicKey length"); } publicKey_address = _to_allocated_buf_address(publicKey); address_pool.push(publicKey_address); var verificationResult = libsodium._crypto_sign_verify_detached(signature_address, message_address, message_length, 0, publicKey_address) | 0; var ret = (verificationResult === 0); _free_all(address_pool); return ret; } function randombytes_buf(length, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: length (uint) _require_defined(address_pool, length, "length"); if (!(typeof length === "number" && (length | 0) === length) && (length | 0) > 0) { _free_and_throw_type_error(address_pool, "length must be an unsigned integer"); } // ---------- output output (buf) var output_length = (length) | 0, output = new AllocatedBuf(output_length), output_address = output.address; address_pool.push(output_address); libsodium._randombytes_buf(output_address, length); var ret = (_format_output(output, outputFormat)); _free_all(address_pool); return ret; } function randombytes_close(outputFormat) { var address_pool = []; _check_output_format(outputFormat); libsodium._randombytes_close(); } function randombytes_random(outputFormat) { var address_pool = []; _check_output_format(outputFormat); var random_value = libsodium._randombytes_random() >>> 0; var ret = (random_value); _free_all(address_pool); return ret; } function randombytes_set_implementation(implementation, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: implementation (randombytes_implementation) var implementation_address = libsodium._malloc(6 * 4); for (var i = 0; i < 6; i++) { libsodium.setValue(implementation_address + i * 4, libsodium.Runtime.addFunction(implementation [["implementation_name", "random", "stir", "uniform", "buf", "close"][i]]), "i32"); } if ((libsodium._randombytes_set_implementation(implementation_address) | 0) === 0) { _free_all(address_pool); return; } _free_and_throw_error(address_pool); } function randombytes_stir(outputFormat) { var address_pool = []; _check_output_format(outputFormat); libsodium._randombytes_stir(); } function randombytes_uniform(upper_bound, outputFormat) { var address_pool = []; _check_output_format(outputFormat); // ---------- input: upper_bound (uint) _require_defined(address_pool, upper_bound, "upper_bound"); if (!(typeof upper_bound === "number" && (upper_bound | 0) === upper_bound) && (upper_bound | 0) > 0) { _free_and_throw_type_error(address_pool, "upper_bound must be an unsigned integer"); } var random_value = libsodium._randombytes_uniform(upper_bound) >>> 0; var ret = (random_value); _free_all(address_pool); return ret; } function sodium_version_string() { var address_pool = []; var version = libsodium._sodium_version_string(); var ret = (libsodium.Pointer_stringify(version)); _free_all(address_pool); return ret; } exports.compare = compare; exports.from_base64 = from_base64; exports.from_hex = from_hex; exports.from_string = from_string; exports.increment = increment; exports.libsodium = libsodium; exports.memcmp = memcmp; exports.memzero = memzero; exports.output_formats = output_formats; exports.symbols = symbols; exports.to_base64 = to_base64; exports.to_hex = to_hex; exports.to_string = to_string; var exported_functions = ["crypto_aead_chacha20poly1305_decrypt", "crypto_aead_chacha20poly1305_encrypt", "crypto_aead_chacha20poly1305_ietf_decrypt", "crypto_aead_chacha20poly1305_ietf_encrypt", "crypto_auth", "crypto_auth_hmacsha256", "crypto_auth_hmacsha256_verify", "crypto_auth_hmacsha512", "crypto_auth_hmacsha512_verify", "crypto_auth_verify", "crypto_box_beforenm", "crypto_box_detached", "crypto_box_easy", "crypto_box_easy_afternm", "crypto_box_keypair", "crypto_box_open_detached", "crypto_box_open_easy", "crypto_box_open_easy_afternm", "crypto_box_seal", "crypto_box_seal_open", "crypto_box_seed_keypair", "crypto_generichash", "crypto_generichash_final", "crypto_generichash_init", "crypto_generichash_update", "crypto_hash", "crypto_hash_sha256", "crypto_hash_sha512", "crypto_onetimeauth", "crypto_onetimeauth_final", "crypto_onetimeauth_init", "crypto_onetimeauth_update", "crypto_onetimeauth_verify", "crypto_pwhash_scryptsalsa208sha256", "crypto_pwhash_scryptsalsa208sha256_ll", "crypto_pwhash_scryptsalsa208sha256_str", "crypto_pwhash_scryptsalsa208sha256_str_verify", "crypto_scalarmult", "crypto_scalarmult_base", "crypto_secretbox_detached", "crypto_secretbox_easy", "crypto_secretbox_open_detached", "crypto_secretbox_open_easy", "crypto_shorthash", "crypto_sign", "crypto_sign_detached", "crypto_sign_ed25519_pk_to_curve25519", "crypto_sign_ed25519_sk_to_curve25519", "crypto_sign_ed25519_sk_to_pk", "crypto_sign_ed25519_sk_to_seed", "crypto_sign_keypair", "crypto_sign_open", "crypto_sign_seed_keypair", "crypto_sign_verify_detached", "randombytes_buf", "randombytes_close", "randombytes_random", "randombytes_set_implementation", "randombytes_stir", "randombytes_uniform", "sodium_version_string"], functions = [crypto_aead_chacha20poly1305_decrypt, crypto_aead_chacha20poly1305_encrypt, crypto_aead_chacha20poly1305_ietf_decrypt, crypto_aead_chacha20poly1305_ietf_encrypt, crypto_auth, crypto_auth_hmacsha256, crypto_auth_hmacsha256_verify, crypto_auth_hmacsha512, crypto_auth_hmacsha512_verify, crypto_auth_verify, crypto_box_beforenm, crypto_box_detached, crypto_box_easy, crypto_box_easy_afternm, crypto_box_keypair, crypto_box_open_detached, crypto_box_open_easy, crypto_box_open_easy_afternm, crypto_box_seal, crypto_box_seal_open, crypto_box_seed_keypair, crypto_generichash, crypto_generichash_final, crypto_generichash_init, crypto_generichash_update, crypto_hash, crypto_hash_sha256, crypto_hash_sha512, crypto_onetimeauth, crypto_onetimeauth_final, crypto_onetimeauth_init, crypto_onetimeauth_update, crypto_onetimeauth_verify, crypto_pwhash_scryptsalsa208sha256, crypto_pwhash_scryptsalsa208sha256_ll, crypto_pwhash_scryptsalsa208sha256_str, crypto_pwhash_scryptsalsa208sha256_str_verify, crypto_scalarmult, crypto_scalarmult_base, crypto_secretbox_detached, crypto_secretbox_easy, crypto_secretbox_open_detached, crypto_secretbox_open_easy, crypto_shorthash, crypto_sign, crypto_sign_detached, crypto_sign_ed25519_pk_to_curve25519, crypto_sign_ed25519_sk_to_curve25519, crypto_sign_ed25519_sk_to_pk, crypto_sign_ed25519_sk_to_seed, crypto_sign_keypair, crypto_sign_open, crypto_sign_seed_keypair, crypto_sign_verify_detached, randombytes_buf, randombytes_close, randombytes_random, randombytes_set_implementation, randombytes_stir, randombytes_uniform, sodium_version_string]; for (var i = 0; i < functions.length; i++) { if (typeof libsodium["_" + exported_functions[i]] === "function") { exports[exported_functions[i]] = functions[i]; } } var constants = ["SODIUM_LIBRARY_VERSION_MAJOR", "SODIUM_LIBRARY_VERSION_MINOR", "crypto_aead_chacha20poly1305_ABYTES", "crypto_aead_chacha20poly1305_KEYBYTES", "crypto_aead_chacha20poly1305_NPUBBYTES", "crypto_aead_chacha20poly1305_NSECBYTES", "crypto_aead_chacha20poly1305_ietf_NPUBBYTES", "crypto_auth_BYTES", "crypto_auth_KEYBYTES", "crypto_auth_hmacsha256_BYTES", "crypto_auth_hmacsha256_KEYBYTES", "crypto_auth_hmacsha512_BYTES", "crypto_auth_hmacsha512_KEYBYTES", "crypto_box_BEFORENMBYTES", "crypto_box_MACBYTES", "crypto_box_NONCEBYTES", "crypto_box_PUBLICKEYBYTES", "crypto_box_SEALBYTES", "crypto_box_SECRETKEYBYTES", "crypto_box_SEEDBYTES", "crypto_generichash_BYTES", "crypto_generichash_BYTES_MAX", "crypto_generichash_BYTES_MIN", "crypto_generichash_KEYBYTES", "crypto_generichash_KEYBYTES_MAX", "crypto_generichash_KEYBYTES_MIN", "crypto_hash_BYTES", "crypto_onetimeauth_BYTES", "crypto_onetimeauth_KEYBYTES", "crypto_pwhash_scryptsalsa208sha256_MEMLIMIT_INTERACTIVE", "crypto_pwhash_scryptsalsa208sha256_MEMLIMIT_SENSITIVE", "crypto_pwhash_scryptsalsa208sha256_OPSLIMIT_INTERACTIVE", "crypto_pwhash_scryptsalsa208sha256_OPSLIMIT_SENSITIVE", "crypto_pwhash_scryptsalsa208sha256_SALTBYTES", "crypto_pwhash_scryptsalsa208sha256_STRBYTES", "crypto_pwhash_scryptsalsa208sha256_STR_VERIFY", "crypto_scalarmult_BYTES", "crypto_scalarmult_SCALARBYTES", "crypto_secretbox_KEYBYTES", "crypto_secretbox_MACBYTES", "crypto_secretbox_NONCEBYTES", "crypto_shorthash_BYTES", "crypto_shorthash_KEYBYTES", "crypto_sign_BYTES", "crypto_sign_PUBLICKEYBYTES", "crypto_sign_SECRETKEYBYTES", "crypto_sign_SEEDBYTES"]; for (var i = 0; i < constants.length; i++) { var raw = libsodium["_" + constants[i].toLowerCase()]; if (typeof raw === "function") exports[constants[i]] = raw()|0; } var constants_str = ["SODIUM_VERSION_STRING", "crypto_pwhash_scryptsalsa208sha256_STRPREFIX"]; for (var i = 0; i < constants_str.length; i++) { var raw = libsodium["_" + constants_str[i].toLowerCase()]; if (typeof raw === "function") exports[constants_str[i]] = libsodium.Pointer_stringify(raw()); } return exports; })); }).call(this,require('_process')) },{"_process":295,"libsodium":223}],223:[function(require,module,exports){ (function (process,Buffer,__dirname){ (function (root, factory) { if (typeof define === "function" && define.amd) { define(["exports"], factory); } else if (typeof exports === 'object' && typeof exports.nodeName !== 'string') { factory(exports); } else { factory(root.libsodium = {}); } })(this, function (exports) { "use strict"; var Module = exports; Object.defineProperty(exports, '__esModule', { value: true }); var Module;if(!Module)Module=(typeof Module!=="undefined"?Module:null)||{};var moduleOverrides={};for(var key in Module){if(Module.hasOwnProperty(key)){moduleOverrides[key]=Module[key]}}var ENVIRONMENT_IS_WEB=typeof window==="object";var ENVIRONMENT_IS_WORKER=typeof importScripts==="function";var ENVIRONMENT_IS_NODE=typeof process==="object"&&typeof require==="function"&&!ENVIRONMENT_IS_WEB&&!ENVIRONMENT_IS_WORKER;var ENVIRONMENT_IS_SHELL=!ENVIRONMENT_IS_WEB&&!ENVIRONMENT_IS_NODE&&!ENVIRONMENT_IS_WORKER;if(ENVIRONMENT_IS_NODE){if(!Module["print"])Module["print"]=function print(x){process["stdout"].write(x+"\n")};if(!Module["printErr"])Module["printErr"]=function printErr(x){process["stderr"].write(x+"\n")};var nodeFS=require("fs");var nodePath=require("path");Module["read"]=function read(filename,binary){filename=nodePath["normalize"](filename);var ret=nodeFS["readFileSync"](filename);if(!ret&&filename!=nodePath["resolve"](filename)){filename=path.join(__dirname,"..","src",filename);ret=nodeFS["readFileSync"](filename)}if(ret&&!binary)ret=ret.toString();return ret};Module["readBinary"]=function readBinary(filename){var ret=Module["read"](filename,true);if(!ret.buffer){ret=new Uint8Array(ret)}assert(ret.buffer);return ret};Module["load"]=function load(f){globalEval(read(f))};if(!Module["thisProgram"]){if(process["argv"].length>1){Module["thisProgram"]=process["argv"][1].replace(/\\/g,"/")}else{Module["thisProgram"]="unknown-program"}}Module["arguments"]=process["argv"].slice(2);if(typeof module!=="undefined"){module["exports"]=Module}process["on"]("uncaughtException",(function(ex){if(!(ex instanceof ExitStatus)){throw ex}}));Module["inspect"]=(function(){return"[Emscripten Module object]"})}else if(ENVIRONMENT_IS_SHELL){if(!Module["print"])Module["print"]=print;if(typeof printErr!="undefined")Module["printErr"]=printErr;if(typeof read!="undefined"){Module["read"]=read}else{Module["read"]=function read(){throw"no read() available (jsc?)"}}Module["readBinary"]=function readBinary(f){if(typeof readbuffer==="function"){return new Uint8Array(readbuffer(f))}var data=read(f,"binary");assert(typeof data==="object");return data};if(typeof scriptArgs!="undefined"){Module["arguments"]=scriptArgs}else if(typeof arguments!="undefined"){Module["arguments"]=arguments}}else if(ENVIRONMENT_IS_WEB||ENVIRONMENT_IS_WORKER){Module["read"]=function read(url){var xhr=new XMLHttpRequest;xhr.open("GET",url,false);xhr.send(null);return xhr.responseText};if(typeof arguments!="undefined"){Module["arguments"]=arguments}if(typeof console!=="undefined"){if(!Module["print"])Module["print"]=function print(x){console.log(x)};if(!Module["printErr"])Module["printErr"]=function printErr(x){console.log(x)}}else{var TRY_USE_DUMP=false;if(!Module["print"])Module["print"]=TRY_USE_DUMP&&typeof dump!=="undefined"?(function(x){dump(x)}):(function(x){})}if(ENVIRONMENT_IS_WORKER){Module["load"]=importScripts}if(typeof Module["setWindowTitle"]==="undefined"){Module["setWindowTitle"]=(function(title){document.title=title})}}else{throw"Unknown runtime environment. Where are we?"}function globalEval(x){throw"NO_DYNAMIC_EXECUTION was set, cannot eval"}if(!Module["load"]&&Module["read"]){Module["load"]=function load(f){globalEval(Module["read"](f))}}if(!Module["print"]){Module["print"]=(function(){})}if(!Module["printErr"]){Module["printErr"]=Module["print"]}if(!Module["arguments"]){Module["arguments"]=[]}if(!Module["thisProgram"]){Module["thisProgram"]="./this.program"}Module.print=Module["print"];Module.printErr=Module["printErr"];Module["preRun"]=[];Module["postRun"]=[];for(var key in moduleOverrides){if(moduleOverrides.hasOwnProperty(key)){Module[key]=moduleOverrides[key]}}var Runtime={setTempRet0:(function(value){tempRet0=value}),getTempRet0:(function(){return tempRet0}),stackSave:(function(){return STACKTOP}),stackRestore:(function(stackTop){STACKTOP=stackTop}),getNativeTypeSize:(function(type){switch(type){case"i1":case"i8":return 1;case"i16":return 2;case"i32":return 4;case"i64":return 8;case"float":return 4;case"double":return 8;default:{if(type[type.length-1]==="*"){return Runtime.QUANTUM_SIZE}else if(type[0]==="i"){var bits=parseInt(type.substr(1));assert(bits%8===0);return bits/8}else{return 0}}}}),getNativeFieldSize:(function(type){return Math.max(Runtime.getNativeTypeSize(type),Runtime.QUANTUM_SIZE)}),STACK_ALIGN:16,prepVararg:(function(ptr,type){if(type==="double"||type==="i64"){if(ptr&7){assert((ptr&7)===4);ptr+=4}}else{assert((ptr&3)===0)}return ptr}),getAlignSize:(function(type,size,vararg){if(!vararg&&(type=="i64"||type=="double"))return 8;if(!type)return Math.min(size,8);return Math.min(size||(type?Runtime.getNativeFieldSize(type):0),Runtime.QUANTUM_SIZE)}),dynCall:(function(sig,ptr,args){if(args&&args.length){if(!args.splice)args=Array.prototype.slice.call(args);args.splice(0,0,ptr);return Module["dynCall_"+sig].apply(null,args)}else{return Module["dynCall_"+sig].call(null,ptr)}}),functionPointers:[null,null,null,null,null,null,null,null],addFunction:(function(func){for(var i=0;i=TOTAL_MEMORY){var success=enlargeMemory();if(!success){DYNAMICTOP=ret;return 0}}return ret}),alignMemory:(function(size,quantum){var ret=size=Math.ceil(size/(quantum?quantum:16))*(quantum?quantum:16);return ret}),makeBigInt:(function(low,high,unsigned){var ret=unsigned?+(low>>>0)+ +(high>>>0)*+4294967296:+(low>>>0)+ +(high|0)*+4294967296;return ret}),GLOBAL_BASE:8,QUANTUM_SIZE:4,__dummy__:0};Module["Runtime"]=Runtime;var __THREW__=0;var ABORT=false;var EXITSTATUS=0;var undef=0;var tempValue,tempInt,tempBigInt,tempInt2,tempBigInt2,tempPair,tempBigIntI,tempBigIntR,tempBigIntS,tempBigIntP,tempBigIntD,tempDouble,tempFloat;var tempI64,tempI64b;var tempRet0,tempRet1,tempRet2,tempRet3,tempRet4,tempRet5,tempRet6,tempRet7,tempRet8,tempRet9;function assert(condition,text){if(!condition){abort("Assertion failed: "+text)}}var globalScope=this;function getCFunc(ident){var func=Module["_"+ident];if(!func){abort("NO_DYNAMIC_EXECUTION was set, cannot eval - ccall/cwrap are not functional")}assert(func,"Cannot call unknown function "+ident+" (perhaps LLVM optimizations or closure removed it?)");return func}var cwrap,ccall;((function(){var JSfuncs={"stackSave":(function(){Runtime.stackSave()}),"stackRestore":(function(){Runtime.stackRestore()}),"arrayToC":(function(arr){var ret=Runtime.stackAlloc(arr.length);writeArrayToMemory(arr,ret);return ret}),"stringToC":(function(str){var ret=0;if(str!==null&&str!==undefined&&str!==0){ret=Runtime.stackAlloc((str.length<<2)+1);writeStringToMemory(str,ret)}return ret})};var toC={"string":JSfuncs["stringToC"],"array":JSfuncs["arrayToC"]};ccall=function ccallFunc(ident,returnType,argTypes,args,opts){var func=getCFunc(ident);var cArgs=[];var stack=0;if(args){for(var i=0;i>0]=value;break;case"i8":HEAP8[ptr>>0]=value;break;case"i16":HEAP16[ptr>>1]=value;break;case"i32":HEAP32[ptr>>2]=value;break;case"i64":tempI64=[value>>>0,(tempDouble=value,+Math_abs(tempDouble)>=+1?tempDouble>+0?(Math_min(+Math_floor(tempDouble/+4294967296),+4294967295)|0)>>>0:~~+Math_ceil((tempDouble- +(~~tempDouble>>>0))/+4294967296)>>>0:0)],HEAP32[ptr>>2]=tempI64[0],HEAP32[ptr+4>>2]=tempI64[1];break;case"float":HEAPF32[ptr>>2]=value;break;case"double":HEAPF64[ptr>>3]=value;break;default:abort("invalid type for setValue: "+type)}}Module["setValue"]=setValue;function getValue(ptr,type,noSafe){type=type||"i8";if(type.charAt(type.length-1)==="*")type="i32";switch(type){case"i1":return HEAP8[ptr>>0];case"i8":return HEAP8[ptr>>0];case"i16":return HEAP16[ptr>>1];case"i32":return HEAP32[ptr>>2];case"i64":return HEAP32[ptr>>2];case"float":return HEAPF32[ptr>>2];case"double":return HEAPF64[ptr>>3];default:abort("invalid type for setValue: "+type)}return null}Module["getValue"]=getValue;var ALLOC_NORMAL=0;var ALLOC_STACK=1;var ALLOC_STATIC=2;var ALLOC_DYNAMIC=3;var ALLOC_NONE=4;Module["ALLOC_NORMAL"]=ALLOC_NORMAL;Module["ALLOC_STACK"]=ALLOC_STACK;Module["ALLOC_STATIC"]=ALLOC_STATIC;Module["ALLOC_DYNAMIC"]=ALLOC_DYNAMIC;Module["ALLOC_NONE"]=ALLOC_NONE;function allocate(slab,types,allocator,ptr){var zeroinit,size;if(typeof slab==="number"){zeroinit=true;size=slab}else{zeroinit=false;size=slab.length}var singleType=typeof types==="string"?types:null;var ret;if(allocator==ALLOC_NONE){ret=ptr}else{ret=[_malloc,Runtime.stackAlloc,Runtime.staticAlloc,Runtime.dynamicAlloc][allocator===undefined?ALLOC_STATIC:allocator](Math.max(size,singleType?1:types.length))}if(zeroinit){var ptr=ret,stop;assert((ret&3)==0);stop=ret+(size&~3);for(;ptr>2]=0}stop=ret+size;while(ptr>0]=0}return ret}if(singleType==="i8"){if(slab.subarray||slab.slice){HEAPU8.set(slab,ret)}else{HEAPU8.set(new Uint8Array(slab),ret)}return ret}var i=0,type,typeSize,previousType;while(i>0];hasUtf|=t;if(t==0&&!length)break;i++;if(length&&i==length)break}if(!length)length=i;var ret="";if(hasUtf<128){var MAX_CHUNK=1024;var curr;while(length>0){curr=String.fromCharCode.apply(String,HEAPU8.subarray(ptr,ptr+Math.min(length,MAX_CHUNK)));ret=ret?ret+curr:curr;ptr+=MAX_CHUNK;length-=MAX_CHUNK}return ret}return Module["UTF8ToString"](ptr)}Module["Pointer_stringify"]=Pointer_stringify;function AsciiToString(ptr){var str="";while(1){var ch=HEAP8[ptr++>>0];if(!ch)return str;str+=String.fromCharCode(ch)}}Module["AsciiToString"]=AsciiToString;function stringToAscii(str,outPtr){return writeAsciiToMemory(str,outPtr,false)}Module["stringToAscii"]=stringToAscii;function UTF8ArrayToString(u8Array,idx){var u0,u1,u2,u3,u4,u5;var str="";while(1){u0=u8Array[idx++];if(!u0)return str;if(!(u0&128)){str+=String.fromCharCode(u0);continue}u1=u8Array[idx++]&63;if((u0&224)==192){str+=String.fromCharCode((u0&31)<<6|u1);continue}u2=u8Array[idx++]&63;if((u0&240)==224){u0=(u0&15)<<12|u1<<6|u2}else{u3=u8Array[idx++]&63;if((u0&248)==240){u0=(u0&7)<<18|u1<<12|u2<<6|u3}else{u4=u8Array[idx++]&63;if((u0&252)==248){u0=(u0&3)<<24|u1<<18|u2<<12|u3<<6|u4}else{u5=u8Array[idx++]&63;u0=(u0&1)<<30|u1<<24|u2<<18|u3<<12|u4<<6|u5}}}if(u0<65536){str+=String.fromCharCode(u0)}else{var ch=u0-65536;str+=String.fromCharCode(55296|ch>>10,56320|ch&1023)}}}Module["UTF8ArrayToString"]=UTF8ArrayToString;function UTF8ToString(ptr){return UTF8ArrayToString(HEAPU8,ptr)}Module["UTF8ToString"]=UTF8ToString;function stringToUTF8Array(str,outU8Array,outIdx,maxBytesToWrite){if(!(maxBytesToWrite>0))return 0;var startIdx=outIdx;var endIdx=outIdx+maxBytesToWrite-1;for(var i=0;i=55296&&u<=57343)u=65536+((u&1023)<<10)|str.charCodeAt(++i)&1023;if(u<=127){if(outIdx>=endIdx)break;outU8Array[outIdx++]=u}else if(u<=2047){if(outIdx+1>=endIdx)break;outU8Array[outIdx++]=192|u>>6;outU8Array[outIdx++]=128|u&63}else if(u<=65535){if(outIdx+2>=endIdx)break;outU8Array[outIdx++]=224|u>>12;outU8Array[outIdx++]=128|u>>6&63;outU8Array[outIdx++]=128|u&63}else if(u<=2097151){if(outIdx+3>=endIdx)break;outU8Array[outIdx++]=240|u>>18;outU8Array[outIdx++]=128|u>>12&63;outU8Array[outIdx++]=128|u>>6&63;outU8Array[outIdx++]=128|u&63}else if(u<=67108863){if(outIdx+4>=endIdx)break;outU8Array[outIdx++]=248|u>>24;outU8Array[outIdx++]=128|u>>18&63;outU8Array[outIdx++]=128|u>>12&63;outU8Array[outIdx++]=128|u>>6&63;outU8Array[outIdx++]=128|u&63}else{if(outIdx+5>=endIdx)break;outU8Array[outIdx++]=252|u>>30;outU8Array[outIdx++]=128|u>>24&63;outU8Array[outIdx++]=128|u>>18&63;outU8Array[outIdx++]=128|u>>12&63;outU8Array[outIdx++]=128|u>>6&63;outU8Array[outIdx++]=128|u&63}}outU8Array[outIdx]=0;return outIdx-startIdx}Module["stringToUTF8Array"]=stringToUTF8Array;function stringToUTF8(str,outPtr,maxBytesToWrite){return stringToUTF8Array(str,HEAPU8,outPtr,maxBytesToWrite)}Module["stringToUTF8"]=stringToUTF8;function lengthBytesUTF8(str){var len=0;for(var i=0;i=55296&&u<=57343)u=65536+((u&1023)<<10)|str.charCodeAt(++i)&1023;if(u<=127){++len}else if(u<=2047){len+=2}else if(u<=65535){len+=3}else if(u<=2097151){len+=4}else if(u<=67108863){len+=5}else{len+=6}}return len}Module["lengthBytesUTF8"]=lengthBytesUTF8;function UTF16ToString(ptr){var i=0;var str="";while(1){var codeUnit=HEAP16[ptr+i*2>>1];if(codeUnit==0)return str;++i;str+=String.fromCharCode(codeUnit)}}Module["UTF16ToString"]=UTF16ToString;function stringToUTF16(str,outPtr,maxBytesToWrite){if(maxBytesToWrite===undefined){maxBytesToWrite=2147483647}if(maxBytesToWrite<2)return 0;maxBytesToWrite-=2;var startPtr=outPtr;var numCharsToWrite=maxBytesToWrite>1]=codeUnit;outPtr+=2}HEAP16[outPtr>>1]=0;return outPtr-startPtr}Module["stringToUTF16"]=stringToUTF16;function lengthBytesUTF16(str){return str.length*2}Module["lengthBytesUTF16"]=lengthBytesUTF16;function UTF32ToString(ptr){var i=0;var str="";while(1){var utf32=HEAP32[ptr+i*4>>2];if(utf32==0)return str;++i;if(utf32>=65536){var ch=utf32-65536;str+=String.fromCharCode(55296|ch>>10,56320|ch&1023)}else{str+=String.fromCharCode(utf32)}}}Module["UTF32ToString"]=UTF32ToString;function stringToUTF32(str,outPtr,maxBytesToWrite){if(maxBytesToWrite===undefined){maxBytesToWrite=2147483647}if(maxBytesToWrite<4)return 0;var startPtr=outPtr;var endPtr=startPtr+maxBytesToWrite-4;for(var i=0;i=55296&&codeUnit<=57343){var trailSurrogate=str.charCodeAt(++i);codeUnit=65536+((codeUnit&1023)<<10)|trailSurrogate&1023}HEAP32[outPtr>>2]=codeUnit;outPtr+=4;if(outPtr+4>endPtr)break}HEAP32[outPtr>>2]=0;return outPtr-startPtr}Module["stringToUTF32"]=stringToUTF32;function lengthBytesUTF32(str){var len=0;for(var i=0;i=55296&&codeUnit<=57343)++i;len+=4}return len}Module["lengthBytesUTF32"]=lengthBytesUTF32;function demangle(func){var hasLibcxxabi=!!Module["___cxa_demangle"];if(hasLibcxxabi){try{var buf=_malloc(func.length);writeStringToMemory(func.substr(1),buf);var status=_malloc(4);var ret=Module["___cxa_demangle"](buf,0,0,status);if(getValue(status,"i32")===0&&ret){return Pointer_stringify(ret)}}catch(e){}finally{if(buf)_free(buf);if(status)_free(status);if(ret)_free(ret)}}var i=3;var basicTypes={"v":"void","b":"bool","c":"char","s":"short","i":"int","l":"long","f":"float","d":"double","w":"wchar_t","a":"signed char","h":"unsigned char","t":"unsigned short","j":"unsigned int","m":"unsigned long","x":"long long","y":"unsigned long long","z":"..."};var subs=[];var first=true;function dump(x){if(x)Module.print(x);Module.print(func);var pre="";for(var a=0;a"}else{ret=name}paramLoop:while(i0){var c=func[i++];if(c in basicTypes){list.push(basicTypes[c])}else{switch(c){case"P":list.push(parse(true,1,true)[0]+"*");break;case"R":list.push(parse(true,1,true)[0]+"&");break;case"L":{i++;var end=func.indexOf("E",i);var size=end-i;list.push(func.substr(i,size));i+=size+2;break};case"A":{var size=parseInt(func.substr(i));i+=size.toString().length;if(func[i]!=="_")throw"?";i++;list.push(parse(true,1,true)[0]+" ["+size+"]");break};case"E":break paramLoop;default:ret+="?"+c;break paramLoop}}}if(!allowVoid&&list.length===1&&list[0]==="void")list=[];if(rawList){if(ret){list.push(ret+"?")}return list}else{return ret+flushList()}}var parsed=func;try{if(func=="Object._main"||func=="_main"){return"main()"}if(typeof func==="number")func=Pointer_stringify(func);if(func[0]!=="_")return func;if(func[1]!=="_")return func;if(func[2]!=="Z")return func;switch(func[3]){case"n":return"operator new()";case"d":return"operator delete()"}parsed=parse()}catch(e){parsed+="?"}if(parsed.indexOf("?")>=0&&!hasLibcxxabi){Runtime.warnOnce("warning: a problem occurred in builtin C++ name demangling; build with -s DEMANGLE_SUPPORT=1 to link in libcxxabi demangling")}return parsed}function demangleAll(text){return text.replace(/__Z[\w\d_]+/g,(function(x){var y=demangle(x);return x===y?x:x+" ["+y+"]"}))}function jsStackTrace(){var err=new Error;if(!err.stack){try{throw new Error(0)}catch(e){err=e}if(!err.stack){return"(no stack trace available)"}}return err.stack.toString()}function stackTrace(){return demangleAll(jsStackTrace())}Module["stackTrace"]=stackTrace;var PAGE_SIZE=4096;function alignMemoryPage(x){if(x%4096>0){x+=4096-x%4096}return x}var HEAP;var HEAP8,HEAPU8,HEAP16,HEAPU16,HEAP32,HEAPU32,HEAPF32,HEAPF64;var STATIC_BASE=0,STATICTOP=0,staticSealed=false;var STACK_BASE=0,STACKTOP=0,STACK_MAX=0;var DYNAMIC_BASE=0,DYNAMICTOP=0;function abortOnCannotGrowMemory(){abort("Cannot enlarge memory arrays. Either (1) compile with -s TOTAL_MEMORY=X with X higher than the current value "+TOTAL_MEMORY+", (2) compile with -s ALLOW_MEMORY_GROWTH=1 which adjusts the size at runtime but prevents some optimizations, (3) set Module.TOTAL_MEMORY to a higher value before the program runs, or if you want malloc to return NULL (0) instead of this abort, compile with -s ABORTING_MALLOC=0 ")}function enlargeMemory(){abortOnCannotGrowMemory()}var TOTAL_STACK=Module["TOTAL_STACK"]||5242880;var TOTAL_MEMORY=Module["TOTAL_MEMORY"]||33554432;var totalMemory=64*1024;while(totalMemory0){var callback=callbacks.shift();if(typeof callback=="function"){callback();continue}var func=callback.func;if(typeof func==="number"){if(callback.arg===undefined){Runtime.dynCall("v",func)}else{Runtime.dynCall("vi",func,[callback.arg])}}else{func(callback.arg===undefined?null:callback.arg)}}}var __ATPRERUN__=[];var __ATINIT__=[];var __ATMAIN__=[];var __ATEXIT__=[];var __ATPOSTRUN__=[];var runtimeInitialized=false;var runtimeExited=false;function preRun(){if(Module["preRun"]){if(typeof Module["preRun"]=="function")Module["preRun"]=[Module["preRun"]];while(Module["preRun"].length){addOnPreRun(Module["preRun"].shift())}}callRuntimeCallbacks(__ATPRERUN__)}function ensureInitRuntime(){if(runtimeInitialized)return;runtimeInitialized=true;callRuntimeCallbacks(__ATINIT__)}function preMain(){callRuntimeCallbacks(__ATMAIN__)}function exitRuntime(){callRuntimeCallbacks(__ATEXIT__);runtimeExited=true}function postRun(){if(Module["postRun"]){if(typeof Module["postRun"]=="function")Module["postRun"]=[Module["postRun"]];while(Module["postRun"].length){addOnPostRun(Module["postRun"].shift())}}callRuntimeCallbacks(__ATPOSTRUN__)}function addOnPreRun(cb){__ATPRERUN__.unshift(cb)}Module["addOnPreRun"]=addOnPreRun;function addOnInit(cb){__ATINIT__.unshift(cb)}Module["addOnInit"]=addOnInit;function addOnPreMain(cb){__ATMAIN__.unshift(cb)}Module["addOnPreMain"]=addOnPreMain;function addOnExit(cb){__ATEXIT__.unshift(cb)}Module["addOnExit"]=addOnExit;function addOnPostRun(cb){__ATPOSTRUN__.unshift(cb)}Module["addOnPostRun"]=addOnPostRun;function intArrayFromString(stringy,dontAddNull,length){var len=length>0?length:lengthBytesUTF8(stringy)+1;var u8array=new Array(len);var numBytesWritten=stringToUTF8Array(stringy,u8array,0,u8array.length);if(dontAddNull)u8array.length=numBytesWritten;return u8array}Module["intArrayFromString"]=intArrayFromString;function intArrayToString(array){var ret=[];for(var i=0;i255){chr&=255}ret.push(String.fromCharCode(chr))}return ret.join("")}Module["intArrayToString"]=intArrayToString;function writeStringToMemory(string,buffer,dontAddNull){var array=intArrayFromString(string,dontAddNull);var i=0;while(i>0]=chr;i=i+1}}Module["writeStringToMemory"]=writeStringToMemory;function writeArrayToMemory(array,buffer){for(var i=0;i>0]=array[i]}}Module["writeArrayToMemory"]=writeArrayToMemory;function writeAsciiToMemory(str,buffer,dontAddNull){for(var i=0;i>0]=str.charCodeAt(i)}if(!dontAddNull)HEAP8[buffer>>0]=0}Module["writeAsciiToMemory"]=writeAsciiToMemory;function unSign(value,bits,ignore){if(value>=0){return value}return bits<=32?2*Math.abs(1<=half&&(bits<=32||value>half)){value=-2*half+value}return value}if(!Math["imul"]||Math["imul"](4294967295,5)!==-5)Math["imul"]=function imul(a,b){var ah=a>>>16;var al=a&65535;var bh=b>>>16;var bl=b&65535;return al*bl+(ah*bl+al*bh<<16)|0};Math.imul=Math["imul"];if(!Math["clz32"])Math["clz32"]=(function(x){x=x>>>0;for(var i=0;i<32;i++){if(x&1<<31-i)return i}return 32});Math.clz32=Math["clz32"];var Math_abs=Math.abs;var Math_cos=Math.cos;var Math_sin=Math.sin;var Math_tan=Math.tan;var Math_acos=Math.acos;var Math_asin=Math.asin;var Math_atan=Math.atan;var Math_atan2=Math.atan2;var Math_exp=Math.exp;var Math_log=Math.log;var Math_sqrt=Math.sqrt;var Math_ceil=Math.ceil;var Math_floor=Math.floor;var Math_pow=Math.pow;var Math_imul=Math.imul;var Math_fround=Math.fround;var Math_min=Math.min;var Math_clz32=Math.clz32;var runDependencies=0;var runDependencyWatcher=null;var dependenciesFulfilled=null;function getUniqueRunDependency(id){return id}function addRunDependency(id){runDependencies++;if(Module["monitorRunDependencies"]){Module["monitorRunDependencies"](runDependencies)}}Module["addRunDependency"]=addRunDependency;function removeRunDependency(id){runDependencies--;if(Module["monitorRunDependencies"]){Module["monitorRunDependencies"](runDependencies)}if(runDependencies==0){if(runDependencyWatcher!==null){clearInterval(runDependencyWatcher);runDependencyWatcher=null}if(dependenciesFulfilled){var callback=dependenciesFulfilled;dependenciesFulfilled=null;callback()}}}Module["removeRunDependency"]=removeRunDependency;Module["preloadedImages"]={};Module["preloadedAudios"]={};var memoryInitializer=null;var ASM_CONSTS=[(function(){{return Module.getRandomValue()}}),(function(){{if(Module.getRandomValue===undefined){try{var window_="object"===typeof window?window:self,crypto_=typeof window_.crypto!=="undefined"?window_.crypto:window_.msCrypto,randomValuesStandard=(function(){var buf=new Uint32Array(1);crypto_.getRandomValues(buf);return buf[0]>>>0});randomValuesStandard();Module.getRandomValue=randomValuesStandard}catch(e){try{var crypto=require("crypto"),randomValueNodeJS=(function(){var buf=crypto.randomBytes(4);return(buf[0]<<24|buf[1]<<16|buf[2]<<8|buf[3])>>>0});randomValueNodeJS();Module.getRandomValue=randomValueNodeJS}catch(e){throw"No secure random number generator found"}}}}})];function _emscripten_asm_const_0(code){return ASM_CONSTS[code]()}STATIC_BASE=8;STATICTOP=STATIC_BASE+34944;__ATINIT__.push();allocate([8,201,188,243,103,230,9,106,59,167,202,132,133,174,103,187,43,248,148,254,114,243,110,60,241,54,29,95,58,245,79,165,209,130,230,173,127,82,14,81,31,108,62,43,140,104,5,155,107,189,65,251,171,217,131,31,121,33,126,19,25,205,224,91,103,230,9,106,133,174,103,187,114,243,110,60,58,245,79,165,127,82,14,81,140,104,5,155,171,217,131,31,25,205,224,91,133,59,140,1,189,241,36,255,248,37,195,1,96,220,55,0,183,76,62,255,195,66,61,0,50,76,164,1,225,164,76,255,76,61,163,255,117,62,31,0,81,145,64,255,118,65,14,0,162,115,214,255,6,138,46,0,124,230,244,255,10,138,143,0,52,26,194,0,184,244,76,0,129,143,41,1,190,244,19,255,123,170,122,255,98,129,68,0,121,213,147,0,86,101,30,255,161,103,155,0,140,89,67,255,239,229,190,1,67,11,181,0,198,240,137,254,238,69,188,255,67,151,238,0,19,42,108,255,229,85,113,1,50,68,135,255,17,106,9,0,50,103,1,255,80,1,168,1,35,152,30,255,16,168,185,1,56,89,232,255,101,210,252,0,41,250,71,0,204,170,79,255,14,46,239,255,80,77,239,0,189,214,75,255,17,141,249,0,38,80,76,255,190,85,117,0,86,228,170,0,156,216,208,1,195,207,164,255,150,66,76,255,175,225,16,255,141,80,98,1,76,219,242,0,198,162,114,0,46,218,152,0,155,43,241,254,155,160,104,255,51,187,165,0,2,17,175,0,66,84,160,1,247,58,30,0,35,65,53,254,69,236,191,0,45,134,245,1,163,123,221,0,32,110,20,255,52,23,165,0,186,214,71,0,233,176,96,0,242,239,54,1,57,89,138,0,83,0,84,255,136,160,100,0,92,142,120,254,104,124,190,0,181,177,62,255,250,41,85,0,152,130,42,1,96,252,246,0,151,151,63,254,239,133,62,0,32,56,156,0,45,167,189,255,142,133,179,1,131,86,211,0,187,179,150,254,250,170,14,255,210,163,78,0,37,52,151,0,99,77,26,0,238,156,213,255,213,192,209,1,73,46,84,0,20,65,41,1,54,206,79,0,201,131,146,254,170,111,24,255,177,33,50,254,171,38,203,255,78,247,116,0,209,221,153,0,133,128,178,1,58,44,25,0,201,39,59,1,189,19,252,0,49,229,210,1,117,187,117,0,181,179,184,1,0,114,219,0,48,94,147,0,245,41,56,0,125,13,204,254,244,173,119,0,44,221,32,254,84,234,20,0,249,160,198,1,236,126,234,255,47,99,168,254,170,226,153,255,102,179,216,0,226,141,122,255,122,66,153,254,182,245,134,0,227,228,25,1,214,57,235,255,216,173,56,255,181,231,210,0,119,128,157,255,129,95,136,255,110,126,51,0,2,169,183,255,7,130,98,254,69,176,94,255,116,4,227,1,217,242,145,255,202,173,31,1,105,1,39,255,46,175,69,0,228,47,58,255,215,224,69,254,207,56,69,255,16,254,139,255,23,207,212,255,202,20,126,255,95,213,96,255,9,176,33,0,200,5,207,255,241,42,128,254,35,33,192,255,248,229,196,1,129,17,120,0,251,103,151,255,7,52,112,255,140,56,66,255,40,226,245,255,217,70,37,254,172,214,9,255,72,67,134,1,146,192,214,255,44,38,112,0,68,184,75,255,206,90,251,0,149,235,141,0,181,170,58,0,116,244,239,0,92,157,2,0,102,173,98,0,233,137,96,1,127,49,203,0,5,155,148,0,23,148,9,255,211,122,12,0,34,134,26,255,219,204,136,0,134,8,41,255,224,83,43,254,85,25,247,0,109,127,0,254,169,136,48,0,238,119,219,255,231,173,213,0,206,18,254,254,8,186,7,255,126,9,7,1,111,42,72,0,111,52,236,254,96,63,141,0,147,191,127,254,205,78,192,255,14,106,237,1,187,219,76,0,175,243,187,254,105,89,173,0,85,25,89,1,162,243,148,0,2,118,209,254,33,158,9,0,139,163,46,255,93,70,40,0,108,42,142,254,111,252,142,255,155,223,144,0,51,229,167,255,73,252,155,255,94,116,12,255,152,160,218,255,156,238,37,255,179,234,207,255,197,0,179,255,154,164,141,0,225,196,104,0,10,35,25,254,209,212,242,255,97,253,222,254,184,101,229,0,222,18,127,1,164,136,135,255,30,207,140,254,146,97,243,0,129,192,26,254,201,84,33,255,111,10,78,255,147,81,178,255,4,4,24,0,161,238,215,255,6,141,33,0,53,215,14,255,41,181,208,255,231,139,157,0,179,203,221,255,255,185,113,0,189,226,172,255,113,66,214,255,202,62,45,255,102,64,8,255,78,174,16,254,133,117,68,255,182,120,89,255,133,114,211,0,189,110,21,255,15,10,106,0,41,192,1,0,152,232,121,255,188,60,160,255,153,113,206,255,0,183,226,254,180,13,72,255,176,160,14,254,211,201,134,255,158,24,143,0,127,105,53,0,96,12,189,0,167,215,251,255,159,76,128,254,106,101,225,255,30,252,4,0,146,12,174,0,89,241,178,254,10,229,166,255,123,221,42,254,30,20,212,0,82,128,3,0,48,209,243,0,119,121,64,255,50,227,156,255,0,110,197,1,103,27,144,0,133,59,140,1,189,241,36,255,248,37,195,1,96,220,55,0,183,76,62,255,195,66,61,0,50,76,164,1,225,164,76,255,76,61,163,255,117,62,31,0,81,145,64,255,118,65,14,0,162,115,214,255,6,138,46,0,124,230,244,255,10,138,143,0,52,26,194,0,184,244,76,0,129,143,41,1,190,244,19,255,123,170,122,255,98,129,68,0,121,213,147,0,86,101,30,255,161,103,155,0,140,89,67,255,239,229,190,1,67,11,181,0,198,240,137,254,238,69,188,255,234,113,60,255,37,255,57,255,69,178,182,254,128,208,179,0,118,26,125,254,3,7,214,255,241,50,77,255,85,203,197,255,211,135,250,255,25,48,100,255,187,213,180,254,17,88,105,0,83,209,158,1,5,115,98,0,4,174,60,254,171,55,110,255,217,181,17,255,20,188,170,0,146,156,102,254,87,214,174,255,114,122,155,1,233,44,170,0,127,8,239,1,214,236,234,0,175,5,219,0,49,106,61,255,6,66,208,255,2,106,110,255,81,234,19,255,215,107,192,255,67,151,238,0,19,42,108,255,229,85,113,1,50,68,135,255,17,106,9,0,50,103,1,255,80,1,168,1,35,152,30,255,16,168,185,1,56,89,232,255,101,210,252,0,41,250,71,0,204,170,79,255,14,46,239,255,80,77,239,0,189,214,75,255,17,141,249,0,38,80,76,255,190,85,117,0,86,228,170,0,156,216,208,1,195,207,164,255,150,66,76,255,175,225,16,255,141,80,98,1,76,219,242,0,198,162,114,0,46,218,152,0,155,43,241,254,155,160,104,255,178,9,252,254,100,110,212,0,14,5,167,0,233,239,163,255,28,151,157,1,101,146,10,255,254,158,70,254,71,249,228,0,88,30,50,0,68,58,160,255,191,24,104,1,129,66,129,255,192,50,85,255,8,179,138,255,38,250,201,0,115,80,160,0,131,230,113,0,125,88,147,0,90,68,199,0,253,76,158,0,28,255,118,0,113,250,254,0,66,75,46,0,230,218,43,0,229,120,186,1,148,68,43,0,136,124,238,1,187,107,197,255,84,53,246,255,51,116,254,255,51,187,165,0,2,17,175,0,66,84,160,1,247,58,30,0,35,65,53,254,69,236,191,0,45,134,245,1,163,123,221,0,32,110,20,255,52,23,165,0,186,214,71,0,233,176,96,0,242,239,54,1,57,89,138,0,83,0,84,255,136,160,100,0,92,142,120,254,104,124,190,0,181,177,62,255,250,41,85,0,152,130,42,1,96,252,246,0,151,151,63,254,239,133,62,0,32,56,156,0,45,167,189,255,142,133,179,1,131,86,211,0,187,179,150,254,250,170,14,255,68,113,21,255,222,186,59,255,66,7,241,1,69,6,72,0,86,156,108,254,55,167,89,0,109,52,219,254,13,176,23,255,196,44,106,255,239,149,71,255,164,140,125,255,159,173,1,0,51,41,231,0,145,62,33,0,138,111,93,1,185,83,69,0,144,115,46,0,97,151,16,255,24,228,26,0,49,217,226,0,113,75,234,254,193,153,12,255,182,48,96,255,14,13,26,0,128,195,249,254,69,193,59,0,132,37,81,254,125,106,60,0,214,240,169,1,164,227,66,0,210,163,78,0,37,52,151,0,99,77,26,0,238,156,213,255,213,192,209,1,73,46,84,0,20,65,41,1,54,206,79,0,201,131,146,254,170,111,24,255,177,33,50,254,171,38,203,255,78,247,116,0,209,221,153,0,133,128,178,1,58,44,25,0,201,39,59,1,189,19,252,0,49,229,210,1,117,187,117,0,181,179,184,1,0,114,219,0,48,94,147,0,245,41,56,0,125,13,204,254,244,173,119,0,44,221,32,254,84,234,20,0,249,160,198,1,236,126,234,255,143,62,221,0,129,89,214,255,55,139,5,254,68,20,191,255,14,204,178,1,35,195,217,0,47,51,206,1,38,246,165,0,206,27,6,254,158,87,36,0,217,52,146,255,125,123,215,255,85,60,31,255,171,13,7,0,218,245,88,254,252,35,60,0,55,214,160,255,133,101,56,0,224,32,19,254,147,64,234,0,26,145,162,1,114,118,125,0,248,252,250,0,101,94,196,255,198,141,226,254,51,42,182,0,135,12,9,254,109,172,210,255,197,236,194,1,241,65,154,0,48,156,47,255,153,67,55,255,218,165,34,254,74,180,179,0,218,66,71,1,88,122,99,0,212,181,219,255,92,42,231,255,239,0,154,0,245,77,183,255,94,81,170,1,18,213,216,0,171,93,71,0,52,94,248,0,18,151,161,254,197,209,66,255,174,244,15,254,162,48,183,0,49,61,240,254,182,93,195,0,199,228,6,1,200,5,17,255,137,45,237,255,108,148,4,0,90,79,237,255,39,63,77,255,53,82,207,1,142,22,118,255,101,232,18,1,92,26,67,0,5,200,88,255,33,168,138,255,149,225,72,0,2,209,27,255,44,245,168,1,220,237,17,255,30,211,105,254,141,238,221,0,128,80,245,254,111,254,14,0,222,95,190,1,223,9,241,0,146,76,212,255,108,205,104,255,63,117,153,0,144,69,48,0,35,228,111,0,192,33,193,255,112,214,190,254,115,152,151,0,23,102,88,0,51,74,248,0,226,199,143,254,204,162,101,255,208,97,189,1,245,104,18,0,230,246,30,255,23,148,69,0,110,88,52,254,226,181,89,255,208,47,90,254,114,161,80,255,33,116,248,0,179,152,87,255,69,144,177,1,88,238,26,255,58,32,113,1,1,77,69,0,59,121,52,255,152,238,83,0,52,8,193,0,231,39,233,255,199,34,138,0,222,68,173,0,91,57,242,254,220,210,127,255,192,7,246,254,151,35,187,0,195,236,165,0,111,93,206,0,212,247,133,1,154,133,209,255,155,231,10,0,64,78,38,0,122,249,100,1,30,19,97,255,62,91,249,1,248,133,77,0,197,63,168,254,116,10,82,0,184,236,113,254,212,203,194,255,61,100,252,254,36,5,202,255,119,91,153,255,129,79,29,0,103,103,171,254,237,215,111,255,216,53,69,0,239,240,23,0,194,149,221,255,38,225,222,0,232,255,180,254,118,82,133,255,57,209,177,1,139,232,133,0,158,176,46,254,194,115,46,0,88,247,229,1,28,103,191,0,221,222,175,254,149,235,44,0,151,228,25,254,218,105,103,0,142,85,210,0,149,129,190,255,213,65,94,254,117,134,224,255,82,198,117,0,157,221,220,0,163,101,36,0,197,114,37,0,104,172,166,254,11,182,0,0,81,72,188,255,97,188,16,255,69,6,10,0,199,147,145,255,8,9,115,1,65,214,175,255,217,173,209,0,80,127,166,0,247,229,4,254,167,183,124,255,90,28,204,254,175,59,240,255,11,41,248,1,108,40,51,255,144,177,195,254,150,250,126,0,138,91,65,1,120,60,222,255,245,193,239,0,29,214,189,255,128,2,25,0,80,154,162,0,77,220,107,1,234,205,74,255,54,166,103,255,116,72,9,0,228,94,47,255,30,200,25,255,35,214,89,255,61,176,140,255,83,226,163,255,75,130,172,0,128,38,17,0,95,137,152,255,215,124,159,1,79,93,0,0,148,82,157,254,195,130,251,255,40,202,76,255,251,126,224,0,157,99,62,254,207,7,225,255,96,68,195,0,140,186,157,255,131,19,231,255,42,128,254,0,52,219,61,254,102,203,72,0,141,7,11,255,186,164,213,0,31,122,119,0,133,242,145,0,208,252,232,255,91,213,182,255,143,4,250,254,249,215,74,0,165,30,111,1,171,9,223,0,229,123,34,1,92,130,26,255,77,155,45,1,195,139,28,255,59,224,78,0,136,17,247,0,108,121,32,0,79,250,189,255,96,227,252,254,38,241,62,0,62,174,125,255,155,111,93,255,10,230,206,1,97,197,40,255,0,49,57,254,65,250,13,0,18,251,150,255,220,109,210,255,5,174,166,254,44,129,189,0,235,35,147,255,37,247,141,255,72,141,4,255,103,107,255,0,247,90,4,0,53,44,42,0,2,30,240,0,4,59,63,0,88,78,36,0,113,167,180,0,190,71,193,255,199,158,164,255,58,8,172,0,77,33,12,0,65,63,3,0,153,77,33,255,172,254,102,1,228,221,4,255,87,30,254,1,146,41,86,255,138,204,239,254,108,141,17,255,187,242,135,0,210,208,127,0,68,45,14,254,73,96,62,0,81,60,24,255,170,6,36,255,3,249,26,0,35,213,109,0,22,129,54,255,21,35,225,255,234,61,56,255,58,217,6,0,143,124,88,0,236,126,66,0,209,38,183,255,34,238,6,255,174,145,102,0,95,22,211,0,196,15,153,254,46,84,232,255,117,34,146,1,231,250,74,255,27,134,100,1,92,187,195,255,170,198,112,0,120,28,42,0,209,70,67,0,29,81,31,0,29,168,100,1,169,173,160,0,107,35,117,0,62,96,59,255,81,12,69,1,135,239,190,255,220,252,18,0,163,220,58,255,137,137,188,255,83,102,109,0,96,6,76,0,234,222,210,255,185,174,205,1,60,158,213,255,13,241,214,0,172,129,140,0,93,104,242,0,192,156,251,0,43,117,30,0,225,81,158,0,127,232,218,0,226,28,203,0,233,27,151,255,117,43,5,255,242,14,47,255,33,20,6,0,137,251,44,254,27,31,245,255,183,214,125,254,40,121,149,0,186,158,213,255,89,8,227,0,69,88,0,254,203,135,225,0,201,174,203,0,147,71,184,0,18,121,41,254,94,5,78,0,224,214,240,254,36,5,180,0,251,135,231,1,163,138,212,0,210,249,116,254,88,129,187,0,19,8,49,254,62,14,144,255,159,76,211,0,214,51,82,0,109,117,228,254,103,223,203,255,75,252,15,1,154,71,220,255,23,13,91,1,141,168,96,255,181,182,133,0,250,51,55,0,234,234,212,254,175,63,158,0,39,240,52,1,158,189,36,255,213,40,85,1,32,180,247,255,19,102,26,1,84,24,97,255,69,21,222,0,148,139,122,255,220,213,235,1,232,203,255,0,121,57,147,0,227,7,154,0,53,22,147,1,72,1,225,0,82,134,48,254,83,60,157,255,145,72,169,0,34,103,239,0,198,233,47,0,116,19,4,255,184,106,9,255,183,129,83,0,36,176,230,1,34,103,72,0,219,162,134,0,245,42,158,0,32,149,96,254,165,44,144,0,202,239,72,254,215,150,5,0,42,66,36,1,132,215,175,0,86,174,86,255,26,197,156,255,49,232,135,254,103,182,82,0,253,128,176,1,153,178,122,0,245,250,10,0,236,24,178,0,137,106,132,0,40,29,41,0,50,30,152,255,124,105,38,0,230,191,75,0,143,43,170,0,44,131,20,255,44,13,23,255,237,255,155,1,159,109,100,255,112,181,24,255,104,220,108,0,55,211,131,0,99,12,213,255,152,151,145,255,238,5,159,0,97,155,8,0,33,108,81,0,1,3,103,0,62,109,34,255,250,155,180,0,32,71,195,255,38,70,145,1,159,95,245,0,69,229,101,1,136,28,240,0,79,224,25,0,78,110,121,255,248,168,124,0,187,128,247,0,2,147,235,254,79,11,132,0,70,58,12,1,181,8,163,255,79,137,133,255,37,170,11,255,141,243,85,255,176,231,215,255,204,150,164,255,239,215,39,255,46,87,156,254,8,163,88,255,172,34,232,0,66,44,102,255,27,54,41,254,236,99,87,255,41,123,169,1,52,114,43,0,117,134,40,0,155,134,26,0,231,207,91,254,35,132,38,255,19,102,125,254,36,227,133,255,118,3,113,255,29,13,124,0,152,96,74,1,88,146,206,255,167,191,220,254,162,18,88,255,182,100,23,0,31,117,52,0,81,46,106,1,12,2,7,0,69,80,201,1,209,246,172,0,12,48,141,1,224,211,88,0,116,226,159,0,122,98,130,0,65,236,234,1,225,226,9,255,207,226,123,1,89,214,59,0,112,135,88,1,90,244,203,255,49,11,38,1,129,108,186,0,89,112,15,1,101,46,204,255,127,204,45,254,79,255,221,255,51,73,18,255,127,42,101,255,241,21,202,0,160,227,7,0,105,50,236,0,79,52,197,255,104,202,208,1,180,15,16,0,101,197,78,255,98,77,203,0,41,185,241,1,35,193,124,0,35,155,23,255,207,53,192,0,11,125,163,1,249,158,185,255,4,131,48,0,21,93,111,255,61,121,231,1,69,200,36,255,185,48,185,255,111,238,21,255,39,50,25,255,99,215,163,255,87,212,30,255,164,147,5,255,128,6,35,1,108,223,110,255,194,76,178,0,74,101,180,0,243,47,48,0,174,25,43,255,82,173,253,1,54,114,192,255,40,55,91,0,215,108,176,255,11,56,7,0,224,233,76,0,209,98,202,254,242,25,125,0,44,193,93,254,203,8,177,0,135,176,19,0,112,71,213,255,206,59,176,1,4,67,26,0,14,143,213,254,42,55,208,255,60,67,120,0,193,21,163,0,99,164,115,0,10,20,118,0,156,212,222,254,160,7,217,255,114,245,76,1,117,59,123,0,176,194,86,254,213,15,176,0,78,206,207,254,213,129,59,0,233,251,22,1,96,55,152,255,236,255,15,255,197,89,84,255,93,149,133,0,174,160,113,0,234,99,169,255,152,116,88,0,144,164,83,255,95,29,198,255,34,47,15,255,99,120,134,255,5,236,193,0,249,247,126,255,147,187,30,0,50,230,117,255,108,217,219,255,163,81,166,255,72,25,169,254,155,121,79,255,28,155,89,254,7,126,17,0,147,65,33,1,47,234,253,0,26,51,18,0,105,83,199,255,163,196,230,0,113,248,164,0,226,254,218,0,189,209,203,255,164,247,222,254,255,35,165,0,4,188,243,1,127,179,71,0,37,237,254,255,100,186,240,0,5,57,71,254,103,72,73,255,244,18,81,254,229,210,132,255,238,6,180,255,11,229,174,255,227,221,192,1,17,49,28,0,163,215,196,254,9,118,4,255,51,240,71,0,113,129,109,255,76,240,231,0,188,177,127,0,125,71,44,1,26,175,243,0,94,169,25,254,27,230,29,0,15,139,119,1,168,170,186,255,172,197,76,255,252,75,188,0,137,124,196,0,72,22,96,255,45,151,249,1,220,145,100,0,64,192,159,255,120,239,226,0,129,178,146,0,0,192,125,0,235,138,234,0,183,157,146,0,83,199,192,255,184,172,72,255,73,225,128,0,77,6,250,255,186,65,67,0,104,246,207,0,188,32,138,255,218,24,242,0,67,138,81,254,237,129,121,255,20,207,150,1,41,199,16,255,6,20,128,0,159,118,5,0,181,16,143,255,220,38,15,0,23,64,147,254,73,26,13,0,87,228,57,1,204,124,128,0,43,24,223,0,219,99,199,0,22,75,20,255,19,27,126,0,157,62,215,0,110,29,230,0,179,167,255,1,54,252,190,0,221,204,182,254,179,158,65,255,81,157,3,0,194,218,159,0,170,223,0,0,224,11,32,255,38,197,98,0,168,164,37,0,23,88,7,1,164,186,110,0,96,36,134,0,234,242,229,0,250,121,19,0,242,254,112,255,3,47,94,1,9,239,6,255,81,134,153,254,214,253,168,255,67,124,224,0,245,95,74,0,28,30,44,254,1,109,220,255,178,89,89,0,252,36,76,0,24,198,46,255,76,77,111,0,134,234,136,255,39,94,29,0,185,72,234,255,70,68,135,255,231,102,7,254,77,231,140,0,167,47,58,1,148,97,118,255,16,27,225,1,166,206,143,255,110,178,214,255,180,131,162,0,143,141,225,1,13,218,78,255,114,153,33,1,98,104,204,0,175,114,117,1,167,206,75,0,202,196,83,1,58,64,67,0,138,47,111,1,196,247,128,255,137,224,224,254,158,112,207,0,154,100,255,1,134,37,107,0,198,128,79,255,127,209,155,255,163,254,185,254,60,14,243,0,31,219,112,254,29,217,65,0,200,13,116,254,123,60,196,255,224,59,184,254,242,89,196,0,123,16,75,254,149,16,206,0,69,254,48,1,231,116,223,255,209,160,65,1,200,80,98,0,37,194,184,254,148,63,34,0,139,240,65,255,217,144,132,255,56,38,45,254,199,120,210,0,108,177,166,255,160,222,4,0,220,126,119,254,165,107,160,255,82,220,248,1,241,175,136,0,144,141,23,255,169,138,84,0,160,137,78,255,226,118,80,255,52,27,132,255,63,96,139,255,152,250,39,0,188,155,15,0,232,51,150,254,40,15,232,255,240,229,9,255,137,175,27,255,75,73,97,1,218,212,11,0,135,5,162,1,107,185,213,0,2,249,107,255,40,242,70,0,219,200,25,0,25,157,13,0,67,82,80,255,196,249,23,255,145,20,149,0,50,72,146,0,94,76,148,1,24,251,65,0,31,192,23,0,184,212,201,255,123,233,162,1,247,173,72,0,162,87,219,254,126,134,89,0,159,11,12,254,166,105,29,0,73,27,228,1,113,120,183,255,66,163,109,1,212,143,11,255,159,231,168,1,255,128,90,0,57,14,58,254,89,52,10,255,253,8,163,1,0,145,210,255,10,129,85,1,46,181,27,0,103,136,160,254,126,188,209,255,34,35,111,0,215,219,24,255,212,11,214,254,101,5,118,0,232,197,133,255,223,167,109,255,237,80,86,255,70,139,94,0,158,193,191,1,155,15,51,255,15,190,115,0,78,135,207,255,249,10,27,1,181,125,233,0,95,172,13,254,170,213,161,255,39,236,138,255,95,93,87,255,190,128,95,0,125,15,206,0,166,150,159,0,227,15,158,255,206,158,120,255,42,141,128,0,101,178,120,1,156,109,131,0,218,14,44,254,247,168,206,255,212,112,28,0,112,17,228,255,90,16,37,1,197,222,108,0,254,207,83,255,9,90,243,255,243,244,172,0,26,88,115,255,205,116,122,0,191,230,193,0,180,100,11,1,217,37,96,255,154,78,156,0,235,234,31,255,206,178,178,255,149,192,251,0,182,250,135,0,246,22,105,0,124,193,109,255,2,210,149,255,169,17,170,0,0,96,110,255,117,9,8,1,50,123,40,255,193,189,99,0,34,227,160,0,48,80,70,254,211,51,236,0,45,122,245,254,44,174,8,0,173,37,233,255,158,65,171,0,122,69,215,255,90,80,2,255,131,106,96,254,227,114,135,0,205,49,119,254,176,62,64,255,82,51,17,255,241,20,243,255,130,13,8,254,128,217,243,255,162,27,1,254,90,118,241,0,246,198,246,255,55,16,118,255,200,159,157,0,163,17,1,0,140,107,121,0,85,161,118,255,38,0,149,0,156,47,238,0,9,166,166,1,75,98,181,255,50,74,25,0,66,15,47,0,139,225,159,0,76,3,142,255,14,238,184,0,11,207,53,255,183,192,186,1,171,32,174,255,191,76,221,1,247,170,219,0,25,172,50,254,217,9,233,0,203,126,68,255,183,92,48,0,127,167,183,1,65,49,254,0,16,63,127,1,254,21,170,255,59,224,127,254,22,48,63,255,27,78,130,254,40,195,29,0,250,132,112,254,35,203,144,0,104,169,168,0,207,253,30,255,104,40,38,254,94,228,88,0,206,16,128,255,212,55,122,255,223,22,234,0,223,197,127,0,253,181,181,1,145,102,118,0,236,153,36,255,212,217,72,255,20,38,24,254,138,62,62,0,152,140,4,0,230,220,99,255,1,21,212,255,148,201,231,0,244,123,9,254,0,171,210,0,51,58,37,255,1,255,14,255,244,183,145,254,0,242,166,0,22,74,132,0,121,216,41,0,95,195,114,254,133,24,151,255,156,226,231,255,247,5,77,255,246,148,115,254,225,92,81,255,222,80,246,254,170,123,89,255,74,199,141,0,29,20,8,255,138,136,70,255,93,75,92,0,221,147,49,254,52,126,226,0,229,124,23,0,46,9,181,0,205,64,52,1,131,254,28,0,151,158,212,0,131,64,78,0,206,25,171,0,0,230,139,0,191,253,110,254,103,247,167,0,64,40,40,1,42,165,241,255,59,75,228,254,124,243,189,255,196,92,178,255,130,140,86,255,141,89,56,1,147,198,5,255,203,248,158,254,144,162,141,0,11,172,226,0,130,42,21,255,1,167,143,255,144,36,36,255,48,88,164,254,168,170,220,0,98,71,214,0,91,208,79,0,159,76,201,1,166,42,214,255,69,255,0,255,6,128,125,255,190,1,140,0,146,83,218,255,215,238,72,1,122,127,53,0,189,116,165,255,84,8,66,255,214,3,208,255,213,110,133,0,195,168,44,1,158,231,69,0,162,64,200,254,91,58,104,0,182,58,187,254,249,228,136,0,203,134,76,254,99,221,233,0,75,254,214,254,80,69,154,0,64,152,248,254,236,136,202,255,157,105,153,254,149,175,20,0,22,35,19,255,124,121,233,0,186,250,198,254,132,229,139,0,137,80,174,255,165,125,68,0,144,202,148,254,235,239,248,0,135,184,118,0,101,94,17,255,122,72,70,254,69,130,146,0,127,222,248,1,69,127,118,255,30,82,215,254,188,74,19,255,229,167,194,254,117,25,66,255,65,234,56,254,213,22,156,0,151,59,93,254,45,28,27,255,186,126,164,255,32,6,239,0,127,114,99,1,219,52,2,255,99,96,166,254,62,190,126,255,108,222,168,1,75,226,174,0,230,226,199,0,60,117,218,255,252,248,20,1,214,188,204,0,31,194,134,254,123,69,192,255,169,173,36,254,55,98,91,0,223,42,102,254,137,1,102,0,157,90,25,0,239,122,64,255,252,6,233,0,7,54,20,255,82,116,174,0,135,37,54,255,15,186,125,0,227,112,175,255,100,180,225,255,42,237,244,255,244,173,226,254,248,18,33,0,171,99,150,255,74,235,50,255,117,82,32,254,106,168,237,0,207,109,208,1,228,9,186,0,135,60,169,254,179,92,143,0,244,170,104,255,235,45,124,255,70,99,186,0,117,137,183,0,224,31,215,0,40,9,100,0,26,16,95,1,68,217,87,0,8,151,20,255,26,100,58,255,176,165,203,1,52,118,70,0,7,32,254,254,244,254,245,255,167,144,194,255,125,113,23,255,176,121,181,0,136,84,209,0,138,6,30,255,89,48,28,0,33,155,14,255,25,240,154,0,141,205,109,1,70,115,62,255,20,40,107,254,138,154,199,255,94,223,226,255,157,171,38,0,163,177,25,254,45,118,3,255,14,222,23,1,209,190,81,255,118,123,232,1,13,213,101,255,123,55,123,254,27,246,165,0,50,99,76,255,140,214,32,255,97,65,67,255,24,12,28,0,174,86,78,1,64,247,96,0,160,135,67,0,66,55,243,255,147,204,96,255,26,6,33,255,98,51,83,1,153,213,208,255,2,184,54,255,25,218,11,0,49,67,246,254,18,149,72,255,13,25,72,0,42,79,214,0,42,4,38,1,27,139,144,255,149,187,23,0,18,164,132,0,245,84,184,254,120,198,104,255,126,218,96,0,56,117,234,255,13,29,214,254,68,47,10,255,167,154,132,254,152,38,198,0,66,178,89,255,200,46,171,255,13,99,83,255,210,187,253,255,170,45,42,1,138,209,124,0,214,162,141,0,12,230,156,0,102,36,112,254,3,147,67,0,52,215,123,255,233,171,54,255,98,137,62,0,247,218,39,255,231,218,236,0,247,191,127,0,195,146,84,0,165,176,92,255,19,212,94,255,17,74,227,0,88,40,153,1,198,147,1,255,206,67,245,254,240,3,218,255,61,141,213,255,97,183,106,0,195,232,235,254,95,86,154,0,209,48,205,254,118,209,241,255,240,120,223,1,213,29,159,0,163,127,147,255,13,218,93,0,85,24,68,254,70,20,80,255,189,5,140,1,82,97,254,255,99,99,191,255,132,84,133,255,107,218,116,255,112,122,46,0,105,17,32,0,194,160,63,255,68,222,39,1,216,253,92,0,177,105,205,255,149,201,195,0,42,225,11,255,40,162,115,0,9,7,81,0,165,218,219,0,180,22,0,254,29,146,252,255,146,207,225,1,180,135,96,0,31,163,112,0,177,11,219,255,133,12,193,254,43,78,50,0,65,113,121,1,59,217,6,255,110,94,24,1,112,172,111,0,7,15,96,0,36,85,123,0,71,150,21,255,208,73,188,0,192,11,167,1,213,245,34,0,9,230,92,0,162,142,39,255,215,90,27,0,98,97,89,0,94,79,211,0,90,157,240,0,95,220,126,1,102,176,226,0,36,30,224,254,35,31,127,0,231,232,115,1,85,83,130,0,210,73,245,255,47,143,114,255,68,65,197,0,59,72,62,255,183,133,173,254,93,121,118,255,59,177,81,255,234,69,173,255,205,128,177,0,220,244,51,0,26,244,209,1,73,222,77,255,163,8,96,254,150,149,211,0,158,254,203,1,54,127,139,0,161,224,59,0,4,109,22,255,222,42,45,255,208,146,102,255,236,142,187,0,50,205,245,255,10,74,89,254,48,79,142,0,222,76,130,255,30,166,63,0,236,12,13,255,49,184,244,0,187,113,102,0,218,101,253,0,153,57,182,254,32,150,42,0,25,198,146,1,237,241,56,0,140,68,5,0,91,164,172,255,78,145,186,254,67,52,205,0,219,207,129,1,109,115,17,0,54,143,58,1,21,248,120,255,179,255,30,0,193,236,66,255,1,255,7,255,253,192,48,255,19,69,217,1,3,214,0,255,64,101,146,1,223,125,35,255,235,73,179,255,249,167,226,0,225,175,10,1,97,162,58,0,106,112,171,1,84,172,5,255,133,140,178,255,134,245,142,0,97,90,125,255,186,203,185,255,223,77,23,255,192,92,106,0,15,198,115,255,217,152,248,0,171,178,120,255,228,134,53,0,176,54,193,1,250,251,53,0,213,10,100,1,34,199,106,0,151,31,244,254,172,224,87,255,14,237,23,255,253,85,26,255,127,39,116,255,172,104,100,0,251,14,70,255,212,208,138,255,253,211,250,0,176,49,165,0,15,76,123,255,37,218,160,255,92,135,16,1,10,126,114,255,70,5,224,255,247,249,141,0,68,20,60,1,241,210,189,255,195,217,187,1,151,3,113,0,151,92,174,0,231,62,178,255,219,183,225,0,23,23,33,255,205,181,80,0,57,184,248,255,67,180,1,255,90,123,93,255,39,0,162,255,96,248,52,255,84,66,140,0,34,127,228,255,194,138,7,1,166,110,188,0,21,17,155,1,154,190,198,255,214,80,59,255,18,7,143,0,72,29,226,1,199,217,249,0,232,161,71,1,149,190,201,0,217,175,95,254,113,147,67,255,138,143,199,255,127,204,1,0,29,182,83,1,206,230,155,255,186,204,60,0,10,125,85,255,232,96,25,255,255,89,247,255,213,254,175,1,232,193,81,0,28,43,156,254,12,69,8,0,147,24,248,0,18,198,49,0,134,60,35,0,118,246,18,255,49,88,254,254,228,21,186,255,182,65,112,1,219,22,1,255,22,126,52,255,189,53,49,255,112,25,143,0,38,127,55,255,226,101,163,254,208,133,61,255,137,69,174,1,190,118,145,255,60,98,219,255,217,13,245,255,250,136,10,0,84,254,226,0,201,31,125,1,240,51,251,255,31,131,130,255,2,138,50,255,215,215,177,1,223,12,238,255,252,149,56,255,124,91,68,255,72,126,170,254,119,255,100,0,130,135,232,255,14,79,178,0,250,131,197,0,138,198,208,0,121,216,139,254,119,18,36,255,29,193,122,0,16,42,45,255,213,240,235,1,230,190,169,255,198,35,228,254,110,173,72,0,214,221,241,255,56,148,135,0,192,117,78,254,141,93,207,255,143,65,149,0,21,18,98,255,95,44,244,1,106,191,77,0,254,85,8,254,214,110,176,255,73,173,19,254,160,196,199,255,237,90,144,0,193,172,113,255,200,155,136,254,228,90,221,0,137,49,74,1,164,221,215,255,209,189,5,255,105,236,55,255,42,31,129,1,193,255,236,0,46,217,60,0,138,88,187,255,226,82,236,255,81,69,151,255,142,190,16,1,13,134,8,0,127,122,48,255,81,64,156,0,171,243,139,0,237,35,246,0,122,143,193,254,212,122,146,0,95,41,255,1,87,132,77,0,4,212,31,0,17,31,78,0,39,45,173,254,24,142,217,255,95,9,6,255,227,83,6,0,98,59,130,254,62,30,33,0,8,115,211,1,162,97,128,255,7,184,23,254,116,28,168,255,248,138,151,255,98,244,240,0,186,118,130,0,114,248,235,255,105,173,200,1,160,124,71,255,94,36,164,1,175,65,146,255,238,241,170,254,202,198,197,0,228,71,138,254,45,246,109,255,194,52,158,0,133,187,176,0,83,252,154,254,89,189,221,255,170,73,252,0,148,58,125,0,36,68,51,254,42,69,177,255,168,76,86,255,38,100,204,255,38,53,35,0,175,19,97,0,225,238,253,255,81,81,135,0,210,27,255,254,235,73,107,0,8,207,115,0,82,127,136,0,84,99,21,254,207,19,136,0,100,164,101,0,80,208,77,255,132,207,237,255,15,3,15,255,33,166,110,0,156,95,85,255,37,185,111,1,150,106,35,255,166,151,76,0,114,87,135,255,159,194,64,0,12,122,31,255,232,7,101,254,173,119,98,0,154,71,220,254,191,57,53,255,168,232,160,255,224,32,99,255,218,156,165,0,151,153,163,0,217,13,148,1,197,113,89,0,149,28,161,254,207,23,30,0,105,132,227,255,54,230,94,255,133,173,204,255,92,183,157,255,88,144,252,254,102,33,90,0,159,97,3,0,181,218,155,255,240,114,119,0,106,214,53,255,165,190,115,1,152,91,225,255,88,106,44,255,208,61,113,0,151,52,124,0,191,27,156,255,110,54,236,1,14,30,166,255,39,127,207,1,229,199,28,0,188,228,188,254,100,157,235,0,246,218,183,1,107,22,193,255,206,160,95,0,76,239,147,0,207,161,117,0,51,166,2,255,52,117,10,254,73,56,227,255,152,193,225,0,132,94,136,255,101,191,209,0,32,107,229,255,198,43,180,1,100,210,118,0,114,67,153,255,23,88,26,255,89,154,92,1,220,120,140,255,144,114,207,255,252,115,250,255,34,206,72,0,138,133,127,255,8,178,124,1,87,75,97,0,15,229,92,254,240,67,131,255,118,123,227,254,146,120,104,255,145,213,255,1,129,187,70,255,219,119,54,0,1,19,173,0,45,150,148,1,248,83,72,0,203,233,169,1,142,107,56,0,247,249,38,1,45,242,80,255,30,233,103,0,96,82,70,0,23,201,111,0,81,39,30,255,161,183,78,255,194,234,33,255,68,227,140,254,216,206,116,0,70,27,235,255,104,144,79,0,164,230,93,254,214,135,156,0,154,187,242,254,188,20,131,255,36,109,174,0,159,112,241,0,5,110,149,1,36,165,218,0,166,29,19,1,178,46,73,0,93,43,32,254,248,189,237,0,102,155,141,0,201,93,195,255,241,139,253,255,15,111,98,255,108,65,163,254,155,79,190,255,73,174,193,254,246,40,48,255,107,88,11,254,202,97,85,255,253,204,18,255,113,242,66,0,110,160,194,254,208,18,186,0,81,21,60,0,188,104,167,255,124,166,97,254,210,133,142,0,56,242,137,254,41,111,130,0,111,151,58,1,111,213,141,255,183,172,241,255,38,6,196,255,185,7,123,255,46,11,246,0,245,105,119,1,15,2,161,255,8,206,45,255,18,202,74,255,83,124,115,1,212,141,157,0,83,8,209,254,139,15,232,255,172,54,173,254,50,247,132,0,214,189,213,0,144,184,105,0,223,254,248,0,255,147,240,255,23,188,72,0,7,51,54,0,188,25,180,254,220,180,0,255,83,160,20,0,163,189,243,255,58,209,194,255,87,73,60,0,106,24,49,0,245,249,220,0,22,173,167,0,118,11,195,255,19,126,237,0,110,159,37,255,59,82,47,0,180,187,86,0,188,148,208,1,100,37,133,255,7,112,193,0,129,188,156,255,84,106,129,255,133,225,202,0,14,236,111,255,40,20,101,0,172,172,49,254,51,54,74,255,251,185,184,255,93,155,224,255,180,249,224,1,230,178,146,0,72,57,54,254,178,62,184,0,119,205,72,0,185,239,253,255,61,15,218,0,196,67,56,255,234,32,171,1,46,219,228,0,208,108,234,255,20,63,232,255,165,53,199,1,133,228,5,255,52,205,107,0,74,238,140,255,150,156,219,254,239,172,178,255,251,189,223,254,32,142,211,255,218,15,138,1,241,196,80,0,28,36,98,254,22,234,199,0,61,237,220,255,246,57,37,0,142,17,142,255,157,62,26,0,43,238,95,254,3,217,6,255,213,25,240,1,39,220,174,255,154,205,48,254,19,13,192,255,244,34,54,254,140,16,155,0,240,181,5,254,155,193,60,0,166,128,4,255,36,145,56,255,150,240,219,0,120,51,145,0,82,153,42,1,140,236,146,0,107,92,248,1,189,10,3,0,63,136,242,0,211,39,24,0,19,202,161,1,173,27,186,255,210,204,239,254,41,209,162,255,182,254,159,255,172,116,52,0,195,103,222,254,205,69,59,0,53,22,41,1,218,48,194,0,80,210,242,0,210,188,207,0,187,161,161,254,216,17,1,0,136,225,113,0,250,184,63,0,223,30,98,254,77,168,162,0,59,53,175,0,19,201,10,255,139,224,194,0,147,193,154,255,212,189,12,254,1,200,174,255,50,133,113,1,94,179,90,0,173,182,135,0,94,177,113,0,43,89,215,255,136,252,106,255,123,134,83,254,5,245,66,255,82,49,39,1,220,2,224,0,97,129,177,0,77,59,89,0,61,29,155,1,203,171,220,255,92,78,139,0,145,33,181,255,169,24,141,1,55,150,179,0,139,60,80,255,218,39,97,0,2,147,107,255,60,248,72,0,173,230,47,1,6,83,182,255,16,105,162,254,137,212,81,255,180,184,134,1,39,222,164,255,221,105,251,1,239,112,125,0,63,7,97,0,63,104,227,255,148,58,12,0,90,60,224,255,84,212,252,0,79,215,168,0,248,221,199,1,115,121,1,0,36,172,120,0,32,162,187,255,57,107,49,255,147,42,21,0,106,198,43,1,57,74,87,0,126,203,81,255,129,135,195,0,140,31,177,0,221,139,194,0,3,222,215,0,131,68,231,0,177,86,178,254,124,151,180,0,184,124,38,1,70,163,17,0,249,251,181,1,42,55,227,0,226,161,44,0,23,236,110,0,51,149,142,1,93,5,236,0,218,183,106,254,67,24,77,0,40,245,209,255,222,121,153,0,165,57,30,0,83,125,60,0,70,38,82,1,229,6,188,0,109,222,157,255,55,118,63,255,205,151,186,0,227,33,149,255,254,176,246,1,227,177,227,0,34,106,163,254,176,43,79,0,106,95,78,1,185,241,122,255,185,14,61,0,36,1,202,0,13,178,162,255,247,11,132,0,161,230,92,1,65,1,185,255,212,50,165,1,141,146,64,255,158,242,218,0,21,164,125,0,213,139,122,1,67,71,87,0,203,158,178,1,151,92,43,0,152,111,5,255,39,3,239,255,217,255,250,255,176,63,71,255,74,245,77,1,250,174,18,255,34,49,227,255,246,46,251,255,154,35,48,1,125,157,61,255,106,36,78,255,97,236,153,0,136,187,120,255,113,134,171,255,19,213,217,254,216,94,209,255,252,5,61,0,94,3,202,0,3,26,183,255,64,191,43,255,30,23,21,0,129,141,77,255,102,120,7,1,194,76,140,0,188,175,52,255,17,81,148,0,232,86,55,1,225,48,172,0,134,42,42,255,238,50,47,0,169,18,254,0,20,147,87,255,14,195,239,255,69,247,23,0,238,229,128,255,177,49,112,0,168,98,251,255,121,71,248,0,243,8,145,254,246,227,153,255,219,169,177,254,251,139,165,255,12,163,185,255,164,40,171,255,153,159,27,254,243,109,91,255,222,24,112,1,18,214,231,0,107,157,181,254,195,147,0,255,194,99,104,255,89,140,190,255,177,66,126,254,106,185,66,0,49,218,31,0,252,174,158,0,188,79,230,1,238,41,224,0,212,234,8,1,136,11,181,0,166,117,83,255,68,195,94,0,46,132,201,0,240,152,88,0,164,57,69,254,160,224,42,255,59,215,67,255,119,195,141,255,36,180,121,254,207,47,8,255,174,210,223,0,101,197,68,255,255,82,141,1,250,137,233,0,97,86,133,1,16,80,69,0,132,131,159,0,116,93,100,0,45,141,139,0,152,172,157,255,90,43,91,0,71,153,46,0,39,16,112,255,217,136,97,255,220,198,25,254,177,53,49,0,222,88,134,255,128,15,60,0,207,192,169,255,192,116,209,255,106,78,211,1,200,213,183,255,7,12,122,254,222,203,60,255,33,110,199,254,251,106,117,0,228,225,4,1,120,58,7,255,221,193,84,254,112,133,27,0,189,200,201,255,139,135,150,0,234,55,176,255,61,50,65,0,152,108,169,255,220,85,1,255,112,135,227,0,162,26,186,0,207,96,185,254,244,136,107,0,93,153,50,1,198,97,151,0,110,11,86,255,143,117,174,255,115,212,200,0,5,202,183,0,237,164,10,254,185,239,62,0,236,120,18,254,98,123,99,255,168,201,194,254,46,234,214,0,191,133,49,255,99,169,119,0,190,187,35,1,115,21,45,255,249,131,72,0,112,6,123,255,214,49,181,254,166,233,34,0,92,197,102,254,253,228,205,255,3,59,201,1,42,98,46,0,219,37,35,255,169,195,38,0,94,124,193,1,156,43,223,0,95,72,133,254,120,206,191,0,122,197,239,255,177,187,79,255,254,46,2,1,250,167,190,0,84,129,19,0,203,113,166,255,249,31,189,254,72,157,202,255,208,71,73,255,207,24,72,0,10,16,18,1,210,81,76,255,88,208,192,255,126,243,107,255,238,141,120,255,199,121,234,255,137,12,59,255,36,220,123,255,148,179,60,254,240,12,29,0,66,0,97,1,36,30,38,255,115,1,93,255,96,103,231,255,197,158,59,1,192,164,240,0,202,202,57,255,24,174,48,0,89,77,155,1,42,76,215,0,244,151,233,0,23,48,81,0,239,127,52,254,227,130,37,255,248,116,93,1,124,132,118,0,173,254,192,1,6,235,83,255,110,175,231,1,251,28,182,0,129,249,93,254,84,184,128,0,76,181,62,0,175,128,186,0,100,53,136,254,109,29,226,0,221,233,58,1,20,99,74,0,0,22,160,0,134,13,21,0,9,52,55,255,17,89,140,0,175,34,59,0,84,165,119,255,224,226,234,255,7,72,166,255,123,115,255,1,18,214,246,0,250,7,71,1,217,220,185,0,212,35,76,255,38,125,175,0,189,97,210,0,114,238,44,255,41,188,169,254,45,186,154,0,81,92,22,0,132,160,193,0,121,208,98,255,13,81,44,255,203,156,82,0,71,58,21,255,208,114,191,254,50,38,147,0,154,216,195,0,101,25,18,0,60,250,215,255,233,132,235,255,103,175,142,1,16,14,92,0,141,31,110,254,238,241,45,255,153,217,239,1,97,168,47,255,249,85,16,1,28,175,62,255,57,254,54,0,222,231,126,0,166,45,117,254,18,189,96,255,228,76,50,0,200,244,94,0,198,152,120,1,68,34,69,255,12,65,160,254,101,19,90,0,167,197,120,255,68,54,185,255,41,218,188,0,113,168,48,0,88,105,189,1,26,82,32,255,185,93,164,1,228,240,237,255,66,182,53,0,171,197,92,255,107,9,233,1,199,120,144,255,78,49,10,255,109,170,105,255,90,4,31,255,28,244,113,255,74,58,11,0,62,220,246,255,121,154,200,254,144,210,178,255,126,57,129,1,43,250,14,255,101,111,28,1,47,86,241,255,61,70,150,255,53,73,5,255,30,26,158,0,209,26,86,0,138,237,74,0,164,95,188,0,142,60,29,254,162,116,248,255,187,175,160,0,151,18,16,0,209,111,65,254,203,134,39,255,88,108,49,255,131,26,71,255,221,27,215,254,104,105,93,255,31,236,31,254,135,0,211,255,143,127,110,1,212,73,229,0,233,67,167,254,195,1,208,255,132,17,221,255,51,217,90,0,67,235,50,255,223,210,143,0,179,53,130,1,233,106,198,0,217,173,220,255,112,229,24,255,175,154,93,254,71,203,246,255,48,66,133,255,3,136,230,255,23,221,113,254,235,111,213,0,170,120,95,254,251,221,2,0,45,130,158,254,105,94,217,255,242,52,180,254,213,68,45,255,104,38,28,0,244,158,76,0,161,200,96,255,207,53,13,255,187,67,148,0,170,54,248,0,119,162,178,255,83,20,11,0,42,42,192,1,146,159,163,255,183,232,111,0,77,229,21,255,71,53,143,0,27,76,34],"i8",ALLOC_NONE,Runtime.GLOBAL_BASE);allocate([246,136,47,255,219,39,182,255,92,224,201,1,19,142,14,255,69,182,241,255,163,118,245,0,9,109,106,1,170,181,247,255,78,47,238,255,84,210,176,255,213,107,139,0,39,38,11,0,72,21,150,0,72,130,69,0,205,77,155,254,142,133,21,0,71,111,172,254,226,42,59,255,179,0,215,1,33,128,241,0,234,252,13,1,184,79,8,0,110,30,73,255,246,141,189,0,170,207,218,1,74,154,69,255,138,246,49,255,155,32,100,0,125,74,105,255,90,85,61,255,35,229,177,255,62,125,193,255,153,86,188,1,73,120,212,0,209,123,246,254,135,209,38,255,151,58,44,1,92,69,214,255,14,12,88,255,252,153,166,255,253,207,112,255,60,78,83,255,227,124,110,0,180,96,252,255,53,117,33,254,164,220,82,255,41,1,27,255,38,164,166,255,164,99,169,254,61,144,70,255,192,166,18,0,107,250,66,0,197,65,50,0,1,179,18,255,255,104,1,255,43,153,35,255,80,111,168,0,110,175,168,0,41,105,45,255,219,14,205,255,164,233,140,254,43,1,118,0,233,67,195,0,178,82,159,255,138,87,122,255,212,238,90,255,144,35,124,254,25,140,164,0,251,215,44,254,133,70,107,255,101,227,80,254,92,169,55,0,215,42,49,0,114,180,85,255,33,232,27,1,172,213,25,0,62,176,123,254,32,133,24,255,225,191,62,0,93,70,153,0,181,42,104,1,22,191,224,255,200,200,140,255,249,234,37,0,149,57,141,0,195,56,208,255,254,130,70,255,32,173,240,255,29,220,199,0,110,100,115,255,132,229,249,0,228,233,223,255,37,216,209,254,178,177,209,255,183,45,165,254,224,97,114,0,137,97,168,255,225,222,172,0,165,13,49,1,210,235,204,255,252,4,28,254,70,160,151,0,232,190,52,254,83,248,93,255,62,215,77,1,175,175,179,255,160,50,66,0,121,48,208,0,63,169,209,255,0,210,200,0,224,187,44,1,73,162,82,0,9,176,143,255,19,76,193,255,29,59,167,1,24,43,154,0,28,190,190,0,141,188,129,0,232,235,203,255,234,0,109,255,54,65,159,0,60,88,232,255,121,253,150,254,252,233,131,255,198,110,41,1,83,77,71,255,200,22,59,254,106,253,242,255,21,12,207,255,237,66,189,0,90,198,202,1,225,172,127,0,53,22,202,0,56,230,132,0,1,86,183,0,109,190,42,0,243,68,174,1,109,228,154,0,200,177,122,1,35,160,183,255,177,48,85,255,90,218,169,255,248,152,78,0,202,254,110,0,6,52,43,0,142,98,65,255,63,145,22,0,70,106,93,0,232,138,107,1,110,179,61,255,211,129,218,1,242,209,92,0,35,90,217,1,182,143,106,255,116,101,217,255,114,250,221,255,173,204,6,0,60,150,163,0,73,172,44,255,239,110,80,255,237,76,153,254,161,140,249,0,149,232,229,0,133,31,40,255,174,164,119,0,113,51,214,0,129,228,2,254,64,34,243,0,107,227,244,255,174,106,200,255,84,153,70,1,50,35,16,0,250,74,216,254,236,189,66,255,153,249,13,0,230,178,4,255,221,41,238,0,118,227,121,255,94,87,140,254,254,119,92,0,73,239,246,254,117,87,128,0,19,211,145,255,177,46,252,0,229,91,246,1,69,128,247,255,202,77,54,1,8,11,9,255,153,96,166,0,217,214,173,255,134,192,2,1,0,207,0,0,189,174,107,1,140,134,100,0,158,193,243,1,182,102,171,0,235,154,51,0,142,5,123,255,60,168,89,1,217,14,92,255,19,214,5,1,211,167,254,0,44,6,202,254,120,18,236,255,15,113,184,255,184,223,139,0,40,177,119,254,182,123,90,255,176,165,176,0,247,77,194,0,27,234,120,0,231,0,214,255,59,39,30,0,125,99,145,255,150,68,68,1,141,222,248,0,153,123,210,255,110,127,152,255,229,33,214,1,135,221,197,0,137,97,2,0,12,143,204,255,81,41,188,0,115,79,130,255,94,3,132,0,152,175,187,255,124,141,10,255,126,192,179,255,11,103,198,0,149,6,45,0,219,85,187,1,230,18,178,255,72,182,152,0,3,198,184,255,128,112,224,1,97,161,230,0,254,99,38,255,58,159,197,0,151,66,219,0,59,69,143,255,185,112,249,0,119,136,47,255,123,130,132,0,168,71,95,255,113,176,40,1,232,185,173,0,207,93,117,1,68,157,108,255,102,5,147,254,49,97,33,0,89,65,111,254,247,30,163,255,124,217,221,1,102,250,216,0,198,174,75,254,57,55,18,0,227,5,236,1,229,213,173,0,201,109,218,1,49,233,239,0,30,55,158,1,25,178,106,0,155,111,188,1,94,126,140,0,215,31,238,1,77,240,16,0,213,242,25,1,38,71,168,0,205,186,93,254,49,211,140,255,219,0,180,255,134,118,165,0,160,147,134,255,110,186,35,255,198,243,42,0,243,146,119,0,134,235,163,1,4,241,135,255,193,46,193,254,103,180,79,255,225,4,184,254,242,118,130,0,146,135,176,1,234,111,30,0,69,66,213,254,41,96,123,0,121,94,42,255,178,191,195,255,46,130,42,0,117,84,8,255,233,49,214,254,238,122,109,0,6,71,89,1,236,211,123,0,244,13,48,254,119,148,14,0,114,28,86,255,75,237,25,255,145,229,16,254,129,100,53,255,134,150,120,254,168,157,50,0,23,72,104,255,224,49,14,0,255,123,22,255,151,185,151,255,170,80,184,1,134,182,20,0,41,100,101,1,153,33,16,0,76,154,111,1,86,206,234,255,192,160,164,254,165,123,93,255,1,216,164,254,67,17,175,255,169,11,59,255,158,41,61,255,73,188,14,255,195,6,137,255,22,147,29,255,20,103,3,255,246,130,227,255,122,40,128,0,226,47,24,254,35,36,32,0,152,186,183,255,69,202,20,0,195,133,195,0,222,51,247,0,169,171,94,1,183,0,160,255,64,205,18,1,156,83,15,255,197,58,249,254,251,89,110,255,50,10,88,254,51,43,216,0,98,242,198,1,245,151,113,0,171,236,194,1,197,31,199,255,229,81,38,1,41,59,20,0,253,104,230,0,152,93,14,255,246,242,146,254,214,169,240,255,240,102,108,254,160,167,236,0,154,218,188,0,150,233,202,255,27,19,250,1,2,71,133,255,175,12,63,1,145,183,198,0,104,120,115,255,130,251,247,0,17,212,167,255,62,123,132,255,247,100,189,0,155,223,152,0,143,197,33,0,155,59,44,255,150,93,240,1,127,3,87,255,95,71,207,1,167,85,1,255,188,152,116,255,10,23,23,0,137,195,93,1,54,98,97,0,240,0,168,255,148,188,127,0,134,107,151,0,76,253,171,0,90,132,192,0,146,22,54,0,224,66,54,254,230,186,229,255,39,182,196,0,148,251,130,255,65,131,108,254,128,1,160,0,169,49,167,254,199,254,148,255,251,6,131,0,187,254,129,255,85,82,62,0,178,23,58,255,254,132,5,0,164,213,39,0,134,252,146,254,37,53,81,255,155,134,82,0,205,167,238,255,94,45,180,255,132,40,161,0,254,111,112,1,54,75,217,0,179,230,221,1,235,94,191,255,23,243,48,1,202,145,203,255,39,118,42,255,117,141,253,0,254,0,222,0,43,251,50,0,54,169,234,1,80,68,208,0,148,203,243,254,145,7,135,0,6,254,0,0,252,185,127,0,98,8,129,255,38,35,72,255,211,36,220,1,40,26,89,0,168,64,197,254,3,222,239,255,2,83,215,254,180,159,105,0,58,115,194,0,186,116,106,255,229,247,219,255,129,118,193,0,202,174,183,1,166,161,72,0,201,107,147,254,237,136,74,0,233,230,106,1,105,111,168,0,64,224,30,1,1,229,3,0,102,151,175,255,194,238,228,255,254,250,212,0,187,237,121,0,67,251,96,1,197,30,11,0,183,95,204,0,205,89,138,0,64,221,37,1,255,223,30,255,178,48,211,255,241,200,90,255,167,209,96,255,57,130,221,0,46,114,200,255,61,184,66,0,55,182,24,254,110,182,33,0,171,190,232,255,114,94,31,0,18,221,8,0,47,231,254,0,255,112,83,0,118,15,215,255,173,25,40,254,192,193,31,255,238,21,146,255,171,193,118,255,101,234,53,254,131,212,112,0,89,192,107,1,8,208,27,0,181,217,15,255,231,149,232,0,140,236,126,0,144,9,199,255,12,79,181,254,147,182,202,255,19,109,182,255,49,212,225,0,74,163,203,0,175,233,148,0,26,112,51,0,193,193,9,255,15,135,249,0,150,227,130,0,204,0,219,1,24,242,205,0,238,208,117,255,22,244,112,0,26,229,34,0,37,80,188,255,38,45,206,254,240,90,225,255,29,3,47,255,42,224,76,0,186,243,167,0,32,132,15,255,5,51,125,0,139,135,24,0,6,241,219,0,172,229,133,255,246,214,50,0,231,11,207,255,191,126,83,1,180,163,170,255,245,56,24,1,178,164,211,255,3,16,202,1,98,57,118,255,141,131,89,254,33,51,24,0,243,149,91,255,253,52,14,0,35,169,67,254,49,30,88,255,179,27,36,255,165,140,183,0,58,189,151,0,88,31,0,0,75,169,66,0,66,101,199,255,24,216,199,1,121,196,26,255,14,79,203,254,240,226,81,255,94,28,10,255,83,193,240,255,204,193,131,255,94,15,86,0,218,40,157,0,51,193,209,0,0,242,177,0,102,185,247,0,158,109,116,0,38,135,91,0,223,175,149,0,220,66,1,255,86,60,232,0,25,96,37,255,225,122,162,1,215,187,168,255,158,157,46,0,56,171,162,0,232,240,101,1,122,22,9,0,51,9,21,255,53,25,238,255,217,30,232,254,125,169,148,0,13,232,102,0,148,9,37,0,165,97,141,1,228,131,41,0,222,15,243,255,254,18,17,0,6,60,237,1,106,3,113,0,59,132,189,0,92,112,30,0,105,208,213,0,48,84,179,255,187,121,231,254,27,216,109,255,162,221,107,254,73,239,195,255,250,31,57,255,149,135,89,255,185,23,115,1,3,163,157,255,18,112,250,0,25,57,187,255,161,96,164,0,47,16,243,0,12,141,251,254,67,234,184,255,41,18,161,0,175,6,96,255,160,172,52,254,24,176,183,255,198,193,85,1,124,121,137,255,151,50,114,255,220,203,60,255,207,239,5,1,0,38,107,255,55,238,94,254,70,152,94,0,213,220,77,1,120,17,69,255,85,164,190,255,203,234,81,0,38,49,37,254,61,144,124,0,137,78,49,254,168,247,48,0,95,164,252,0,105,169,135,0,253,228,134,0,64,166,75,0,81,73,20,255,207,210,10,0,234,106,150,255,94,34,90,255,254,159,57,254,220,133,99,0,139,147,180,254,24,23,185,0,41,57,30,255,189,97,76,0,65,187,223,255,224,172,37,255,34,62,95,1,231,144,240,0,77,106,126,254,64,152,91,0,29,98,155,0,226,251,53,255,234,211,5,255,144,203,222,255,164,176,221,254,5,231,24,0,179,122,205,0,36,1,134,255,125,70,151,254,97,228,252,0,172,129,23,254,48,90,209,255,150,224,82,1,84,134,30,0,241,196,46,0,103,113,234,255,46,101,121,254,40,124,250,255,135,45,242,254,9,249,168,255,140,108,131,255,143,163,171,0,50,173,199,255,88,222,142,255,200,95,158,0,142,192,163,255,7,117,135,0,111,124,22,0,236,12,65,254,68,38,65,255,227,174,254,0,244,245,38,0,240,50,208,255,161,63,250,0,60,209,239,0,122,35,19,0,14,33,230,254,2,159,113,0,106,20,127,255,228,205,96,0,137,210,174,254,180,212,144,255,89,98,154,1,34,88,139,0,167,162,112,1,65,110,197,0,241,37,169,0,66,56,131,255,10,201,83,254,133,253,187,255,177,112,45,254,196,251,0,0,196,250,151,255,238,232,214,255,150,209,205,0,28,240,118,0,71,76,83,1,236,99,91,0,42,250,131,1,96,18,64,255,118,222,35,0,113,214,203,255,122,119,184,255,66,19,36,0,204,64,249,0,146,89,139,0,134,62,135,1,104,233,101,0,188,84,26,0,49,249,129,0,208,214,75,255,207,130,77,255,115,175,235,0,171,2,137,255,175,145,186,1,55,245,135,255,154,86,181,1,100,58,246,255,109,199,60,255,82,204,134,255,215,49,230,1,140,229,192,255,222,193,251,255,81,136,15,255,179,149,162,255,23,39,29,255,7,95,75,254,191,81,222,0,241,81,90,255,107,49,201,255,244,211,157,0,222,140,149,255,65,219,56,254,189,246,90,255,178,59,157,1,48,219,52,0,98,34,215,0,28,17,187,255,175,169,24,0,92,79,161,255,236,200,194,1,147,143,234,0,229,225,7,1,197,168,14,0,235,51,53,1,253,120,174,0,197,6,168,255,202,117,171,0,163,21,206,0,114,85,90,255,15,41,10,255,194,19,99,0,65,55,216,254,162,146,116,0,50,206,212,255,64,146,29,255,158,158,131,1,100,165,130,255,172,23,129,255,125,53,9,255,15,193,18,1,26,49,11,255,181,174,201,1,135,201,14,255,100,19,149,0,219,98,79,0,42,99,143,254,96,0,48,255,197,249,83,254,104,149,79,255,235,110,136,254,82,128,44,255,65,41,36,254,88,211,10,0,187,121,187,0,98,134,199,0,171,188,179,254,210,11,238,255,66,123,130,254,52,234,61,0,48,113,23,254,6,86,120,255,119,178,245,0,87,129,201,0,242,141,209,0,202,114,85,0,148,22,161,0,103,195,48,0,25,49,171,255,138,67,130,0,182,73,122,254,148,24,130,0,211,229,154,0,32,155,158,0,84,105,61,0,177,194,9,255,166,89,86,1,54,83,187,0,249,40,117,255,109,3,215,255,53,146,44,1,63,47,179,0,194,216,3,254,14,84,136,0,136,177,13,255,72,243,186,255,117,17,125,255,211,58,211,255,93,79,223,0,90,88,245,255,139,209,111,255,70,222,47,0,10,246,79,255,198,217,178,0,227,225,11,1,78,126,179,255,62,43,126,0,103,148,35,0,129,8,165,254,245,240,148,0,61,51,142,0,81,208,134,0,15,137,115,255,211,119,236,255,159,245,248,255,2,134,136,255,230,139,58,1,160,164,254,0,114,85,141,255,49,166,182,255,144,70,84,1,85,182,7,0,46,53,93,0,9,166,161,255,55,162,178,255,45,184,188,0,146,28,44,254,169,90,49,0,120,178,241,1,14,123,127,255,7,241,199,1,189,66,50,255,198,143,101,254,189,243,135,255,141,24,24,254,75,97,87,0,118,251,154,1,237,54,156,0,171,146,207,255,131,196,246,255,136,64,113,1,151,232,57,0,240,218,115,0,49,61,27,255,64,129,73,1,252,169,27,255,40,132,10,1,90,201,193,255,252,121,240,1,186,206,41,0,43,198,97,0,145,100,183,0,204,216,80,254,172,150,65,0,249,229,196,254,104,123,73,255,77,104,96,254,130,180,8,0,104,123,57,0,220,202,229,255,102,249,211,0,86,14,232,255,182,78,209,0,239,225,164,0,106,13,32,255,120,73,17,255,134,67,233,0,83,254,181,0,183,236,112,1,48,64,131,255,241,216,243,255,65,193,226,0,206,241,100,254,100,134,166,255,237,202,197,0,55,13,81,0,32,124,102,255,40,228,177,0,118,181,31,1,231,160,134,255,119,187,202,0,0,142,60,255,128,38,189,255,166,201,150,0,207,120,26,1,54,184,172,0,12,242,204,254,133,66,230,0,34,38,31,1,184,112,80,0,32,51,165,254,191,243,55,0,58,73,146,254,155,167,205,255,100,104,152,255,197,254,207,255,173,19,247,0,238,10,202,0,239,151,242,0,94,59,39,255,240,29,102,255,10,92,154,255,229,84,219,255,161,129,80,0,208,90,204,1,240,219,174,255,158,102,145,1,53,178,76,255,52,108,168,1,83,222,107,0,211,36,109,0,118,58,56,0,8,29,22,0,237,160,199,0,170,209,157,0,137,71,47,0,143,86,32,0,198,242,2,0,212,48,136,1,92,172,186,0,230,151,105,1,96,191,229,0,138,80,191,254,240,216,130,255,98,43,6,254,168,196,49,0,253,18,91,1,144,73,121,0,61,146,39,1,63,104,24,255,184,165,112,254,126,235,98,0,80,213,98,255,123,60,87,255,82,140,245,1,223,120,173,255,15,198,134,1,206,60,239,0,231,234,92,255,33,238,19,255,165,113,142,1,176,119,38,0,160,43,166,254,239,91,105,0,107,61,194,1,25,4,68,0,15,139,51,0,164,132,106,255,34,116,46,254,168,95,197,0,137,212,23,0,72,156,58,0,137,112,69,254,150,105,154,255,236,201,157,0,23,212,154,255,136,82,227,254,226,59,221,255,95,149,192,0,81,118,52,255,33,43,215,1,14,147,75,255,89,156,121,254,14,18,79,0,147,208,139,1,151,218,62,255,156,88,8,1,210,184,98,255,20,175,123,255,102,83,229,0,220,65,116,1,150,250,4,255,92,142,220,255,34,247,66,255,204,225,179,254,151,81,151,0,71,40,236,255,138,63,62,0,6,79,240,255,183,185,181,0,118,50,27,0,63,227,192,0,123,99,58,1,50,224,155,255,17,225,223,254,220,224,77,255,14,44,123,1,141,128,175,0,248,212,200,0,150,59,183,255,147,97,29,0,150,204,181,0,253,37,71,0,145,85,119,0,154,200,186,0,2,128,249,255,83,24,124,0,14,87,143,0,168,51,245,1,124,151,231,255,208,240,197,1,124,190,185,0,48,58,246,0,20,233,232,0,125,18,98,255,13,254,31,255,245,177,130,255,108,142,35,0,171,125,242,254,140,12,34,255,165,161,162,0,206,205,101,0,247,25,34,1,100,145,57,0,39,70,57,0,118,204,203,255,242,0,162,0,165,244,30,0,198,116,226,0,128,111,153,255,140,54,182,1,60,122,15,255,155,58,57,1,54,50,198,0,171,211,29,255,107,138,167,255,173,107,199,255,109,161,193,0,89,72,242,255,206,115,89,255,250,254,142,254,177,202,94,255,81,89,50,0,7,105,66,255,25,254,255,254,203,64,23,255,79,222,108,255,39,249,75,0,241,124,50,0,239,152,133,0,221,241,105,0,147,151,98,0,213,161,121,254,242,49,137,0,233,37,249,254,42,183,27,0,184,119,230,255,217,32,163,255,208,251,228,1,137,62,131,255,79,64,9,254,94,48,113,0,17,138,50,254,193,255,22,0,247,18,197,1,67,55,104,0,16,205,95,255,48,37,66,0,55,156,63,1,64,82,74,255,200,53,71,254,239,67,125,0,26,224,222,0,223,137,93,255,30,224,202,255,9,220,132,0,198,38,235,1,102,141,86,0,60,43,81,1,136,28,26,0,233,36,8,254,207,242,148,0,164,162,63,0,51,46,224,255,114,48,79,255,9,175,226,0,222,3,193,255,47,160,232,255,255,93,105,254,14,42,230,0,26,138,82,1,208,43,244,0,27,39,38,255,98,208,127,255,64,149,182,255,5,250,209,0,187,60,28,254,49,25,218,255,169,116,205,255,119,18,120,0,156,116,147,255,132,53,109,255,13,10,202,0,110,83,167,0,157,219,137,255,6,3,130,255,50,167,30,255,60,159,47,255,129,128,157,254,94,3,189,0,3,166,68,0,83,223,215,0,150,90,194,1,15,168,65,0,227,83,51,255,205,171,66,255,54,187,60,1,152,102,45,255,119,154,225,0,240,247,136,0,100,197,178,255,139,71,223,255,204,82,16,1,41,206,42,255,156,192,221,255,216,123,244,255,218,218,185,255,187,186,239,255,252,172,160,255,195,52,22,0,144,174,181,254,187,100,115,255,211,78,176,255,27,7,193,0,147,213,104,255,90,201,10,255,80,123,66,1,22,33,186,0,1,7,99,254,30,206,10,0,229,234,5,0,53,30,210,0,138,8,220,254,71,55,167,0,72,225,86,1,118,190,188,0,254,193,101,1,171,249,172,255,94,158,183,254,93,2,108,255,176,93,76,255,73,99,79,255,74,64,129,254,246,46,65,0,99,241,127,254,246,151,102,255,44,53,208,254,59,102,234,0,154,175,164,255,88,242,32,0,111,38,1,0,255,182,190,255,115,176,15,254,169,60,129,0,122,237,241,0,90,76,63,0,62,74,120,255,122,195,110,0,119,4,178,0,222,242,210,0,130,33,46,254,156,40,41,0,167,146,112,1,49,163,111,255,121,176,235,0,76,207,14,255,3,25,198,1,41,235,213,0,85,36,214,1,49,92,109,255,200,24,30,254,168,236,195,0,145,39,124,1,236,195,149,0,90,36,184,255,67,85,170,255,38,35,26,254,131,124,68,255,239,155,35,255,54,201,164,0,196,22,117,255,49,15,205,0,24,224,29,1,126,113,144,0,117,21,182,0,203,159,141,0,223,135,77,0,176,230,176,255,190,229,215,255,99,37,181,255,51,21,138,255,25,189,89,255,49,48,165,254,152,45,247,0,170,108,222,0,80,202,5,0,27,69,103,254,204,22,129,255,180,252,62,254,210,1,91,255,146,110,254,255,219,162,28,0,223,252,213,1,59,8,33,0,206,16,244,0,129,211,48,0,107,160,208,0,112,59,209,0,109,77,216,254,34,21,185,255,246,99,56,255,179,139,19,255,185,29,50,255,84,89,19,0,74,250,98,255,225,42,200,255,192,217,205,255,210,16,167,0,99,132,95,1,43,230,57,0,254,11,203,255,99,188,63,255,119,193,251,254,80,105,54,0,232,181,189,1,183,69,112,255,208,171,165,255,47,109,180,255,123,83,165,0,146,162,52,255,154,11,4,255,151,227,90,255,146,137,97,254,61,233,41,255,94,42,55,255,108,164,236,0,152,68,254,0,10,140,131,255,10,106,79,254,243,158,137,0,67,178,66,254,177,123,198,255,15,62,34,0,197,88,42,255,149,95,177,255,152,0,198,255,149,254,113,255,225,90,163,255,125,217,247,0,18,17,224,0,128,66,120,254,192,25,9,255,50,221,205,0,49,212,70,0,233,255,164,0,2,209,9,0,221,52,219,254,172,224,244,255,94,56,206,1,242,179,2,255,31,91,164,1,230,46,138,255,189,230,220,0,57,47,61,255,111,11,157,0,177,91,152,0,28,230,98,0,97,87,126,0,198,89,145,255,167,79,107,0,249,77,160,1,29,233,230,255,150,21,86,254,60,11,193,0,151,37,36,254,185,150,243,255,228,212,83,1,172,151,180,0,201,169,155,0,244,60,234,0,142,235,4,1,67,218,60,0,192,113,75,1,116,243,207,255,65,172,155,0,81,30,156,255,80,72,33,254,18,231,109,255,142,107,21,254,125,26,132,255,176,16,59,255,150,201,58,0,206,169,201,0,208,121,226,0,40,172,14,255,150,61,94,255,56,57,156,255,141,60,145,255,45,108,149,255,238,145,155,255,209,85,31,254,192,12,210,0,99,98,93,254,152,16,151,0,225,185,220,0,141,235,44,255,160,172,21,254,71,26,31,255,13,64,93,254,28,56,198,0,177,62,248,1,182,8,241,0,166,101,148,255,78,81,133,255,129,222,215,1,188,169,129,255,232,7,97,0,49,112,60,255,217,229,251,0,119,108,138,0,39,19,123,254,131,49,235,0,132,84,145,0,130,230,148,255,25,74,187,0,5,245,54,255,185,219,241,1,18,194,228,255,241,202,102,0,105,113,202,0,155,235,79,0,21,9,178,255,156,1,239,0,200,148,61,0,115,247,210,255,49,221,135,0,58,189,8,1,35,46,9,0,81,65,5,255,52,158,185,255,125,116,46,255,74,140,13,255,210,92,172,254,147,23,71,0,217,224,253,254,115,108,180,255,145,58,48,254,219,177,24,255,156,255,60,1,154,147,242,0,253,134,87,0,53,75,229,0,48,195,222,255,31,175,50,255,156,210,120,255,208,35,222,255,18,248,179,1,2,10,101,255,157,194,248,255,158,204,101,255,104,254,197,255,79,62,4,0,178,172,101,1,96,146,251,255,65,10,156,0,2,137,165,255,116,4,231,0,242,215,1,0,19,35,29,255,43,161,79,0,59,149,246,1,251,66,176,0,200,33,3,255,80,110,142,255,195,161,17,1,228,56,66,255,123,47,145,254,132,4,164,0,67,174,172,0,25,253,114,0,87,97,87,1,250,220,84,0,96,91,200,255,37,125,59,0,19,65,118,0,161,52,241,255,237,172,6,255,176,191,255,255,1,65,130,254,223,190,230,0,101,253,231,255,146,35,109,0,250,29,77,1,49,0,19,0,123,90,155,1,22,86,32,255,218,213,65,0,111,93,127,0,60,93,169,255,8,127,182,0,17,186,14,254,253,137,246,255,213,25,48,254,76,238,0,255,248,92,70,255,99,224,139,0,184,9,255,1,7,164,208,0,205,131,198,1,87,214,199,0,130,214,95,0,221,149,222,0,23,38,171,254,197,110,213,0,43,115,140,254,215,177,118,0,96,52,66,1,117,158,237,0,14,64,182,255,46,63,174,255,158,95,190,255,225,205,177,255,43,5,142,255,172,99,212,255,244,187,147,0,29,51,153,255,228,116,24,254,30,101,207,0,19,246,150,255,134,231,5,0,125,134,226,1,77,65,98,0,236,130,33,255,5,110,62,0,69,108,127,255,7,113,22,0,145,20,83,254,194,161,231,255,131,181,60,0,217,209,177,255,229,148,212,254,3,131,184,0,117,177,187,1,28,14,31,255,176,102,80,0,50,84,151,255,125,31,54,255,21,157,133,255,19,179,139,1,224,232,26,0,34,117,170,255,167,252,171,255,73,141,206,254,129,250,35,0,72,79,236,1,220,229,20,255,41,202,173,255,99,76,238,255,198,22,224,255,108,198,195,255,36,141,96,1,236,158,59,255,106,100,87,0,110,226,2,0,227,234,222,0,154,93,119,255,74,112,164,255,67,91,2,255,21,145,33,255,102,214,137,255,175,230,103,254,163,246,166,0,93,247,116,254,167,224,28,255,220,2,57,1,171,206,84,0,123,228,17,255,27,120,119,0,119,11,147,1,180,47,225,255,104,200,185,254,165,2,114,0,77,78,212,0,45,154,177,255,24,196,121,254,82,157,182,0,90,16,190,1,12,147,197,0,95,239,152,255,11,235,71,0,86,146,119,255,172,134,214,0,60,131,196,0,161,225,129,0,31,130,120,254,95,200,51,0,105,231,210,255,58,9,148,255,43,168,221,255,124,237,142,0,198,211,50,254,46,245,103,0,164,248,84,0,152,70,208,255,180,117,177,0,70,79,185,0,243,74,32,0,149,156,207,0,197,196,161,1,245,53,239,0,15,93,246,254,139,240,49,255,196,88,36,255,162,38,123,0,128,200,157,1,174,76,103,255,173,169,34,254,216,1,171,255,114,51,17,0,136,228,194,0,110,150,56,254,106,246,159,0,19,184,79,255,150,77,240,255,155,80,162,0,0,53,169,255,29,151,86,0,68,94,16,0,92,7,110,254,98,117,149,255,249,77,230,255,253,10,140,0,214,124,92,254,35,118,235,0,89,48,57,1,22,53,166,0,184,144,61,255,179,255,194,0,214,248,61,254,59,110,246,0,121,21,81,254,166,3,228,0,106,64,26,255,69,232,134,255,242,220,53,254,46,220,85,0,113,149,247,255,97,179,103,255,190,127,11,0,135,209,182,0,95,52,129,1,170,144,206,255,122,200,204,255,168,100,146,0,60,144,149,254,70,60,40,0,122,52,177,255,246,211,101,255,174,237,8,0,7,51,120,0,19,31,173,0,126,239,156,255,143,189,203,0,196,128,88,255,233,133,226,255,30,125,173,255,201,108,50,0,123,100,59,255,254,163,3,1,221,148,181,255,214,136,57,254,222,180,137,255,207,88,54,255,28,33,251,255,67,214,52,1,210,208,100,0,81,170,94,0,145,40,53,0,224,111,231,254,35,28,244,255,226,199,195,254,238,17,230,0,217,217,164,254,169,157,221,0,218,46,162,1,199,207,163,255,108,115,162,1,14,96,187,255,118,60,76,0,184,159,152,0,209,231,71,254,42,164,186,255,186,153,51,254,221,171,182,255,162,142,173,0,235,47,193,0,7,139,16,1,95,164,64,255,16,221,166,0,219,197,16,0,132,29,44,255,100,69,117,255,60,235,88,254,40,81,173,0,71,190,61,255,187,88,157,0,231,11,23,0,237,117,164,0,225,168,223,255,154,114,116,255,163,152,242,1,24,32,170,0,125,98,113,254,168,19,76,0,17,157,220,254,155,52,5,0,19,111,161,255,71,90,252,255,173,110,240,0,10,198,121,255,253,255,240,255,66,123,210,0,221,194,215,254,121,163,17,255,225,7,99,0,190,49,182,0,115,9,133,1,232,26,138,255,213,68,132,0,44,119,122,255,179,98,51,0,149,90,106,0,71,50,230,255,10,153,118,255,177,70,25,0,165,87,205,0,55,138,234,0,238,30,97,0,113,155,207,0,98,153,127,0,34,107,219,254,117,114,172,255,76,180,255,254,242,57,179,255,221,34,172,254,56,162,49,255,83,3,255,255,113,221,189,255,188,25,228,254,16,88,89,255,71,28,198,254,22,17,149,255,243,121,254,255,107,202,99,255,9,206,14,1,220,47,153,0,107,137,39,1,97,49,194,255,149,51,197,254,186,58,11,255,107,43,232,1,200,6,14,255,181,133,65,254,221,228,171,255,123,62,231,1,227,234,179,255,34,189,212,254,244,187,249,0,190,13,80,1,130,89,1,0,223,133,173,0,9,222,198,255,66,127,74,0,167,216,93,255,155,168,198,1,66,145,0,0,68,102,46,1,172,90,154,0,216,128,75,255,160,40,51,0,158,17,27,1,124,240,49,0,236,202,176,255,151,124,192,255,38,193,190,0,95,182,61,0,163,147,124,255,255,165,51,255,28,40,17,254,215,96,78,0,86,145,218,254,31,36,202,255,86,9,5,0,111,41,200,255,237,108,97,0,57,62,44,0,117,184,15,1,45,241,116,0,152,1,220,255,157,165,188,0,250,15,131,1,60,44,125,255,65,220,251,255,75,50,184,0,53,90,128,255,231,80,194,255,136,129,127,1,21,18,187,255,45,58,161,255,71,147,34,0,174,249,11,254,35,141,29,0,239,68,177,255,115,110,58,0,238,190,177,1,87,245,166,255,190,49,247,255,146,83,184,255,173,14,39,255,146,215,104,0,142,223,120,0,149,200,155,255,212,207,145,1,16,181,217,0,173,32,87,255,255,35,181,0,119,223,161,1,200,223,94,255,70,6,186,255,192,67,85,255,50,169,152,0,144,26,123,255,56,243,179,254,20,68,136,0,39,140,188,254,253,208,5,255,200,115,135,1,43,172,229,255,156,104,187,0,151,251,167,0,52,135,23,0,151,153,72,0,147,197,107,254,148,158,5,255,238,143,206,0,126,153,137,255,88,152,197,254,7,68,167,0,252,159,165,255,239,78,54,255,24,63,55,255,38,222,94,0,237,183,12,255,206,204,210,0,19,39,246,254,30,74,231,0,135,108,29,1,179,115,0,0,117,118,116,1,132,6,252,255,145,129,161,1,105,67,141,0,82,37,226,255,238,226,228,255,204,214,129,254,162,123,100,255,185,121,234,0,45,108,231,0,66,8,56,255,132,136,128,0,172,224,66,254,175,157,188,0,230,223,226,254,242,219,69,0,184,14,119,1,82,162,56,0,114,123,20,0,162,103,85,255,49,239,99,254,156,135,215,0,111,255,167,254,39,196,214,0,144,38,79,1,249,168,125,0,155,97,156,255,23,52,219,255,150,22,144,0,44,149,165,255,40,127,183,0,196,77,233,255,118,129,210,255,170,135,230,255,214,119,198,0,233,240,35,0,253,52,7,255,117,102,48,255,21,204,154,255,179,136,177,255,23,2,3,1,149,130,89,255,252,17,159,1,70,60,26,0,144,107,17,0,180,190,60,255,56,182,59,255,110,71,54,255,198,18,129,255,149,224,87,255,223,21,152,255,138,22,182,255,250,156,205,0,236,45,208,255,79,148,242,1,101,70,209,0,103,78,174,0,101,144,172,255,152,136,237,1,191,194,136,0,113,80,125,1,152,4,141,0,155,150,53,255,196,116,245,0,239,114,73,254,19,82,17,255,124,125,234,255,40,52,191,0,42,210,158,255,155,132,165,0,178,5,42,1,64,92,40,255,36,85,77,255,178,228,118,0,137,66,96,254,115,226,66,0,110,240,69,254,151,111,80,0,167,174,236,255,227,108,107,255,188,242,65,255,183,81,255,0,57,206,181,255,47,34,181,255,213,240,158,1,71,75,95,0,156,40,24,255,102,210,81,0,171,199,228,255,154,34,41,0,227,175,75,0,21,239,195,0,138,229,95,1,76,192,49,0,117,123,87,1,227,225,130,0,125,62,63,255,2,198,171,0,254,36,13,254,145,186,206,0,148,255,244,255,35,0,166,0,30,150,219,1,92,228,212,0,92,198,60,254,62,133,200,255,201,41,59,0,125,238,109,255,180,163,238,1,140,122,82,0,9,22,88,255,197,157,47,255,153,94,57,0,88,30,182,0,84,161,85,0,178,146,124,0,166,166,7,255,21,208,223,0,156,182,242,0,155,121,185,0,83,156,174,254,154,16,118,255,186,83,232,1,223,58,121,255,29,23,88,0,35,125,127,255,170,5,149,254,164,12,130,255,155,196,29,0,161,96,136,0,7,35,29,1,162,37,251,0,3,46,242,255,0,217,188,0,57,174,226,1,206,233,2,0,57,187,136,254,123,189,9,255,201,117,127,255,186,36,204,0,231,25,216,0,80,78,105,0,19,134,129,255,148,203,68,0,141,81,125,254,248,165,200,255,214,144,135,0,151,55,166,255,38,235,91,0,21,46,154,0,223,254,150,255,35,153,180,255,125,176,29,1,43,98,30,255,216,122,230,255,233,160,12,0,57,185,12,254,240,113,7,255,5,9,16,254,26,91,108,0,109,198,203,0,8,147,40,0,129,134,228,255,124,186,40,255,114,98,132,254,166,132,23,0,99,69,44,0,9,242,238,255,184,53,59,0,132,129,102,255,52,32,243,254,147,223,200,255,123,83,179,254,135,144,201,255,141,37,56,1,151,60,227,255,90,73,156,1,203,172,187,0,80,151,47,255,94,137,231,255,36,191,59,255,225,209,181,255,74,215,213,254,6,118,179,255,153,54,193,1,50,0,231,0,104,157,72,1,140,227,154,255,182,226,16,254,96,225,92,255,115,20,170,254,6,250,78,0,248,75,173,255,53,89,6,255,0,180,118,0,72,173,1,0,64,8,206,1,174,133,223,0,185,62,133,255,214,11,98,0,197,31,208,0,171,167,244,255,22,231,181,1,150,218,185,0,247,169,97,1,165,139,247,255,47,120,149,1,103,248,51,0,60,69,28,254,25,179,196,0,124,7,218,254,58,107,81,0,184,233,156,255,252,74,36,0,118,188,67,0,141,95,53,255,222,94,165,254,46,61,53,0,206,59,115,255,47,236,250,255,74,5,32,1,129,154,238,255,106,32,226,0,121,187,61,255,3,166,241,254,67,170,172,255,29,216,178,255,23,201,252,0,253,110,243,0,200,125,57,0,109,192,96,255,52,115,238,0,38,121,243,255,201,56,33,0,194,118,130,0,75,96,25,255,170,30,230,254,39,63,253,0,36,45,250,255,251,1,239,0,160,212,92,1,45,209,237,0,243,33,87,254,237,84,201,255,212,18,157,254,212,99,127,255,217,98,16,254,139,172,239,0,168,201,130,255,143,193,169,255,238,151,193,1,215,104,41,0,239,61,165,254,2,3,242,0,22,203,177,254,177,204,22,0,149,129,213,254,31,11,41,255,0,159,121,254,160,25,114,255,162,80,200,0,157,151,11,0,154,134,78,1,216,54,252,0,48,103,133,0,105,220,197,0,253,168,77,254,53,179,23,0,24,121,240,1,255,46,96,255,107,60,135,254,98,205,249,255,63,249,119,255,120,59,211,255,114,180,55,254,91,85,237,0,149,212,77,1,56,73,49,0,86,198,150,0,93,209,160,0,69,205,182,255,244,90,43,0,20,36,176,0,122,116,221,0,51,167,39,1,231,1,63,255,13,197,134,0,3,209,34,255,135,59,202,0,167,100,78,0,47,223,76,0,185,60,62,0,178,166,123,1,132,12,161,255,61,174,43,0,195,69,144,0,127,47,191,1,34,44,78,0,57,234,52,1,255,22,40,255,246,94,146,0,83,228,128,0,60,78,224,255,0,96,210,255,153,175,236,0,159,21,73,0,180,115,196,254,131,225,106,0,255,167,134,0,159,8,112,255,120,68,194,255,176,196,198,255,118,48,168,255,93,169,1,0,112,200,102,1,74,24,254,0,19,141,4,254,142,62,63,0,131,179,187,255,77,156,155,255,119,86,164,0,170,208,146,255,208,133,154,255,148,155,58,255,162,120,232,254,252,213,155,0,241,13,42,0,94,50,131,0,179,170,112,0,140,83,151,255,55,119,84,1,140,35,239,255,153,45,67,1,236,175,39,0,54,151,103,255,158,42,65,255,196,239,135,254,86,53,203,0,149,97,47,254,216,35,17,255,70,3,70,1,103,36,90,255,40,26,173,0,184,48,13,0,163,219,217,255,81,6,1,255,221,170,108,254,233,208,93,0,100,201,249,254,86,36,35,255,209,154,30,1,227,201,251,255,2,189,167,254,100,57,3,0,13,128,41,0,197,100,75,0,150,204,235,255,145,174,59,0,120,248,149,255,85,55,225,0,114,210,53,254,199,204,119,0,14,247,74,1,63,251,129,0,67,104,151,1,135,130,80,0,79,89,55,255,117,230,157,255,25,96,143,0,213,145,5,0,69,241,120,1,149,243,95,255,114,42,20,0,131,72,2,0,154,53,20,255,73,62,109,0,196,102,152,0,41,12,204,255,122,38,11,1,250,10,145,0,207,125,148,0,246,244,222,255,41,32,85,1,112,213,126,0,162,249,86,1,71,198,127,255,81,9,21,1,98,39,4,255,204,71,45,1,75,111,137,0,234,59,231,0,32,48,95,255,204,31,114,1,29,196,181,255,51,241,167,254,93,109,142,0,104,144,45,0,235,12,181,255,52,112,164,0,76,254,202,255,174,14,162,0,61,235,147,255,43,64,185,254,233,125,217,0,243,88,167,254,74,49,8,0,156,204,66,0,124,214,123,0,38,221,118,1,146,112,236,0,114,98,177,0,151,89,199,0,87,197,112,0,185,149,161,0,44,96,165,0,248,179,20,255,188,219,216,254,40,62,13,0,243,142,141,0,229,227,206,255,172,202,35,255,117,176,225,255,82,110,38,1,42,245,14,255,20,83,97,0,49,171,10,0,242,119,120,0,25,232,61,0,212,240,147,255,4,115,56,255,145,17,239,254,202,17,251,255,249,18,245,255,99,117,239,0,184,4,179,255,246,237,51,255,37,239,137,255,166,112,166,255,81,188,33,255,185,250,142,255,54,187,173,0,208,112,201,0,246,43,228,1,104,184,88,255,212,52,196,255,51,117,108,255,254,117,155,0,46,91,15,255,87,14,144,255,87,227,204,0,83,26,83,1,159,76,227,0,159,27,213,1,24,151,108,0,117,144,179,254,137,209,82,0,38,159,10,0,115,133,201,0,223,182,156,1,110,196,93,255,57,60,233,0,5,167,105,255,154,197,164,0,96,34,186,255,147,133,37,1,220,99,190,0,1,167,84,255,20,145,171,0,194,197,251,254,95,78,133,255,252,248,243,255,225,93,131,255,187,134,196,255,216,153,170,0,20,118,158,254,140,1,118,0,86,158,15,1,45,211,41,255,147,1,100,254,113,116,76,255,211,127,108,1,103,15,48,0,193,16,102,1,69,51,95,255,107,128,157,0,137,171,233,0,90,124,144,1,106,161,182,0,175,76,236,1,200,141,172,255,163,58,104,0,233,180,52,255,240,253,14,255,162,113,254,255,38,239,138,254,52,46,166,0,241,101,33,254,131,186,156,0,111,208,62,255,124,94,160,255,31,172,254,0,112,174,56,255,188,99,27,255,67,138,251,0,125,58,128,1,156,152,174,255,178,12,247,255,252,84,158,0,82,197,14,254,172,200,83,255,37,39,46,1,106,207,167,0,24,189,34,0,131,178,144,0,206,213,4,0,161,226,210,0,72,51,105,255,97,45,187,255,78,184,223,255,176,29,251,0,79,160,86,255,116,37,178,0,82,77,213,1,82,84,141,255,226,101,212,1,175,88,199,255,245,94,247,1,172,118,109,255,166,185,190,0,131,181,120,0,87,254,93,255,134,240,73,255,32,245,143,255,139,162,103,255,179,98,18,254,217,204,112,0,147,223,120,255,53,10,243,0,166,140,150,0,125,80,200,255,14,109,219,255,91,218,1,255,252,252,47,254,109,156,116,255,115,49,127,1,204,87,211,255,148,202,217,255,26,85,249,255,14,245,134,1,76,89,169,255,242,45,230,0,59,98,172,255,114,73,132,254,78,155,49,255,158,126,84,0,49,175,43,255,16,182,84,255,157,103,35,0,104,193,109,255,67,221,154,0,201,172,1,254,8,162,88,0,165,1,29,255,125,155,229,255,30,154,220,1,103,239,92,0,220,1,109,255,202,198,1,0,94,2,142,1,36,54,44,0,235,226,158,255,170,251,214,255,185,77,9,0,97,74,242,0,219,163,149,255,240,35,118,255,223,114,88,254,192,199,3,0,106,37,24,255,201,161,118,255,97,89,99,1,224,58,103,255,101,199,147,254,222,60,99,0,234,25,59,1,52,135,27,0,102,3,91,254,168,216,235,0,229,232,136,0,104,60,129,0,46,168,238,0,39,191,67,0,75,163,47,0,143,97,98,255,56,216,168,1,168,233,252,255,35,111,22,255,92,84,43,0,26,200,87,1,91,253,152,0,202,56,70,0,142,8,77,0,80,10,175,1,252,199,76,0,22,110,82,255,129,1,194,0,11,128,61,1,87,14,145,255,253,222,190,1,15,72,174,0,85,163,86,254,58,99,44,255,45,24,188,254,26,205,15,0,19,229,210,254,248,67,195,0,99,71,184,0,154,199,37,255,151,243,121,255,38,51,75,255,201,85,130,254,44,65,250,0,57,147,243,254,146,43,59,255,89,28,53,0,33,84,24,255,179,51,18,254,189,70,83,0,11,156,179,1,98,134,119,0,158,111,111,0,119,154,73,255,200,63,140,254,45,13,13,255,154,192,2,254,81,72,42,0,46,160,185,254,44,112,6,0,146,215,149,1,26,176,104,0,68,28,87,1,236,50,153,255,179,128,250,254,206,193,191,255,166,92,137,254,53,40,239,0,210,1,204,254,168,173,35,0,141,243,45,1,36,50,109,255,15,242,194,255,227,159,122,255,176,175,202,254,70,57,72,0,40,223,56,0,208,162,58,255,183,98,93,0,15,111,12,0,30,8,76,255,132,127,246,255,45,242,103,0,69,181,15,255,10,209,30,0,3,179,121,0,241,232,218,1,123,199,88,255,2,210,202,1,188,130,81,255,94,101,208,1,103,36,45,0,76,193,24,1,95,26,241,255,165,162,187,0,36,114,140,0,202,66,5,255,37,56,147,0,152,11,243,1,127,85,232,255,250,135,212,1,185,177,113,0,90,220,75,255,69,248,146,0,50,111,50,0,92,22,80,0,244,36,115,254,163,100,82,255,25,193,6,1,127,61,36,0,253,67,30,254,65,236,170,255,161,17,215,254,63,175,140,0,55,127,4,0,79,112,233,0,109,160,40,0,143,83,7,255,65,26,238,255,217,169,140,255,78,94,189,255,0,147,190,255,147,71,186,254,106,77,127,255,233,157,233,1,135,87,237,255,208,13,236,1,155,109,36,255,180,100,218,0,180,163,18,0,190,110,9,1,17,63,123,255,179,136,180,255,165,123,123,255,144,188,81,254,71,240,108,255,25,112,11,255,227,218,51,255,167,50,234,255,114,79,108,255,31,19,115,255,183,240,99,0,227,87,143,255,72,217,248,255,102,169,95,1,129,149,149,0,238,133,12,1,227,204,35,0,208,115,26,1,102,8,234,0,112,88,143,1,144,249,14,0,240,158,172,254,100,112,119,0,194,141,153,254,40,56,83,255,121,176,46,0,42,53,76,255,158,191,154,0,91,209,92,0,173,13,16,1,5,72,226,255,204,254,149,0,80,184,207,0,100,9,122,254,118,101,171,255,252,203,0,254,160,207,54,0,56,72,249,1,56,140,13,255,10,64,107,254,91,101,52,255,225,181,248,1,139,255,132,0,230,145,17,0,233,56,23,0,119,1,241,255,213,169,151,255,99,99,9,254,185,15,191,255,173,103,109,1,174,13,251,255,178,88,7,254,27,59,68,255,10,33,2,255,248,97,59,0,26,30,146,1,176,147,10,0,95,121,207,1,188,88,24,0,185,94,254,254,115,55,201,0,24,50,70,0,120,53,6,0,142,66,146,0,228,226,249,255,104,192,222,1,173,68,219,0,162,184,36,255,143,102,137,255,157,11,23,0,125,45,98,0,235,93,225,254,56,112,160,255,70,116,243,1,153,249,55,255,129,39,17,1,241,80,244,0,87,69,21,1,94,228,73,255,78,66,65,255,194,227,231,0,61,146,87,255,173,155,23,255,112,116,219,254,216,38,11,255,131,186,133,0,94,212,187,0,100,47,91,0,204,254,175,255,222,18,215,254,173,68,108,255,227,228,79,255,38,221,213,0,163,227,150,254,31,190,18,0,160,179,11,1,10,90,94,255,220,174,88,0,163,211,229,255,199,136,52,0,130,95,221,255,140,188,231,254,139,113,128,255,117,171,236,254,49,220,20,255,59,20,171,255,228,109,188,0,20,225,32,254,195,16,174,0,227,254,136,1,135,39,105,0,150,77,206,255,210,238,226],"i8",ALLOC_NONE,Runtime.GLOBAL_BASE+10240);allocate([55,212,132,254,239,57,124,0,170,194,93,255,249,16,247,255,24,151,62,255,10,151,10,0,79,139,178,255,120,242,202,0,26,219,213,0,62,125,35,255,144,2,108,255,230,33,83,255,81,45,216,1,224,62,17,0,214,217,125,0,98,153,153,255,179,176,106,254,131,93,138,255,109,62,36,255,178,121,32,255,120,252,70,0,220,248,37,0,204,88,103,1,128,220,251,255,236,227,7,1,106,49,198,255,60,56,107,0,99,114,238,0,220,204,94,1,73,187,1,0,89,154,34,0,78,217,165,255,14,195,249,255,9,230,253,255,205,135,245,0,26,252,7,255,84,205,27,1,134,2,112,0,37,158,32,0,231,91,237,255,191,170,204,255,152,7,222,0,109,192,49,0,193,166,146,255,232,19,181,255,105,142,52,255,103,16,27,1,253,200,165,0,195,217,4,255,52,189,144,255,123,155,160,254,87,130,54,255,78,120,61,255,14,56,41,0,25,41,125,255,87,168,245,0,214,165,70,0,212,169,6,255,219,211,194,254,72,93,164,255,197,33,103,255,43,142,141,0,131,225,172,0,244,105,28,0,68,68,225,0,136,84,13,255,130,57,40,254,139,77,56,0,84,150,53,0,54,95,157,0,144,13,177,254,95,115,186,0,117,23,118,255,244,166,241,255,11,186,135,0,178,106,203,255,97,218,93,0,43,253,45,0,164,152,4,0,139,118,239,0,96,1,24,254,235,153,211,255,168,110,20,255,50,239,176,0,114,41,232,0,193,250,53,0,254,160,111,254,136,122,41,255,97,108,67,0,215,152,23,255,140,209,212,0,42,189,163,0,202,42,50,255,106,106,189,255,190,68,217,255,233,58,117,0,229,220,243,1,197,3,4,0,37,120,54,254,4,156,134,255,36,61,171,254,165,136,100,255,212,232,14,0,90,174,10,0,216,198,65,255,12,3,64,0,116,113,115,255,248,103,8,0,231,125,18,255,160,28,197,0,30,184,35,1,223,73,249,255,123,20,46,254,135,56,37,255,173,13,229,1,119,161,34,255,245,61,73,0,205,125,112,0,137,104,134,0,217,246,30,255,237,142,143,0,65,159,102,255,108,164,190,0,219,117,173,255,34,37,120,254,200,69,80,0,31,124,218,254,74,27,160,255,186,154,199,255,71,199,252,0,104,81,159,1,17,200,39,0,211,61,192,1,26,238,91,0,148,217,12,0,59,91,213,255,11,81,183,255,129,230,122,255,114,203,145,1,119,180,66,255,72,138,180,0,224,149,106,0,119,82,104,255,208,140,43,0,98,9,182,255,205,101,134,255,18,101,38,0,95,197,166,255,203,241,147,0,62,208,145,255,133,246,251,0,2,169,14,0,13,247,184,0,142,7,254,0,36,200,23,255,88,205,223,0,91,129,52,255,21,186,30,0,143,228,210,1,247,234,248,255,230,69,31,254,176,186,135,255,238,205,52,1,139,79,43,0,17,176,217,254,32,243,67,0,242,111,233,0,44,35,9,255,227,114,81,1,4,71,12,255,38,105,191,0,7,117,50,255,81,79,16,0,63,68,65,255,157,36,110,255,77,241,3,255,226,45,251,1,142,25,206,0,120,123,209,1,28,254,238,255,5,128,126,255,91,222,215,255,162,15,191,0,86,240,73,0,135,185,81,254,44,241,163,0,212,219,210,255,112,162,155,0,207,101,118,0,168,72,56,255,196,5,52,0,72,172,242,255,126,22,157,255,146,96,59,255,162,121,152,254,140,16,95,0,195,254,200,254,82,150,162,0,119,43,145,254,204,172,78,255,166,224,159,0,104,19,237,255,245,126,208,255,226,59,213,0,117,217,197,0,152,72,237,0,220,31,23,254,14,90,231,255,188,212,64,1,60,101,246,255,85,24,86,0,1,177,109,0,146,83,32,1,75,182,192,0,119,241,224,0,185,237,27,255,184,101,82,1,235,37,77,255,253,134,19,0,232,246,122,0,60,106,179,0,195,11,12,0,109,66,235,1,125,113,59,0,61,40,164,0,175,104,240,0,2,47,187,255,50,12,141,0,194,139,181,255,135,250,104,0,97,92,222,255,217,149,201,255,203,241,118,255,79,151,67,0,122,142,218,255,149,245,239,0,138,42,200,254,80,37,97,255,124,112,167,255,36,138,87,255,130,29,147,255,241,87,78,255,204,97,19,1,177,209,22,255,247,227,127,254,99,119,83,255,212,25,198,1,16,179,179,0,145,77,172,254,89,153,14,255,218,189,167,0,107,233,59,255,35,33,243,254,44,112,112,255,161,127,79,1,204,175,10,0,40,21,138,254,104,116,228,0,199,95,137,255,133,190,168,255,146,165,234,1,183,99,39,0,183,220,54,254,255,222,133,0,162,219,121,254,63,239,6,0,225,102,54,255,251,18,246,0,4,34,129,1,135,36,131,0,206,50,59,1,15,97,183,0,171,216,135,255,101,152,43,255,150,251,91,0,38,145,95,0,34,204,38,254,178,140,83,255,25,129,243,255,76,144,37,0,106,36,26,254,118,144,172,255,68,186,229,255,107,161,213,255,46,163,68,255,149,170,253,0,187,17,15,0,218,160,165,255,171,35,246,1,96,13,19,0,165,203,117,0,214,107,192,255,244,123,177,1,100,3,104,0,178,242,97,255,251,76,130,255,211,77,42,1,250,79,70,255,63,244,80,1,105,101,246,0,61,136,58,1,238,91,213,0,14,59,98,255,167,84,77,0,17,132,46,254,57,175,197,255,185,62,184,0,76,64,207,0,172,175,208,254,175,74,37,0,138,27,211,254,148,125,194,0,10,89,81,0,168,203,101,255,43,213,209,1,235,245,54,0,30,35,226,255,9,126,70,0,226,125,94,254,156,117,20,255,57,248,112,1,230,48,64,255,164,92,166,1,224,214,230,255,36,120,143,0,55,8,43,255,251,1,245,1,106,98,165,0,74,107,106,254,53,4,54,255,90,178,150,1,3,120,123,255,244,5,89,1,114,250,61,255,254,153,82,1,77,15,17,0,57,238,90,1,95,223,230,0,236,52,47,254,103,148,164,255,121,207,36,1,18,16,185,255,75,20,74,0,187,11,101,0,46,48,129,255,22,239,210,255,77,236,129,255,111,77,204,255,61,72,97,255,199,217,251,255,42,215,204,0,133,145,201,255,57,230,146,1,235,100,198,0,146,73,35,254,108,198,20,255,182,79,210,255,82,103,136,0,246,108,176,0,34,17,60,255,19,74,114,254,168,170,78,255,157,239,20,255,149,41,168,0,58,121,28,0,79,179,134,255,231,121,135,255,174,209,98,255,243,122,190,0,171,166,205,0,212,116,48,0,29,108,66,255,162,222,182,1,14,119,21,0,213,39,249,255,254,223,228,255,183,165,198,0,133,190,48,0,124,208,109,255,119,175,85,255,9,209,121,1,48,171,189,255,195,71,134,1,136,219,51,255,182,91,141,254,49,159,72,0,35,118,245,255,112,186,227,255,59,137,31,0,137,44,163,0,114,103,60,254,8,213,150,0,162,10,113,255,194,104,72,0,220,131,116,255,178,79,92,0,203,250,213,254,93,193,189,255,130,255,34,254,212,188,151,0,136,17,20,255,20,101,83,255,212,206,166,0,229,238,73,255,151,74,3,255,168,87,215,0,155,188,133,255,166,129,73,0,240,79,133,255,178,211,81,255,203,72,163,254,193,168,165,0,14,164,199,254,30,255,204,0,65,72,91,1,166,74,102,255,200,42,0,255,194,113,227,255,66,23,208,0,229,216,100,255,24,239,26,0,10,233,62,255,123,10,178,1,26,36,174,255,119,219,199,1,45,163,190,0,16,168,42,0,166,57,198,255,28,26,26,0,126,165,231,0,251,108,100,255,61,229,121,255,58,118,138,0,76,207,17,0,13,34,112,254,89,16,168,0,37,208,105,255,35,201,215,255,40,106,101,254,6,239,114,0,40,103,226,254,246,127,110,255,63,167,58,0,132,240,142,0,5,158,88,255,129,73,158,255,94,89,146,0,230,54,146,0,8,45,173,0,79,169,1,0,115,186,247,0,84,64,131,0,67,224,253,255,207,189,64,0,154,28,81,1,45,184,54,255,87,212,224,255,0,96,73,255,129,33,235,1,52,66,80,255,251,174,155,255,4,179,37,0,234,164,93,254,93,175,253,0,198,69,87,255,224,106,46,0,99,29,210,0,62,188,114,255,44,234,8,0,169,175,247,255,23,109,137,255,229,182,39,0,192,165,94,254,245,101,217,0,191,88,96,0,196,94,99,255,106,238,11,254,53,126,243,0,94,1,101,255,46,147,2,0,201,124,124,255,141,12,218,0,13,166,157,1,48,251,237,255,155,250,124,255,106,148,146,255,182,13,202,0,28,61,167,0,217,152,8,254,220,130,45,255,200,230,255,1,55,65,87,255,93,191,97,254,114,251,14,0,32,105,92,1,26,207,141,0,24,207,13,254,21,50,48,255,186,148,116,255,211,43,225,0,37,34,162,254,164,210,42,255,68,23,96,255,182,214,8,255,245,117,137,255,66,195,50,0,75,12,83,254,80,140,164,0,9,165,36,1,228,110,227,0,241,17,90,1,25,52,212,0,6,223,12,255,139,243,57,0,12,113,75,1,246,183,191,255,213,191,69,255,230,15,142,0,1,195,196,255,138,171,47,255,64,63,106,1,16,169,214,255,207,174,56,1,88,73,133,255,182,133,140,0,177,14,25,255,147,184,53,255,10,227,161,255,120,216,244,255,73,77,233,0,157,238,139,1,59,65,233,0,70,251,216,1,41,184,153,255,32,203,112,0,146,147,253,0,87,101,109,1,44,82,133,255,244,150,53,255,94,152,232,255,59,93,39,255,88,147,220,255,78,81,13,1,32,47,252,255,160,19,114,255,93,107,39,255,118,16,211,1,185,119,209,255,227,219,127,254,88,105,236,255,162,110,23,255,36,166,110,255,91,236,221,255,66,234,116,0,111,19,244,254,10,233,26,0,32,183,6,254,2,191,242,0,218,156,53,254,41,60,70,255,168,236,111,0,121,185,126,255,238,142,207,255,55,126,52,0,220,129,208,254,80,204,164,255,67,23,144,254,218,40,108,255,127,202,164,0,203,33,3,255,2,158,0,0,37,96,188,255,192,49,74,0,109,4,0,0,111,167,10,254,91,218,135,255,203,66,173,255,150,194,226,0,201,253,6,255,174,102,121,0,205,191,110,0,53,194,4,0,81,40,45,254,35,102,143,255,12,108,198,255,16,27,232,255,252,71,186,1,176,110,114,0,142,3,117,1,113,77,142,0,19,156,197,1,92,47,252,0,53,232,22,1,54,18,235,0,46,35,189,255,236,212,129,0,2,96,208,254,200,238,199,255,59,175,164,255,146,43,231,0,194,217,52,255,3,223,12,0,138,54,178,254,85,235,207,0,232,207,34,0,49,52,50,255,166,113,89,255,10,45,216,255,62,173,28,0,111,165,246,0,118,115,91,255,128,84,60,0,167,144,203,0,87,13,243,0,22,30,228,1,177,113,146,255,129,170,230,254,252,153,129,255,145,225,43,0,70,231,5,255,122,105,126,254,86,246,148,255,110,37,154,254,209,3,91,0,68,145,62,0,228,16,165,255,55,221,249,254,178,210,91,0,83,146,226,254,69,146,186,0,93,210,104,254,16,25,173,0,231,186,38,0,189,122,140,255,251,13,112,255,105,110,93,0,251,72,170,0,192,23,223,255,24,3,202,1,225,93,228,0,153,147,199,254,109,170,22,0,248,101,246,255,178,124,12,255,178,254,102,254,55,4,65,0,125,214,180,0,183,96,147,0,45,117,23,254,132,191,249,0,143,176,203,254,136,183,54,255,146,234,177,0,146,101,86,255,44,123,143,1,33,209,152,0,192,90,41,254,83,15,125,255,213,172,82,0,215,169,144,0,16,13,34,0,32,209,100,255,84,18,249,1,197,17,236,255,217,186,230,0,49,160,176,255,111,118,97,255,237,104,235,0,79,59,92,254,69,249,11,255,35,172,74,1,19,118,68,0,222,124,165,255,180,66,35,255,86,174,246,0,43,74,111,255,126,144,86,255,228,234,91,0,242,213,24,254,69,44,235,255,220,180,35,0,8,248,7,255,102,47,92,255,240,205,102,255,113,230,171,1,31,185,201,255,194,246,70,255,122,17,187,0,134,70,199,255,149,3,150,255,117,63,103,0,65,104,123,255,212,54,19,1,6,141,88,0,83,134,243,255,136,53,103,0,169,27,180,0,177,49,24,0,111,54,167,0,195,61,215,255,31,1,108,1,60,42,70,0,185,3,162,255,194,149,40,255,246,127,38,254,190,119,38,255,61,119,8,1,96,161,219,255,42,203,221,1,177,242,164,255,245,159,10,0,116,196,0,0,5,93,205,254,128,127,179,0,125,237,246,255,149,162,217,255,87,37,20,254,140,238,192,0,9,9,193,0,97,1,226,0,29,38,10,0,0,136,63,255,229,72,210,254,38,134,92,255,78,218,208,1,104,36,84,255,12,5,193,255,242,175,61,255,191,169,46,1,179,147,147,255,113,190,139,254,125,172,31,0,3,75,252,254,215,36,15,0,193,27,24,1,255,69,149,255,110,129,118,0,203,93,249,0,138,137,64,254,38,70,6,0,153,116,222,0,161,74,123,0,193,99,79,255,118,59,94,255,61,12,43,1,146,177,157,0,46,147,191,0,16,255,38,0,11,51,31,1,60,58,98,255,111,194,77,1,154,91,244,0,140,40,144,1,173,10,251,0,203,209,50,254,108,130,78,0,228,180,90,0,174,7,250,0,31,174,60,0,41,171,30,0,116,99,82,255,118,193,139,255,187,173,198,254,218,111,56,0,185,123,216,0,249,158,52,0,52,180,93,255,201,9,91,255,56,45,166,254,132,155,203,255,58,232,110,0,52,211,89,255,253,0,162,1,9,87,183,0,145,136,44,1,94,122,245,0,85,188,171,1,147,92,198,0,0,8,104,0,30,95,174,0,221,230,52,1,247,247,235,255,137,174,53,255,35,21,204,255,71,227,214,1,232,82,194,0,11,48,227,255,170,73,184,255,198,251,252,254,44,112,34,0,131,101,131,255,72,168,187,0,132,135,125,255,138,104,97,255,238,184,168,255,243,104,84,255,135,216,226,255,139,144,237,0,188,137,150,1,80,56,140,255,86,169,167,255,194,78,25,255,220,17,180,255,17,13,193,0,117,137,212,255,141,224,151,0,49,244,175,0,193,99,175,255,19,99,154,1,255,65,62,255,156,210,55,255,242,244,3,255,250,14,149,0,158,88,217,255,157,207,134,254,251,232,28,0,46,156,251,255,171,56,184,255,239,51,234,0,142,138,131,255,25,254,243,1,10,201,194,0,63,97,75,0,210,239,162,0,192,200,31,1,117,214,243,0,24,71,222,254,54,40,232,255,76,183,111,254,144,14,87,255,214,79,136,255,216,196,212,0,132,27,140,254,131,5,253,0,124,108,19,255,28,215,75,0,76,222,55,254,233,182,63,0,68,171,191,254,52,111,222,255,10,105,77,255,80,170,235,0,143,24,88,255,45,231,121,0,148,129,224,1,61,246,84,0,253,46,219,255,239,76,33,0,49,148,18,254,230,37,69,0,67,134,22,254,142,155,94,0,31,157,211,254,213,42,30,255,4,228,247,254,252,176,13,255,39,0,31,254,241,244,255,255,170,45,10,254,253,222,249,0,222,114,132,0,255,47,6,255,180,163,179,1,84,94,151,255,89,209,82,254,229,52,169,255,213,236,0,1,214,56,228,255,135,119,151,255,112,201,193,0,83,160,53,254,6,151,66,0,18,162,17,0,233,97,91,0,131,5,78,1,181,120,53,255,117,95,63,255,237,117,185,0,191,126,136,255,144,119,233,0,183,57,97,1,47,201,187,255,167,165,119,1,45,100,126,0,21,98,6,254,145,150,95,255,120,54,152,0,209,98,104,0,143,111,30,254,184,148,249,0,235,216,46,0,248,202,148,255,57,95,22,0,242,225,163,0,233,247,232,255,71,171,19,255,103,244,49,255,84,103,93,255,68,121,244,1,82,224,13,0,41,79,43,255,249,206,167,255,215,52,21,254,192,32,22,255,247,111,60,0,101,74,38,255,22,91,84,254,29,28,13,255,198,231,215,254,244,154,200,0,223,137,237,0,211,132,14,0,95,64,206,255,17,62,247,255,233,131,121,1,93,23,77,0,205,204,52,254,81,189,136,0,180,219,138,1,143,18,94,0,204,43,140,254,188,175,219,0,111,98,143,255,151,63,162,255,211,50,71,254,19,146,53,0,146,45,83,254,178,82,238,255,16,133,84,255,226,198,93,255,201,97,20,255,120,118,35,255,114,50,231,255,162,229,156,255,211,26,12,0,114,39,115,255,206,212,134,0,197,217,160,255,116,129,94,254,199,215,219,255,75,223,249,1,253,116,181,255,232,215,104,255,228,130,246,255,185,117,86,0,14,5,8,0,239,29,61,1,237,87,133,255,125,146,137,254,204,168,223,0,46,168,245,0,154,105,22,0,220,212,161,255,107,69,24,255,137,218,181,255,241,84,198,255,130,122,211,255,141,8,153,255,190,177,118,0,96,89,178,0,255,16,48,254,122,96,105,255,117,54,232,255,34,126,105,255,204,67,166,0,232,52,138,255,211,147,12,0,25,54,7,0,44,15,215,254,51,236,45,0,190,68,129,1,106,147,225,0,28,93,45,254,236,141,15,255,17,61,161,0,220,115,192,0,236,145,24,254,111,168,169,0,224,58,63,255,127,164,188,0,82,234,75,1,224,158,134,0,209,68,110,1,217,166,217,0,70,225,166,1,187,193,143,255,16,7,88,255,10,205,140,0,117,192,156,1,17,56,38,0,27,124,108,1,171,215,55,255,95,253,212,0,155,135,168,255,246,178,153,254,154,68,74,0,232,61,96,254,105,132,59,0,33,76,199,1,189,176,130,255,9,104,25,254,75,198,102,255,233,1,112,0,108,220,20,255,114,230,70,0,140,194,133,255,57,158,164,254,146,6,80,255,169,196,97,1,85,183,130,0,70,158,222,1,59,237,234,255,96,25,26,255,232,175,97,255,11,121,248,254,88,35,194,0,219,180,252,254,74,8,227,0,195,227,73,1,184,110,161,255,49,233,164,1,128,53,47,0,82,14,121,255,193,190,58,0,48,174,117,255,132,23,32,0,40,10,134,1,22,51,25,255,240,11,176,255,110,57,146,0,117,143,239,1,157,101,118,255,54,84,76,0,205,184,18,255,47,4,72,255,78,112,85,255,193,50,66,1,93,16,52,255,8,105,134,0,12,109,72,255,58,156,251,0,144,35,204,0,44,160,117,254,50,107,194,0,1,68,165,255,111,110,162,0,158,83,40,254,76,214,234,0,58,216,205,255,171,96,147,255,40,227,114,1,176,227,241,0,70,249,183,1,136,84,139,255,60,122,247,254,143,9,117,255,177,174,137,254,73,247,143,0,236,185,126,255,62,25,247,255,45,64,56,255,161,244,6,0,34,57,56,1,105,202,83,0,128,147,208,0,6,103,10,255,74,138,65,255,97,80,100,255,214,174,33,255,50,134,74,255,110,151,130,254,111,84,172,0,84,199,75,254,248,59,112,255,8,216,178,1,9,183,95,0,238,27,8,254,170,205,220,0,195,229,135,0,98,76,237,255,226,91,26,1,82,219,39,255,225,190,199,1,217,200,121,255,81,179,8,255,140,65,206,0,178,207,87,254,250,252,46,255,104,89,110,1,253,189,158,255,144,214,158,255,160,245,54,255,53,183,92,1,21,200,194,255,146,33,113,1,209,1,255,0,235,106,43,255,167,52,232,0,157,229,221,0,51,30,25,0,250,221,27,1,65,147,87,255,79,123,196,0,65,196,223,255,76,44,17,1,85,241,68,0,202,183,249,255,65,212,212,255,9,33,154,1,71,59,80,0,175,194,59,255,141,72,9,0,100,160,244,0,230,208,56,0,59,25,75,254,80,194,194,0,18,3,200,254,160,159,115,0,132,143,247,1,111,93,57,255,58,237,11,1,134,222,135,255,122,163,108,1,123,43,190,255,251,189,206,254,80,182,72,255,208,246,224,1,17,60,9,0,161,207,38,0,141,109,91,0,216,15,211,255,136,78,110,0,98,163,104,255,21,80,121,255,173,178,183,1,127,143,4,0,104,60,82,254,214,16,13,255,96,238,33,1,158,148,230,255,127,129,62,255,51,255,210,255,62,141,236,254,157,55,224,255,114,39,244,0,192,188,250,255,228,76,53,0,98,84,81,255,173,203,61,254,147,50,55,255,204,235,191,0,52,197,244,0,88,43,211,254,27,191,119,0,188,231,154,0,66,81,161,0,92,193,160,1,250,227,120,0,123,55,226,0,184,17,72,0,133,168,10,254,22,135,156,255,41,25,103,255,48,202,58,0,186,149,81,255,188,134,239,0,235,181,189,254,217,139,188,255,74,48,82,0,46,218,229,0,189,253,251,0,50,229,12,255,211,141,191,1,128,244,25,255,169,231,122,254,86,47,189,255,132,183,23,255,37,178,150,255,51,137,253,0,200,78,31,0,22,105,50,0,130,60,0,0,132,163,91,254,23,231,187,0,192,79,239,0,157,102,164,255,192,82,20,1,24,181,103,255,240,9,234,0,1,123,164,255,133,233,0,255,202,242,242,0,60,186,245,0,241,16,199,255,224,116,158,254,191,125,91,255,224,86,207,0,121,37,231,255,227,9,198,255,15,153,239,255,121,232,217,254,75,112,82,0,95,12,57,254,51,214,105,255,148,220,97,1,199,98,36,0,156,209,12,254,10,212,52,0,217,180,55,254,212,170,232,255,216,20,84,255,157,250,135,0,157,99,127,254,1,206,41,0,149,36,70,1,54,196,201,255,87,116,0,254,235,171,150,0,27,163,234,0,202,135,180,0,208,95,0,254,123,156,93,0,183,62,75,0,137,235,182,0,204,225,255,255,214,139,210,255,2,115,8,255,29,12,111,0,52,156,1,0,253,21,251,255,37,165,31,254,12,130,211,0,106,18,53,254,42,99,154,0,14,217,61,254,216,11,92,255,200,197,112,254,147,38,199,0,36,252,120,254,107,169,77,0,1,123,159,255,207,75,102,0,163,175,196,0,44,1,240,0,120,186,176,254,13,98,76,255,237,124,241,255,232,146,188,255,200,96,224,0,204,31,41,0,208,200,13,0,21,225,96,255,175,156,196,0,247,208,126,0,62,184,244,254,2,171,81,0,85,115,158,0,54,64,45,255,19,138,114,0,135,71,205,0,227,47,147,1,218,231,66,0,253,209,28,0,244,15,173,255,6,15,118,254,16,150,208,255,185,22,50,255,86,112,207,255,75,113,215,1,63,146,43,255,4,225,19,254,227,23,62,255,14,255,214,254,45,8,205,255,87,197,151,254,210,82,215,255,245,248,247,255,128,248,70,0,225,247,87,0,90,120,70,0,213,245,92,0,13,133,226,0,47,181,5,1,92,163,105,255,6,30,133,254,232,178,61,255,230,149,24,255,18,49,158,0,228,100,61,254,116,243,251,255,77,75,92,1,81,219,147,255,76,163,254,254,141,213,246,0,232,37,152,254,97,44,100,0,201,37,50,1,212,244,57,0,174,171,183,255,249,74,112,0,166,156,30,0,222,221,97,255,243,93,73,254,251,101,100,255,216,217,93,255,254,138,187,255,142,190,52,255,59,203,177,255,200,94,52,0,115,114,158,255,165,152,104,1,126,99,226,255,118,157,244,1,107,200,16,0,193,90,229,0,121,6,88,0,156,32,93,254,125,241,211,255,14,237,157,255,165,154,21,255,184,224,22,255,250,24,152,255,113,77,31,0,247,171,23,255,237,177,204,255,52,137,145,255,194,182,114,0,224,234,149,0,10,111,103,1,201,129,4,0,238,142,78,0,52,6,40,255,110,213,165,254,60,207,253,0,62,215,69,0,96,97,0,255,49,45,202,0,120,121,22,255,235,139,48,1,198,45,34,255,182,50,27,1,131,210,91,255,46,54,128,0,175,123,105,255,198,141,78,254,67,244,239,255,245,54,103,254,78,38,242,255,2,92,249,254,251,174,87,255,139,63,144,0,24,108,27,255,34,102,18,1,34,22,152,0,66,229,118,254,50,143,99,0,144,169,149,1,118,30,152,0,178,8,121,1,8,159,18,0,90,101,230,255,129,29,119,0,68,36,11,1,232,183,55,0,23,255,96,255,161,41,193,255,63,139,222,0,15,179,243,0,255,100,15,255,82,53,135,0,137,57,149,1,99,240,170,255,22,230,228,254,49,180,82,255,61,82,43,0,110,245,217,0,199,125,61,0,46,253,52,0,141,197,219,0,211,159,193,0,55,121,105,254,183,20,129,0,169,119,170,255,203,178,139,255,135,40,182,255,172,13,202,255,65,178,148,0,8,207,43,0,122,53,127,1,74,161,48,0,227,214,128,254,86,11,243,255,100,86,7,1,245,68,134,255,61,43,21,1,152,84,94,255,190,60,250,254,239,118,232,255,214,136,37,1,113,76,107,255,93,104,100,1,144,206,23,255,110,150,154,1,228,103,185,0,218,49,50,254,135,77,139,255,185,1,78,0,0,161,148,255,97,29,233,255,207,148,149,255,160,168,0,0,91,128,171,255,6,28,19,254,11,111,247,0,39,187,150,255,138,232,149,0,117,62,68,255,63,216,188,255,235,234,32,254,29,57,160,255,25,12,241,1,169,60,191,0,32,131,141,255,237,159,123,255,94,197,94,254,116,254,3,255,92,179,97,254,121,97,92,255,170,112,14,0,21,149,248,0,248,227,3,0,80,96,109,0,75,192,74,1,12,90,226,255,161,106,68,1,208,114,127,255,114,42,255,254,74,26,74,255,247,179,150,254,121,140,60,0,147,70,200,255,214,40,161,255,161,188,201,255,141,65,135,255,242,115,252,0,62,47,202,0,180,149,255,254,130,55,237,0,165,17,186,255,10,169,194,0,156,109,218,255,112,140,123,255,104,128,223,254,177,142,108,255,121,37,219,255,128,77,18,255,111,108,23,1,91,192,75,0,174,245,22,255,4,236,62,255,43,64,153,1,227,173,254,0,237,122,132,1,127,89,186,255,142,82,128,254,252,84,174,0,90,179,177,1,243,214,87,255,103,60,162,255,208,130,14,255,11,130,139,0,206,129,219,255,94,217,157,255,239,230,230,255,116,115,159,254,164,107,95,0,51,218,2,1,216,125,198,255,140,202,128,254,11,95,68,255,55,9,93,254,174,153,6,255,204,172,96,0,69,160,110,0,213,38,49,254,27,80,213,0,118,125,114,0,70,70,67,255,15,142,73,255,131,122,185,255,243,20,50,254,130,237,40,0,210,159,140,1,197,151,65,255,84,153,66,0,195,126,90,0,16,238,236,1,118,187,102,255,3,24,133,255,187,69,230,0,56,197,92,1,213,69,94,255,80,138,229,1,206,7,230,0,222,111,230,1,91,233,119,255,9,89,7,1,2,98,1,0,148,74,133,255,51,246,180,255,228,177,112,1,58,189,108,255,194,203,237,254,21,209,195,0,147,10,35,1,86,157,226,0,31,163,139,254,56,7,75,255,62,90,116,0,181,60,169,0,138,162,212,254,81,167,31,0,205,90,112,255,33,112,227,0,83,151,117,1,177,224,73,255,174,144,217,255,230,204,79,255,22,77,232,255,114,78,234,0,224,57,126,254,9,49,141,0,242,147,165,1,104,182,140,255,167,132,12,1,123,68,127,0,225,87,39,1,251,108,8,0,198,193,143,1,121,135,207,255,172,22,70,0,50,68,116,255,101,175,40,255,248,105,233,0,166,203,7,0,110,197,218,0,215,254,26,254,168,226,253,0,31,143,96,0,11,103,41,0,183,129,203,254,100,247,74,255,213,126,132,0,210,147,44,0,199,234,27,1,148,47,181,0,155,91,158,1,54,105,175,255,2,78,145,254,102,154,95,0,128,207,127,254,52,124,236,255,130,84,71,0,221,243,211,0,152,170,207,0,222,106,199,0,183,84,94,254,92,200,56,255,138,182,115,1,142,96,146,0,133,136,228,0,97,18,150,0,55,251,66,0,140,102,4,0,202,103,151,0,30,19,248,255,51,184,207,0,202,198,89,0,55,197,225,254,169,95,249,255,66,65,68,255,188,234,126,0,166,223,100,1,112,239,244,0,144,23,194,0,58,39,182,0,244,44,24,254,175,68,179,255,152,118,154,1,176,162,130,0,217,114,204,254,173,126,78,255,33,222,30,255,36,2,91,255,2,143,243,0,9,235,215,0,3,171,151,1,24,215,245,255,168,47,164,254,241,146,207,0,69,129,180,0,68,243,113,0,144,53,72,254,251,45,14,0,23,110,168,0,68,68,79,255,110,70,95,254,174,91,144,255,33,206,95,255,137,41,7,255,19,187,153,254,35,255,112,255,9,145,185,254,50,157,37,0,11,112,49,1,102,8,190,255,234,243,169,1,60,85,23,0,74,39,189,0,116,49,239,0,173,213,210,0,46,161,108,255,159,150,37,0,196,120,185,255,34,98,6,255,153,195,62,255,97,230,71,255,102,61,76,0,26,212,236,255,164,97,16,0,198,59,146,0,163,23,196,0,56,24,61,0,181,98,193,0,251,147,229,255,98,189,24,255,46,54,206,255,234,82,246,0,183,103,38,1,109,62,204,0,10,240,224,0,146,22,117,255,142,154,120,0,69,212,35,0,208,99,118,1,121,255,3,255,72,6,194,0,117,17,197,255,125,15,23,0,154,79,153,0,214,94,197,255,185,55,147,255,62,254,78,254,127,82,153,0,110,102,63,255,108,82,161,255,105,187,212,1,80,138,39,0,60,255,93,255,72,12,186,0,210,251,31,1,190,167,144,255,228,44,19,254,128,67,232,0,214,249,107,254,136,145,86,255,132,46,176,0,189,187,227,255,208,22,140,0,217,211,116,0,50,81,186,254,139,250,31,0,30,64,198,1,135,155,100,0,160,206,23,254,187,162,211,255,16,188,63,0,254,208,49,0,85,84,191,0,241,192,242,255,153,126,145,1,234,162,162,255,230,97,216,1,64,135,126,0,190,148,223,1,52,0,43,255,28,39,189,1,64,136,238,0,175,196,185,0,98,226,213,255,127,159,244,1,226,175,60,0,160,233,142,1,180,243,207,255,69,152,89,1,31,101,21,0,144,25,164,254,139,191,209,0,91,25,121,0,32,147,5,0,39,186,123,255,63,115,230,255,93,167,198,255,143,213,220,255,179,156,19,255,25,66,122,0,214,160,217,255,2,45,62,255,106,79,146,254,51,137,99,255,87,100,231,255,175,145,232,255,101,184,1,255,174,9,125,0,82,37,161,1,36,114,141,255,48,222,142,255,245,186,154,0,5,174,221,254,63,114,155,255,135,55,160,1,80,31,135,0,126,250,179,1,236,218,45,0,20,28,145,1,16,147,73,0,249,189,132,1,17,189,192,255,223,142,198,255,72,20,15,255,250,53,237,254,15,11,18,0,27,211,113,254,213,107,56,255,174,147,146,255,96,126,48,0,23,193,109,1,37,162,94,0,199,157,249,254,24,128,187,255,205,49,178,254,93,164,42,255,43,119,235,1,88,183,237,255,218,210,1,255,107,254,42,0,230,10,99,255,162,0,226,0,219,237,91,0,129,178,203,0,208,50,95,254,206,208,95,255,247,191,89,254,110,234,79,255,165,61,243,0,20,122,112,255,246,246,185,254,103,4,123,0,233,99,230,1,219,91,252,255,199,222,22,255,179,245,233,255,211,241,234,0,111,250,192,255,85,84,136,0,101,58,50,255,131,173,156,254,119,45,51,255,118,233,16,254,242,90,214,0,94,159,219,1,3,3,234,255,98,76,92,254,80,54,230,0,5,228,231,254,53,24,223,255,113,56,118,1,20,132,1,255,171,210,236,0,56,241,158,255,186,115,19,255,8,229,174,0,48,44,0,1,114,114,166,255,6,73,226,255,205,89,244,0,137,227,75,1,248,173,56,0,74,120,246,254,119,3,11,255,81,120,198,255,136,122,98,255,146,241,221,1,109,194,78,255,223,241,70,1,214,200,169,255,97,190,47,255,47,103,174,255,99,92,72,254,118,233,180,255,193,35,233,254,26,229,32,255,222,252,198,0,204,43,71,255,199,84,172,0,134,102,190,0,111,238,97,254,230,40,230,0,227,205,64,254,200,12,225,0,166,25,222,0,113,69,51,255,143,159,24,0,167,184,74,0,29,224,116,254,158,208,233,0,193,116,126,255,212,11,133,255,22,58,140,1,204,36,51,255,232,30,43,0,235,70,181,255,64,56,146,254,169,18,84,255,226,1,13,255,200,50,176,255,52,213,245,254,168,209,97,0,191,71,55,0,34,78,156,0,232,144,58,1,185,74,189,0,186,142,149,254,64,69,127,255,161,203,147,255,176,151,191,0,136,231,203,254,163,182,137,0,161,126,251,254,233,32,66,0,68,207,66,0,30,28,37,0,93,114,96,1,254,92,247,255,44,171,69,0,202,119,11,255,188,118,50,1,255,83,136,255,71,82,26,0,70,227,2,0,32,235,121,1,181,41,154,0,71,134,229,254,202,255,36,0,41,152,5,0,154,63,73,255,34,182,124,0,121,221,150,255,26,204,213,1,41,172,87,0,90,157,146,255,109,130,20,0,71,107,200,255,243,102,189,0,1,195,145,254,46,88,117,0,8,206,227,0,191,110,253,255,109,128,20,254,134,85,51,255,137,177,112,1,216,34,22,255,131,16,208,255,121,149,170,0,114,19,23,1,166,80,31,255,113,240,122,0,232,179,250,0,68,110,180,254,210,170,119,0,223,108,164,255,207,79,233,255,27,229,226,254,209,98,81,255,79,68,7,0,131,185,100,0,170,29,162,255,17,162,107,255,57,21,11,1,100,200,181,255,127,65,166,1,165,134,204,0,104,167,168,0,1,164,79,0,146,135,59,1,70,50,128,255,102,119,13,254,227,6,135,0,162,142,179,255,160,100,222,0,27,224,219,1,158,93,195,255,234,141,137,0,16,24,125,255,238,206,47,255,97,17,98,255,116,110,12,255,96,115,77,0,91,227,232,255,248,254,79,255,92,229,6,254,88,198,139,0,206,75,129,0,250,77,206,255,141,244,123,1,138,69,220,0,32,151,6,1,131,167,22,255,237,68,167,254,199,189,150,0,163,171,138,255,51,188,6,255,95,29,137,254,148,226,179,0,181,107,208,255,134,31,82,255,151,101,45,255,129,202,225,0,224,72,147,0,48,138,151,255,195,64,206,254,237,218,158,0,106,29,137,254,253,189,233,255,103,15,17,255,194,97,255,0,178,45,169,254,198,225,155,0,39,48,117,255,135,106,115,0,97,38,181,0,150,47,65,255,83,130,229,254,246,38,129,0,92,239,154,254,91,99,127,0,161,111,33,255,238,217,242,255,131,185,195,255,213,191,158,255,41,150,218,0,132,169,131,0,89,84,252,1,171,70,128,255,163,248,203,254,1,50,180,255,124,76,85,1,251,111,80,0,99,66,239,255,154,237,182,255,221,126,133,254,74,204,99,255,65,147,119,255,99,56,167,255,79,248,149,255,116,155,228,255,237,43,14,254,69,137,11,255,22,250,241,1,91,122,143,255,205,249,243,0,212,26,60,255,48,182,176,1,48,23,191,255,203,121,152,254,45,74,213,255,62,90,18,254,245,163,230,255,185,106,116,255,83,35,159,0,12,33,2,255,80,34,62,0,16,87,174,255,173,101,85,0,202,36,81,254,160,69,204,255,64,225,187,0,58,206,94,0,86,144,47,0,229,86,245,0,63,145,190,1,37,5,39,0,109,251,26,0,137,147,234,0,162,121,145,255,144,116,206,255,197,232,185,255,183,190,140,255,73,12,254,255,139,20,242,255,170,90,239,255,97,66,187,255,245,181,135,254,222,136,52,0,245,5,51,254,203,47,78,0,152,101,216,0,73,23,125,0,254,96,33,1,235,210,73,255,43,209,88,1,7,129,109,0,122,104,228,254,170,242,203,0,242,204,135,255,202,28,233,255,65,6,127,0,159,144,71,0,100,140,95,0,78,150,13,0,251,107,118,1,182,58,125,255,1,38,108,255,141,189,209,255,8,155,125,1,113,163,91,255,121,79,190,255,134,239,108,255,76,47,248,0,163,228,239,0,17,111,10,0,88,149,75,255,215,235,239,0,167,159,24,255,47,151,108,255,107,209,188,0,233,231,99,254,28,202,148,255,174,35,138,255,110,24,68,255,2,69,181,0,107,102,82,0,102,237,7,0,92,36,237,255,221,162,83,1,55,202,6,255,135,234,135,255,24,250,222,0,65,94,168,254,245,248,210,255,167,108,201,254,255,161,111,0,205,8,254,0,136,13,116,0,100,176,132,255,43,215,126,255,177,133,130,255,158,79,148,0,67,224,37,1,12,206,21,255,62,34,110,1,237,104,175,255,80,132,111,255,142,174,72,0,84,229,180,254,105,179,140,0,64,248,15,255,233,138,16,0,245,67,123,254,218,121,212,255,63,95,218,1,213,133,137,255,143,182,82,255,48,28,11,0,244,114,141,1,209,175,76,255,157,181,150,255,186,229,3,255,164,157,111,1,231,189,139,0,119,202,190,255,218,106,64,255,68,235,63,254,96,26,172,255,187,47,11,1,215,18,251,255,81,84,89,0,68,58,128,0,94,113,5,1,92,129,208,255,97,15,83,254,9,28,188,0,239,9,164,0,60,205,152,0,192,163,98,255,184,18,60,0,217,182,139,0,109,59,120,255,4,192,251,0,169,210,240,255,37,172,92,254,148,211,245,255,179,65,52,0,253,13,115,0,185,174,206,1,114,188,149,255,237,90,173,0,43,199,192,255,88,108,113,0,52,35,76,0,66,25,148,255,221,4,7,255,151,241,114,255,190,209,232,0,98,50,199,0,151,150,213,255,18,74,36,1,53,40,7,0,19,135,65,255,26,172,69,0,174,237,85,0,99,95,41,0,3,56,16,0,39,160,177,255,200,106,218,254,185,68,84,255,91,186,61,254,67,143,141,255,13,244,166,255,99,114,198,0,199,110,163,255,193,18,186,0,124,239,246,1,110,68,22,0,2,235,46,1,212,60,107,0,105,42,105,1,14,230,152,0,7,5,131,0,141,104,154,255,213,3,6,0,131,228,162,255,179,100,28,1,231,123,85,255,206,14,223,1,253,96,230,0,38,152,149,1,98,137,122,0,214,205,3,255,226,152,179,255,6,133,137,0,158,69,140,255,113,162,154,255,180,243,172,255,27,189,115,255,143,46,220,255,213,134,225,255,126,29,69,0,188,43,137,1,242,70,9,0,90,204,255,255,231,170,147,0,23,56,19,254,56,125,157,255,48,179,218,255,79,182,253,255,38,212,191,1,41,235,124,0,96,151,28,0,135,148,190,0,205,249,39,254,52,96,136,255,212,44,136,255,67,209,131,255,252,130,23,255,219,128,20,255,198,129,118,0,108,101,11,0,178,5,146,1,62,7,100,255,181,236,94,254,28,26,164,0,76,22,112,255,120,102,79,0,202,192,229,1,200,176,215,0,41,64,244,255,206,184,78,0,167,45,63,1,160,35,0,255,59,12,142,255,204,9,144,255,219,94,229,1,122,27,112,0,189,105,109,255,64,208,74,255,251,127,55,1,2,226,198,0,44,76,209,0,151,152,77,255,210,23,46,1,201,171,69,255,44,211,231,0,190,37,224,255,245,196,62,255,169,181,222,255,34,211,17,0,119,241,197,255,229,35,152,1,21,69,40,255,178,226,161,0,148,179,193,0,219,194,254,1,40,206,51,255,231,92,250,1,67,153,170,0,21,148,241,0,170,69,82,255,121,18,231,255,92,114,3,0,184,62,230,0,225,201,87,255,146,96,162,255,181,242,220,0,173,187,221,1,226,62,170,255,56,126,217,1,117,13,227,255,179,44,239,0,157,141,155,255,144,221,83,0,235,209,208,0,42,17,165,1,251,81,133,0,124,245,201,254,97,211,24,255,83,214,166,0,154,36,9,255,248,47,127,0,90,219,140,255,161,217,38,254,212,147,63,255,66,84,148,1,207,3,1,0,230,134,89,1,127,78,122,255,224,155,1,255,82,136,74,0,178,156,208,255,186,25,49,255,222,3,210,1,229,150,190,255,85,162,52,255,41,84,141,255,73,123,84,254,93,17,150,0,119,19,28,1,32,22,215,255,28,23,204,255,142,241,52,255,228,52,125,0,29,76,207,0,215,167,250,254,175,164,230,0,55,207,105,1,109,187,245,255,161,44,220,1,41,101,128,255,167,16,94,0,93,214,107,255,118,72,0,254,80,61,234,255,121,175,125,0,139,169,251,0,97,39,147,254,250,196,49,255,165,179,110,254,223,70,187,255,22,142,125,1,154,179,138,255,118,176,42,1,10,174,153,0,156,92,102,0,168,13,161,255,143,16,32,0,250,197,180,255,203,163,44,1,87,32,36,0,161,153,20,255,123,252,15,0,25,227,80,0,60,88,142,0,17,22,201,1,154,205,77,255,39,63,47,0,8,122,141,0,128,23,182,254,204,39,19,255,4,112,29,255,23,36,140,255,210,234,116,254,53,50,63,255,121,171,104,255,160,219,94,0,87,82,14,254,231,42,5,0,165,139,127,254,86,78,38,0,130,60,66,254,203,30,45,255,46,196,122,1,249,53,162,255,136,143,103,254,215,210,114,0,231,7,160,254,169,152,42,255,111,45,246,0,142,131,135,255,131,71,204,255,36,226,11,0,0,28,242,255,225,138,213,255,247,46,216,254,245,3,183,0,108,252,74,1,206,26,48,255,205,54,246,255,211,198,36,255,121,35,50,0,52,216,202,255,38,139,129,254,242,73,148,0,67,231,141,255,42,47,204,0,78,116,25,1,4,225,191,255,6,147,228,0,58,88,177,0,122,165,229,255,252,83,201,255,224,167,96,1,177,184,158,255,242,105,179,1,248,198,240,0,133,66,203,1,254,36,47,0,45,24,115,255,119,62,254,0,196,225,186,254,123,141,172,0,26,85,41,255,226,111,183,0,213,231,151,0,4,59,7,255,238,138,148,0,66,147,33,255,31,246,141,255,209,141,116,255,104,112,31,0,88,161,172,0,83,215,230,254,47,111,151,0,45,38,52,1,132,45,204,0,138,128,109,254,233,117,134,255,243,190,173,254,241,236,240,0,82,127,236,254,40,223,161,255,110,182,225,255,123,174,239,0,135,242,145,1,51,209,154,0,150,3,115,254,217,164,252,255,55,156,69,1,84,94,255,255,232,73,45,1,20,19,212,255,96,197,59,254,96,251,33,0,38,199,73,1,64,172,247,255,117,116,56,255,228,17,18,0,62,138,103,1,246,229,164,255,244,118,201,254,86,32,159,255,109,34,137,1,85,211,186,0,10,193,193,254,122,194,177,0,122,238,102,255,162,218,171,0,108,217,161,1,158,170,34,0,176,47,155,1,181,228,11,255,8,156,0,0,16,75,93,0,206,98,255,1,58,154,35,0,12,243,184,254,67,117,66,255,230,229,123,0,201,42,110,0,134,228,178,254,186,108,118,255,58,19,154,255,82,169,62,255,114,143,115,1,239,196,50,255,173,48,193,255,147,2,84,255,150,134,147,254,95,232,73,0,109,227,52,254,191,137,10,0,40,204,30,254,76,52,97,255,164,235,126,0,254,124,188,0,74,182,21,1,121,29,35,255,241,30,7,254,85,218,214,255,7,84,150,254,81,27,117,255,160,159,152,254,66,24,221,255,227,10,60,1,141,135,102,0,208,189,150,1,117,179,92,0,132,22,136,255,120,199,28,0,21,129,79,254,182,9,65,0,218,163,169,0,246,147,198,255,107,38,144,1,78,175,205,255,214,5,250,254,47,88,29,255,164,47,204,255,43,55,6,255,131,134,207,254,116,100,214,0,96,140,75,1,106,220,144,0,195,32,28,1,172,81,5,255,199,179,52,255,37,84,203,0,170,112,174,0,11,4,91,0,69,244,27,1,117,131,92,0,33,152,175,255,140,153,107,255,251,135,43,254,87,138,4,255,198,234,147,254,121,152,84,255,205,101,155,1,157,9,25,0,72,106,17,254,108,153,0,255,189,229,186,0,193,8,176,255,174,149,209,0,238,130,29,0,233,214,126,1,61,226,102,0,57,163,4,1,198,111,51,255,45,79,78,1,115,210,10,255,218,9,25,255,158,139,198,255,211,82,187,254,80,133,83,0,157,129,230,1,243,133,134,255,40,136,16,0,77,107,79,255,183,85,92,1,177,204,202,0,163,71,147,255,152,69,190,0,172,51,188,1,250,210,172,255,211,242,113,1,89,89,26,255,64,66,111,254,116,152,42,0,161,39,27,255,54,80,254,0,106,209,115,1,103,124,97,0,221,230,98,255,31,231,6,0,178,192,120,254,15,217,203,255,124,158,79,0,112,145,247,0,92,250,48,1,163,181,193,255,37,47,142,254,144,189,165,255,46,146,240,0,6,75,128,0,41,157,200,254,87,121,213,0,1,113,236,0,5,45,250,0,144,12,82,0,31,108,231,0,225,239,119,255,167,7,189,255,187,228,132,255,110,189,34,0,94,44,204,1,162,52,197,0,78,188,241,254,57,20,141,0,244,146,47,1,206,100,51,0,125,107,148,254,27,195,77,0,152,253,90,1,7,143,144,255,51,37,31,0,34,119,38,255,7,197,118,0,153,188,211,0,151,20,116,254,245,65,52,255,180,253,110,1,47,177,209,0,161,99,17,255,118,222,202,0,125,179,252,1,123,54,126,255,145,57,191,0,55,186,121,0,10,243,138,0,205,211,229,255,125,156,241,254,148,156,185,255,227,19,188,255,124,41,32,255,31,34,206,254,17,57,83,0,204,22,37,255,42,96,98,0,119,102,184,1,3,190,28],"i8",ALLOC_NONE,Runtime.GLOBAL_BASE+20480);allocate([110,82,218,255,200,204,192,255,201,145,118,0,117,204,146,0,132,32,98,1,192,194,121,0,106,161,248,1,237,88,124,0,23,212,26,0,205,171,90,255,248,48,216,1,141,37,230,255,124,203,0,254,158,168,30,255,214,248,21,0,112,187,7,255,75,133,239,255,74,227,243,255,250,147,70,0,214,120,162,0,167,9,179,255,22,158,18,0,218,77,209,1,97,109,81,255,244,33,179,255,57,52,57,255,65,172,210,255,249,71,209,255,142,169,238,0,158,189,153,255,174,254,103,254,98,33,14,0,141,76,230,255,113,139,52,255,15,58,212,0,168,215,201,255,248,204,215,1,223,68,160,255,57,154,183,254,47,231,121,0,106,166,137,0,81,136,138,0,165,43,51,0,231,139,61,0,57,95,59,254,118,98,25,255,151,63,236,1,94,190,250,255,169,185,114,1,5,250,58,255,75,105,97,1,215,223,134,0,113,99,163,1,128,62,112,0,99,106,147,0,163,195,10,0,33,205,182,0,214,14,174,255,129,38,231,255,53,182,223,0,98,42,159,255,247,13,40,0,188,210,177,1,6,21,0,255,255,61,148,254,137,45,129,255,89,26,116,254,126,38,114,0,251,50,242,254,121,134,128,255,204,249,167,254,165,235,215,0,202,177,243,0,133,141,62,0,240,130,190,1,110,175,255,0,0,20,146,1,37,210,121,255,7,39,130,0,142,250,84,255,141,200,207,0,9,95,104,255,11,244,174,0,134,232,126,0,167,1,123,254,16,193,149,255,232,233,239,1,213,70,112,255,252,116,160,254,242,222,220,255,205,85,227,0,7,185,58,0,118,247,63,1,116,77,177,255,62,245,200,254,63,18,37,255,107,53,232,254,50,221,211,0,162,219,7,254,2,94,43,0,182,62,182,254,160,78,200,255,135,140,170,0,235,184,228,0,175,53,138,254,80,58,77,255,152,201,2,1,63,196,34,0,5,30,184,0,171,176,154,0,121,59,206,0,38,99,39,0,172,80,77,254,0,134,151,0,186,33,241,254,94,253,223,255,44,114,252,0,108,126,57,255,201,40,13,255,39,229,27,255,39,239,23,1,151,121,51,255,153,150,248,0,10,234,174,255,118,246,4,254,200,245,38,0,69,161,242,1,16,178,150,0,113,56,130,0,171,31,105,0,26,88,108,255,49,42,106,0,251,169,66,0,69,93,149,0,20,57,254,0,164,25,111,0,90,188,90,255,204,4,197,0,40,213,50,1,212,96,132,255,88,138,180,254,228,146,124,255,184,246,247,0,65,117,86,255,253,102,210,254,254,121,36,0,137,115,3,255,60,24,216,0,134,18,29,0,59,226,97,0,176,142,71,0,7,209,161,0,189,84,51,254,155,250,72,0,213,84,235,255,45,222,224,0,238,148,143,255,170,42,53,255,78,167,117,0,186,0,40,255,125,177,103,255,69,225,66,0,227,7,88,1,75,172,6,0,169,45,227,1,16,36,70,255,50,2,9,255,139,193,22,0,143,183,231,254,218,69,50,0,236,56,161,1,213,131,42,0,138,145,44,254,136,229,40,255,49,63,35,255,61,145,245,255,101,192,2,254,232,167,113,0,152,104,38,1,121,185,218,0,121,139,211,254,119,240,35,0,65,189,217,254,187,179,162,255,160,187,230,0,62,248,14,255,60,78,97,0,255,247,163,255,225,59,91,255,107,71,58,255,241,47,33,1,50,117,236,0,219,177,63,254,244,90,179,0,35,194,215,255,189,67,50,255,23,135,129,0,104,189,37,255,185,57,194,0,35,62,231,255,220,248,108,0,12,231,178,0,143,80,91,1,131,93,101,255,144,39,2,1,255,250,178,0,5,17,236,254,139,32,46,0,204,188,38,254,245,115,52,255,191,113,73,254,191,108,69,255,22,69,245,1,23,203,178,0,170,99,170,0,65,248,111,0,37,108,153,255,64,37,69,0,0,88,62,254,89,148,144,255,191,68,224,1,241,39,53,0,41,203,237,255,145,126,194,255,221,42,253,255,25,99,151,0,97,253,223,1,74,115,49,255,6,175,72,255,59,176,203,0,124,183,249,1,228,228,99,0,129,12,207,254,168,192,195,255,204,176,16,254,152,234,171,0,77,37,85,255,33,120,135,255,142,194,227,1,31,214,58,0,213,187,125,255,232,46,60,255,190,116,42,254,151,178,19,255,51,62,237,254,204,236,193,0,194,232,60,0,172,34,157,255,189,16,184,254,103,3,95,255,141,233,36,254,41,25,11,255,21,195,166,0,118,245,45,0,67,213,149,255,159,12,18,255,187,164,227,1,160,25,5,0,12,78,195,1,43,197,225,0,48,142,41,254,196,155,60,255,223,199,18,1,145,136,156,0,252,117,169,254,145,226,238,0,239,23,107,0,109,181,188,255,230,112,49,254,73,170,237,255,231,183,227,255,80,220,20,0,194,107,127,1,127,205,101,0,46,52,197,1,210,171,36,255,88,3,90,255,56,151,141,0,96,187,255,255,42,78,200,0,254,70,70,1,244,125,168,0,204,68,138,1,124,215,70,0,102,66,200,254,17,52,228,0,117,220,143,254,203,248,123,0,56,18,174,255,186,151,164,255,51,232,208,1,160,228,43,255,249,29,25,1,68,190,63,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,224,124,0,0,0,0,0,0,5,0,0,0,0,0,0,0,0,0,0,0,18,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,18,0,0,0,19,0,0,0,65,132,0,0,0,4,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,10,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,101,120,112,97,110,100,32,51,50,45,98,121,116,101,32,107,111,117,116,108,101,110,32,60,61,32,85,73,78,84,56,95,77,65,88,0,99,114,121,112,116,111,95,103,101,110,101,114,105,99,104,97,115,104,47,98,108,97,107,101,50,47,114,101,102,47,103,101,110,101,114,105,99,104,97,115,104,95,98,108,97,107,101,50,98,46,99,0,99,114,121,112,116,111,95,103,101,110,101,114,105,99,104,97,115,104,95,98,108,97,107,101,50,98,0,107,101,121,108,101,110,32,60,61,32,85,73,78,84,56,95,77,65,88,0,99,114,121,112,116,111,95,103,101,110,101,114,105,99,104,97,115,104,95,98,108,97,107,101,50,98,95,105,110,105,116,0,99,114,121,112,116,111,95,103,101,110,101,114,105,99,104,97,115,104,95,98,108,97,107,101,50,98,95,102,105,110,97,108,0,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,36,55,36,0,101,120,112,97,110,100,32,51,50,45,98,121,116,101,32,107,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,123,32,114,101,116,117,114,110,32,77,111,100,117,108,101,46,103,101,116,82,97,110,100,111,109,86,97,108,117,101,40,41,59,32,125,0,123,32,105,102,32,40,77,111,100,117,108,101,46,103,101,116,82,97,110,100,111,109,86,97,108,117,101,32,61,61,61,32,117,110,100,101,102,105,110,101,100,41,32,123,32,116,114,121,32,123,32,118,97,114,32,119,105,110,100,111,119,95,32,61,32,34,111,98,106,101,99,116,34,32,61,61,61,32,116,121,112,101,111,102,32,119,105,110,100,111,119,32,63,32,119,105,110,100,111,119,32,58,32,115,101,108,102,44,32,99,114,121,112,116,111,95,32,61,32,116,121,112,101,111,102,32,119,105,110,100,111,119,95,46,99,114,121,112,116,111,32,33,61,61,32,34,117,110,100,101,102,105,110,101,100,34,32,63,32,119,105,110,100,111,119,95,46,99,114,121,112,116,111,32,58,32,119,105,110,100,111,119,95,46,109,115,67,114,121,112,116,111,44,32,114,97,110,100,111,109,86,97,108,117,101,115,83,116,97,110,100,97,114,100,32,61,32,102,117,110,99,116,105,111,110,40,41,32,123,32,118,97,114,32,98,117,102,32,61,32,110,101,119,32,85,105,110,116,51,50,65,114,114,97,121,40,49,41,59,32,99,114,121,112,116,111,95,46,103,101,116,82,97,110,100,111,109,86,97,108,117,101,115,40,98,117,102,41,59,32,114,101,116,117,114,110,32,98,117,102,91,48,93,32,62,62,62,32,48,59,32,125,59,32,114,97,110,100,111,109,86,97,108,117,101,115,83,116,97,110,100,97,114,100,40,41,59,32,77,111,100,117,108,101,46,103,101,116,82,97,110,100,111,109,86,97,108,117,101,32,61,32,114,97,110,100,111,109,86,97,108,117,101,115,83,116,97,110,100,97,114,100,59,32,125,32,99,97,116,99,104,32,40,101,41,32,123,32,116,114,121,32,123,32,118,97,114,32,99,114,121,112,116,111,32,61,32,114,101,113,117,105,114,101,40,39,99,114,121,112,116,111,39,41,44,32,114,97,110,100,111,109,86,97,108,117,101,78,111,100,101,74,83,32,61,32,102,117,110,99,116,105,111,110,40,41,32,123,32,118,97,114,32,98,117,102,32,61,32,99,114,121,112,116,111,46,114,97,110,100,111,109,66,121,116,101,115,40,52,41,59,32,114,101,116,117,114,110,32,40,98,117,102,91,48,93,32,60,60,32,50,52,32,124,32,98,117,102,91,49,93,32,60,60,32,49,54,32,124,32,98,117,102,91,50,93,32,60,60,32,56,32,124,32,98,117,102,91,51,93,41,32,62,62,62,32,48,59,32,125,59,32,114,97,110,100,111,109,86,97,108,117,101,78,111,100,101,74,83,40,41,59,32,77,111,100,117,108,101,46,103,101,116,82,97,110,100,111,109,86,97,108,117,101,32,61,32,114,97,110,100,111,109,86,97,108,117,101,78,111,100,101,74,83,59,32,125,32,99,97,116,99,104,32,40,101,41,32,123,32,116,104,114,111,119,32,39,78,111,32,115,101,99,117,114,101,32,114,97,110,100,111,109,32,110,117,109,98,101,114,32,103,101,110,101,114,97,116,111,114,32,102,111,117,110,100,39,59,32,125,32,125,32,125,32,125,0,49,46,48,46,54,0,9,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,101,120,112,97,110,100,32,51,50,45,98,121,116,101,32,107,101,120,112,97,110,100,32,51,50,45,98,121,116,101,32,107],"i8",ALLOC_NONE,Runtime.GLOBAL_BASE+30720);allocate([46,47,48,49,50,51,52,53,54,55,56,57,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,0],"i8",ALLOC_NONE,Runtime.GLOBAL_BASE+34873);var tempDoublePtr=Runtime.alignMemory(allocate(12,"i8",ALLOC_STATIC),8);assert(tempDoublePtr%8==0);function copyTempFloat(ptr){HEAP8[tempDoublePtr]=HEAP8[ptr];HEAP8[tempDoublePtr+1]=HEAP8[ptr+1];HEAP8[tempDoublePtr+2]=HEAP8[ptr+2];HEAP8[tempDoublePtr+3]=HEAP8[ptr+3]}function copyTempDouble(ptr){HEAP8[tempDoublePtr]=HEAP8[ptr];HEAP8[tempDoublePtr+1]=HEAP8[ptr+1];HEAP8[tempDoublePtr+2]=HEAP8[ptr+2];HEAP8[tempDoublePtr+3]=HEAP8[ptr+3];HEAP8[tempDoublePtr+4]=HEAP8[ptr+4];HEAP8[tempDoublePtr+5]=HEAP8[ptr+5];HEAP8[tempDoublePtr+6]=HEAP8[ptr+6];HEAP8[tempDoublePtr+7]=HEAP8[ptr+7]}function ___setErrNo(value){if(Module["___errno_location"])HEAP32[Module["___errno_location"]()>>2]=value;return value}var ERRNO_CODES={EPERM:1,ENOENT:2,ESRCH:3,EINTR:4,EIO:5,ENXIO:6,E2BIG:7,ENOEXEC:8,EBADF:9,ECHILD:10,EAGAIN:11,EWOULDBLOCK:11,ENOMEM:12,EACCES:13,EFAULT:14,ENOTBLK:15,EBUSY:16,EEXIST:17,EXDEV:18,ENODEV:19,ENOTDIR:20,EISDIR:21,EINVAL:22,ENFILE:23,EMFILE:24,ENOTTY:25,ETXTBSY:26,EFBIG:27,ENOSPC:28,ESPIPE:29,EROFS:30,EMLINK:31,EPIPE:32,EDOM:33,ERANGE:34,ENOMSG:42,EIDRM:43,ECHRNG:44,EL2NSYNC:45,EL3HLT:46,EL3RST:47,ELNRNG:48,EUNATCH:49,ENOCSI:50,EL2HLT:51,EDEADLK:35,ENOLCK:37,EBADE:52,EBADR:53,EXFULL:54,ENOANO:55,EBADRQC:56,EBADSLT:57,EDEADLOCK:35,EBFONT:59,ENOSTR:60,ENODATA:61,ETIME:62,ENOSR:63,ENONET:64,ENOPKG:65,EREMOTE:66,ENOLINK:67,EADV:68,ESRMNT:69,ECOMM:70,EPROTO:71,EMULTIHOP:72,EDOTDOT:73,EBADMSG:74,ENOTUNIQ:76,EBADFD:77,EREMCHG:78,ELIBACC:79,ELIBBAD:80,ELIBSCN:81,ELIBMAX:82,ELIBEXEC:83,ENOSYS:38,ENOTEMPTY:39,ENAMETOOLONG:36,ELOOP:40,EOPNOTSUPP:95,EPFNOSUPPORT:96,ECONNRESET:104,ENOBUFS:105,EAFNOSUPPORT:97,EPROTOTYPE:91,ENOTSOCK:88,ENOPROTOOPT:92,ESHUTDOWN:108,ECONNREFUSED:111,EADDRINUSE:98,ECONNABORTED:103,ENETUNREACH:101,ENETDOWN:100,ETIMEDOUT:110,EHOSTDOWN:112,EHOSTUNREACH:113,EINPROGRESS:115,EALREADY:114,EDESTADDRREQ:89,EMSGSIZE:90,EPROTONOSUPPORT:93,ESOCKTNOSUPPORT:94,EADDRNOTAVAIL:99,ENETRESET:102,EISCONN:106,ENOTCONN:107,ETOOMANYREFS:109,EUSERS:87,EDQUOT:122,ESTALE:116,ENOTSUP:95,ENOMEDIUM:123,EILSEQ:84,EOVERFLOW:75,ECANCELED:125,ENOTRECOVERABLE:131,EOWNERDEAD:130,ESTRPIPE:86};function _sysconf(name){switch(name){case 30:return PAGE_SIZE;case 85:return totalMemory/PAGE_SIZE;case 132:case 133:case 12:case 137:case 138:case 15:case 235:case 16:case 17:case 18:case 19:case 20:case 149:case 13:case 10:case 236:case 153:case 9:case 21:case 22:case 159:case 154:case 14:case 77:case 78:case 139:case 80:case 81:case 82:case 68:case 67:case 164:case 11:case 29:case 47:case 48:case 95:case 52:case 51:case 46:return 200809;case 79:return 0;case 27:case 246:case 127:case 128:case 23:case 24:case 160:case 161:case 181:case 182:case 242:case 183:case 184:case 243:case 244:case 245:case 165:case 178:case 179:case 49:case 50:case 168:case 169:case 175:case 170:case 171:case 172:case 97:case 76:case 32:case 173:case 35:return-1;case 176:case 177:case 7:case 155:case 8:case 157:case 125:case 126:case 92:case 93:case 129:case 130:case 131:case 94:case 91:return 1;case 74:case 60:case 69:case 70:case 4:return 1024;case 31:case 42:case 72:return 32;case 87:case 26:case 33:return 2147483647;case 34:case 1:return 47839;case 38:case 36:return 99;case 43:case 37:return 2048;case 0:return 2097152;case 3:return 65536;case 28:return 32768;case 44:return 32767;case 75:return 16384;case 39:return 1e3;case 89:return 700;case 71:return 256;case 40:return 255;case 2:return 100;case 180:return 64;case 25:return 20;case 5:return 16;case 6:return 6;case 73:return 4;case 84:{if(typeof navigator==="object")return navigator["hardwareConcurrency"]||1;return 1}}___setErrNo(ERRNO_CODES.EINVAL);return-1}Module["_i64Subtract"]=_i64Subtract;Module["_i64Add"]=_i64Add;Module["_bitshift64Ashr"]=_bitshift64Ashr;Module["_memset"]=_memset;function _pthread_cleanup_push(routine,arg){__ATEXIT__.push((function(){Runtime.dynCall("vi",routine,[arg])}));_pthread_cleanup_push.level=__ATEXIT__.length}Module["_bitshift64Lshr"]=_bitshift64Lshr;Module["_bitshift64Shl"]=_bitshift64Shl;function _pthread_cleanup_pop(){assert(_pthread_cleanup_push.level==__ATEXIT__.length,"cannot pop if something else added meanwhile!");__ATEXIT__.pop();_pthread_cleanup_push.level=__ATEXIT__.length}function _abort(){Module["abort"]()}function ___lock(){}function ___unlock(){}var ERRNO_MESSAGES={0:"Success",1:"Not super-user",2:"No such file or directory",3:"No such process",4:"Interrupted system call",5:"I/O error",6:"No such device or address",7:"Arg list too long",8:"Exec format error",9:"Bad file number",10:"No children",11:"No more processes",12:"Not enough core",13:"Permission denied",14:"Bad address",15:"Block device required",16:"Mount device busy",17:"File exists",18:"Cross-device link",19:"No such device",20:"Not a directory",21:"Is a directory",22:"Invalid argument",23:"Too many open files in system",24:"Too many open files",25:"Not a typewriter",26:"Text file busy",27:"File too large",28:"No space left on device",29:"Illegal seek",30:"Read only file system",31:"Too many links",32:"Broken pipe",33:"Math arg out of domain of func",34:"Math result not representable",35:"File locking deadlock error",36:"File or path name too long",37:"No record locks available",38:"Function not implemented",39:"Directory not empty",40:"Too many symbolic links",42:"No message of desired type",43:"Identifier removed",44:"Channel number out of range",45:"Level 2 not synchronized",46:"Level 3 halted",47:"Level 3 reset",48:"Link number out of range",49:"Protocol driver not attached",50:"No CSI structure available",51:"Level 2 halted",52:"Invalid exchange",53:"Invalid request descriptor",54:"Exchange full",55:"No anode",56:"Invalid request code",57:"Invalid slot",59:"Bad font file fmt",60:"Device not a stream",61:"No data (for no delay io)",62:"Timer expired",63:"Out of streams resources",64:"Machine is not on the network",65:"Package not installed",66:"The object is remote",67:"The link has been severed",68:"Advertise error",69:"Srmount error",70:"Communication error on send",71:"Protocol error",72:"Multihop attempted",73:"Cross mount point (not really error)",74:"Trying to read unreadable message",75:"Value too large for defined data type",76:"Given log. name not unique",77:"f.d. invalid for this operation",78:"Remote address changed",79:"Can access a needed shared lib",80:"Accessing a corrupted shared lib",81:".lib section in a.out corrupted",82:"Attempting to link in too many libs",83:"Attempting to exec a shared library",84:"Illegal byte sequence",86:"Streams pipe error",87:"Too many users",88:"Socket operation on non-socket",89:"Destination address required",90:"Message too long",91:"Protocol wrong type for socket",92:"Protocol not available",93:"Unknown protocol",94:"Socket type not supported",95:"Not supported",96:"Protocol family not supported",97:"Address family not supported by protocol family",98:"Address already in use",99:"Address not available",100:"Network interface is not configured",101:"Network is unreachable",102:"Connection reset by network",103:"Connection aborted",104:"Connection reset by peer",105:"No buffer space available",106:"Socket is already connected",107:"Socket is not connected",108:"Can't send after socket shutdown",109:"Too many references",110:"Connection timed out",111:"Connection refused",112:"Host is down",113:"Host is unreachable",114:"Socket already connected",115:"Connection already in progress",116:"Stale file handle",122:"Quota exceeded",123:"No medium (in tape drive)",125:"Operation canceled",130:"Previous owner died",131:"State not recoverable"};var PATH={splitPath:(function(filename){var splitPathRe=/^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/;return splitPathRe.exec(filename).slice(1)}),normalizeArray:(function(parts,allowAboveRoot){var up=0;for(var i=parts.length-1;i>=0;i--){var last=parts[i];if(last==="."){parts.splice(i,1)}else if(last===".."){parts.splice(i,1);up++}else if(up){parts.splice(i,1);up--}}if(allowAboveRoot){for(;up--;up){parts.unshift("..")}}return parts}),normalize:(function(path){var isAbsolute=path.charAt(0)==="/",trailingSlash=path.substr(-1)==="/";path=PATH.normalizeArray(path.split("/").filter((function(p){return!!p})),!isAbsolute).join("/");if(!path&&!isAbsolute){path="."}if(path&&trailingSlash){path+="/"}return(isAbsolute?"/":"")+path}),dirname:(function(path){var result=PATH.splitPath(path),root=result[0],dir=result[1];if(!root&&!dir){return"."}if(dir){dir=dir.substr(0,dir.length-1)}return root+dir}),basename:(function(path){if(path==="/")return"/";var lastSlash=path.lastIndexOf("/");if(lastSlash===-1)return path;return path.substr(lastSlash+1)}),extname:(function(path){return PATH.splitPath(path)[3]}),join:(function(){var paths=Array.prototype.slice.call(arguments,0);return PATH.normalize(paths.join("/"))}),join2:(function(l,r){return PATH.normalize(l+"/"+r)}),resolve:(function(){var resolvedPath="",resolvedAbsolute=false;for(var i=arguments.length-1;i>=-1&&!resolvedAbsolute;i--){var path=i>=0?arguments[i]:FS.cwd();if(typeof path!=="string"){throw new TypeError("Arguments to path.resolve must be strings")}else if(!path){return""}resolvedPath=path+"/"+resolvedPath;resolvedAbsolute=path.charAt(0)==="/"}resolvedPath=PATH.normalizeArray(resolvedPath.split("/").filter((function(p){return!!p})),!resolvedAbsolute).join("/");return(resolvedAbsolute?"/":"")+resolvedPath||"."}),relative:(function(from,to){from=PATH.resolve(from).substr(1);to=PATH.resolve(to).substr(1);function trim(arr){var start=0;for(;start=0;end--){if(arr[end]!=="")break}if(start>end)return[];return arr.slice(start,end-start+1)}var fromParts=trim(from.split("/"));var toParts=trim(to.split("/"));var length=Math.min(fromParts.length,toParts.length);var samePartsLength=length;for(var i=0;i0){result=buf.slice(0,bytesRead).toString("utf-8")}else{result=null}}else if(typeof window!="undefined"&&typeof window.prompt=="function"){result=window.prompt("Input: ");if(result!==null){result+="\n"}}else if(typeof readline=="function"){result=readline();if(result!==null){result+="\n"}}if(!result){return null}tty.input=intArrayFromString(result,true)}return tty.input.shift()}),put_char:(function(tty,val){if(val===null||val===10){Module["print"](UTF8ArrayToString(tty.output,0));tty.output=[]}else{if(val!=0)tty.output.push(val)}}),flush:(function(tty){if(tty.output&&tty.output.length>0){Module["print"](UTF8ArrayToString(tty.output,0));tty.output=[]}})},default_tty1_ops:{put_char:(function(tty,val){if(val===null||val===10){Module["printErr"](UTF8ArrayToString(tty.output,0));tty.output=[]}else{if(val!=0)tty.output.push(val)}}),flush:(function(tty){if(tty.output&&tty.output.length>0){Module["printErr"](UTF8ArrayToString(tty.output,0));tty.output=[]}})}};var MEMFS={ops_table:null,mount:(function(mount){return MEMFS.createNode(null,"/",16384|511,0)}),createNode:(function(parent,name,mode,dev){if(FS.isBlkdev(mode)||FS.isFIFO(mode)){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}if(!MEMFS.ops_table){MEMFS.ops_table={dir:{node:{getattr:MEMFS.node_ops.getattr,setattr:MEMFS.node_ops.setattr,lookup:MEMFS.node_ops.lookup,mknod:MEMFS.node_ops.mknod,rename:MEMFS.node_ops.rename,unlink:MEMFS.node_ops.unlink,rmdir:MEMFS.node_ops.rmdir,readdir:MEMFS.node_ops.readdir,symlink:MEMFS.node_ops.symlink},stream:{llseek:MEMFS.stream_ops.llseek}},file:{node:{getattr:MEMFS.node_ops.getattr,setattr:MEMFS.node_ops.setattr},stream:{llseek:MEMFS.stream_ops.llseek,read:MEMFS.stream_ops.read,write:MEMFS.stream_ops.write,allocate:MEMFS.stream_ops.allocate,mmap:MEMFS.stream_ops.mmap,msync:MEMFS.stream_ops.msync}},link:{node:{getattr:MEMFS.node_ops.getattr,setattr:MEMFS.node_ops.setattr,readlink:MEMFS.node_ops.readlink},stream:{}},chrdev:{node:{getattr:MEMFS.node_ops.getattr,setattr:MEMFS.node_ops.setattr},stream:FS.chrdev_stream_ops}}}var node=FS.createNode(parent,name,mode,dev);if(FS.isDir(node.mode)){node.node_ops=MEMFS.ops_table.dir.node;node.stream_ops=MEMFS.ops_table.dir.stream;node.contents={}}else if(FS.isFile(node.mode)){node.node_ops=MEMFS.ops_table.file.node;node.stream_ops=MEMFS.ops_table.file.stream;node.usedBytes=0;node.contents=null}else if(FS.isLink(node.mode)){node.node_ops=MEMFS.ops_table.link.node;node.stream_ops=MEMFS.ops_table.link.stream}else if(FS.isChrdev(node.mode)){node.node_ops=MEMFS.ops_table.chrdev.node;node.stream_ops=MEMFS.ops_table.chrdev.stream}node.timestamp=Date.now();if(parent){parent.contents[name]=node}return node}),getFileDataAsRegularArray:(function(node){if(node.contents&&node.contents.subarray){var arr=[];for(var i=0;inode.contents.length){node.contents=MEMFS.getFileDataAsRegularArray(node);node.usedBytes=node.contents.length}if(!node.contents||node.contents.subarray){var prevCapacity=node.contents?node.contents.buffer.byteLength:0;if(prevCapacity>=newCapacity)return;var CAPACITY_DOUBLING_MAX=1024*1024;newCapacity=Math.max(newCapacity,prevCapacity*(prevCapacity0)node.contents.set(oldContents.subarray(0,node.usedBytes),0);return}if(!node.contents&&newCapacity>0)node.contents=[];while(node.contents.lengthnewSize)node.contents.length=newSize;else while(node.contents.length=stream.node.usedBytes)return 0;var size=Math.min(stream.node.usedBytes-position,length);assert(size>=0);if(size>8&&contents.subarray){buffer.set(contents.subarray(position,position+size),offset)}else{for(var i=0;i0||position+lengthe2.timestamp){create.push(key);total++}}));var remove=[];Object.keys(dst.entries).forEach((function(key){var e=dst.entries[key];var e2=src.entries[key];if(!e2){remove.push(key);total++}}));if(!total){return callback(null)}var errored=false;var completed=0;var db=src.type==="remote"?src.db:dst.db;var transaction=db.transaction([IDBFS.DB_STORE_NAME],"readwrite");var store=transaction.objectStore(IDBFS.DB_STORE_NAME);function done(err){if(err){if(!done.errored){done.errored=true;return callback(err)}return}if(++completed>=total){return callback(null)}}transaction.onerror=(function(e){done(this.error);e.preventDefault()});create.sort().forEach((function(path){if(dst.type==="local"){IDBFS.loadRemoteEntry(store,path,(function(err,entry){if(err)return done(err);IDBFS.storeLocalEntry(path,entry,done)}))}else{IDBFS.loadLocalEntry(path,(function(err,entry){if(err)return done(err);IDBFS.storeRemoteEntry(store,path,entry,done)}))}}));remove.sort().reverse().forEach((function(path){if(dst.type==="local"){IDBFS.removeLocalEntry(path,done)}else{IDBFS.removeRemoteEntry(store,path,done)}}))})};var NODEFS={isWindows:false,staticInit:(function(){NODEFS.isWindows=!!process.platform.match(/^win/)}),mount:(function(mount){assert(ENVIRONMENT_IS_NODE);return NODEFS.createNode(null,"/",NODEFS.getMode(mount.opts.root),0)}),createNode:(function(parent,name,mode,dev){if(!FS.isDir(mode)&&!FS.isFile(mode)&&!FS.isLink(mode)){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var node=FS.createNode(parent,name,mode);node.node_ops=NODEFS.node_ops;node.stream_ops=NODEFS.stream_ops;return node}),getMode:(function(path){var stat;try{stat=fs.lstatSync(path);if(NODEFS.isWindows){stat.mode=stat.mode|(stat.mode&146)>>1}}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}return stat.mode}),realPath:(function(node){var parts=[];while(node.parent!==node){parts.push(node.name);node=node.parent}parts.push(node.mount.opts.root);parts.reverse();return PATH.join.apply(null,parts)}),flagsToPermissionStringMap:{0:"r",1:"r+",2:"r+",64:"r",65:"r+",66:"r+",129:"rx+",193:"rx+",514:"w+",577:"w",578:"w+",705:"wx",706:"wx+",1024:"a",1025:"a",1026:"a+",1089:"a",1090:"a+",1153:"ax",1154:"ax+",1217:"ax",1218:"ax+",4096:"rs",4098:"rs+"},flagsToPermissionString:(function(flags){flags&=~32768;if(flags in NODEFS.flagsToPermissionStringMap){return NODEFS.flagsToPermissionStringMap[flags]}else{throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}}),node_ops:{getattr:(function(node){var path=NODEFS.realPath(node);var stat;try{stat=fs.lstatSync(path)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}if(NODEFS.isWindows&&!stat.blksize){stat.blksize=4096}if(NODEFS.isWindows&&!stat.blocks){stat.blocks=(stat.size+stat.blksize-1)/stat.blksize|0}return{dev:stat.dev,ino:stat.ino,mode:stat.mode,nlink:stat.nlink,uid:stat.uid,gid:stat.gid,rdev:stat.rdev,size:stat.size,atime:stat.atime,mtime:stat.mtime,ctime:stat.ctime,blksize:stat.blksize,blocks:stat.blocks}}),setattr:(function(node,attr){var path=NODEFS.realPath(node);try{if(attr.mode!==undefined){fs.chmodSync(path,attr.mode);node.mode=attr.mode}if(attr.timestamp!==undefined){var date=new Date(attr.timestamp);fs.utimesSync(path,date,date)}if(attr.size!==undefined){fs.truncateSync(path,attr.size)}}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),lookup:(function(parent,name){var path=PATH.join2(NODEFS.realPath(parent),name);var mode=NODEFS.getMode(path);return NODEFS.createNode(parent,name,mode)}),mknod:(function(parent,name,mode,dev){var node=NODEFS.createNode(parent,name,mode,dev);var path=NODEFS.realPath(node);try{if(FS.isDir(node.mode)){fs.mkdirSync(path,node.mode)}else{fs.writeFileSync(path,"",{mode:node.mode})}}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}return node}),rename:(function(oldNode,newDir,newName){var oldPath=NODEFS.realPath(oldNode);var newPath=PATH.join2(NODEFS.realPath(newDir),newName);try{fs.renameSync(oldPath,newPath)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),unlink:(function(parent,name){var path=PATH.join2(NODEFS.realPath(parent),name);try{fs.unlinkSync(path)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),rmdir:(function(parent,name){var path=PATH.join2(NODEFS.realPath(parent),name);try{fs.rmdirSync(path)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),readdir:(function(node){var path=NODEFS.realPath(node);try{return fs.readdirSync(path)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),symlink:(function(parent,newName,oldPath){var newPath=PATH.join2(NODEFS.realPath(parent),newName);try{fs.symlinkSync(oldPath,newPath)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),readlink:(function(node){var path=NODEFS.realPath(node);try{path=fs.readlinkSync(path);path=NODEJS_PATH.relative(NODEJS_PATH.resolve(node.mount.opts.root),path);return path}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}})},stream_ops:{open:(function(stream){var path=NODEFS.realPath(stream.node);try{if(FS.isFile(stream.node.mode)){stream.nfd=fs.openSync(path,NODEFS.flagsToPermissionString(stream.flags))}}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),close:(function(stream){try{if(FS.isFile(stream.node.mode)&&stream.nfd){fs.closeSync(stream.nfd)}}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),read:(function(stream,buffer,offset,length,position){if(length===0)return 0;var nbuffer=new Buffer(length);var res;try{res=fs.readSync(stream.nfd,nbuffer,0,length,position)}catch(e){throw new FS.ErrnoError(ERRNO_CODES[e.code])}if(res>0){for(var i=0;i=stream.node.size)return 0;var chunk=stream.node.contents.slice(position,position+length);var ab=WORKERFS.reader.readAsArrayBuffer(chunk);buffer.set(new Uint8Array(ab),offset);return chunk.size}),write:(function(stream,buffer,offset,length,position){throw new FS.ErrnoError(ERRNO_CODES.EIO)}),llseek:(function(stream,offset,whence){var position=offset;if(whence===1){position+=stream.position}else if(whence===2){if(FS.isFile(stream.node.mode)){position+=stream.node.size}}if(position<0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}return position})}};var _stdin=allocate(1,"i32*",ALLOC_STATIC);var _stdout=allocate(1,"i32*",ALLOC_STATIC);var _stderr=allocate(1,"i32*",ALLOC_STATIC);var FS={root:null,mounts:[],devices:[null],streams:[],nextInode:1,nameTable:null,currentPath:"/",initialized:false,ignorePermissions:true,trackingDelegate:{},tracking:{openFlags:{READ:1,WRITE:2}},ErrnoError:null,genericErrors:{},filesystems:null,handleFSError:(function(e){if(!(e instanceof FS.ErrnoError))throw e+" : "+stackTrace();return ___setErrNo(e.errno)}),lookupPath:(function(path,opts){path=PATH.resolve(FS.cwd(),path);opts=opts||{};if(!path)return{path:"",node:null};var defaults={follow_mount:true,recurse_count:0};for(var key in defaults){if(opts[key]===undefined){opts[key]=defaults[key]}}if(opts.recurse_count>8){throw new FS.ErrnoError(ERRNO_CODES.ELOOP)}var parts=PATH.normalizeArray(path.split("/").filter((function(p){return!!p})),false);var current=FS.root;var current_path="/";for(var i=0;i40){throw new FS.ErrnoError(ERRNO_CODES.ELOOP)}}}}return{path:current_path,node:current}}),getPath:(function(node){var path;while(true){if(FS.isRoot(node)){var mount=node.mount.mountpoint;if(!path)return mount;return mount[mount.length-1]!=="/"?mount+"/"+path:mount+path}path=path?node.name+"/"+path:node.name;node=node.parent}}),hashName:(function(parentid,name){var hash=0;for(var i=0;i>>0)%FS.nameTable.length}),hashAddNode:(function(node){var hash=FS.hashName(node.parent.id,node.name);node.name_next=FS.nameTable[hash];FS.nameTable[hash]=node}),hashRemoveNode:(function(node){var hash=FS.hashName(node.parent.id,node.name);if(FS.nameTable[hash]===node){FS.nameTable[hash]=node.name_next}else{var current=FS.nameTable[hash];while(current){if(current.name_next===node){current.name_next=node.name_next;break}current=current.name_next}}}),lookupNode:(function(parent,name){var err=FS.mayLookup(parent);if(err){throw new FS.ErrnoError(err,parent)}var hash=FS.hashName(parent.id,name);for(var node=FS.nameTable[hash];node;node=node.name_next){var nodeName=node.name;if(node.parent.id===parent.id&&nodeName===name){return node}}return FS.lookup(parent,name)}),createNode:(function(parent,name,mode,rdev){if(!FS.FSNode){FS.FSNode=(function(parent,name,mode,rdev){if(!parent){parent=this}this.parent=parent;this.mount=parent.mount;this.mounted=null;this.id=FS.nextInode++;this.name=name;this.mode=mode;this.node_ops={};this.stream_ops={};this.rdev=rdev});FS.FSNode.prototype={};var readMode=292|73;var writeMode=146;Object.defineProperties(FS.FSNode.prototype,{read:{get:(function(){return(this.mode&readMode)===readMode}),set:(function(val){val?this.mode|=readMode:this.mode&=~readMode})},write:{get:(function(){return(this.mode&writeMode)===writeMode}),set:(function(val){val?this.mode|=writeMode:this.mode&=~writeMode})},isFolder:{get:(function(){return FS.isDir(this.mode)})},isDevice:{get:(function(){return FS.isChrdev(this.mode)})}})}var node=new FS.FSNode(parent,name,mode,rdev);FS.hashAddNode(node);return node}),destroyNode:(function(node){FS.hashRemoveNode(node)}),isRoot:(function(node){return node===node.parent}),isMountpoint:(function(node){return!!node.mounted}),isFile:(function(mode){return(mode&61440)===32768}),isDir:(function(mode){return(mode&61440)===16384}),isLink:(function(mode){return(mode&61440)===40960}),isChrdev:(function(mode){return(mode&61440)===8192}),isBlkdev:(function(mode){return(mode&61440)===24576}),isFIFO:(function(mode){return(mode&61440)===4096}),isSocket:(function(mode){return(mode&49152)===49152}),flagModes:{"r":0,"rs":1052672,"r+":2,"w":577,"wx":705,"xw":705,"w+":578,"wx+":706,"xw+":706,"a":1089,"ax":1217,"xa":1217,"a+":1090,"ax+":1218,"xa+":1218},modeStringToFlags:(function(str){var flags=FS.flagModes[str];if(typeof flags==="undefined"){throw new Error("Unknown file open mode: "+str)}return flags}),flagsToPermissionString:(function(flag){var perms=["r","w","rw"][flag&3];if(flag&512){perms+="w"}return perms}),nodePermissions:(function(node,perms){if(FS.ignorePermissions){return 0}if(perms.indexOf("r")!==-1&&!(node.mode&292)){return ERRNO_CODES.EACCES}else if(perms.indexOf("w")!==-1&&!(node.mode&146)){return ERRNO_CODES.EACCES}else if(perms.indexOf("x")!==-1&&!(node.mode&73)){return ERRNO_CODES.EACCES}return 0}),mayLookup:(function(dir){var err=FS.nodePermissions(dir,"x");if(err)return err;if(!dir.node_ops.lookup)return ERRNO_CODES.EACCES;return 0}),mayCreate:(function(dir,name){try{var node=FS.lookupNode(dir,name);return ERRNO_CODES.EEXIST}catch(e){}return FS.nodePermissions(dir,"wx")}),mayDelete:(function(dir,name,isdir){var node;try{node=FS.lookupNode(dir,name)}catch(e){return e.errno}var err=FS.nodePermissions(dir,"wx");if(err){return err}if(isdir){if(!FS.isDir(node.mode)){return ERRNO_CODES.ENOTDIR}if(FS.isRoot(node)||FS.getPath(node)===FS.cwd()){return ERRNO_CODES.EBUSY}}else{if(FS.isDir(node.mode)){return ERRNO_CODES.EISDIR}}return 0}),mayOpen:(function(node,flags){if(!node){return ERRNO_CODES.ENOENT}if(FS.isLink(node.mode)){return ERRNO_CODES.ELOOP}else if(FS.isDir(node.mode)){if((flags&2097155)!==0||flags&512){return ERRNO_CODES.EISDIR}}return FS.nodePermissions(node,FS.flagsToPermissionString(flags))}),MAX_OPEN_FDS:4096,nextfd:(function(fd_start,fd_end){fd_start=fd_start||0;fd_end=fd_end||FS.MAX_OPEN_FDS;for(var fd=fd_start;fd<=fd_end;fd++){if(!FS.streams[fd]){return fd}}throw new FS.ErrnoError(ERRNO_CODES.EMFILE)}),getStream:(function(fd){return FS.streams[fd]}),createStream:(function(stream,fd_start,fd_end){if(!FS.FSStream){FS.FSStream=(function(){});FS.FSStream.prototype={};Object.defineProperties(FS.FSStream.prototype,{object:{get:(function(){return this.node}),set:(function(val){this.node=val})},isRead:{get:(function(){return(this.flags&2097155)!==1})},isWrite:{get:(function(){return(this.flags&2097155)!==0})},isAppend:{get:(function(){return this.flags&1024})}})}var newStream=new FS.FSStream;for(var p in stream){newStream[p]=stream[p]}stream=newStream;var fd=FS.nextfd(fd_start,fd_end);stream.fd=fd;FS.streams[fd]=stream;return stream}),closeStream:(function(fd){FS.streams[fd]=null}),chrdev_stream_ops:{open:(function(stream){var device=FS.getDevice(stream.node.rdev);stream.stream_ops=device.stream_ops;if(stream.stream_ops.open){stream.stream_ops.open(stream)}}),llseek:(function(){throw new FS.ErrnoError(ERRNO_CODES.ESPIPE)})},major:(function(dev){return dev>>8}),minor:(function(dev){return dev&255}),makedev:(function(ma,mi){return ma<<8|mi}),registerDevice:(function(dev,ops){FS.devices[dev]={stream_ops:ops}}),getDevice:(function(dev){return FS.devices[dev]}),getMounts:(function(mount){var mounts=[];var check=[mount];while(check.length){var m=check.pop();mounts.push(m);check.push.apply(check,m.mounts)}return mounts}),syncfs:(function(populate,callback){if(typeof populate==="function"){callback=populate;populate=false}var mounts=FS.getMounts(FS.root.mount);var completed=0;function done(err){if(err){if(!done.errored){done.errored=true;return callback(err)}return}if(++completed>=mounts.length){callback(null)}}mounts.forEach((function(mount){if(!mount.type.syncfs){return done(null)}mount.type.syncfs(mount,populate,done)}))}),mount:(function(type,opts,mountpoint){var root=mountpoint==="/";var pseudo=!mountpoint;var node;if(root&&FS.root){throw new FS.ErrnoError(ERRNO_CODES.EBUSY)}else if(!root&&!pseudo){var lookup=FS.lookupPath(mountpoint,{follow_mount:false});mountpoint=lookup.path;node=lookup.node;if(FS.isMountpoint(node)){throw new FS.ErrnoError(ERRNO_CODES.EBUSY)}if(!FS.isDir(node.mode)){throw new FS.ErrnoError(ERRNO_CODES.ENOTDIR)}}var mount={type:type,opts:opts,mountpoint:mountpoint,mounts:[]};var mountRoot=type.mount(mount);mountRoot.mount=mount;mount.root=mountRoot;if(root){FS.root=mountRoot}else if(node){node.mounted=mount;if(node.mount){node.mount.mounts.push(mount)}}return mountRoot}),unmount:(function(mountpoint){var lookup=FS.lookupPath(mountpoint,{follow_mount:false});if(!FS.isMountpoint(lookup.node)){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var node=lookup.node;var mount=node.mounted;var mounts=FS.getMounts(mount);Object.keys(FS.nameTable).forEach((function(hash){var current=FS.nameTable[hash];while(current){var next=current.name_next;if(mounts.indexOf(current.mount)!==-1){FS.destroyNode(current)}current=next}}));node.mounted=null;var idx=node.mount.mounts.indexOf(mount);assert(idx!==-1);node.mount.mounts.splice(idx,1)}),lookup:(function(parent,name){return parent.node_ops.lookup(parent,name)}),mknod:(function(path,mode,dev){var lookup=FS.lookupPath(path,{parent:true});var parent=lookup.node;var name=PATH.basename(path);if(!name||name==="."||name===".."){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var err=FS.mayCreate(parent,name);if(err){throw new FS.ErrnoError(err)}if(!parent.node_ops.mknod){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}return parent.node_ops.mknod(parent,name,mode,dev)}),create:(function(path,mode){mode=mode!==undefined?mode:438;mode&=4095;mode|=32768;return FS.mknod(path,mode,0)}),mkdir:(function(path,mode){mode=mode!==undefined?mode:511;mode&=511|512;mode|=16384;return FS.mknod(path,mode,0)}),mkdev:(function(path,mode,dev){if(typeof dev==="undefined"){dev=mode;mode=438}mode|=8192;return FS.mknod(path,mode,dev)}),symlink:(function(oldpath,newpath){if(!PATH.resolve(oldpath)){throw new FS.ErrnoError(ERRNO_CODES.ENOENT)}var lookup=FS.lookupPath(newpath,{parent:true});var parent=lookup.node;if(!parent){throw new FS.ErrnoError(ERRNO_CODES.ENOENT)}var newname=PATH.basename(newpath);var err=FS.mayCreate(parent,newname);if(err){throw new FS.ErrnoError(err)}if(!parent.node_ops.symlink){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}return parent.node_ops.symlink(parent,newname,oldpath)}),rename:(function(old_path,new_path){var old_dirname=PATH.dirname(old_path);var new_dirname=PATH.dirname(new_path);var old_name=PATH.basename(old_path);var new_name=PATH.basename(new_path);var lookup,old_dir,new_dir;try{lookup=FS.lookupPath(old_path,{parent:true});old_dir=lookup.node;lookup=FS.lookupPath(new_path,{parent:true});new_dir=lookup.node}catch(e){throw new FS.ErrnoError(ERRNO_CODES.EBUSY)}if(!old_dir||!new_dir)throw new FS.ErrnoError(ERRNO_CODES.ENOENT);if(old_dir.mount!==new_dir.mount){throw new FS.ErrnoError(ERRNO_CODES.EXDEV)}var old_node=FS.lookupNode(old_dir,old_name);var relative=PATH.relative(old_path,new_dirname);if(relative.charAt(0)!=="."){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}relative=PATH.relative(new_path,old_dirname);if(relative.charAt(0)!=="."){throw new FS.ErrnoError(ERRNO_CODES.ENOTEMPTY)}var new_node;try{new_node=FS.lookupNode(new_dir,new_name)}catch(e){}if(old_node===new_node){return}var isdir=FS.isDir(old_node.mode);var err=FS.mayDelete(old_dir,old_name,isdir);if(err){throw new FS.ErrnoError(err)}err=new_node?FS.mayDelete(new_dir,new_name,isdir):FS.mayCreate(new_dir,new_name);if(err){throw new FS.ErrnoError(err)}if(!old_dir.node_ops.rename){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}if(FS.isMountpoint(old_node)||new_node&&FS.isMountpoint(new_node)){throw new FS.ErrnoError(ERRNO_CODES.EBUSY)}if(new_dir!==old_dir){err=FS.nodePermissions(old_dir,"w");if(err){throw new FS.ErrnoError(err)}}try{if(FS.trackingDelegate["willMovePath"]){FS.trackingDelegate["willMovePath"](old_path,new_path)}}catch(e){console.log("FS.trackingDelegate['willMovePath']('"+old_path+"', '"+new_path+"') threw an exception: "+e.message)}FS.hashRemoveNode(old_node);try{old_dir.node_ops.rename(old_node,new_dir,new_name)}catch(e){throw e}finally{FS.hashAddNode(old_node)}try{if(FS.trackingDelegate["onMovePath"])FS.trackingDelegate["onMovePath"](old_path,new_path)}catch(e){console.log("FS.trackingDelegate['onMovePath']('"+old_path+"', '"+new_path+"') threw an exception: "+e.message)}}),rmdir:(function(path){var lookup=FS.lookupPath(path,{parent:true});var parent=lookup.node;var name=PATH.basename(path);var node=FS.lookupNode(parent,name);var err=FS.mayDelete(parent,name,true);if(err){throw new FS.ErrnoError(err)}if(!parent.node_ops.rmdir){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}if(FS.isMountpoint(node)){throw new FS.ErrnoError(ERRNO_CODES.EBUSY)}try{if(FS.trackingDelegate["willDeletePath"]){FS.trackingDelegate["willDeletePath"](path)}}catch(e){console.log("FS.trackingDelegate['willDeletePath']('"+path+"') threw an exception: "+e.message)}parent.node_ops.rmdir(parent,name);FS.destroyNode(node);try{if(FS.trackingDelegate["onDeletePath"])FS.trackingDelegate["onDeletePath"](path)}catch(e){console.log("FS.trackingDelegate['onDeletePath']('"+path+"') threw an exception: "+e.message)}}),readdir:(function(path){var lookup=FS.lookupPath(path,{follow:true});var node=lookup.node;if(!node.node_ops.readdir){throw new FS.ErrnoError(ERRNO_CODES.ENOTDIR)}return node.node_ops.readdir(node)}),unlink:(function(path){var lookup=FS.lookupPath(path,{parent:true});var parent=lookup.node;var name=PATH.basename(path);var node=FS.lookupNode(parent,name);var err=FS.mayDelete(parent,name,false);if(err){if(err===ERRNO_CODES.EISDIR)err=ERRNO_CODES.EPERM;throw new FS.ErrnoError(err)}if(!parent.node_ops.unlink){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}if(FS.isMountpoint(node)){throw new FS.ErrnoError(ERRNO_CODES.EBUSY)}try{if(FS.trackingDelegate["willDeletePath"]){FS.trackingDelegate["willDeletePath"](path)}}catch(e){console.log("FS.trackingDelegate['willDeletePath']('"+path+"') threw an exception: "+e.message)}parent.node_ops.unlink(parent,name);FS.destroyNode(node);try{if(FS.trackingDelegate["onDeletePath"])FS.trackingDelegate["onDeletePath"](path)}catch(e){console.log("FS.trackingDelegate['onDeletePath']('"+path+"') threw an exception: "+e.message)}}),readlink:(function(path){var lookup=FS.lookupPath(path);var link=lookup.node;if(!link){throw new FS.ErrnoError(ERRNO_CODES.ENOENT)}if(!link.node_ops.readlink){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}return PATH.resolve(FS.getPath(link.parent),link.node_ops.readlink(link))}),stat:(function(path,dontFollow){var lookup=FS.lookupPath(path,{follow:!dontFollow});var node=lookup.node;if(!node){throw new FS.ErrnoError(ERRNO_CODES.ENOENT)}if(!node.node_ops.getattr){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}return node.node_ops.getattr(node)}),lstat:(function(path){return FS.stat(path,true)}),chmod:(function(path,mode,dontFollow){var node;if(typeof path==="string"){var lookup=FS.lookupPath(path,{follow:!dontFollow});node=lookup.node}else{node=path}if(!node.node_ops.setattr){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}node.node_ops.setattr(node,{mode:mode&4095|node.mode&~4095,timestamp:Date.now()})}),lchmod:(function(path,mode){FS.chmod(path,mode,true)}),fchmod:(function(fd,mode){var stream=FS.getStream(fd);if(!stream){throw new FS.ErrnoError(ERRNO_CODES.EBADF)}FS.chmod(stream.node,mode)}),chown:(function(path,uid,gid,dontFollow){var node;if(typeof path==="string"){var lookup=FS.lookupPath(path,{follow:!dontFollow});node=lookup.node}else{node=path}if(!node.node_ops.setattr){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}node.node_ops.setattr(node,{timestamp:Date.now()})}),lchown:(function(path,uid,gid){FS.chown(path,uid,gid,true)}),fchown:(function(fd,uid,gid){var stream=FS.getStream(fd);if(!stream){throw new FS.ErrnoError(ERRNO_CODES.EBADF)}FS.chown(stream.node,uid,gid)}),truncate:(function(path,len){if(len<0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var node;if(typeof path==="string"){var lookup=FS.lookupPath(path,{follow:true});node=lookup.node}else{node=path}if(!node.node_ops.setattr){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}if(FS.isDir(node.mode)){throw new FS.ErrnoError(ERRNO_CODES.EISDIR)}if(!FS.isFile(node.mode)){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var err=FS.nodePermissions(node,"w");if(err){throw new FS.ErrnoError(err)}node.node_ops.setattr(node,{size:len,timestamp:Date.now()})}),ftruncate:(function(fd,len){var stream=FS.getStream(fd);if(!stream){throw new FS.ErrnoError(ERRNO_CODES.EBADF)}if((stream.flags&2097155)===0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}FS.truncate(stream.node,len)}),utime:(function(path,atime,mtime){var lookup=FS.lookupPath(path,{follow:true});var node=lookup.node;node.node_ops.setattr(node,{timestamp:Math.max(atime,mtime)})}),open:(function(path,flags,mode,fd_start,fd_end){if(path===""){throw new FS.ErrnoError(ERRNO_CODES.ENOENT)}flags=typeof flags==="string"?FS.modeStringToFlags(flags):flags;mode=typeof mode==="undefined"?438:mode;if(flags&64){mode=mode&4095|32768}else{mode=0}var node;if(typeof path==="object"){node=path}else{path=PATH.normalize(path);try{var lookup=FS.lookupPath(path,{follow:!(flags&131072)});node=lookup.node}catch(e){}}var created=false;if(flags&64){if(node){if(flags&128){throw new FS.ErrnoError(ERRNO_CODES.EEXIST)}}else{node=FS.mknod(path,mode,0);created=true}}if(!node){throw new FS.ErrnoError(ERRNO_CODES.ENOENT)}if(FS.isChrdev(node.mode)){flags&=~512}if(flags&65536&&!FS.isDir(node.mode)){throw new FS.ErrnoError(ERRNO_CODES.ENOTDIR)}if(!created){var err=FS.mayOpen(node,flags);if(err){throw new FS.ErrnoError(err)}}if(flags&512){FS.truncate(node,0)}flags&=~(128|512);var stream=FS.createStream({node:node,path:FS.getPath(node),flags:flags,seekable:true,position:0,stream_ops:node.stream_ops,ungotten:[],error:false},fd_start,fd_end);if(stream.stream_ops.open){stream.stream_ops.open(stream)}if(Module["logReadFiles"]&&!(flags&1)){if(!FS.readFiles)FS.readFiles={};if(!(path in FS.readFiles)){FS.readFiles[path]=1;Module["printErr"]("read file: "+path)}}try{if(FS.trackingDelegate["onOpenFile"]){var trackingFlags=0;if((flags&2097155)!==1){trackingFlags|=FS.tracking.openFlags.READ}if((flags&2097155)!==0){trackingFlags|=FS.tracking.openFlags.WRITE}FS.trackingDelegate["onOpenFile"](path,trackingFlags)}}catch(e){console.log("FS.trackingDelegate['onOpenFile']('"+path+"', flags) threw an exception: "+e.message)}return stream}),close:(function(stream){if(stream.getdents)stream.getdents=null;try{if(stream.stream_ops.close){stream.stream_ops.close(stream)}}catch(e){throw e}finally{FS.closeStream(stream.fd)}}),llseek:(function(stream,offset,whence){if(!stream.seekable||!stream.stream_ops.llseek){throw new FS.ErrnoError(ERRNO_CODES.ESPIPE)}stream.position=stream.stream_ops.llseek(stream,offset,whence);stream.ungotten=[];return stream.position}),read:(function(stream,buffer,offset,length,position){if(length<0||position<0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}if((stream.flags&2097155)===1){throw new FS.ErrnoError(ERRNO_CODES.EBADF)}if(FS.isDir(stream.node.mode)){throw new FS.ErrnoError(ERRNO_CODES.EISDIR)}if(!stream.stream_ops.read){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var seeking=true;if(typeof position==="undefined"){position=stream.position;seeking=false}else if(!stream.seekable){throw new FS.ErrnoError(ERRNO_CODES.ESPIPE)}var bytesRead=stream.stream_ops.read(stream,buffer,offset,length,position);if(!seeking)stream.position+=bytesRead;return bytesRead}),write:(function(stream,buffer,offset,length,position,canOwn){if(length<0||position<0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}if((stream.flags&2097155)===0){throw new FS.ErrnoError(ERRNO_CODES.EBADF)}if(FS.isDir(stream.node.mode)){throw new FS.ErrnoError(ERRNO_CODES.EISDIR)}if(!stream.stream_ops.write){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}if(stream.flags&1024){FS.llseek(stream,0,2)}var seeking=true;if(typeof position==="undefined"){position=stream.position;seeking=false}else if(!stream.seekable){throw new FS.ErrnoError(ERRNO_CODES.ESPIPE)}var bytesWritten=stream.stream_ops.write(stream,buffer,offset,length,position,canOwn);if(!seeking)stream.position+=bytesWritten;try{if(stream.path&&FS.trackingDelegate["onWriteToFile"])FS.trackingDelegate["onWriteToFile"](stream.path)}catch(e){console.log("FS.trackingDelegate['onWriteToFile']('"+path+"') threw an exception: "+e.message)}return bytesWritten}),allocate:(function(stream,offset,length){if(offset<0||length<=0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}if((stream.flags&2097155)===0){throw new FS.ErrnoError(ERRNO_CODES.EBADF)}if(!FS.isFile(stream.node.mode)&&!FS.isDir(node.mode)){throw new FS.ErrnoError(ERRNO_CODES.ENODEV)}if(!stream.stream_ops.allocate){throw new FS.ErrnoError(ERRNO_CODES.EOPNOTSUPP)}stream.stream_ops.allocate(stream,offset,length)}),mmap:(function(stream,buffer,offset,length,position,prot,flags){if((stream.flags&2097155)===1){throw new FS.ErrnoError(ERRNO_CODES.EACCES)}if(!stream.stream_ops.mmap){throw new FS.ErrnoError(ERRNO_CODES.ENODEV)}return stream.stream_ops.mmap(stream,buffer,offset,length,position,prot,flags)}),msync:(function(stream,buffer,offset,length,mmapFlags){if(!stream||!stream.stream_ops.msync){return 0}return stream.stream_ops.msync(stream,buffer,offset,length,mmapFlags)}),munmap:(function(stream){return 0}),ioctl:(function(stream,cmd,arg){if(!stream.stream_ops.ioctl){throw new FS.ErrnoError(ERRNO_CODES.ENOTTY)}return stream.stream_ops.ioctl(stream,cmd,arg)}),readFile:(function(path,opts){opts=opts||{};opts.flags=opts.flags||"r";opts.encoding=opts.encoding||"binary";if(opts.encoding!=="utf8"&&opts.encoding!=="binary"){throw new Error('Invalid encoding type "'+opts.encoding+'"')}var ret;var stream=FS.open(path,opts.flags);var stat=FS.stat(path);var length=stat.size;var buf=new Uint8Array(length);FS.read(stream,buf,0,length,0);if(opts.encoding==="utf8"){ret=UTF8ArrayToString(buf,0)}else if(opts.encoding==="binary"){ret=buf}FS.close(stream);return ret}),writeFile:(function(path,data,opts){opts=opts||{};opts.flags=opts.flags||"w";opts.encoding=opts.encoding||"utf8";if(opts.encoding!=="utf8"&&opts.encoding!=="binary"){throw new Error('Invalid encoding type "'+opts.encoding+'"')}var stream=FS.open(path,opts.flags,opts.mode);if(opts.encoding==="utf8"){var buf=new Uint8Array(lengthBytesUTF8(data)+1);var actualNumBytes=stringToUTF8Array(data,buf,0,buf.length);FS.write(stream,buf,0,actualNumBytes,0,opts.canOwn)}else if(opts.encoding==="binary"){FS.write(stream,data,0,data.length,0,opts.canOwn)}FS.close(stream)}),cwd:(function(){return FS.currentPath}),chdir:(function(path){var lookup=FS.lookupPath(path,{follow:true});if(!FS.isDir(lookup.node.mode)){throw new FS.ErrnoError(ERRNO_CODES.ENOTDIR)}var err=FS.nodePermissions(lookup.node,"x");if(err){throw new FS.ErrnoError(err)}FS.currentPath=lookup.path}),createDefaultDirectories:(function(){FS.mkdir("/tmp");FS.mkdir("/home");FS.mkdir("/home/web_user")}),createDefaultDevices:(function(){FS.mkdir("/dev");FS.registerDevice(FS.makedev(1,3),{read:(function(){return 0}),write:(function(stream,buffer,offset,length,pos){return length})});FS.mkdev("/dev/null",FS.makedev(1,3));TTY.register(FS.makedev(5,0),TTY.default_tty_ops);TTY.register(FS.makedev(6,0),TTY.default_tty1_ops);FS.mkdev("/dev/tty",FS.makedev(5,0));FS.mkdev("/dev/tty1",FS.makedev(6,0));var random_device;if(typeof crypto!=="undefined"){var randomBuffer=new Uint8Array(1);random_device=(function(){crypto.getRandomValues(randomBuffer);return randomBuffer[0]})}else if(ENVIRONMENT_IS_NODE){random_device=(function(){return require("crypto").randomBytes(1)[0]})}else{random_device=(function(){return Math.random()*256|0})}FS.createDevice("/dev","random",random_device);FS.createDevice("/dev","urandom",random_device);FS.mkdir("/dev/shm");FS.mkdir("/dev/shm/tmp")}),createSpecialDirectories:(function(){FS.mkdir("/proc");FS.mkdir("/proc/self");FS.mkdir("/proc/self/fd");FS.mount({mount:(function(){var node=FS.createNode("/proc/self","fd",16384|511,73);node.node_ops={lookup:(function(parent,name){var fd=+name;var stream=FS.getStream(fd);if(!stream)throw new FS.ErrnoError(ERRNO_CODES.EBADF);var ret={parent:null,mount:{mountpoint:"fake"},node_ops:{readlink:(function(){return stream.path})}};ret.parent=ret;return ret})};return node})},{},"/proc/self/fd")}),createStandardStreams:(function(){if(Module["stdin"]){FS.createDevice("/dev","stdin",Module["stdin"])}else{FS.symlink("/dev/tty","/dev/stdin")}if(Module["stdout"]){FS.createDevice("/dev","stdout",null,Module["stdout"])}else{FS.symlink("/dev/tty","/dev/stdout")}if(Module["stderr"]){FS.createDevice("/dev","stderr",null,Module["stderr"])}else{FS.symlink("/dev/tty1","/dev/stderr")}var stdin=FS.open("/dev/stdin","r");assert(stdin.fd===0,"invalid handle for stdin ("+stdin.fd+")");var stdout=FS.open("/dev/stdout","w");assert(stdout.fd===1,"invalid handle for stdout ("+stdout.fd+")");var stderr=FS.open("/dev/stderr","w");assert(stderr.fd===2,"invalid handle for stderr ("+stderr.fd+")")}),ensureErrnoError:(function(){if(FS.ErrnoError)return;FS.ErrnoError=function ErrnoError(errno,node){this.node=node;this.setErrno=(function(errno){this.errno=errno;for(var key in ERRNO_CODES){if(ERRNO_CODES[key]===errno){this.code=key;break}}});this.setErrno(errno);this.message=ERRNO_MESSAGES[errno]};FS.ErrnoError.prototype=new Error;FS.ErrnoError.prototype.constructor=FS.ErrnoError;[ERRNO_CODES.ENOENT].forEach((function(code){FS.genericErrors[code]=new FS.ErrnoError(code);FS.genericErrors[code].stack=""}))}),staticInit:(function(){FS.ensureErrnoError();FS.nameTable=new Array(4096);FS.mount(MEMFS,{},"/");FS.createDefaultDirectories();FS.createDefaultDevices();FS.createSpecialDirectories();FS.filesystems={"MEMFS":MEMFS,"IDBFS":IDBFS,"NODEFS":NODEFS,"WORKERFS":WORKERFS}}),init:(function(input,output,error){assert(!FS.init.initialized,"FS.init was previously called. If you want to initialize later with custom parameters, remove any earlier calls (note that one is automatically added to the generated code)");FS.init.initialized=true;FS.ensureErrnoError();Module["stdin"]=input||Module["stdin"];Module["stdout"]=output||Module["stdout"];Module["stderr"]=error||Module["stderr"];FS.createStandardStreams()}),quit:(function(){FS.init.initialized=false;var fflush=Module["_fflush"];if(fflush)fflush(0);for(var i=0;ithis.length-1||idx<0){return undefined}var chunkOffset=idx%this.chunkSize;var chunkNum=idx/this.chunkSize|0;return this.getter(chunkNum)[chunkOffset]};LazyUint8Array.prototype.setDataGetter=function LazyUint8Array_setDataGetter(getter){this.getter=getter};LazyUint8Array.prototype.cacheLength=function LazyUint8Array_cacheLength(){var xhr=new XMLHttpRequest;xhr.open("HEAD",url,false);xhr.send(null);if(!(xhr.status>=200&&xhr.status<300||xhr.status===304))throw new Error("Couldn't load "+url+". Status: "+xhr.status);var datalength=Number(xhr.getResponseHeader("Content-length"));var header;var hasByteServing=(header=xhr.getResponseHeader("Accept-Ranges"))&&header==="bytes";var chunkSize=1024*1024;if(!hasByteServing)chunkSize=datalength;var doXHR=(function(from,to){if(from>to)throw new Error("invalid range ("+from+", "+to+") or no bytes requested!");if(to>datalength-1)throw new Error("only "+datalength+" bytes available! programmer error!");var xhr=new XMLHttpRequest;xhr.open("GET",url,false);if(datalength!==chunkSize)xhr.setRequestHeader("Range","bytes="+from+"-"+to);if(typeof Uint8Array!="undefined")xhr.responseType="arraybuffer";if(xhr.overrideMimeType){xhr.overrideMimeType("text/plain; charset=x-user-defined")}xhr.send(null);if(!(xhr.status>=200&&xhr.status<300||xhr.status===304))throw new Error("Couldn't load "+url+". Status: "+xhr.status);if(xhr.response!==undefined){return new Uint8Array(xhr.response||[])}else{return intArrayFromString(xhr.responseText||"",true)}});var lazyArray=this;lazyArray.setDataGetter((function(chunkNum){var start=chunkNum*chunkSize;var end=(chunkNum+1)*chunkSize-1;end=Math.min(end,datalength-1);if(typeof lazyArray.chunks[chunkNum]==="undefined"){lazyArray.chunks[chunkNum]=doXHR(start,end)}if(typeof lazyArray.chunks[chunkNum]==="undefined")throw new Error("doXHR failed!");return lazyArray.chunks[chunkNum]}));this._length=datalength;this._chunkSize=chunkSize;this.lengthKnown=true};if(typeof XMLHttpRequest!=="undefined"){if(!ENVIRONMENT_IS_WORKER)throw"Cannot do synchronous binary XHRs outside webworkers in modern browsers. Use --embed-file or --preload-file in emcc";var lazyArray=new LazyUint8Array;Object.defineProperty(lazyArray,"length",{get:(function(){if(!this.lengthKnown){this.cacheLength()}return this._length})});Object.defineProperty(lazyArray,"chunkSize",{get:(function(){if(!this.lengthKnown){this.cacheLength()}return this._chunkSize})});var properties={isDevice:false,contents:lazyArray}}else{var properties={isDevice:false,url:url}}var node=FS.createFile(parent,name,properties,canRead,canWrite);if(properties.contents){node.contents=properties.contents}else if(properties.url){node.contents=null;node.url=properties.url}Object.defineProperty(node,"usedBytes",{get:(function(){return this.contents.length})});var stream_ops={};var keys=Object.keys(node.stream_ops);keys.forEach((function(key){var fn=node.stream_ops[key];stream_ops[key]=function forceLoadLazyFile(){if(!FS.forceLoadFile(node)){throw new FS.ErrnoError(ERRNO_CODES.EIO)}return fn.apply(null,arguments)}}));stream_ops.read=function stream_ops_read(stream,buffer,offset,length,position){if(!FS.forceLoadFile(node)){throw new FS.ErrnoError(ERRNO_CODES.EIO)}var contents=stream.node.contents;if(position>=contents.length)return 0;var size=Math.min(contents.length-position,length);assert(size>=0);if(contents.slice){for(var i=0;i>2]=stat.dev;HEAP32[buf+4>>2]=0;HEAP32[buf+8>>2]=stat.ino;HEAP32[buf+12>>2]=stat.mode;HEAP32[buf+16>>2]=stat.nlink;HEAP32[buf+20>>2]=stat.uid;HEAP32[buf+24>>2]=stat.gid;HEAP32[buf+28>>2]=stat.rdev;HEAP32[buf+32>>2]=0;HEAP32[buf+36>>2]=stat.size;HEAP32[buf+40>>2]=4096;HEAP32[buf+44>>2]=stat.blocks;HEAP32[buf+48>>2]=stat.atime.getTime()/1e3|0;HEAP32[buf+52>>2]=0;HEAP32[buf+56>>2]=stat.mtime.getTime()/1e3|0;HEAP32[buf+60>>2]=0;HEAP32[buf+64>>2]=stat.ctime.getTime()/1e3|0;HEAP32[buf+68>>2]=0;HEAP32[buf+72>>2]=stat.ino;return 0}),doMsync:(function(addr,stream,len,flags){var buffer=new Uint8Array(HEAPU8.subarray(addr,addr+len));FS.msync(stream,buffer,0,len,flags)}),doMkdir:(function(path,mode){path=PATH.normalize(path);if(path[path.length-1]==="/")path=path.substr(0,path.length-1);FS.mkdir(path,mode,0);return 0}),doMknod:(function(path,mode,dev){switch(mode&61440){case 32768:case 8192:case 24576:case 4096:case 49152:break;default:return-ERRNO_CODES.EINVAL}FS.mknod(path,mode,dev);return 0}),doReadlink:(function(path,buf,bufsize){if(bufsize<=0)return-ERRNO_CODES.EINVAL;var ret=FS.readlink(path);ret=ret.slice(0,Math.max(0,bufsize));writeStringToMemory(ret,buf,true);return ret.length}),doAccess:(function(path,amode){if(amode&~7){return-ERRNO_CODES.EINVAL}var node;var lookup=FS.lookupPath(path,{follow:true});node=lookup.node;var perms="";if(amode&4)perms+="r";if(amode&2)perms+="w";if(amode&1)perms+="x";if(perms&&FS.nodePermissions(node,perms)){return-ERRNO_CODES.EACCES}return 0}),doDup:(function(path,flags,suggestFD){var suggest=FS.getStream(suggestFD);if(suggest)FS.close(suggest);return FS.open(path,flags,0,suggestFD,suggestFD).fd}),doReadv:(function(stream,iov,iovcnt,offset){var ret=0;for(var i=0;i>2];var len=HEAP32[iov+(i*8+4)>>2];var curr=FS.read(stream,HEAP8,ptr,len,offset);if(curr<0)return-1;ret+=curr;if(curr>2];var len=HEAP32[iov+(i*8+4)>>2];var curr=FS.write(stream,HEAP8,ptr,len,offset);if(curr<0)return-1;ret+=curr}return ret}),varargs:0,get:(function(varargs){SYSCALLS.varargs+=4;var ret=HEAP32[SYSCALLS.varargs-4>>2];return ret}),getStr:(function(){var ret=Pointer_stringify(SYSCALLS.get());return ret}),getStreamFromFD:(function(){var stream=FS.getStream(SYSCALLS.get());if(!stream)throw new FS.ErrnoError(ERRNO_CODES.EBADF);return stream}),getSocketFromFD:(function(){var socket=SOCKFS.getSocket(SYSCALLS.get());if(!socket)throw new FS.ErrnoError(ERRNO_CODES.EBADF);return socket}),getSocketAddress:(function(allowNull){var addrp=SYSCALLS.get(),addrlen=SYSCALLS.get();if(allowNull&&addrp===0)return null;var info=__read_sockaddr(addrp,addrlen);if(info.errno)throw new FS.ErrnoError(info.errno);info.addr=DNS.lookup_addr(info.addr)||info.addr;return info}),get64:(function(){var low=SYSCALLS.get(),high=SYSCALLS.get();if(low>=0)assert(high===0);else assert(high===-1);return low}),getZero:(function(){assert(SYSCALLS.get()===0)})};function ___syscall6(which,varargs){SYSCALLS.varargs=varargs;try{var stream=SYSCALLS.getStreamFromFD();FS.close(stream);return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}var _emscripten_asm_const=true;function ___assert_fail(condition,filename,line,func){ABORT=true;throw"Assertion failed: "+Pointer_stringify(condition)+", at: "+[filename?Pointer_stringify(filename):"unknown filename",line,func?Pointer_stringify(func):"unknown function"]+" at "+stackTrace()}function _sbrk(bytes){var self=_sbrk;if(!self.called){DYNAMICTOP=alignMemoryPage(DYNAMICTOP);self.called=true;assert(Runtime.dynamicAlloc);self.alloc=Runtime.dynamicAlloc;Runtime.dynamicAlloc=(function(){abort("cannot dynamically allocate, sbrk now has control")})}var ret=DYNAMICTOP;if(bytes!=0){var success=self.alloc(bytes);if(!success)return-1>>>0}return ret}function _emscripten_memcpy_big(dest,src,num){HEAPU8.set(HEAPU8.subarray(src,src+num),dest);return dest}Module["_memcpy"]=_memcpy;Module["_memmove"]=_memmove;var _emscripten_asm_const_int=true;function _time(ptr){var ret=Date.now()/1e3|0;if(ptr){HEAP32[ptr>>2]=ret}return ret}function _pthread_self(){return 0}function ___syscall140(which,varargs){SYSCALLS.varargs=varargs;try{var stream=SYSCALLS.getStreamFromFD(),offset_high=SYSCALLS.get(),offset_low=SYSCALLS.get(),result=SYSCALLS.get(),whence=SYSCALLS.get();var offset=offset_low;assert(offset_high===0);FS.llseek(stream,offset,whence);HEAP32[result>>2]=stream.position;if(stream.getdents&&offset===0&&whence===0)stream.getdents=null;return 0}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___syscall146(which,varargs){SYSCALLS.varargs=varargs;try{var stream=SYSCALLS.getStreamFromFD(),iov=SYSCALLS.get(),iovcnt=SYSCALLS.get();return SYSCALLS.doWritev(stream,iov,iovcnt)}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___syscall54(which,varargs){SYSCALLS.varargs=varargs;try{var stream=SYSCALLS.getStreamFromFD(),op=SYSCALLS.get();switch(op){case 21505:{if(!stream.tty)return-ERRNO_CODES.ENOTTY;return 0};case 21506:{if(!stream.tty)return-ERRNO_CODES.ENOTTY;return 0};case 21519:{if(!stream.tty)return-ERRNO_CODES.ENOTTY;var argp=SYSCALLS.get();HEAP32[argp>>2]=0;return 0};case 21520:{if(!stream.tty)return-ERRNO_CODES.ENOTTY;return-ERRNO_CODES.EINVAL};case 21531:{var argp=SYSCALLS.get();return FS.ioctl(stream,op,argp)};default:abort("bad ioctl syscall "+op)}}catch(e){if(typeof FS==="undefined"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}FS.staticInit();__ATINIT__.unshift((function(){if(!Module["noFSInit"]&&!FS.init.initialized)FS.init()}));__ATMAIN__.push((function(){FS.ignorePermissions=false}));__ATEXIT__.push((function(){FS.quit()}));Module["FS_createFolder"]=FS.createFolder;Module["FS_createPath"]=FS.createPath;Module["FS_createDataFile"]=FS.createDataFile;Module["FS_createPreloadedFile"]=FS.createPreloadedFile;Module["FS_createLazyFile"]=FS.createLazyFile;Module["FS_createLink"]=FS.createLink;Module["FS_createDevice"]=FS.createDevice;Module["FS_unlink"]=FS.unlink;__ATINIT__.unshift((function(){TTY.init()}));__ATEXIT__.push((function(){TTY.shutdown()}));if(ENVIRONMENT_IS_NODE){var fs=require("fs");var NODEJS_PATH=require("path");NODEFS.staticInit()}STACK_BASE=STACKTOP=Runtime.alignMemory(STATICTOP);staticSealed=true;STACK_MAX=STACK_BASE+TOTAL_STACK;DYNAMIC_BASE=DYNAMICTOP=Runtime.alignMemory(STACK_MAX);assert(DYNAMIC_BASE>0]|0;M=Hd(d[e+1>>0]|0|0,0,8)|0;J=C;r=Hd(d[e+2>>0]|0|0,0,16)|0;J=J|C;s=Hd(d[e+3>>0]|0|0,0,24)|0;J=J|C;I=a[e+6>>0]|0;L=d[e+4>>0]|0;p=Hd(d[e+5>>0]|0|0,0,8)|0;K=C;I=Hd(I&255|0,0,16)|0;K=Hd(p|L|I|0,K|C|0,6)|0;I=C;L=a[e+9>>0]|0;p=d[e+7>>0]|0;f=Hd(d[e+8>>0]|0|0,0,8)|0;w=C;L=Hd(L&255|0,0,16)|0;w=Hd(f|p|L|0,w|C|0,5)|0;L=C;p=a[e+12>>0]|0;f=d[e+10>>0]|0;y=Hd(d[e+11>>0]|0|0,0,8)|0;n=C;p=Hd(p&255|0,0,16)|0;n=Hd(y|f|p|0,n|C|0,3)|0;p=C;f=a[e+15>>0]|0;y=d[e+13>>0]|0;F=Hd(d[e+14>>0]|0|0,0,8)|0;A=C;f=Hd(f&255|0,0,16)|0;A=Hd(F|y|f|0,A|C|0,2)|0;f=C;y=d[e+16>>0]|0;F=Hd(d[e+17>>0]|0|0,0,8)|0;u=C;h=Hd(d[e+18>>0]|0|0,0,16)|0;u=u|C;t=Hd(d[e+19>>0]|0|0,0,24)|0;t=F|y|h|t;u=u|C;h=a[e+22>>0]|0;y=d[e+20>>0]|0;F=Hd(d[e+21>>0]|0|0,0,8)|0;E=C;h=Hd(h&255|0,0,16)|0;E=Hd(F|y|h|0,E|C|0,7)|0;h=C;y=a[e+25>>0]|0;F=d[e+23>>0]|0;N=Hd(d[e+24>>0]|0|0,0,8)|0;x=C;y=Hd(y&255|0,0,16)|0;x=Hd(N|F|y|0,x|C|0,5)|0;y=C;F=a[e+28>>0]|0;N=d[e+26>>0]|0;g=Hd(d[e+27>>0]|0|0,0,8)|0;G=C;F=Hd(F&255|0,0,16)|0;G=Hd(g|N|F|0,G|C|0,4)|0;F=C;N=e+31|0;g=a[N>>0]|0;D=d[e+29>>0]|0;v=Hd(d[e+30>>0]|0|0,0,8)|0;B=C;g=Hd(g&255|0,0,16)|0;B=Hd(v|D|g|0,B|C|0,2)|0;B=B&33554428;g=Dd(B|0,0,16777216,0)|0;g=Gd(g|0,C|0,25)|0;D=C;v=Cd(0,0,g|0,D|0)|0;J=Dd(v&19|0,0,M|T|r|s|0,J|0)|0;s=C;D=Hd(g|0,D|0,25)|0;g=C;r=Dd(K|0,I|0,16777216,0)|0;r=Gd(r|0,C|0,25)|0;T=C;L=Dd(w|0,L|0,r|0,T|0)|0;w=C;T=Hd(r|0,T|0,25)|0;T=Cd(K|0,I|0,T|0,C|0)|0;I=C;K=Dd(n|0,p|0,16777216,0)|0;K=Gd(K|0,C|0,25)|0;r=C;f=Dd(A|0,f|0,K|0,r|0)|0;A=C;r=Hd(K|0,r|0,25)|0;K=C;M=Dd(t|0,u|0,16777216,0)|0;M=Gd(M|0,C|0,25)|0;v=C;h=Dd(E|0,h|0,M|0,v|0)|0;E=C;v=Hd(M|0,v|0,25)|0;M=C;e=Dd(x|0,y|0,16777216,0)|0;e=Gd(e|0,C|0,25)|0;z=C;F=Dd(G|0,F|0,e|0,z|0)|0;G=C;z=Hd(e|0,z|0,25)|0;e=C;S=Dd(J|0,s|0,33554432,0)|0;S=Ed(S|0,C|0,26)|0;H=C;I=Dd(T|0,I|0,S|0,H|0)|0;H=Hd(S|0,H|0,26)|0;H=Cd(J|0,s|0,H|0,C|0)|0;s=Dd(L|0,w|0,33554432,0)|0;s=Ed(s|0,C|0,26)|0;J=C;p=Dd(s|0,J|0,n|0,p|0)|0;K=Cd(p|0,C|0,r|0,K|0)|0;J=Hd(s|0,J|0,26)|0;J=Cd(L|0,w|0,J|0,C|0)|0;w=Dd(f|0,A|0,33554432,0)|0;w=Ed(w|0,C|0,26)|0;L=C;u=Dd(w|0,L|0,t|0,u|0)|0;M=Cd(u|0,C|0,v|0,M|0)|0;L=Hd(w|0,L|0,26)|0;L=Cd(f|0,A|0,L|0,C|0)|0;A=Dd(h|0,E|0,33554432,0)|0;A=Ed(A|0,C|0,26)|0;f=C;y=Dd(A|0,f|0,x|0,y|0)|0;e=Cd(y|0,C|0,z|0,e|0)|0;f=Hd(A|0,f|0,26)|0;f=Cd(h|0,E|0,f|0,C|0)|0;E=Dd(F|0,G|0,33554432,0)|0;E=Ed(E|0,C|0,26)|0;h=C;B=Dd(B|0,0,E|0,h|0)|0;g=Cd(B|0,C|0,D|0,g|0)|0;h=Hd(E|0,h|0,26)|0;h=Cd(F|0,G|0,h|0,C|0)|0;c[O>>2]=H;c[b+44>>2]=I;c[b+48>>2]=J;c[b+52>>2]=K;c[b+56>>2]=L;c[b+60>>2]=M;c[b+64>>2]=f;c[b+68>>2]=e;c[b+72>>2]=h;c[b+76>>2]=g;g=b+80|0;c[g>>2]=1;h=b+84|0;e=h;f=e+36|0;do{c[e>>2]=0;e=e+4|0}while((e|0)<(f|0));Kc(q,O);Jc(l,q,1064);f=q+4|0;n=q+8|0;p=q+12|0;r=q+16|0;s=q+20|0;v=q+24|0;x=q+28|0;z=q+32|0;B=q+36|0;g=c[g>>2]|0;t=c[h>>2]|0;w=c[b+88>>2]|0;A=c[b+92>>2]|0;E=c[b+96>>2]|0;G=c[b+100>>2]|0;I=c[b+104>>2]|0;K=c[b+108>>2]|0;M=c[b+112>>2]|0;T=c[b+116>>2]|0;e=(c[f>>2]|0)-t|0;S=(c[n>>2]|0)-w|0;L=(c[p>>2]|0)-A|0;J=(c[r>>2]|0)-E|0;H=(c[s>>2]|0)-G|0;F=(c[v>>2]|0)-I|0;D=(c[x>>2]|0)-K|0;y=(c[z>>2]|0)-M|0;u=(c[B>>2]|0)-T|0;c[q>>2]=(c[q>>2]|0)-g;c[f>>2]=e;c[n>>2]=S;c[p>>2]=L;c[r>>2]=J;c[s>>2]=H;c[v>>2]=F;c[x>>2]=D;c[z>>2]=y;c[B>>2]=u;u=l+4|0;y=l+8|0;D=l+12|0;F=l+16|0;H=l+20|0;J=l+24|0;L=l+28|0;S=l+32|0;e=l+36|0;t=t+(c[u>>2]|0)|0;w=w+(c[y>>2]|0)|0;A=A+(c[D>>2]|0)|0;E=E+(c[F>>2]|0)|0;G=G+(c[H>>2]|0)|0;I=I+(c[J>>2]|0)|0;K=K+(c[L>>2]|0)|0;M=M+(c[S>>2]|0)|0;T=T+(c[e>>2]|0)|0;c[l>>2]=g+(c[l>>2]|0);c[u>>2]=t;c[y>>2]=w;c[D>>2]=A;c[F>>2]=E;c[H>>2]=G;c[J>>2]=I;c[L>>2]=K;c[S>>2]=M;c[e>>2]=T;Kc(m,l);Jc(m,m,l);Kc(b,m);Jc(b,b,l);Jc(b,b,q);Kc(Q,b);Kc(k,Q);Kc(k,k);Jc(k,b,k);Jc(Q,Q,k);Kc(Q,Q);Jc(Q,k,Q);Kc(k,Q);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Jc(Q,k,Q);Kc(k,Q);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Jc(k,k,Q);Kc(j,k);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Jc(k,j,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Jc(Q,k,Q);Kc(k,Q);e=1;do{Kc(k,k);e=e+1|0}while((e|0)!=50);Jc(k,k,Q);Kc(j,k);e=1;do{Kc(j,j);e=e+1|0}while((e|0)!=100);Jc(k,j,k);Kc(k,k);e=1;do{Kc(k,k);e=e+1|0}while((e|0)!=50);Jc(Q,k,Q);Kc(Q,Q);Kc(Q,Q);Jc(b,Q,b);Jc(b,b,m);Jc(b,b,q);Kc(o,b);Jc(o,o,l);E=c[o>>2]|0;F=c[o+4>>2]|0;G=c[o+8>>2]|0;H=c[o+12>>2]|0;I=c[o+16>>2]|0;J=c[o+20>>2]|0;K=c[o+24>>2]|0;L=c[o+28>>2]|0;M=c[o+32>>2]|0;D=c[o+36>>2]|0;A=c[q>>2]|0;y=c[f>>2]|0;w=c[n>>2]|0;u=c[p>>2]|0;t=c[r>>2]|0;s=c[s>>2]|0;r=c[v>>2]|0;q=c[x>>2]|0;p=c[z>>2]|0;e=c[B>>2]|0;c[P>>2]=E-A;f=P+4|0;c[f>>2]=F-y;g=P+8|0;c[g>>2]=G-w;h=P+12|0;c[h>>2]=H-u;j=P+16|0;c[j>>2]=I-t;k=P+20|0;c[k>>2]=J-s;l=P+24|0;c[l>>2]=K-r;m=P+28|0;c[m>>2]=L-q;n=P+32|0;c[n>>2]=M-p;o=P+36|0;c[o>>2]=D-e;Lc(Q,P);do if(Yc(Q,33004)|0){c[P>>2]=A+E;c[f>>2]=y+F;c[g>>2]=w+G;c[h>>2]=u+H;c[j>>2]=t+I;c[k>>2]=s+J;c[l>>2]=r+K;c[m>>2]=q+L;c[n>>2]=p+M;c[o>>2]=e+D;Lc(Q,P);if(!(Yc(Q,33004)|0)){Jc(b,b,1104);break}else{T=-1;i=R;return T|0}}while(0);Lc(Q,b);if(((d[Q>>0]|0)&1|0)==((d[N>>0]|0)>>>7|0)){A=b+4|0;D=b+8|0;F=b+12|0;H=b+16|0;J=b+20|0;L=b+24|0;N=b+28|0;Q=b+32|0;T=b+36|0;z=0-(c[A>>2]|0)|0;B=0-(c[D>>2]|0)|0;E=0-(c[F>>2]|0)|0;G=0-(c[H>>2]|0)|0;I=0-(c[J>>2]|0)|0;K=0-(c[L>>2]|0)|0;M=0-(c[N>>2]|0)|0;P=0-(c[Q>>2]|0)|0;S=0-(c[T>>2]|0)|0;c[b>>2]=0-(c[b>>2]|0);c[A>>2]=z;c[D>>2]=B;c[F>>2]=E;c[H>>2]=G;c[J>>2]=I;c[L>>2]=K;c[N>>2]=M;c[Q>>2]=P;c[T>>2]=S}Jc(b+120|0,b,O);T=0;i=R;return T|0}function Oc(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0;V=b+40|0;j=b+44|0;m=b+48|0;p=b+52|0;s=b+56|0;v=b+60|0;y=b+64|0;B=b+68|0;E=b+72|0;C=b+76|0;S=b+4|0;P=b+8|0;e=b+12|0;l=b+16|0;n=b+20|0;u=b+24|0;w=b+28|0;D=b+32|0;O=b+36|0;ga=(c[S>>2]|0)+(c[j>>2]|0)|0;fa=(c[P>>2]|0)+(c[m>>2]|0)|0;ea=(c[e>>2]|0)+(c[p>>2]|0)|0;da=(c[l>>2]|0)+(c[s>>2]|0)|0;ca=(c[n>>2]|0)+(c[v>>2]|0)|0;ba=(c[u>>2]|0)+(c[y>>2]|0)|0;aa=(c[w>>2]|0)+(c[B>>2]|0)|0;$=(c[D>>2]|0)+(c[E>>2]|0)|0;Y=(c[O>>2]|0)+(c[C>>2]|0)|0;c[a>>2]=(c[b>>2]|0)+(c[V>>2]|0);ha=a+4|0;c[ha>>2]=ga;ga=a+8|0;c[ga>>2]=fa;fa=a+12|0;c[fa>>2]=ea;ea=a+16|0;c[ea>>2]=da;da=a+20|0;c[da>>2]=ca;ca=a+24|0;c[ca>>2]=ba;ba=a+28|0;c[ba>>2]=aa;aa=a+32|0;c[aa>>2]=$;$=a+36|0;c[$>>2]=Y;Y=a+40|0;S=(c[j>>2]|0)-(c[S>>2]|0)|0;P=(c[m>>2]|0)-(c[P>>2]|0)|0;e=(c[p>>2]|0)-(c[e>>2]|0)|0;l=(c[s>>2]|0)-(c[l>>2]|0)|0;n=(c[v>>2]|0)-(c[n>>2]|0)|0;u=(c[y>>2]|0)-(c[u>>2]|0)|0;w=(c[B>>2]|0)-(c[w>>2]|0)|0;D=(c[E>>2]|0)-(c[D>>2]|0)|0;O=(c[C>>2]|0)-(c[O>>2]|0)|0;c[Y>>2]=(c[V>>2]|0)-(c[b>>2]|0);V=a+44|0;c[V>>2]=S;S=a+48|0;c[S>>2]=P;P=a+52|0;c[P>>2]=e;e=a+56|0;c[e>>2]=l;l=a+60|0;c[l>>2]=n;n=a+64|0;c[n>>2]=u;u=a+68|0;c[u>>2]=w;w=a+72|0;c[w>>2]=D;D=a+76|0;c[D>>2]=O;O=a+80|0;Jc(O,a,d);Jc(Y,Y,d+40|0);C=a+120|0;Jc(C,d+80|0,b+120|0);E=c[b+80>>2]<<1;B=c[b+84>>2]<<1;y=c[b+88>>2]<<1;v=c[b+92>>2]<<1;s=c[b+96>>2]<<1;p=c[b+100>>2]<<1;m=c[b+104>>2]<<1;j=c[b+108>>2]<<1;g=c[b+112>>2]<<1;b=c[b+116>>2]<<1;Z=c[O>>2]|0;N=a+84|0;W=c[N>>2]|0;M=a+88|0;T=c[M>>2]|0;L=a+92|0;Q=c[L>>2]|0;K=a+96|0;f=c[K>>2]|0;J=a+100|0;h=c[J>>2]|0;I=a+104|0;o=c[I>>2]|0;H=a+108|0;q=c[H>>2]|0;G=a+112|0;x=c[G>>2]|0;F=a+116|0;z=c[F>>2]|0;_=c[Y>>2]|0;X=c[V>>2]|0;U=c[S>>2]|0;R=c[P>>2]|0;d=c[e>>2]|0;i=c[l>>2]|0;k=c[n>>2]|0;r=c[u>>2]|0;t=c[w>>2]|0;A=c[D>>2]|0;c[a>>2]=Z-_;c[ha>>2]=W-X;c[ga>>2]=T-U;c[fa>>2]=Q-R;c[ea>>2]=f-d;c[da>>2]=h-i;c[ca>>2]=o-k;c[ba>>2]=q-r;c[aa>>2]=x-t;c[$>>2]=z-A;c[Y>>2]=_+Z;c[V>>2]=X+W;c[S>>2]=U+T;c[P>>2]=R+Q;c[e>>2]=d+f;c[l>>2]=i+h;c[n>>2]=k+o;c[u>>2]=r+q;c[w>>2]=t+x;c[D>>2]=A+z;D=c[C>>2]|0;z=a+124|0;A=c[z>>2]|0;w=a+128|0;x=c[w>>2]|0;t=a+132|0;u=c[t>>2]|0;q=a+136|0;r=c[q>>2]|0;n=a+140|0;o=c[n>>2]|0;k=a+144|0;l=c[k>>2]|0;h=a+148|0;i=c[h>>2]|0;e=a+152|0;f=c[e>>2]|0;a=a+156|0;d=c[a>>2]|0;c[O>>2]=D+E;c[N>>2]=A+B;c[M>>2]=x+y;c[L>>2]=u+v;c[K>>2]=r+s;c[J>>2]=o+p;c[I>>2]=l+m;c[H>>2]=i+j;c[G>>2]=f+g;c[F>>2]=d+b;c[C>>2]=E-D;c[z>>2]=B-A;c[w>>2]=y-x;c[t>>2]=v-u;c[q>>2]=s-r;c[n>>2]=p-o;c[k>>2]=m-l;c[h>>2]=j-i;c[e>>2]=g-f;c[a>>2]=b-d;return}function Pc(a,b){a=a|0;b=b|0;var d=0,e=0,f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0,xa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha=0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa=0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0,db=0,eb=0,fb=0,gb=0,hb=0,ib=0,jb=0,kb=0,lb=0,mb=0,nb=0;d=i;S=i=i+63&-64;i=i+48|0;Kc(a,b);aa=a+80|0;ta=b+40|0;Kc(aa,ta);v=a+120|0;ib=c[b+80>>2]|0;Sa=c[b+84>>2]|0;p=c[b+88>>2]|0;x=c[b+92>>2]|0;f=c[b+96>>2]|0;kb=c[b+100>>2]|0;_=c[b+104>>2]|0;wa=c[b+108>>2]|0;l=c[b+112>>2]|0;ua=c[b+116>>2]|0;t=ib<<1;ra=Sa<<1;cb=p<<1;g=x<<1;Ma=f<<1;e=kb<<1;va=_<<1;n=wa<<1;bb=kb*38|0;Qa=_*19|0;Q=wa*38|0;H=l*19|0;nb=ua*38|0;jb=((ib|0)<0)<<31>>31;jb=Od(ib|0,jb|0,ib|0,jb|0)|0;ib=C;qa=((t|0)<0)<<31>>31;Ta=((Sa|0)<0)<<31>>31;$a=Od(t|0,qa|0,Sa|0,Ta|0)|0;_a=C;r=((p|0)<0)<<31>>31;Va=Od(p|0,r|0,t|0,qa|0)|0;Ua=C;R=((x|0)<0)<<31>>31;La=Od(x|0,R|0,t|0,qa|0)|0;Ka=C;ka=((f|0)<0)<<31>>31;za=Od(f|0,ka|0,t|0,qa|0)|0;ya=C;lb=((kb|0)<0)<<31>>31;K=Od(kb|0,lb|0,t|0,qa|0)|0;M=C;j=((_|0)<0)<<31>>31;k=Od(_|0,j|0,t|0,qa|0)|0;F=C;xa=((wa|0)<0)<<31>>31;u=Od(wa|0,xa|0,t|0,qa|0)|0;P=C;ma=((l|0)<0)<<31>>31;W=Od(l|0,ma|0,t|0,qa|0)|0;fa=C;oa=((ua|0)<0)<<31>>31;qa=Od(ua|0,oa|0,t|0,qa|0)|0;t=C;pa=((ra|0)<0)<<31>>31;Ta=Od(ra|0,pa|0,Sa|0,Ta|0)|0;Sa=C;Ja=Od(ra|0,pa|0,p|0,r|0)|0;Ia=C;ja=((g|0)<0)<<31>>31;Da=Od(g|0,ja|0,ra|0,pa|0)|0;Ca=C;B=Od(f|0,ka|0,ra|0,pa|0)|0;E=C;la=((e|0)<0)<<31>>31;h=Od(e|0,la|0,ra|0,pa|0)|0;D=C;s=Od(_|0,j|0,ra|0,pa|0)|0;N=C;$=((n|0)<0)<<31>>31;V=Od(n|0,$|0,ra|0,pa|0)|0;ea=C;sa=Od(l|0,ma|0,ra|0,pa|0)|0;na=C;mb=((nb|0)<0)<<31>>31;pa=Od(nb|0,mb|0,ra|0,pa|0)|0;ra=C;Ba=Od(p|0,r|0,p|0,r|0)|0;Aa=C;db=((cb|0)<0)<<31>>31;G=Od(cb|0,db|0,x|0,R|0)|0;I=C;y=Od(f|0,ka|0,cb|0,db|0)|0;A=C;o=Od(kb|0,lb|0,cb|0,db|0)|0;J=C;w=Od(_|0,j|0,cb|0,db|0)|0;ba=C;Z=Od(wa|0,xa|0,cb|0,db|0)|0;ia=C;m=((H|0)<0)<<31>>31;db=Od(H|0,m|0,cb|0,db|0)|0;cb=C;r=Od(nb|0,mb|0,p|0,r|0)|0;p=C;R=Od(g|0,ja|0,x|0,R|0)|0;x=C;q=Od(g|0,ja|0,f|0,ka|0)|0;L=C;U=Od(e|0,la|0,g|0,ja|0)|0;da=C;X=Od(_|0,j|0,g|0,ja|0)|0;ga=C;O=((Q|0)<0)<<31>>31;fb=Od(Q|0,O|0,g|0,ja|0)|0;eb=C;Xa=Od(H|0,m|0,g|0,ja|0)|0;Wa=C;ja=Od(nb|0,mb|0,g|0,ja|0)|0;g=C;T=Od(f|0,ka|0,f|0,ka|0)|0;ca=C;Na=((Ma|0)<0)<<31>>31;Y=Od(Ma|0,Na|0,kb|0,lb|0)|0;ha=C;Ra=((Qa|0)<0)<<31>>31;hb=Od(Qa|0,Ra|0,Ma|0,Na|0)|0;gb=C;Za=Od(Q|0,O|0,f|0,ka|0)|0;Ya=C;Na=Od(H|0,m|0,Ma|0,Na|0)|0;Ma=C;ka=Od(nb|0,mb|0,f|0,ka|0)|0;f=C;lb=Od(bb|0,((bb|0)<0)<<31>>31|0,kb|0,lb|0)|0;kb=C;bb=Od(Qa|0,Ra|0,e|0,la|0)|0;ab=C;Pa=Od(Q|0,O|0,e|0,la|0)|0;Oa=C;Fa=Od(H|0,m|0,e|0,la|0)|0;Ea=C;la=Od(nb|0,mb|0,e|0,la|0)|0;e=C;Ra=Od(Qa|0,Ra|0,_|0,j|0)|0;Qa=C;Ha=Od(Q|0,O|0,_|0,j|0)|0;Ga=C;va=Od(H|0,m|0,va|0,((va|0)<0)<<31>>31|0)|0;z=C;j=Od(nb|0,mb|0,_|0,j|0)|0;_=C;xa=Od(Q|0,O|0,wa|0,xa|0)|0;wa=C;O=Od(H|0,m|0,n|0,$|0)|0;Q=C;$=Od(nb|0,mb|0,n|0,$|0)|0;n=C;m=Od(H|0,m|0,l|0,ma|0)|0;H=C;ma=Od(nb|0,mb|0,l|0,ma|0)|0;l=C;oa=Od(nb|0,mb|0,ua|0,oa|0)|0;ua=C;ib=Dd(lb|0,kb|0,jb|0,ib|0)|0;gb=Dd(ib|0,C|0,hb|0,gb|0)|0;eb=Dd(gb|0,C|0,fb|0,eb|0)|0;cb=Dd(eb|0,C|0,db|0,cb|0)|0;ra=Dd(cb|0,C|0,pa|0,ra|0)|0;pa=C;_a=Dd(bb|0,ab|0,$a|0,_a|0)|0;Ya=Dd(_a|0,C|0,Za|0,Ya|0)|0;Wa=Dd(Ya|0,C|0,Xa|0,Wa|0)|0;p=Dd(Wa|0,C|0,r|0,p|0)|0;r=C;Sa=Dd(Va|0,Ua|0,Ta|0,Sa|0)|0;Qa=Dd(Sa|0,C|0,Ra|0,Qa|0)|0;Oa=Dd(Qa|0,C|0,Pa|0,Oa|0)|0;Ma=Dd(Oa|0,C|0,Na|0,Ma|0)|0;g=Dd(Ma|0,C|0,ja|0,g|0)|0;ja=C;Ia=Dd(La|0,Ka|0,Ja|0,Ia|0)|0;Ga=Dd(Ia|0,C|0,Ha|0,Ga|0)|0;Ea=Dd(Ga|0,C|0,Fa|0,Ea|0)|0;f=Dd(Ea|0,C|0,ka|0,f|0)|0;ka=C;Aa=Dd(Da|0,Ca|0,Ba|0,Aa|0)|0;ya=Dd(Aa|0,C|0,za|0,ya|0)|0;wa=Dd(ya|0,C|0,xa|0,wa|0)|0;z=Dd(wa|0,C|0,va|0,z|0)|0;e=Dd(z|0,C|0,la|0,e|0)|0;la=C;I=Dd(B|0,E|0,G|0,I|0)|0;M=Dd(I|0,C|0,K|0,M|0)|0;Q=Dd(M|0,C|0,O|0,Q|0)|0;_=Dd(Q|0,C|0,j|0,_|0)|0;j=C;A=Dd(R|0,x|0,y|0,A|0)|0;D=Dd(A|0,C|0,h|0,D|0)|0;F=Dd(D|0,C|0,k|0,F|0)|0;H=Dd(F|0,C|0,m|0,H|0)|0;n=Dd(H|0,C|0,$|0,n|0)|0;$=C;L=Dd(o|0,J|0,q|0,L|0)|0;N=Dd(L|0,C|0,s|0,N|0)|0;P=Dd(N|0,C|0,u|0,P|0)|0;l=Dd(P|0,C|0,ma|0,l|0)|0;ma=C;ca=Dd(w|0,ba|0,T|0,ca|0)|0;da=Dd(ca|0,C|0,U|0,da|0)|0;ea=Dd(da|0,C|0,V|0,ea|0)|0;fa=Dd(ea|0,C|0,W|0,fa|0)|0;ua=Dd(fa|0,C|0,oa|0,ua|0)|0;oa=C;ha=Dd(X|0,ga|0,Y|0,ha|0)|0;ia=Dd(ha|0,C|0,Z|0,ia|0)|0;na=Dd(ia|0,C|0,sa|0,na|0)|0;t=Dd(na|0,C|0,qa|0,t|0)|0;qa=C;pa=Hd(ra|0,pa|0,1)|0;ra=C;r=Hd(p|0,r|0,1)|0;p=C;ja=Hd(g|0,ja|0,1)|0;g=C;ka=Hd(f|0,ka|0,1)|0;f=C;la=Hd(e|0,la|0,1)|0;e=C;j=Hd(_|0,j|0,1)|0;_=C;$=Hd(n|0,$|0,1)|0;n=C;ma=Hd(l|0,ma|0,1)|0;l=C;oa=Hd(ua|0,oa|0,1)|0;ua=C;qa=Hd(t|0,qa|0,1)|0;t=C;na=Dd(pa|0,ra|0,33554432,0)|0;na=Ed(na|0,C|0,26)|0;sa=C;p=Dd(na|0,sa|0,r|0,p|0)|0;r=C;sa=Hd(na|0,sa|0,26)|0;sa=Cd(pa|0,ra|0,sa|0,C|0)|0;ra=C;pa=Dd(la|0,e|0,33554432,0)|0;pa=Ed(pa|0,C|0,26)|0;na=C;_=Dd(pa|0,na|0,j|0,_|0)|0;j=C;na=Hd(pa|0,na|0,26)|0;na=Cd(la|0,e|0,na|0,C|0)|0;e=C;la=Dd(p|0,r|0,16777216,0)|0;la=Ed(la|0,C|0,25)|0;pa=C;g=Dd(la|0,pa|0,ja|0,g|0)|0;ja=C;pa=Hd(la|0,pa|0,25)|0;pa=Cd(p|0,r|0,pa|0,C|0)|0;r=C;p=Dd(_|0,j|0,16777216,0)|0;p=Ed(p|0,C|0,25)|0;la=C;n=Dd(p|0,la|0,$|0,n|0)|0;$=C;la=Hd(p|0,la|0,25)|0;la=Cd(_|0,j|0,la|0,C|0)|0;j=C;_=Dd(g|0,ja|0,33554432,0)|0;_=Ed(_|0,C|0,26)|0;p=C;f=Dd(_|0,p|0,ka|0,f|0)|0;ka=C;p=Hd(_|0,p|0,26)|0;p=Cd(g|0,ja|0,p|0,C|0)|0;ja=Dd(n|0,$|0,33554432,0)|0;ja=Ed(ja|0,C|0,26)|0;g=C;l=Dd(ja|0,g|0,ma|0,l|0)|0;ma=C;g=Hd(ja|0,g|0,26)|0;g=Cd(n|0,$|0,g|0,C|0)|0;$=Dd(f|0,ka|0,16777216,0)|0;$=Ed($|0,C|0,25)|0;n=C;e=Dd($|0,n|0,na|0,e|0)|0;na=C;n=Hd($|0,n|0,25)|0;n=Cd(f|0,ka|0,n|0,C|0)|0;ka=Dd(l|0,ma|0,16777216,0)|0;ka=Ed(ka|0,C|0,25)|0;f=C;ua=Dd(ka|0,f|0,oa|0,ua|0)|0;oa=C;f=Hd(ka|0,f|0,25)|0;f=Cd(l|0,ma|0,f|0,C|0)|0;ma=Dd(e|0,na|0,33554432,0)|0;ma=Ed(ma|0,C|0,26)|0;l=C;j=Dd(la|0,j|0,ma|0,l|0)|0;l=Hd(ma|0,l|0,26)|0;l=Cd(e|0,na|0,l|0,C|0)|0;na=Dd(ua|0,oa|0,33554432,0)|0;na=Ed(na|0,C|0,26)|0;e=C;t=Dd(na|0,e|0,qa|0,t|0)|0;qa=C;e=Hd(na|0,e|0,26)|0;e=Cd(ua|0,oa|0,e|0,C|0)|0;oa=Dd(t|0,qa|0,16777216,0)|0;oa=Ed(oa|0,C|0,25)|0;ua=C;na=Od(oa|0,ua|0,19,0)|0;ra=Dd(na|0,C|0,sa|0,ra|0)|0;sa=C;ua=Hd(oa|0,ua|0,25)|0;ua=Cd(t|0,qa|0,ua|0,C|0)|0;qa=Dd(ra|0,sa|0,33554432,0)|0;qa=Ed(qa|0,C|0,26)|0;t=C;r=Dd(pa|0,r|0,qa|0,t|0)|0;t=Hd(qa|0,t|0,26)|0;t=Cd(ra|0,sa|0,t|0,C|0)|0;c[v>>2]=t;t=a+124|0;c[t>>2]=r;r=a+128|0;c[r>>2]=p;p=a+132|0;c[p>>2]=n;n=a+136|0;c[n>>2]=l;l=a+140|0;c[l>>2]=j;j=a+144|0;c[j>>2]=g;g=a+148|0;c[g>>2]=f;f=a+152|0;c[f>>2]=e;e=a+156|0;c[e>>2]=ua;ua=a+40|0;sa=(c[b+44>>2]|0)+(c[b+4>>2]|0)|0;ra=(c[b+48>>2]|0)+(c[b+8>>2]|0)|0;qa=(c[b+52>>2]|0)+(c[b+12>>2]|0)|0;pa=(c[b+56>>2]|0)+(c[b+16>>2]|0)|0;oa=(c[b+60>>2]|0)+(c[b+20>>2]|0)|0;na=(c[b+64>>2]|0)+(c[b+24>>2]|0)|0;ma=(c[b+68>>2]|0)+(c[b+28>>2]|0)|0;la=(c[b+72>>2]|0)+(c[b+32>>2]|0)|0;ka=(c[b+76>>2]|0)+(c[b+36>>2]|0)|0;c[ua>>2]=(c[ta>>2]|0)+(c[b>>2]|0);ta=a+44|0;c[ta>>2]=sa;sa=a+48|0;c[sa>>2]=ra;ra=a+52|0;c[ra>>2]=qa;qa=a+56|0;c[qa>>2]=pa;pa=a+60|0;c[pa>>2]=oa;oa=a+64|0;c[oa>>2]=na;na=a+68|0;c[na>>2]=ma;ma=a+72|0;c[ma>>2]=la;la=a+76|0;c[la>>2]=ka;Kc(S,ua);ka=c[aa>>2]|0;$=a+84|0;ja=c[$>>2]|0;_=a+88|0;ia=c[_>>2]|0;Z=a+92|0;ha=c[Z>>2]|0;Y=a+96|0;ga=c[Y>>2]|0;X=a+100|0;fa=c[X>>2]|0;W=a+104|0;ea=c[W>>2]|0;V=a+108|0;da=c[V>>2]|0;U=a+112|0;ca=c[U>>2]|0;T=a+116|0;ba=c[T>>2]|0;w=c[a>>2]|0;P=a+4|0;u=c[P>>2]|0;N=a+8|0;s=c[N>>2]|0;L=a+12|0;q=c[L>>2]|0;J=a+16|0;o=c[J>>2]|0;H=a+20|0;m=c[H>>2]|0;F=a+24|0;k=c[F>>2]|0;D=a+28|0;h=c[D>>2]|0;A=a+32|0;b=c[A>>2]|0;y=a+36|0;x=c[y>>2]|0;R=w+ka|0;Q=u+ja|0;O=s+ia|0;M=q+ha|0;K=o+ga|0;I=m+fa|0;G=k+ea|0;E=h+da|0;B=b+ca|0;z=x+ba|0;c[ua>>2]=R;c[ta>>2]=Q;c[sa>>2]=O;c[ra>>2]=M;c[qa>>2]=K;c[pa>>2]=I;c[oa>>2]=G;c[na>>2]=E;c[ma>>2]=B;c[la>>2]=z;w=ka-w|0;u=ja-u|0;s=ia-s|0;q=ha-q|0;o=ga-o|0;m=fa-m|0;k=ea-k|0;h=da-h|0;b=ca-b|0;x=ba-x|0;c[aa>>2]=w;c[$>>2]=u;c[_>>2]=s;c[Z>>2]=q;c[Y>>2]=o;c[X>>2]=m;c[W>>2]=k;c[V>>2]=h;c[U>>2]=b;c[T>>2]=x;Q=(c[S+4>>2]|0)-Q|0;O=(c[S+8>>2]|0)-O|0;M=(c[S+12>>2]|0)-M|0;K=(c[S+16>>2]|0)-K|0;I=(c[S+20>>2]|0)-I|0;G=(c[S+24>>2]|0)-G|0;E=(c[S+28>>2]|0)-E|0;B=(c[S+32>>2]|0)-B|0;z=(c[S+36>>2]|0)-z|0;c[a>>2]=(c[S>>2]|0)-R;c[P>>2]=Q;c[N>>2]=O;c[L>>2]=M;c[J>>2]=K;c[H>>2]=I;c[F>>2]=G;c[D>>2]=E;c[A>>2]=B;c[y>>2]=z;u=(c[t>>2]|0)-u|0;s=(c[r>>2]|0)-s|0;q=(c[p>>2]|0)-q|0;o=(c[n>>2]|0)-o|0;m=(c[l>>2]|0)-m|0;k=(c[j>>2]|0)-k|0;h=(c[g>>2]|0)-h|0;b=(c[f>>2]|0)-b|0;a=(c[e>>2]|0)-x|0;c[v>>2]=(c[v>>2]|0)-w;c[t>>2]=u;c[r>>2]=s;c[p>>2]=q;c[n>>2]=o;c[l>>2]=m;c[j>>2]=k;c[g>>2]=h;c[f>>2]=b;c[e>>2]=a;i=d;return}function Qc(a,b){a=a|0;b=b|0;var d=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0;m=b+40|0;v=b+44|0;u=b+48|0;t=b+52|0;s=b+56|0;r=b+60|0;q=b+64|0;p=b+68|0;o=b+72|0;n=b+76|0;d=b+4|0;e=b+8|0;f=b+12|0;g=b+16|0;h=b+20|0;i=b+24|0;j=b+28|0;k=b+32|0;l=b+36|0;E=(c[d>>2]|0)+(c[v>>2]|0)|0;D=(c[e>>2]|0)+(c[u>>2]|0)|0;C=(c[f>>2]|0)+(c[t>>2]|0)|0;B=(c[g>>2]|0)+(c[s>>2]|0)|0;A=(c[h>>2]|0)+(c[r>>2]|0)|0;z=(c[i>>2]|0)+(c[q>>2]|0)|0;y=(c[j>>2]|0)+(c[p>>2]|0)|0;x=(c[k>>2]|0)+(c[o>>2]|0)|0;w=(c[l>>2]|0)+(c[n>>2]|0)|0;c[a>>2]=(c[b>>2]|0)+(c[m>>2]|0);c[a+4>>2]=E;c[a+8>>2]=D;c[a+12>>2]=C;c[a+16>>2]=B;c[a+20>>2]=A;c[a+24>>2]=z;c[a+28>>2]=y;c[a+32>>2]=x;c[a+36>>2]=w;d=(c[v>>2]|0)-(c[d>>2]|0)|0;e=(c[u>>2]|0)-(c[e>>2]|0)|0;f=(c[t>>2]|0)-(c[f>>2]|0)|0;g=(c[s>>2]|0)-(c[g>>2]|0)|0;h=(c[r>>2]|0)-(c[h>>2]|0)|0;i=(c[q>>2]|0)-(c[i>>2]|0)|0;j=(c[p>>2]|0)-(c[j>>2]|0)|0;k=(c[o>>2]|0)-(c[k>>2]|0)|0;l=(c[n>>2]|0)-(c[l>>2]|0)|0;c[a+40>>2]=(c[m>>2]|0)-(c[b>>2]|0);c[a+44>>2]=d;c[a+48>>2]=e;c[a+52>>2]=f;c[a+56>>2]=g;c[a+60>>2]=h;c[a+64>>2]=i;c[a+68>>2]=j;c[a+72>>2]=k;c[a+76>>2]=l;l=c[b+84>>2]|0;k=c[b+88>>2]|0;j=c[b+92>>2]|0;i=c[b+96>>2]|0;h=c[b+100>>2]|0;g=c[b+104>>2]|0;f=c[b+108>>2]|0;e=c[b+112>>2]|0;d=c[b+116>>2]|0;c[a+80>>2]=c[b+80>>2];c[a+84>>2]=l;c[a+88>>2]=k;c[a+92>>2]=j;c[a+96>>2]=i;c[a+100>>2]=h;c[a+104>>2]=g;c[a+108>>2]=f;c[a+112>>2]=e;c[a+116>>2]=d;Jc(a+120|0,b+120|0,1144);return}function Rc(b,e){b=b|0;e=e|0;var f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0;u=i;t=i=i+63&-64;i=i+592|0;p=t+400|0;r=t+520|0;s=t+240|0;q=t+120|0;f=0;do{n=a[e+f>>0]|0;o=f<<1;a[r+o>>0]=n&15;a[r+(o|1)>>0]=(n&255)>>>4;f=f+1|0}while((f|0)!=32);e=0;f=0;do{o=r+f|0;n=(d[o>>0]|0)+e|0;e=(n<<24)+134217728>>28;a[o>>0]=n-(e<<4);f=f+1|0}while((f|0)!=63);f=r+63|0;a[f>>0]=(d[f>>0]|0)+e;e=b;f=e+40|0;do{c[e>>2]=0;e=e+4|0}while((e|0)<(f|0));j=b+40|0;c[j>>2]=1;g=b+44|0;e=g;f=e+36|0;do{c[e>>2]=0;e=e+4|0}while((e|0)<(f|0));k=b+80|0;c[k>>2]=1;h=b+84|0;l=b+120|0;m=s+120|0;n=s+40|0;o=s+80|0;e=h;f=e+76|0;do{c[e>>2]=0;e=e+4|0}while((e|0)<(f|0));e=1;do{Sc(t,(e|0)/2|0,a[r+e>>0]|0);Oc(s,b,t);Jc(b,s,m);Jc(j,n,o);Jc(k,o,m);Jc(l,s,n);e=e+2|0}while((e|0)<64);B=c[b+4>>2]|0;z=c[b+8>>2]|0;y=c[b+12>>2]|0;x=c[b+16>>2]|0;w=c[b+20>>2]|0;v=c[b+24>>2]|0;f=c[b+28>>2]|0;e=c[b+32>>2]|0;A=c[b+36>>2]|0;c[p>>2]=c[b>>2];c[p+4>>2]=B;c[p+8>>2]=z;c[p+12>>2]=y;c[p+16>>2]=x;c[p+20>>2]=w;c[p+24>>2]=v;c[p+28>>2]=f;c[p+32>>2]=e;c[p+36>>2]=A;A=c[g>>2]|0;e=c[b+48>>2]|0;g=c[b+52>>2]|0;f=c[b+56>>2]|0;v=c[b+60>>2]|0;w=c[b+64>>2]|0;x=c[b+68>>2]|0;y=c[b+72>>2]|0;z=c[b+76>>2]|0;c[p+40>>2]=c[j>>2];c[p+44>>2]=A;c[p+48>>2]=e;c[p+52>>2]=g;c[p+56>>2]=f;c[p+60>>2]=v;c[p+64>>2]=w;c[p+68>>2]=x;c[p+72>>2]=y;c[p+76>>2]=z;z=c[h>>2]|0;y=c[b+88>>2]|0;x=c[b+92>>2]|0;w=c[b+96>>2]|0;v=c[b+100>>2]|0;f=c[b+104>>2]|0;g=c[b+108>>2]|0;h=c[b+112>>2]|0;e=c[b+116>>2]|0;c[p+80>>2]=c[k>>2];c[p+84>>2]=z;c[p+88>>2]=y;c[p+92>>2]=x;c[p+96>>2]=w;c[p+100>>2]=v;c[p+104>>2]=f;c[p+108>>2]=g;c[p+112>>2]=h;c[p+116>>2]=e;Pc(s,p);Jc(q,s,m);p=q+40|0;Jc(p,n,o);e=q+80|0;Jc(e,o,m);Pc(s,q);Jc(q,s,m);Jc(p,n,o);Jc(e,o,m);Pc(s,q);Jc(q,s,m);Jc(p,n,o);Jc(e,o,m);Pc(s,q);Jc(b,s,m);Jc(j,n,o);Jc(k,o,m);Jc(l,s,n);e=0;do{Sc(t,(e|0)/2|0,a[r+e>>0]|0);Oc(s,b,t);Jc(b,s,m);Jc(j,n,o);Jc(k,o,m);Jc(l,s,n);e=e+2|0}while((e|0)<64);i=u;return}function Sc(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0;s=d<<24>>24;s=Gd(s|0,((s|0)<0)<<31>>31|0,63)|0;h=d<<24>>24;s=0-s|0;d=a+4|0;c[d>>2]=0;c[d+4>>2]=0;c[d+8>>2]=0;c[d+12>>2]=0;c[d+16>>2]=0;c[d+20>>2]=0;c[d+24>>2]=0;c[d+28>>2]=0;e=a+40|0;c[e>>2]=1;f=a+44|0;g=a+80|0;h=h-((h&s)<<1)&255;i=(h^1)+-1|0;j=1184+(b*960|0)|0;k=a+8|0;l=a+12|0;m=a+16|0;n=a+20|0;o=a+24|0;p=a+28|0;q=a+32|0;r=a+36|0;t=f;u=t+76|0;do{c[t>>2]=0;t=t+4|0}while((t|0)<(u|0));H=i>>31;A=c[1184+(b*960|0)+4>>2]&H;I=c[1184+(b*960|0)+8>>2]&H;K=c[1184+(b*960|0)+12>>2]&H;M=c[1184+(b*960|0)+16>>2]&H;O=c[1184+(b*960|0)+20>>2]&H;Q=c[1184+(b*960|0)+24>>2]&H;S=c[1184+(b*960|0)+28>>2]&H;U=c[1184+(b*960|0)+32>>2]&H;W=c[1184+(b*960|0)+36>>2]&H;c[a>>2]=(c[j>>2]^1)&H^1;c[d>>2]=A;c[k>>2]=I;c[l>>2]=K;c[m>>2]=M;c[n>>2]=O;c[o>>2]=Q;c[p>>2]=S;c[q>>2]=U;c[r>>2]=W;W=a+48|0;U=a+52|0;S=a+56|0;Q=a+60|0;O=a+64|0;M=a+68|0;K=a+72|0;I=a+76|0;A=c[1184+(b*960|0)+44>>2]&H;z=c[1184+(b*960|0)+48>>2]&H;w=c[1184+(b*960|0)+52>>2]&H;B=c[1184+(b*960|0)+56>>2]&H;ia=c[1184+(b*960|0)+60>>2]&H;D=c[1184+(b*960|0)+64>>2]&H;ea=c[1184+(b*960|0)+68>>2]&H;F=c[1184+(b*960|0)+72>>2]&H;ga=c[1184+(b*960|0)+76>>2]&H;c[e>>2]=(c[1184+(b*960|0)+40>>2]^1)&H^1;c[f>>2]=A;c[W>>2]=z;c[U>>2]=w;c[S>>2]=B;c[Q>>2]=ia;c[O>>2]=D;c[M>>2]=ea;c[K>>2]=F;c[I>>2]=ga;ga=c[g>>2]|0;F=a+84|0;ea=c[F>>2]|0;D=a+88|0;ia=c[D>>2]|0;B=a+92|0;w=c[B>>2]|0;z=a+96|0;A=c[z>>2]|0;x=a+100|0;fa=c[x>>2]|0;v=a+104|0;ba=c[v>>2]|0;i=a+108|0;G=c[i>>2]|0;t=a+112|0;_=c[t>>2]|0;u=a+116|0;da=c[u>>2]|0;$=(c[1184+(b*960|0)+84>>2]^ea)&H;aa=(c[1184+(b*960|0)+88>>2]^ia)&H;y=(c[1184+(b*960|0)+92>>2]^w)&H;j=(c[1184+(b*960|0)+96>>2]^A)&H;ha=(c[1184+(b*960|0)+100>>2]^fa)&H;Z=(c[1184+(b*960|0)+104>>2]^ba)&H;ca=(c[1184+(b*960|0)+108>>2]^G)&H;C=(c[1184+(b*960|0)+112>>2]^_)&H;E=(c[1184+(b*960|0)+116>>2]^da)&H;c[g>>2]=(c[1184+(b*960|0)+80>>2]^ga)&H^ga;c[F>>2]=$^ea;c[D>>2]=aa^ia;c[B>>2]=y^w;c[z>>2]=j^A;c[x>>2]=ha^fa;c[v>>2]=Z^ba;c[i>>2]=ca^G;c[t>>2]=C^_;c[u>>2]=E^da;da=c[a>>2]|0;E=c[d>>2]|0;_=c[k>>2]|0;C=c[l>>2]|0;G=c[m>>2]|0;ca=c[n>>2]|0;ba=c[o>>2]|0;Z=c[p>>2]|0;fa=c[q>>2]|0;ha=c[r>>2]|0;A=(h^2)+-1>>31;j=(c[1184+(b*960|0)+124>>2]^E)&A;w=(c[1184+(b*960|0)+128>>2]^_)&A;y=(c[1184+(b*960|0)+132>>2]^C)&A;ia=(c[1184+(b*960|0)+136>>2]^G)&A;aa=(c[1184+(b*960|0)+140>>2]^ca)&A;ea=(c[1184+(b*960|0)+144>>2]^ba)&A;$=(c[1184+(b*960|0)+148>>2]^Z)&A;ga=(c[1184+(b*960|0)+152>>2]^fa)&A;H=(c[1184+(b*960|0)+156>>2]^ha)&A;c[a>>2]=(c[1184+(b*960|0)+120>>2]^da)&A^da;c[d>>2]=j^E;c[k>>2]=w^_;c[l>>2]=y^C;c[m>>2]=ia^G;c[n>>2]=aa^ca;c[o>>2]=ea^ba;c[p>>2]=$^Z;c[q>>2]=ga^fa;c[r>>2]=H^ha;ha=c[e>>2]|0;H=c[f>>2]|0;fa=c[W>>2]|0;ga=c[U>>2]|0;Z=c[S>>2]|0;$=c[Q>>2]|0;ba=c[O>>2]|0;ea=c[M>>2]|0;ca=c[K>>2]|0;aa=c[I>>2]|0;G=(c[1184+(b*960|0)+164>>2]^H)&A;ia=(c[1184+(b*960|0)+168>>2]^fa)&A;C=(c[1184+(b*960|0)+172>>2]^ga)&A;y=(c[1184+(b*960|0)+176>>2]^Z)&A;_=(c[1184+(b*960|0)+180>>2]^$)&A;w=(c[1184+(b*960|0)+184>>2]^ba)&A;E=(c[1184+(b*960|0)+188>>2]^ea)&A;j=(c[1184+(b*960|0)+192>>2]^ca)&A;da=(c[1184+(b*960|0)+196>>2]^aa)&A;c[e>>2]=(c[1184+(b*960|0)+160>>2]^ha)&A^ha;c[f>>2]=G^H;c[W>>2]=ia^fa;c[U>>2]=C^ga;c[S>>2]=y^Z;c[Q>>2]=_^$;c[O>>2]=w^ba;c[M>>2]=E^ea;c[K>>2]=j^ca;c[I>>2]=da^aa;aa=c[g>>2]|0;da=c[F>>2]|0;ca=c[D>>2]|0;j=c[B>>2]|0;ea=c[z>>2]|0;E=c[x>>2]|0;ba=c[v>>2]|0;w=c[i>>2]|0;$=c[t>>2]|0;_=c[u>>2]|0;Z=(c[1184+(b*960|0)+204>>2]^da)&A;y=(c[1184+(b*960|0)+208>>2]^ca)&A;ga=(c[1184+(b*960|0)+212>>2]^j)&A;C=(c[1184+(b*960|0)+216>>2]^ea)&A;fa=(c[1184+(b*960|0)+220>>2]^E)&A;ia=(c[1184+(b*960|0)+224>>2]^ba)&A;H=(c[1184+(b*960|0)+228>>2]^w)&A;G=(c[1184+(b*960|0)+232>>2]^$)&A;ha=(c[1184+(b*960|0)+236>>2]^_)&A;c[g>>2]=(c[1184+(b*960|0)+200>>2]^aa)&A^aa;c[F>>2]=Z^da;c[D>>2]=y^ca;c[B>>2]=ga^j;c[z>>2]=C^ea;c[x>>2]=fa^E;c[v>>2]=ia^ba;c[i>>2]=H^w;c[t>>2]=G^$;c[u>>2]=ha^_;_=c[a>>2]|0;ha=c[d>>2]|0;$=c[k>>2]|0;G=c[l>>2]|0;w=c[m>>2]|0;H=c[n>>2]|0;ba=c[o>>2]|0;ia=c[p>>2]|0;E=c[q>>2]|0;fa=c[r>>2]|0;ea=(h^3)+-1>>31;C=(c[1184+(b*960|0)+244>>2]^ha)&ea;j=(c[1184+(b*960|0)+248>>2]^$)&ea;ga=(c[1184+(b*960|0)+252>>2]^G)&ea;ca=(c[1184+(b*960|0)+256>>2]^w)&ea;y=(c[1184+(b*960|0)+260>>2]^H)&ea;da=(c[1184+(b*960|0)+264>>2]^ba)&ea;Z=(c[1184+(b*960|0)+268>>2]^ia)&ea;aa=(c[1184+(b*960|0)+272>>2]^E)&ea;A=(c[1184+(b*960|0)+276>>2]^fa)&ea;c[a>>2]=(c[1184+(b*960|0)+240>>2]^_)&ea^_;c[d>>2]=C^ha;c[k>>2]=j^$;c[l>>2]=ga^G;c[m>>2]=ca^w;c[n>>2]=y^H;c[o>>2]=da^ba;c[p>>2]=Z^ia;c[q>>2]=aa^E;c[r>>2]=A^fa;fa=c[e>>2]|0;A=c[f>>2]|0;E=c[W>>2]|0;aa=c[U>>2]|0;ia=c[S>>2]|0;Z=c[Q>>2]|0;ba=c[O>>2]|0;da=c[M>>2]|0;H=c[K>>2]|0;y=c[I>>2]|0;w=(c[1184+(b*960|0)+284>>2]^A)&ea;ca=(c[1184+(b*960|0)+288>>2]^E)&ea;G=(c[1184+(b*960|0)+292>>2]^aa)&ea;ga=(c[1184+(b*960|0)+296>>2]^ia)&ea;$=(c[1184+(b*960|0)+300>>2]^Z)&ea;j=(c[1184+(b*960|0)+304>>2]^ba)&ea;ha=(c[1184+(b*960|0)+308>>2]^da)&ea;C=(c[1184+(b*960|0)+312>>2]^H)&ea;_=(c[1184+(b*960|0)+316>>2]^y)&ea;c[e>>2]=(c[1184+(b*960|0)+280>>2]^fa)&ea^fa;c[f>>2]=w^A;c[W>>2]=ca^E;c[U>>2]=G^aa;c[S>>2]=ga^ia;c[Q>>2]=$^Z;c[O>>2]=j^ba;c[M>>2]=ha^da;c[K>>2]=C^H;c[I>>2]=_^y;y=c[g>>2]|0;_=c[F>>2]|0;H=c[D>>2]|0;C=c[B>>2]|0;da=c[z>>2]|0;ha=c[x>>2]|0;ba=c[v>>2]|0;j=c[i>>2]|0;Z=c[t>>2]|0;$=c[u>>2]|0;ia=(c[1184+(b*960|0)+324>>2]^_)&ea;ga=(c[1184+(b*960|0)+328>>2]^H)&ea;aa=(c[1184+(b*960|0)+332>>2]^C)&ea;G=(c[1184+(b*960|0)+336>>2]^da)&ea;E=(c[1184+(b*960|0)+340>>2]^ha)&ea;ca=(c[1184+(b*960|0)+344>>2]^ba)&ea;A=(c[1184+(b*960|0)+348>>2]^j)&ea;w=(c[1184+(b*960|0)+352>>2]^Z)&ea;fa=(c[1184+(b*960|0)+356>>2]^$)&ea;c[g>>2]=(c[1184+(b*960|0)+320>>2]^y)&ea^y;c[F>>2]=ia^_;c[D>>2]=ga^H;c[B>>2]=aa^C;c[z>>2]=G^da;c[x>>2]=E^ha;c[v>>2]=ca^ba;c[i>>2]=A^j;c[t>>2]=w^Z;c[u>>2]=fa^$;$=c[a>>2]|0;fa=c[d>>2]|0;Z=c[k>>2]|0;w=c[l>>2]|0;j=c[m>>2]|0;A=c[n>>2]|0;ba=c[o>>2]|0;ca=c[p>>2]|0;ha=c[q>>2]|0;E=c[r>>2]|0;da=(h^4)+-1>>31;G=(c[1184+(b*960|0)+364>>2]^fa)&da;C=(c[1184+(b*960|0)+368>>2]^Z)&da;aa=(c[1184+(b*960|0)+372>>2]^w)&da;H=(c[1184+(b*960|0)+376>>2]^j)&da;ga=(c[1184+(b*960|0)+380>>2]^A)&da;_=(c[1184+(b*960|0)+384>>2]^ba)&da;ia=(c[1184+(b*960|0)+388>>2]^ca)&da;y=(c[1184+(b*960|0)+392>>2]^ha)&da;ea=(c[1184+(b*960|0)+396>>2]^E)&da;c[a>>2]=(c[1184+(b*960|0)+360>>2]^$)&da^$;c[d>>2]=G^fa;c[k>>2]=C^Z;c[l>>2]=aa^w;c[m>>2]=H^j;c[n>>2]=ga^A;c[o>>2]=_^ba;c[p>>2]=ia^ca;c[q>>2]=y^ha;c[r>>2]=ea^E;E=c[e>>2]|0;ea=c[f>>2]|0;ha=c[W>>2]|0;y=c[U>>2]|0;ca=c[S>>2]|0;ia=c[Q>>2]|0;ba=c[O>>2]|0;_=c[M>>2]|0;A=c[K>>2]|0;ga=c[I>>2]|0;j=(c[1184+(b*960|0)+404>>2]^ea)&da;H=(c[1184+(b*960|0)+408>>2]^ha)&da;w=(c[1184+(b*960|0)+412>>2]^y)&da;aa=(c[1184+(b*960|0)+416>>2]^ca)&da;Z=(c[1184+(b*960|0)+420>>2]^ia)&da;C=(c[1184+(b*960|0)+424>>2]^ba)&da;fa=(c[1184+(b*960|0)+428>>2]^_)&da;G=(c[1184+(b*960|0)+432>>2]^A)&da;$=(c[1184+(b*960|0)+436>>2]^ga)&da;c[e>>2]=(c[1184+(b*960|0)+400>>2]^E)&da^E;c[f>>2]=j^ea;c[W>>2]=H^ha;c[U>>2]=w^y;c[S>>2]=aa^ca;c[Q>>2]=Z^ia;c[O>>2]=C^ba;c[M>>2]=fa^_;c[K>>2]=G^A;c[I>>2]=$^ga;ga=c[g>>2]|0;$=c[F>>2]|0;A=c[D>>2]|0;G=c[B>>2]|0;_=c[z>>2]|0;fa=c[x>>2]|0;ba=c[v>>2]|0;C=c[i>>2]|0;ia=c[t>>2]|0;Z=c[u>>2]|0;ca=(c[1184+(b*960|0)+444>>2]^$)&da;aa=(c[1184+(b*960|0)+448>>2]^A)&da;y=(c[1184+(b*960|0)+452>>2]^G)&da;w=(c[1184+(b*960|0)+456>>2]^_)&da;ha=(c[1184+(b*960|0)+460>>2]^fa)&da;H=(c[1184+(b*960|0)+464>>2]^ba)&da;ea=(c[1184+(b*960|0)+468>>2]^C)&da;j=(c[1184+(b*960|0)+472>>2]^ia)&da;E=(c[1184+(b*960|0)+476>>2]^Z)&da;c[g>>2]=(c[1184+(b*960|0)+440>>2]^ga)&da^ga;c[F>>2]=ca^$;c[D>>2]=aa^A;c[B>>2]=y^G;c[z>>2]=w^_;c[x>>2]=ha^fa;c[v>>2]=H^ba;c[i>>2]=ea^C;c[t>>2]=j^ia;c[u>>2]=E^Z;Z=c[a>>2]|0;E=c[d>>2]|0;ia=c[k>>2]|0;j=c[l>>2]|0;C=c[m>>2]|0;ea=c[n>>2]|0;ba=c[o>>2]|0;H=c[p>>2]|0;fa=c[q>>2]|0;ha=c[r>>2]|0;_=(h^5)+-1>>31;w=(c[1184+(b*960|0)+484>>2]^E)&_;G=(c[1184+(b*960|0)+488>>2]^ia)&_;y=(c[1184+(b*960|0)+492>>2]^j)&_;A=(c[1184+(b*960|0)+496>>2]^C)&_;aa=(c[1184+(b*960|0)+500>>2]^ea)&_;$=(c[1184+(b*960|0)+504>>2]^ba)&_;ca=(c[1184+(b*960|0)+508>>2]^H)&_;ga=(c[1184+(b*960|0)+512>>2]^fa)&_;da=(c[1184+(b*960|0)+516>>2]^ha)&_;c[a>>2]=(c[1184+(b*960|0)+480>>2]^Z)&_^Z;c[d>>2]=w^E;c[k>>2]=G^ia;c[l>>2]=y^j;c[m>>2]=A^C;c[n>>2]=aa^ea;c[o>>2]=$^ba;c[p>>2]=ca^H;c[q>>2]=ga^fa;c[r>>2]=da^ha;ha=c[e>>2]|0;da=c[f>>2]|0;fa=c[W>>2]|0;ga=c[U>>2]|0;H=c[S>>2]|0;ca=c[Q>>2]|0;ba=c[O>>2]|0;$=c[M>>2]|0;ea=c[K>>2]|0;aa=c[I>>2]|0;C=(c[1184+(b*960|0)+524>>2]^da)&_;A=(c[1184+(b*960|0)+528>>2]^fa)&_;j=(c[1184+(b*960|0)+532>>2]^ga)&_;y=(c[1184+(b*960|0)+536>>2]^H)&_;ia=(c[1184+(b*960|0)+540>>2]^ca)&_;G=(c[1184+(b*960|0)+544>>2]^ba)&_;E=(c[1184+(b*960|0)+548>>2]^$)&_;w=(c[1184+(b*960|0)+552>>2]^ea)&_;Z=(c[1184+(b*960|0)+556>>2]^aa)&_;c[e>>2]=(c[1184+(b*960|0)+520>>2]^ha)&_^ha;c[f>>2]=C^da;c[W>>2]=A^fa;c[U>>2]=j^ga;c[S>>2]=y^H;c[Q>>2]=ia^ca;c[O>>2]=G^ba;c[M>>2]=E^$;c[K>>2]=w^ea;c[I>>2]=Z^aa;aa=c[g>>2]|0;Z=c[F>>2]|0;ea=c[D>>2]|0;w=c[B>>2]|0;$=c[z>>2]|0;E=c[x>>2]|0;ba=c[v>>2]|0;G=c[i>>2]|0;ca=c[t>>2]|0;ia=c[u>>2]|0;H=(c[1184+(b*960|0)+564>>2]^Z)&_;y=(c[1184+(b*960|0)+568>>2]^ea)&_;ga=(c[1184+(b*960|0)+572>>2]^w)&_;j=(c[1184+(b*960|0)+576>>2]^$)&_;fa=(c[1184+(b*960|0)+580>>2]^E)&_;A=(c[1184+(b*960|0)+584>>2]^ba)&_;da=(c[1184+(b*960|0)+588>>2]^G)&_;C=(c[1184+(b*960|0)+592>>2]^ca)&_;ha=(c[1184+(b*960|0)+596>>2]^ia)&_;c[g>>2]=(c[1184+(b*960|0)+560>>2]^aa)&_^aa;c[F>>2]=H^Z;c[D>>2]=y^ea;c[B>>2]=ga^w;c[z>>2]=j^$;c[x>>2]=fa^E;c[v>>2]=A^ba;c[i>>2]=da^G;c[t>>2]=C^ca;c[u>>2]=ha^ia;ia=c[a>>2]|0;ha=c[d>>2]|0;ca=c[k>>2]|0;C=c[l>>2]|0;G=c[m>>2]|0;da=c[n>>2]|0;ba=c[o>>2]|0;A=c[p>>2]|0;E=c[q>>2]|0;fa=c[r>>2]|0;$=(h^6)+-1>>31;j=(c[1184+(b*960|0)+604>>2]^ha)&$;w=(c[1184+(b*960|0)+608>>2]^ca)&$;ga=(c[1184+(b*960|0)+612>>2]^C)&$;ea=(c[1184+(b*960|0)+616>>2]^G)&$;y=(c[1184+(b*960|0)+620>>2]^da)&$;Z=(c[1184+(b*960|0)+624>>2]^ba)&$;H=(c[1184+(b*960|0)+628>>2]^A)&$;aa=(c[1184+(b*960|0)+632>>2]^E)&$;_=(c[1184+(b*960|0)+636>>2]^fa)&$;c[a>>2]=(c[1184+(b*960|0)+600>>2]^ia)&$^ia;c[d>>2]=j^ha;c[k>>2]=w^ca;c[l>>2]=ga^C;c[m>>2]=ea^G;c[n>>2]=y^da;c[o>>2]=Z^ba;c[p>>2]=H^A;c[q>>2]=aa^E;c[r>>2]=_^fa;fa=c[e>>2]|0;_=c[f>>2]|0;E=c[W>>2]|0;aa=c[U>>2]|0;A=c[S>>2]|0;H=c[Q>>2]|0;ba=c[O>>2]|0;Z=c[M>>2]|0;da=c[K>>2]|0;y=c[I>>2]|0;G=(c[1184+(b*960|0)+644>>2]^_)&$;ea=(c[1184+(b*960|0)+648>>2]^E)&$;C=(c[1184+(b*960|0)+652>>2]^aa)&$;ga=(c[1184+(b*960|0)+656>>2]^A)&$;ca=(c[1184+(b*960|0)+660>>2]^H)&$;w=(c[1184+(b*960|0)+664>>2]^ba)&$;ha=(c[1184+(b*960|0)+668>>2]^Z)&$;j=(c[1184+(b*960|0)+672>>2]^da)&$;ia=(c[1184+(b*960|0)+676>>2]^y)&$;c[e>>2]=(c[1184+(b*960|0)+640>>2]^fa)&$^fa;c[f>>2]=G^_;c[W>>2]=ea^E;c[U>>2]=C^aa;c[S>>2]=ga^A;c[Q>>2]=ca^H;c[O>>2]=w^ba;c[M>>2]=ha^Z;c[K>>2]=j^da;c[I>>2]=ia^y;y=c[g>>2]|0;ia=c[F>>2]|0;da=c[D>>2]|0;j=c[B>>2]|0;Z=c[z>>2]|0;ha=c[x>>2]|0;ba=c[v>>2]|0;w=c[i>>2]|0;H=c[t>>2]|0;ca=c[u>>2]|0;A=(c[1184+(b*960|0)+684>>2]^ia)&$;ga=(c[1184+(b*960|0)+688>>2]^da)&$;aa=(c[1184+(b*960|0)+692>>2]^j)&$;C=(c[1184+(b*960|0)+696>>2]^Z)&$;E=(c[1184+(b*960|0)+700>>2]^ha)&$;ea=(c[1184+(b*960|0)+704>>2]^ba)&$;_=(c[1184+(b*960|0)+708>>2]^w)&$;G=(c[1184+(b*960|0)+712>>2]^H)&$;fa=(c[1184+(b*960|0)+716>>2]^ca)&$;c[g>>2]=(c[1184+(b*960|0)+680>>2]^y)&$^y;c[F>>2]=A^ia;c[D>>2]=ga^da;c[B>>2]=aa^j;c[z>>2]=C^Z;c[x>>2]=E^ha;c[v>>2]=ea^ba;c[i>>2]=_^w;c[t>>2]=G^H;c[u>>2]=fa^ca;ca=c[a>>2]|0;fa=c[d>>2]|0;H=c[k>>2]|0;G=c[l>>2]|0;w=c[m>>2]|0;_=c[n>>2]|0;ba=c[o>>2]|0;ea=c[p>>2]|0;ha=c[q>>2]|0;E=c[r>>2]|0;Z=(h^7)+-1>>31;C=(c[1184+(b*960|0)+724>>2]^fa)&Z;j=(c[1184+(b*960|0)+728>>2]^H)&Z;aa=(c[1184+(b*960|0)+732>>2]^G)&Z;da=(c[1184+(b*960|0)+736>>2]^w)&Z;ga=(c[1184+(b*960|0)+740>>2]^_)&Z;ia=(c[1184+(b*960|0)+744>>2]^ba)&Z;A=(c[1184+(b*960|0)+748>>2]^ea)&Z;y=(c[1184+(b*960|0)+752>>2]^ha)&Z;$=(c[1184+(b*960|0)+756>>2]^E)&Z;c[a>>2]=(c[1184+(b*960|0)+720>>2]^ca)&Z^ca;c[d>>2]=C^fa;c[k>>2]=j^H;c[l>>2]=aa^G;c[m>>2]=da^w;c[n>>2]=ga^_;c[o>>2]=ia^ba;c[p>>2]=A^ea;c[q>>2]=y^ha;c[r>>2]=$^E;E=c[e>>2]|0;$=c[f>>2]|0;ha=c[W>>2]|0;y=c[U>>2]|0;ea=c[S>>2]|0;A=c[Q>>2]|0;ba=c[O>>2]|0;ia=c[M>>2]|0;_=c[K>>2]|0;ga=c[I>>2]|0;w=(c[1184+(b*960|0)+764>>2]^$)&Z;da=(c[1184+(b*960|0)+768>>2]^ha)&Z;G=(c[1184+(b*960|0)+772>>2]^y)&Z;aa=(c[1184+(b*960|0)+776>>2]^ea)&Z;H=(c[1184+(b*960|0)+780>>2]^A)&Z;j=(c[1184+(b*960|0)+784>>2]^ba)&Z;fa=(c[1184+(b*960|0)+788>>2]^ia)&Z;C=(c[1184+(b*960|0)+792>>2]^_)&Z;ca=(c[1184+(b*960|0)+796>>2]^ga)&Z;c[e>>2]=(c[1184+(b*960|0)+760>>2]^E)&Z^E;c[f>>2]=w^$;c[W>>2]=da^ha;c[U>>2]=G^y;c[S>>2]=aa^ea;c[Q>>2]=H^A;c[O>>2]=j^ba;c[M>>2]=fa^ia;c[K>>2]=C^_;c[I>>2]=ca^ga;ga=c[g>>2]|0;ca=c[F>>2]|0;_=c[D>>2]|0;C=c[B>>2]|0;ia=c[z>>2]|0;fa=c[x>>2]|0;ba=c[v>>2]|0;j=c[i>>2]|0;A=c[t>>2]|0;H=c[u>>2]|0;ea=(c[1184+(b*960|0)+804>>2]^ca)&Z;aa=(c[1184+(b*960|0)+808>>2]^_)&Z;y=(c[1184+(b*960|0)+812>>2]^C)&Z;G=(c[1184+(b*960|0)+816>>2]^ia)&Z;ha=(c[1184+(b*960|0)+820>>2]^fa)&Z;da=(c[1184+(b*960|0)+824>>2]^ba)&Z;$=(c[1184+(b*960|0)+828>>2]^j)&Z;w=(c[1184+(b*960|0)+832>>2]^A)&Z;E=(c[1184+(b*960|0)+836>>2]^H)&Z;c[g>>2]=(c[1184+(b*960|0)+800>>2]^ga)&Z^ga;c[F>>2]=ea^ca;c[D>>2]=aa^_;c[B>>2]=y^C;c[z>>2]=G^ia;c[x>>2]=ha^fa;c[v>>2]=da^ba;c[i>>2]=$^j;c[t>>2]=w^A;c[u>>2]=E^H;H=c[a>>2]|0;E=c[d>>2]|0;A=c[k>>2]|0;w=c[l>>2]|0;j=c[m>>2]|0;$=c[n>>2]|0;ba=c[o>>2]|0;da=c[p>>2]|0;fa=c[q>>2]|0;ha=c[r>>2]|0;ia=(h^8)+-1>>31;G=(c[1184+(b*960|0)+844>>2]^E)&ia;C=(c[1184+(b*960|0)+848>>2]^A)&ia;y=(c[1184+(b*960|0)+852>>2]^w)&ia;h=(c[1184+(b*960|0)+856>>2]^j)&ia;_=(c[1184+(b*960|0)+860>>2]^$)&ia;aa=(c[1184+(b*960|0)+864>>2]^ba)&ia;ca=(c[1184+(b*960|0)+868>>2]^da)&ia;ea=(c[1184+(b*960|0)+872>>2]^fa)&ia;ga=(c[1184+(b*960|0)+876>>2]^ha)&ia;c[a>>2]=(c[1184+(b*960|0)+840>>2]^H)&ia^H;c[d>>2]=G^E;c[k>>2]=C^A;c[l>>2]=y^w;c[m>>2]=h^j;c[n>>2]=_^$;c[o>>2]=aa^ba;c[p>>2]=ca^da;c[q>>2]=ea^fa;c[r>>2]=ga^ha;ha=c[e>>2]|0;ga=c[f>>2]|0;fa=c[W>>2]|0;ea=c[U>>2]|0;da=c[S>>2]|0;ca=c[Q>>2]|0;ba=c[O>>2]|0;aa=c[M>>2]|0;$=c[K>>2]|0;_=c[I>>2]|0;j=(c[1184+(b*960|0)+884>>2]^ga)&ia;h=(c[1184+(b*960|0)+888>>2]^fa)&ia;w=(c[1184+(b*960|0)+892>>2]^ea)&ia;y=(c[1184+(b*960|0)+896>>2]^da)&ia;A=(c[1184+(b*960|0)+900>>2]^ca)&ia;C=(c[1184+(b*960|0)+904>>2]^ba)&ia;E=(c[1184+(b*960|0)+908>>2]^aa)&ia;G=(c[1184+(b*960|0)+912>>2]^$)&ia;H=(c[1184+(b*960|0)+916>>2]^_)&ia;ha=(c[1184+(b*960|0)+880>>2]^ha)&ia^ha;c[e>>2]=ha;ga=j^ga;c[f>>2]=ga;fa=h^fa;c[W>>2]=fa;ea=w^ea;c[U>>2]=ea;da=y^da;c[S>>2]=da;ca=A^ca;c[Q>>2]=ca;ba=C^ba;c[O>>2]=ba;aa=E^aa;c[M>>2]=aa;$=G^$;c[K>>2]=$;_=H^_;c[I>>2]=_;H=c[g>>2]|0;G=c[F>>2]|0;E=c[D>>2]|0;C=c[B>>2]|0;A=c[z>>2]|0;y=c[x>>2]|0;w=c[v>>2]|0;h=c[i>>2]|0;j=c[t>>2]|0;Z=c[u>>2]|0;J=(c[1184+(b*960|0)+924>>2]^G)&ia;L=(c[1184+(b*960|0)+928>>2]^E)&ia;N=(c[1184+(b*960|0)+932>>2]^C)&ia;P=(c[1184+(b*960|0)+936>>2]^A)&ia;R=(c[1184+(b*960|0)+940>>2]^y)&ia;T=(c[1184+(b*960|0)+944>>2]^w)&ia;V=(c[1184+(b*960|0)+948>>2]^h)&ia;X=(c[1184+(b*960|0)+952>>2]^j)&ia;Y=(c[1184+(b*960|0)+956>>2]^Z)&ia;H=(c[1184+(b*960|0)+920>>2]^H)&ia^H;c[g>>2]=H;G=J^G;c[F>>2]=G;E=L^E;c[D>>2]=E;C=N^C;c[B>>2]=C;A=P^A;c[z>>2]=A;y=R^y;c[x>>2]=y;w=T^w;c[v>>2]=w;h=V^h;c[i>>2]=h;j=X^j;c[t>>2]=j;b=Y^Z;c[u>>2]=b;Z=c[a>>2]|0;Y=c[d>>2]|0;X=c[k>>2]|0;V=c[l>>2]|0;T=c[m>>2]|0;R=c[n>>2]|0;P=c[o>>2]|0;N=c[p>>2]|0;L=c[q>>2]|0;J=c[r>>2]|0;c[a>>2]=(ha^Z)&s^Z;c[d>>2]=(ga^Y)&s^Y;c[k>>2]=(fa^X)&s^X;c[l>>2]=(ea^V)&s^V;c[m>>2]=(da^T)&s^T;c[n>>2]=(ca^R)&s^R;c[o>>2]=(ba^P)&s^P;c[p>>2]=(aa^N)&s^N;c[q>>2]=($^L)&s^L;c[r>>2]=(_^J)&s^J;d=c[e>>2]|0;a=c[f>>2]|0;r=c[W>>2]|0;q=c[U>>2]|0;p=c[S>>2]|0;o=c[Q>>2]|0;n=c[O>>2]|0;m=c[M>>2]|0;l=c[K>>2]|0;k=c[I>>2]|0;c[e>>2]=(Z^d)&s^d;c[f>>2]=(Y^a)&s^a;c[W>>2]=(X^r)&s^r;c[U>>2]=(V^q)&s^q;c[S>>2]=(T^p)&s^p;c[Q>>2]=(R^o)&s^o;c[O>>2]=(P^n)&s^n;c[M>>2]=(N^m)&s^m;c[K>>2]=(L^l)&s^l;c[I>>2]=(J^k)&s^k;f=c[g>>2]|0;k=c[F>>2]|0;l=c[D>>2]|0;m=c[B>>2]|0;n=c[z>>2]|0;o=c[x>>2]|0;p=c[v>>2]|0;q=c[i>>2]|0;r=c[t>>2]|0;a=c[u>>2]|0;c[g>>2]=(f^0-H)&s^f;c[F>>2]=(k^0-G)&s^k;c[D>>2]=(l^0-E)&s^l;c[B>>2]=(m^0-C)&s^m;c[z>>2]=(n^0-A)&s^n;c[x>>2]=(o^0-y)&s^o;c[v>>2]=(p^0-w)&s^p;c[i>>2]=(q^0-h)&s^q;c[t>>2]=(r^0-j)&s^r;c[u>>2]=(a^0-b)&s^a;return}function Tc(a,b){a=a|0;b=b|0;var d=0,e=0,f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0;g=i;e=i=i+63&-64;i=i+240|0;d=e+80|0;f=e+40|0;if(Nc(d,b)|0){f=-1;i=g;return f|0}y=e+4|0;c[y>>2]=0;c[y+4>>2]=0;c[y+8>>2]=0;c[y+12>>2]=0;c[y+16>>2]=0;c[y+20>>2]=0;c[y+24>>2]=0;c[y+28>>2]=0;q=d+40|0;p=d+44|0;n=d+48|0;m=d+52|0;l=d+56|0;k=d+60|0;j=d+64|0;h=d+68|0;r=d+72|0;b=d+76|0;z=0-(c[p>>2]|0)|0;x=0-(c[n>>2]|0)|0;w=0-(c[m>>2]|0)|0;v=0-(c[l>>2]|0)|0;u=0-(c[k>>2]|0)|0;t=0-(c[j>>2]|0)|0;s=0-(c[h>>2]|0)|0;d=0-(c[r>>2]|0)|0;o=0-(c[b>>2]|0)|0;c[e>>2]=1-(c[q>>2]|0);c[y>>2]=z;c[e+8>>2]=x;c[e+12>>2]=w;c[e+16>>2]=v;c[e+20>>2]=u;c[e+24>>2]=t;c[e+28>>2]=s;c[e+32>>2]=d;c[e+36>>2]=o;Ic(e,e);o=f+4|0;c[o>>2]=0;c[o+4>>2]=0;c[o+8>>2]=0;c[o+12>>2]=0;c[o+16>>2]=0;c[o+20>>2]=0;c[o+24>>2]=0;c[o+28>>2]=0;p=c[p>>2]|0;n=c[n>>2]|0;m=c[m>>2]|0;l=c[l>>2]|0;k=c[k>>2]|0;j=c[j>>2]|0;h=c[h>>2]|0;d=c[r>>2]|0;b=c[b>>2]|0;c[f>>2]=(c[q>>2]|0)+1;c[o>>2]=p;c[f+8>>2]=n;c[f+12>>2]=m;c[f+16>>2]=l;c[f+20>>2]=k;c[f+24>>2]=j;c[f+28>>2]=h;c[f+32>>2]=d;c[f+36>>2]=b;Jc(f,f,e);Lc(a,f);f=0;i=g;return f|0}function Uc(b,e){b=b|0;e=e|0;var f=0,g=0,h=0,j=0,k=0,l=0,m=0;k=i;g=i=i+63&-64;i=i+272|0;h=g;g=g+208|0;f=h+64|0;j=h;l=8;m=j+64|0;do{c[j>>2]=c[l>>2];j=j+4|0;l=l+4|0}while((j|0)<(m|0));j=h+72|0;c[j>>2]=256;c[j+4>>2]=0;j=f;c[j>>2]=0;c[j+4>>2]=0;j=h+80|0;l=e;m=j+32|0;do{a[j>>0]=a[l>>0]|0;j=j+1|0;l=l+1|0}while((j|0)<(m|0));Gb(h,g);a[g>>0]=(d[g>>0]|0)&248;j=g+31|0;a[j>>0]=(d[j>>0]|0)&63|64;j=b;l=g;m=j+32|0;do{a[j>>0]=a[l>>0]|0;j=j+1|0;l=l+1|0}while((j|0)<(m|0));i=k;return 0}function Vc(b,e,f,g,h){b=b|0;e=e|0;f=f|0;g=g|0;h=h|0;var j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0,xa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha=0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa=0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0,db=0,eb=0,fb=0,gb=0,hb=0,ib=0,jb=0,kb=0,lb=0,mb=0,nb=0,ob=0,pb=0,qb=0,rb=0;Qa=i;j=i=i+63&-64;i=i+3024|0;Ma=j+2800|0;Na=j+2544|0;Oa=j+2288|0;k=j+2248|0;Ja=j+968|0;Ka=j+808|0;La=j+648|0;t=j+488|0;n=j;p=j+2952|0;Pa=j+2920|0;s=j+328|0;j=j+208|0;if((d[b+63>>0]|0)>31){b=-1;i=Qa;return b|0}if(Nc(s,h)|0){b=-1;i=Qa;return b|0}if(!((a[h+31>>0]|(a[h+30>>0]|(a[h+29>>0]|(a[h+28>>0]|(a[h+27>>0]|(a[h+26>>0]|(a[h+25>>0]|(a[h+24>>0]|(a[h+23>>0]|(a[h+22>>0]|(a[h+21>>0]|(a[h+20>>0]|(a[h+19>>0]|(a[h+18>>0]|(a[h+17>>0]|(a[h+16>>0]|(a[h+15>>0]|(a[h+14>>0]|(a[h+13>>0]|(a[h+12>>0]|(a[h+11>>0]|(a[h+10>>0]|(a[h+9>>0]|(a[h+8>>0]|(a[h+7>>0]|(a[h+6>>0]|(a[h+5>>0]|(a[h+4>>0]|(a[h+3>>0]|(a[h+2>>0]|(a[h+1>>0]|a[h>>0])))))))))))))))))))))))))))))))<<24>>24)){b=-1;i=Qa;return b|0}l=n+64|0;q=l;c[q>>2]=0;c[q+4>>2]=0;q=n;o=8;r=q+64|0;do{c[q>>2]=c[o>>2];q=q+4|0;o=o+4|0}while((q|0)<(r|0));m=n+72|0;q=m;c[q>>2]=256;c[q+4>>2]=0;q=l;c[q>>2]=0;c[q+4>>2]=0;q=n+80|0;o=b;r=q+32|0;do{a[q>>0]=a[o>>0]|0;q=q+1|0;o=o+1|0}while((q|0)<(r|0));q=m;c[q>>2]=512;c[q+4>>2]=0;q=l;c[q>>2]=0;c[q+4>>2]=0;q=n+112|0;o=h;r=q+32|0;do{a[q>>0]=a[o>>0]|0;q=q+1|0;o=o+1|0}while((q|0)<(r|0));Fb(n,e,f,g);Gb(n,p);Wc(p);f=0;do{a[Na+f>>0]=(d[p+(f>>3)>>0]|0)>>>(f&7)&1;f=f+1|0}while((f|0)!=256);p=b+32|0;o=0;while(1){e=Na+o|0;a:do if(a[e>>0]|0){h=1;do{g=h+o|0;if((g|0)>=256)break a;m=Na+g|0;f=a[m>>0]|0;b:do if(f<<24>>24){n=a[e>>0]|0;f=f<<24>>24<>0]=l;a[m>>0]=0;break}f=n-f|0;if((f|0)<=-16)break a;a[e>>0]=f;while(1){f=Na+g|0;if(!(a[f>>0]|0))break;a[f>>0]=0;g=g+1|0;if((g|0)>=256)break b}a[f>>0]=1}while(0);h=h+1|0}while((h|0)<7)}while(0);o=o+1|0;if((o|0)==256){f=0;break}}do{a[Oa+f>>0]=(d[p+(f>>3)>>0]|0)>>>(f&7)&1;f=f+1|0}while((f|0)!=256);o=0;do{e=Oa+o|0;c:do if(a[e>>0]|0){h=1;do{g=h+o|0;if((g|0)>=256)break c;m=Oa+g|0;f=a[m>>0]|0;d:do if(f<<24>>24){n=a[e>>0]|0;f=f<<24>>24<>0]=l;a[m>>0]=0;break}f=n-f|0;if((f|0)<=-16)break c;a[e>>0]=f;while(1){f=Oa+g|0;if(!(a[f>>0]|0))break;a[f>>0]=0;g=g+1|0;if((g|0)>=256)break d}a[f>>0]=1}while(0);h=h+1|0}while((h|0)<7)}while(0);o=o+1|0}while((o|0)!=256);Qc(Ja,s);Ia=c[s+4>>2]|0;r=c[s+8>>2]|0;q=c[s+12>>2]|0;Ga=c[s+16>>2]|0;Fa=c[s+20>>2]|0;Ea=c[s+24>>2]|0;Da=c[s+28>>2]|0;Ca=c[s+32>>2]|0;Ba=c[s+36>>2]|0;c[Ma>>2]=c[s>>2];c[Ma+4>>2]=Ia;c[Ma+8>>2]=r;c[Ma+12>>2]=q;c[Ma+16>>2]=Ga;c[Ma+20>>2]=Fa;c[Ma+24>>2]=Ea;c[Ma+28>>2]=Da;c[Ma+32>>2]=Ca;c[Ma+36>>2]=Ba;Ba=c[s+44>>2]|0;Ca=c[s+48>>2]|0;Da=c[s+52>>2]|0;Ea=c[s+56>>2]|0;Fa=c[s+60>>2]|0;Ga=c[s+64>>2]|0;q=c[s+68>>2]|0;r=c[s+72>>2]|0;Ia=c[s+76>>2]|0;c[Ma+40>>2]=c[s+40>>2];c[Ma+44>>2]=Ba;c[Ma+48>>2]=Ca;c[Ma+52>>2]=Da;c[Ma+56>>2]=Ea;c[Ma+60>>2]=Fa;c[Ma+64>>2]=Ga;c[Ma+68>>2]=q;c[Ma+72>>2]=r;c[Ma+76>>2]=Ia;Ia=c[s+84>>2]|0;r=c[s+88>>2]|0;q=c[s+92>>2]|0;Ga=c[s+96>>2]|0;Fa=c[s+100>>2]|0;Ea=c[s+104>>2]|0;Da=c[s+108>>2]|0;Ca=c[s+112>>2]|0;Ba=c[s+116>>2]|0;c[Ma+80>>2]=c[s+80>>2];c[Ma+84>>2]=Ia;c[Ma+88>>2]=r;c[Ma+92>>2]=q;c[Ma+96>>2]=Ga;c[Ma+100>>2]=Fa;c[Ma+104>>2]=Ea;c[Ma+108>>2]=Da;c[Ma+112>>2]=Ca;c[Ma+116>>2]=Ba;Pc(Ka,Ma);Ba=Ka+120|0;Jc(t,Ka,Ba);Ca=Ka+40|0;Da=Ka+80|0;Jc(t+40|0,Ca,Da);Jc(t+80|0,Da,Ba);Jc(t+120|0,Ka,Ca);Mc(Ka,t,Ja);Jc(La,Ka,Ba);Ea=La+40|0;Jc(Ea,Ca,Da);Fa=La+80|0;Jc(Fa,Da,Ba);Ga=La+120|0;Jc(Ga,Ka,Ca);q=Ja+160|0;Qc(q,La);Mc(Ka,t,q);Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);q=Ja+320|0;Qc(q,La);Mc(Ka,t,q);Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);q=Ja+480|0;Qc(q,La);Mc(Ka,t,q);Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);q=Ja+640|0;Qc(q,La);Mc(Ka,t,q);Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);q=Ja+800|0;Qc(q,La);Mc(Ka,t,q);Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);q=Ja+960|0;Qc(q,La);Mc(Ka,t,q);Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);Qc(Ja+1120|0,La);q=j;r=q+40|0;do{c[q>>2]=0;q=q+4|0}while((q|0)<(r|0));Ha=j+40|0;c[Ha>>2]=1;q=j+44|0;r=q+36|0;do{c[q>>2]=0;q=q+4|0}while((q|0)<(r|0));Ia=j+80|0;c[Ia>>2]=1;q=j+84|0;r=q+36|0;do{c[q>>2]=0;q=q+4|0}while((q|0)<(r|0));g=255;while(1){if(a[Na+g>>0]|0){f=g;break}if(a[Oa+g>>0]|0){f=g;break}f=g+-1|0;if((g|0)>0)g=f;else break}if((f|0)>-1){l=La+44|0;m=La+48|0;n=La+52|0;e=La+56|0;h=La+60|0;o=La+64|0;p=La+68|0;q=La+72|0;r=La+76|0;s=La+4|0;t=La+8|0;u=La+12|0;v=La+16|0;w=La+20|0;x=La+24|0;y=La+28|0;z=La+32|0;A=La+36|0;B=Ka+4|0;C=Ka+8|0;D=Ka+12|0;E=Ka+16|0;F=Ka+20|0;G=Ka+24|0;H=Ka+28|0;I=Ka+32|0;J=Ka+36|0;K=Ka+44|0;L=Ka+48|0;M=Ka+52|0;N=Ka+56|0;O=Ka+60|0;P=Ka+64|0;Q=Ka+68|0;R=Ka+72|0;S=Ka+76|0;T=La+84|0;U=La+88|0;V=La+92|0;W=La+96|0;X=La+100|0;Y=La+104|0;Z=La+108|0;_=La+112|0;$=La+116|0;aa=k+4|0;ba=k+8|0;ca=k+12|0;da=k+16|0;ea=k+20|0;fa=k+24|0;ga=k+28|0;ha=k+32|0;ia=k+36|0;ja=Ka+84|0;ka=Ka+88|0;la=Ka+92|0;ma=Ka+96|0;na=Ka+100|0;oa=Ka+104|0;pa=Ka+108|0;qa=Ka+112|0;ra=Ka+116|0;sa=Ka+124|0;ta=Ka+128|0;ua=Ka+132|0;va=Ka+136|0;wa=Ka+140|0;xa=Ka+144|0;ya=Ka+148|0;za=Ka+152|0;Aa=Ka+156|0;while(1){Pc(Ka,j);g=a[Na+f>>0]|0;if(g<<24>>24<=0){if(g<<24>>24<0){Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);hb=(g<<24>>24|0)/-2|0;rb=c[Ea>>2]|0;Xa=c[l>>2]|0;Ta=c[m>>2]|0;ib=c[n>>2]|0;mb=c[e>>2]|0;qb=c[h>>2]|0;$a=c[o>>2]|0;bb=c[p>>2]|0;db=c[q>>2]|0;fb=c[r>>2]|0;Za=c[La>>2]|0;Va=c[s>>2]|0;Ra=c[t>>2]|0;kb=c[u>>2]|0;ob=c[v>>2]|0;_a=c[w>>2]|0;ab=c[x>>2]|0;cb=c[y>>2]|0;eb=c[z>>2]|0;gb=c[A>>2]|0;c[Ka>>2]=Za+rb;c[B>>2]=Va+Xa;c[C>>2]=Ra+Ta;c[D>>2]=kb+ib;c[E>>2]=ob+mb;c[F>>2]=_a+qb;c[G>>2]=ab+$a;c[H>>2]=cb+bb;c[I>>2]=eb+db;c[J>>2]=gb+fb;c[Ca>>2]=rb-Za;c[K>>2]=Xa-Va;c[L>>2]=Ta-Ra;c[M>>2]=ib-kb;c[N>>2]=mb-ob;c[O>>2]=qb-_a;c[P>>2]=$a-ab;c[Q>>2]=bb-cb;c[R>>2]=db-eb;c[S>>2]=fb-gb;Jc(Da,Ka,Ja+(hb*160|0)+40|0);Jc(Ca,Ca,Ja+(hb*160|0)|0);Jc(Ba,Ja+(hb*160|0)+120|0,Ga);Jc(Ka,Fa,Ja+(hb*160|0)+80|0);hb=c[Ka>>2]<<1;gb=c[B>>2]<<1;fb=c[C>>2]<<1;eb=c[D>>2]<<1;db=c[E>>2]<<1;cb=c[F>>2]<<1;bb=c[G>>2]<<1;ab=c[H>>2]<<1;$a=c[I>>2]<<1;_a=c[J>>2]<<1;c[k>>2]=hb;c[aa>>2]=gb;c[ba>>2]=fb;c[ca>>2]=eb;c[da>>2]=db;c[ea>>2]=cb;c[fa>>2]=bb;c[ga>>2]=ab;c[ha>>2]=$a;c[ia>>2]=_a;qb=c[Da>>2]|0;ob=c[ja>>2]|0;mb=c[ka>>2]|0;kb=c[la>>2]|0;ib=c[ma>>2]|0;Ra=c[na>>2]|0;Ta=c[oa>>2]|0;Va=c[pa>>2]|0;Xa=c[qa>>2]|0;Za=c[ra>>2]|0;rb=c[Ca>>2]|0;pb=c[K>>2]|0;nb=c[L>>2]|0;lb=c[M>>2]|0;jb=c[N>>2]|0;g=c[O>>2]|0;Sa=c[P>>2]|0;Ua=c[Q>>2]|0;Wa=c[R>>2]|0;Ya=c[S>>2]|0;c[Ka>>2]=qb-rb;c[B>>2]=ob-pb;c[C>>2]=mb-nb;c[D>>2]=kb-lb;c[E>>2]=ib-jb;c[F>>2]=Ra-g;c[G>>2]=Ta-Sa;c[H>>2]=Va-Ua;c[I>>2]=Xa-Wa;c[J>>2]=Za-Ya;c[Ca>>2]=rb+qb;c[K>>2]=pb+ob;c[L>>2]=nb+mb;c[M>>2]=lb+kb;c[N>>2]=jb+ib;c[O>>2]=g+Ra;c[P>>2]=Sa+Ta;c[Q>>2]=Ua+Va;c[R>>2]=Wa+Xa;c[S>>2]=Ya+Za;Za=c[Ba>>2]|0;Ya=c[sa>>2]|0;Xa=c[ta>>2]|0;Wa=c[ua>>2]|0;Va=c[va>>2]|0;Ua=c[wa>>2]|0;Ta=c[xa>>2]|0;Sa=c[ya>>2]|0;Ra=c[za>>2]|0;g=c[Aa>>2]|0;c[Da>>2]=hb-Za;c[ja>>2]=gb-Ya;c[ka>>2]=fb-Xa;c[la>>2]=eb-Wa;c[ma>>2]=db-Va;c[na>>2]=cb-Ua;c[oa>>2]=bb-Ta;c[pa>>2]=ab-Sa;c[qa>>2]=$a-Ra;c[ra>>2]=_a-g;Ya=Ya+(c[aa>>2]|0)|0;Xa=Xa+(c[ba>>2]|0)|0;Wa=Wa+(c[ca>>2]|0)|0;Va=Va+(c[da>>2]|0)|0;Ua=Ua+(c[ea>>2]|0)|0;Ta=Ta+(c[fa>>2]|0)|0;Sa=Sa+(c[ga>>2]|0)|0;Ra=Ra+(c[ha>>2]|0)|0;g=g+(c[ia>>2]|0)|0;c[Ba>>2]=Za+(c[k>>2]|0);c[sa>>2]=Ya;c[ta>>2]=Xa;c[ua>>2]=Wa;c[va>>2]=Va;c[wa>>2]=Ua;c[xa>>2]=Ta;c[ya>>2]=Sa;c[za>>2]=Ra;c[Aa>>2]=g}}else{Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);Mc(Ka,La,Ja+(((g<<24>>24|0)/2|0)*160|0)|0)}g=a[Oa+f>>0]|0;if(g<<24>>24<=0){if(g<<24>>24<0){Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);_a=(g<<24>>24|0)/-2|0;g=c[Ea>>2]|0;kb=c[l>>2]|0;ob=c[m>>2]|0;Za=c[n>>2]|0;Va=c[e>>2]|0;Ra=c[h>>2]|0;gb=c[o>>2]|0;eb=c[p>>2]|0;cb=c[q>>2]|0;ab=c[r>>2]|0;ib=c[La>>2]|0;mb=c[s>>2]|0;qb=c[t>>2]|0;Xa=c[u>>2]|0;Ta=c[v>>2]|0;hb=c[w>>2]|0;fb=c[x>>2]|0;db=c[y>>2]|0;bb=c[z>>2]|0;$a=c[A>>2]|0;c[Ka>>2]=ib+g;c[B>>2]=mb+kb;c[C>>2]=qb+ob;c[D>>2]=Xa+Za;c[E>>2]=Ta+Va;c[F>>2]=hb+Ra;c[G>>2]=fb+gb;c[H>>2]=db+eb;c[I>>2]=bb+cb;c[J>>2]=$a+ab;c[Ca>>2]=g-ib;c[K>>2]=kb-mb;c[L>>2]=ob-qb;c[M>>2]=Za-Xa;c[N>>2]=Va-Ta;c[O>>2]=Ra-hb;c[P>>2]=gb-fb;c[Q>>2]=eb-db;c[R>>2]=cb-bb;c[S>>2]=ab-$a;Jc(Da,Ka,104+(_a*120|0)+40|0);Jc(Ca,Ca,104+(_a*120|0)|0);Jc(Ba,104+(_a*120|0)+80|0,Ga);_a=c[Fa>>2]<<1;$a=c[T>>2]<<1;ab=c[U>>2]<<1;bb=c[V>>2]<<1;cb=c[W>>2]<<1;db=c[X>>2]<<1;eb=c[Y>>2]<<1;fb=c[Z>>2]<<1;gb=c[_>>2]<<1;hb=c[$>>2]<<1;c[k>>2]=_a;c[aa>>2]=$a;c[ba>>2]=ab;c[ca>>2]=bb;c[da>>2]=cb;c[ea>>2]=db;c[fa>>2]=eb;c[ga>>2]=fb;c[ha>>2]=gb;c[ia>>2]=hb;Ra=c[Da>>2]|0;Ta=c[ja>>2]|0;Va=c[ka>>2]|0;Xa=c[la>>2]|0;Za=c[ma>>2]|0;qb=c[na>>2]|0;ob=c[oa>>2]|0;mb=c[pa>>2]|0;kb=c[qa>>2]|0;ib=c[ra>>2]|0;g=c[Ca>>2]|0;Sa=c[K>>2]|0;Ua=c[L>>2]|0;Wa=c[M>>2]|0;Ya=c[N>>2]|0;rb=c[O>>2]|0;pb=c[P>>2]|0;nb=c[Q>>2]|0;lb=c[R>>2]|0;jb=c[S>>2]|0;c[Ka>>2]=Ra-g;c[B>>2]=Ta-Sa;c[C>>2]=Va-Ua;c[D>>2]=Xa-Wa;c[E>>2]=Za-Ya;c[F>>2]=qb-rb;c[G>>2]=ob-pb;c[H>>2]=mb-nb;c[I>>2]=kb-lb;c[J>>2]=ib-jb;c[Ca>>2]=g+Ra;c[K>>2]=Sa+Ta;c[L>>2]=Ua+Va;c[M>>2]=Wa+Xa;c[N>>2]=Ya+Za;c[O>>2]=rb+qb;c[P>>2]=pb+ob;c[Q>>2]=nb+mb;c[R>>2]=lb+kb;c[S>>2]=jb+ib;ib=c[Ba>>2]|0;jb=c[sa>>2]|0;kb=c[ta>>2]|0;lb=c[ua>>2]|0;mb=c[va>>2]|0;nb=c[wa>>2]|0;ob=c[xa>>2]|0;pb=c[ya>>2]|0;qb=c[za>>2]|0;rb=c[Aa>>2]|0;c[Da>>2]=_a-ib;c[ja>>2]=$a-jb;c[ka>>2]=ab-kb;c[la>>2]=bb-lb;c[ma>>2]=cb-mb;c[na>>2]=db-nb;c[oa>>2]=eb-ob;c[pa>>2]=fb-pb;c[qa>>2]=gb-qb;c[ra>>2]=hb-rb;jb=jb+(c[aa>>2]|0)|0;kb=kb+(c[ba>>2]|0)|0;lb=lb+(c[ca>>2]|0)|0;mb=mb+(c[da>>2]|0)|0;nb=nb+(c[ea>>2]|0)|0;ob=ob+(c[fa>>2]|0)|0;pb=pb+(c[ga>>2]|0)|0;qb=qb+(c[ha>>2]|0)|0;rb=rb+(c[ia>>2]|0)|0;c[Ba>>2]=ib+(c[k>>2]|0);c[sa>>2]=jb;c[ta>>2]=kb;c[ua>>2]=lb;c[va>>2]=mb;c[wa>>2]=nb;c[xa>>2]=ob;c[ya>>2]=pb;c[za>>2]=qb;c[Aa>>2]=rb}}else{Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);Oc(Ka,La,104+(((g<<24>>24|0)/2|0)*120|0)|0)}Jc(j,Ka,Ba);Jc(Ha,Ca,Da);Jc(Ia,Da,Ba);if((f|0)>0)f=f+-1|0;else break}}Ic(k,Ia);Jc(Na,j,k);Jc(Oa,Ha,k);Lc(Pa,Oa);Lc(Ma,Na);j=Pa+31|0;a[j>>0]=d[j>>0]^d[Ma>>0]<<7;j=Yc(Pa,b)|0;k=(Pa|0)==(b|0);f=0;g=0;do{f=a[Pa+g>>0]^a[b+g>>0]|f;g=g+1|0}while((g|0)!=32);rb=(k?-1:j)|(((f&255)+511|0)>>>8&1)+-1;i=Qa;return rb|0}function Wc(b){b=b|0;var c=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0,xa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha=0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa=0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0,db=0,eb=0,fb=0,gb=0;ea=b+1|0;ba=b+2|0;D=a[ba>>0]|0;f=d[b>>0]|0;n=Hd(d[ea>>0]|0|0,0,8)|0;va=C;D=D&255;V=Hd(D|0,0,16)|0;aa=b+3|0;y=Hd(d[aa>>0]|0|0,0,8)|0;ga=C;$=b+4|0;U=Hd(d[$>>0]|0|0,0,16)|0;ga=ga|C;Y=b+5|0;N=d[Y>>0]|0;X=Hd(N|0,0,24)|0;ga=Gd(y|D|U|X|0,ga|C|0,5)|0;X=b+6|0;U=b+7|0;D=a[U>>0]|0;y=Hd(d[X>>0]|0|0,0,8)|0;Ba=C;D=D&255;T=Hd(D|0,0,16)|0;Ba=Gd(y|N|T|0,Ba|C|0,2)|0;T=b+8|0;N=Hd(d[T>>0]|0|0,0,8)|0;y=C;S=b+9|0;Ca=Hd(d[S>>0]|0|0,0,16)|0;y=y|C;P=b+10|0;Sa=d[P>>0]|0;O=Hd(Sa|0,0,24)|0;y=Gd(N|D|Ca|O|0,y|C|0,7)|0;O=b+11|0;Ca=Hd(d[O>>0]|0|0,0,8)|0;D=C;N=b+12|0;G=Hd(d[N>>0]|0|0,0,16)|0;D=D|C;K=b+13|0;u=d[K>>0]|0;J=Hd(u|0,0,24)|0;D=Gd(Ca|Sa|G|J|0,D|C|0,4)|0;J=b+14|0;G=b+15|0;Sa=a[G>>0]|0;Ca=Hd(d[J>>0]|0|0,0,8)|0;Da=C;Sa=Sa&255;F=Hd(Sa|0,0,16)|0;Da=Gd(Ca|u|F|0,Da|C|0,1)|0;F=b+16|0;u=Hd(d[F>>0]|0|0,0,8)|0;Ca=C;E=b+17|0;w=Hd(d[E>>0]|0|0,0,16)|0;Ca=Ca|C;A=b+18|0;v=d[A>>0]|0;z=Hd(v|0,0,24)|0;Ca=Gd(u|Sa|w|z|0,Ca|C|0,6)|0;z=b+19|0;w=b+20|0;Sa=a[w>>0]|0;u=Hd(d[z>>0]|0|0,0,8)|0;Ta=C;Sa=Hd(Sa&255|0,0,16)|0;Ta=Gd(u|v|Sa|0,Ta|C|0,3)|0;Sa=C;v=b+21|0;u=b+22|0;r=b+23|0;na=a[r>>0]|0;ab=d[v>>0]|0;bb=Hd(d[u>>0]|0|0,0,8)|0;_a=C;na=na&255;$a=Hd(na|0,0,16)|0;q=b+24|0;Ka=Hd(d[q>>0]|0|0,0,8)|0;Pa=C;p=b+25|0;i=Hd(d[p>>0]|0|0,0,16)|0;Pa=Pa|C;m=b+26|0;xa=d[m>>0]|0;l=Hd(xa|0,0,24)|0;Pa=Gd(Ka|na|i|l|0,Pa|C|0,5)|0;l=b+27|0;i=b+28|0;na=a[i>>0]|0;Ka=Hd(d[l>>0]|0|0,0,8)|0;Za=C;na=na&255;h=Hd(na|0,0,16)|0;Za=Gd(Ka|xa|h|0,Za|C|0,2)|0;h=b+29|0;xa=Hd(d[h>>0]|0|0,0,8)|0;Ka=C;g=b+30|0;fb=Hd(d[g>>0]|0|0,0,16)|0;Ka=Ka|C;c=b+31|0;qa=d[c>>0]|0;oa=Hd(qa|0,0,24)|0;Ka=Gd(xa|na|fb|oa|0,Ka|C|0,7)|0;oa=Hd(d[b+32>>0]|0|0,0,8)|0;fb=C;na=Hd(d[b+33>>0]|0|0,0,16)|0;fb=fb|C;xa=d[b+34>>0]|0;la=Hd(xa|0,0,24)|0;fb=Gd(oa|qa|na|la|0,fb|C|0,4)|0;la=a[b+36>>0]|0;na=Hd(d[b+35>>0]|0|0,0,8)|0;qa=C;la=la&255;oa=Hd(la|0,0,16)|0;qa=Gd(na|xa|oa|0,qa|C|0,1)|0;oa=Hd(d[b+37>>0]|0|0,0,8)|0;xa=C;na=Hd(d[b+38>>0]|0|0,0,16)|0;xa=xa|C;Ma=d[b+39>>0]|0;fa=Hd(Ma|0,0,24)|0;xa=Gd(oa|la|na|fa|0,xa|C|0,6)|0;fa=a[b+41>>0]|0;na=Hd(d[b+40>>0]|0|0,0,8)|0;la=C;fa=Hd(fa&255|0,0,16)|0;la=Gd(na|Ma|fa|0,la|C|0,3)|0;fa=C;Ma=a[b+44>>0]|0;na=d[b+42>>0]|0;oa=Hd(d[b+43>>0]|0|0,0,8)|0;j=C;Ma=Ma&255;za=Hd(Ma|0,0,16)|0;ja=Hd(d[b+45>>0]|0|0,0,8)|0;L=C;W=Hd(d[b+46>>0]|0|0,0,16)|0;L=L|C;gb=d[b+47>>0]|0;o=Hd(gb|0,0,24)|0;L=Gd(ja|Ma|W|o|0,L|C|0,5)|0;o=a[b+49>>0]|0;W=Hd(d[b+48>>0]|0|0,0,8)|0;Ma=C;o=o&255;ja=Hd(o|0,0,16)|0;Ma=Gd(W|gb|ja|0,Ma|C|0,2)|0;Ma=Ma&2097151;ja=Hd(d[b+50>>0]|0|0,0,8)|0;gb=C;W=Hd(d[b+51>>0]|0|0,0,16)|0;gb=gb|C;Aa=d[b+52>>0]|0;M=Hd(Aa|0,0,24)|0;gb=Gd(ja|o|W|M|0,gb|C|0,7)|0;gb=gb&2097151;M=Hd(d[b+53>>0]|0|0,0,8)|0;W=C;o=Hd(d[b+54>>0]|0|0,0,16)|0;W=W|C;ja=d[b+55>>0]|0;R=Hd(ja|0,0,24)|0;W=Gd(M|Aa|o|R|0,W|C|0,4)|0;W=W&2097151;R=a[b+57>>0]|0;o=Hd(d[b+56>>0]|0|0,0,8)|0;Aa=C;R=R&255;M=Hd(R|0,0,16)|0;Aa=Gd(o|ja|M|0,Aa|C|0,1)|0;Aa=Aa&2097151;M=Hd(d[b+58>>0]|0|0,0,8)|0;ja=C;o=Hd(d[b+59>>0]|0|0,0,16)|0;ja=ja|C;ha=d[b+60>>0]|0;Q=Hd(ha|0,0,24)|0;ja=Gd(M|R|o|Q|0,ja|C|0,6)|0;ja=ja&2097151;Q=Hd(d[b+61>>0]|0|0,0,8)|0;o=C;R=Hd(d[b+62>>0]|0|0,0,16)|0;o=o|C;M=Hd(d[b+63>>0]|0|0,0,24)|0;o=Gd(Q|ha|R|M|0,o|C|0,3)|0;M=C;R=Od(o|0,M|0,666643,0)|0;ha=C;Q=Od(o|0,M|0,470296,0)|0;I=C;ca=Od(o|0,M|0,654183,0)|0;ta=C;Ea=Od(o|0,M|0,-997805,-1)|0;t=C;k=Od(o|0,M|0,136657,0)|0;B=C;M=Od(o|0,M|0,-683901,-1)|0;j=Dd(M|0,C|0,oa|na|za&2031616|0,j|0)|0;za=C;na=Od(ja|0,0,666643,0)|0;oa=C;M=Od(ja|0,0,470296,0)|0;o=C;Va=Od(ja|0,0,654183,0)|0;s=C;ma=Od(ja|0,0,-997805,-1)|0;_=C;ya=Od(ja|0,0,136657,0)|0;sa=C;ja=Od(ja|0,0,-683901,-1)|0;H=C;e=Od(Aa|0,0,666643,0)|0;ra=C;wa=Od(Aa|0,0,470296,0)|0;La=C;Fa=Od(Aa|0,0,654183,0)|0;da=C;cb=Od(Aa|0,0,-997805,-1)|0;Ua=C;ka=Od(Aa|0,0,136657,0)|0;x=C;Aa=Od(Aa|0,0,-683901,-1)|0;xa=Dd(Aa|0,C|0,xa&2097151|0,0)|0;sa=Dd(xa|0,C|0,ya|0,sa|0)|0;t=Dd(sa|0,C|0,Ea|0,t|0)|0;Ea=C;sa=Od(W|0,0,666643,0)|0;ya=C;xa=Od(W|0,0,470296,0)|0;Aa=C;Wa=Od(W|0,0,654183,0)|0;Z=C;Ha=Od(W|0,0,-997805,-1)|0;Ga=C;eb=Od(W|0,0,136657,0)|0;db=C;W=Od(W|0,0,-683901,-1)|0;pa=C;ia=Od(gb|0,0,666643,0)|0;ua=C;Qa=Od(gb|0,0,470296,0)|0;Ra=C;Oa=Od(gb|0,0,654183,0)|0;Na=C;Ya=Od(gb|0,0,-997805,-1)|0;Xa=C;Ja=Od(gb|0,0,136657,0)|0;Ia=C;gb=Od(gb|0,0,-683901,-1)|0;fb=Dd(gb|0,C|0,fb&2097151|0,0)|0;db=Dd(fb|0,C|0,eb|0,db|0)|0;Ua=Dd(db|0,C|0,cb|0,Ua|0)|0;s=Dd(Ua|0,C|0,Va|0,s|0)|0;I=Dd(s|0,C|0,Q|0,I|0)|0;Q=C;s=Od(Ma|0,0,666643,0)|0;Ca=Dd(s|0,C|0,Ca&2097151|0,0)|0;s=C;Va=Od(Ma|0,0,470296,0)|0;Ua=C;cb=Od(Ma|0,0,654183,0)|0;_a=Dd(cb|0,C|0,bb|ab|$a&2031616|0,_a|0)|0;Ra=Dd(_a|0,C|0,Qa|0,Ra|0)|0;ya=Dd(Ra|0,C|0,sa|0,ya|0)|0;sa=C;Ra=Od(Ma|0,0,-997805,-1)|0;Qa=C;_a=Od(Ma|0,0,136657,0)|0;Za=Dd(_a|0,C|0,Za&2097151|0,0)|0;Xa=Dd(Za|0,C|0,Ya|0,Xa|0)|0;Z=Dd(Xa|0,C|0,Wa|0,Z|0)|0;La=Dd(Z|0,C|0,wa|0,La|0)|0;oa=Dd(La|0,C|0,na|0,oa|0)|0;na=C;Ma=Od(Ma|0,0,-683901,-1)|0;La=C;wa=Dd(Ca|0,s|0,1048576,0)|0;wa=Gd(wa|0,C|0,21)|0;Z=C;Sa=Dd(Va|0,Ua|0,Ta|0,Sa|0)|0;Sa=Dd(Sa|0,C|0,wa|0,Z|0)|0;ua=Dd(Sa|0,C|0,ia|0,ua|0)|0;ia=C;Z=Hd(wa|0,Z|0,21)|0;Z=Cd(Ca|0,s|0,Z|0,C|0)|0;s=C;Ca=Dd(ya|0,sa|0,1048576,0)|0;Ca=Gd(Ca|0,C|0,21)|0;wa=C;Pa=Dd(Ra|0,Qa|0,Pa&2097151|0,0)|0;Na=Dd(Pa|0,C|0,Oa|0,Na|0)|0;Aa=Dd(Na|0,C|0,xa|0,Aa|0)|0;ra=Dd(Aa|0,C|0,e|0,ra|0)|0;ra=Dd(ra|0,C|0,Ca|0,wa|0)|0;e=C;wa=Hd(Ca|0,wa|0,21)|0;Ca=C;Aa=Dd(oa|0,na|0,1048576,0)|0;Aa=Ed(Aa|0,C|0,21)|0;xa=C;Ka=Dd(Ma|0,La|0,Ka&2097151|0,0)|0;Ia=Dd(Ka|0,C|0,Ja|0,Ia|0)|0;Ga=Dd(Ia|0,C|0,Ha|0,Ga|0)|0;da=Dd(Ga|0,C|0,Fa|0,da|0)|0;o=Dd(da|0,C|0,M|0,o|0)|0;ha=Dd(o|0,C|0,R|0,ha|0)|0;ha=Dd(ha|0,C|0,Aa|0,xa|0)|0;R=C;xa=Hd(Aa|0,xa|0,21)|0;Aa=C;o=Dd(I|0,Q|0,1048576,0)|0;o=Ed(o|0,C|0,21)|0;M=C;qa=Dd(W|0,pa|0,qa&2097151|0,0)|0;x=Dd(qa|0,C|0,ka|0,x|0)|0;_=Dd(x|0,C|0,ma|0,_|0)|0;ta=Dd(_|0,C|0,ca|0,ta|0)|0;ta=Dd(ta|0,C|0,o|0,M|0)|0;ca=C;M=Hd(o|0,M|0,21)|0;M=Cd(I|0,Q|0,M|0,C|0)|0;Q=C;I=Dd(t|0,Ea|0,1048576,0)|0;I=Ed(I|0,C|0,21)|0;o=C;fa=Dd(ja|0,H|0,la|0,fa|0)|0;B=Dd(fa|0,C|0,k|0,B|0)|0;B=Dd(B|0,C|0,I|0,o|0)|0;k=C;o=Hd(I|0,o|0,21)|0;o=Cd(t|0,Ea|0,o|0,C|0)|0;Ea=C;t=Dd(j|0,za|0,1048576,0)|0;t=Ed(t|0,C|0,21)|0;I=C;L=Dd(t|0,I|0,L&2097151|0,0)|0;fa=C;I=Hd(t|0,I|0,21)|0;I=Cd(j|0,za|0,I|0,C|0)|0;za=C;j=Dd(ua|0,ia|0,1048576,0)|0;j=Gd(j|0,C|0,21)|0;t=C;la=Hd(j|0,t|0,21)|0;la=Cd(ua|0,ia|0,la|0,C|0)|0;ia=C;ua=Dd(ra|0,e|0,1048576,0)|0;ua=Ed(ua|0,C|0,21)|0;H=C;ja=Hd(ua|0,H|0,21)|0;ja=Cd(ra|0,e|0,ja|0,C|0)|0;e=C;ra=Dd(ha|0,R|0,1048576,0)|0;ra=Ed(ra|0,C|0,21)|0;_=C;Q=Dd(M|0,Q|0,ra|0,_|0)|0;M=C;_=Hd(ra|0,_|0,21)|0;_=Cd(ha|0,R|0,_|0,C|0)|0;R=C;ha=Dd(ta|0,ca|0,1048576,0)|0;ha=Ed(ha|0,C|0,21)|0;ra=C;Ea=Dd(ha|0,ra|0,o|0,Ea|0)|0;o=C;ra=Hd(ha|0,ra|0,21)|0;ra=Cd(ta|0,ca|0,ra|0,C|0)|0;ca=C;ta=Dd(B|0,k|0,1048576,0)|0;ta=Ed(ta|0,C|0,21)|0;ha=C;za=Dd(ta|0,ha|0,I|0,za|0)|0;I=C;ha=Hd(ta|0,ha|0,21)|0;ha=Cd(B|0,k|0,ha|0,C|0)|0;k=C;B=Od(L|0,fa|0,666643,0)|0;Da=Dd(B|0,C|0,Da&2097151|0,0)|0;B=C;ta=Od(L|0,fa|0,470296,0)|0;ta=Dd(Z|0,s|0,ta|0,C|0)|0;s=C;Z=Od(L|0,fa|0,654183,0)|0;Z=Dd(la|0,ia|0,Z|0,C|0)|0;ia=C;la=Od(L|0,fa|0,-997805,-1)|0;ma=C;x=Od(L|0,fa|0,136657,0)|0;x=Dd(ja|0,e|0,x|0,C|0)|0;e=C;fa=Od(L|0,fa|0,-683901,-1)|0;L=C;H=Dd(oa|0,na|0,ua|0,H|0)|0;Aa=Cd(H|0,C|0,xa|0,Aa|0)|0;L=Dd(Aa|0,C|0,fa|0,L|0)|0;fa=C;Aa=Od(za|0,I|0,666643,0)|0;D=Dd(Aa|0,C|0,D&2097151|0,0)|0;Aa=C;xa=Od(za|0,I|0,470296,0)|0;xa=Dd(Da|0,B|0,xa|0,C|0)|0;B=C;Da=Od(za|0,I|0,654183,0)|0;Da=Dd(ta|0,s|0,Da|0,C|0)|0;s=C;ta=Od(za|0,I|0,-997805,-1)|0;ta=Dd(Z|0,ia|0,ta|0,C|0)|0;ia=C;Z=Od(za|0,I|0,136657,0)|0;H=C;I=Od(za|0,I|0,-683901,-1)|0;I=Dd(x|0,e|0,I|0,C|0)|0;e=C;x=Od(ha|0,k|0,666643,0)|0;y=Dd(x|0,C|0,y&2097151|0,0)|0;x=C;za=Od(ha|0,k|0,470296,0)|0;za=Dd(D|0,Aa|0,za|0,C|0)|0;Aa=C;D=Od(ha|0,k|0,654183,0)|0;D=Dd(xa|0,B|0,D|0,C|0)|0;B=C;xa=Od(ha|0,k|0,-997805,-1)|0;xa=Dd(Da|0,s|0,xa|0,C|0)|0;s=C;Da=Od(ha|0,k|0,136657,0)|0;Da=Dd(ta|0,ia|0,Da|0,C|0)|0;ia=C;k=Od(ha|0,k|0,-683901,-1)|0;ha=C;t=Dd(ya|0,sa|0,j|0,t|0)|0;Ca=Cd(t|0,C|0,wa|0,Ca|0)|0;ma=Dd(Ca|0,C|0,la|0,ma|0)|0;H=Dd(ma|0,C|0,Z|0,H|0)|0;ha=Dd(H|0,C|0,k|0,ha|0)|0;k=C;H=Od(Ea|0,o|0,666643,0)|0;Z=C;ma=Od(Ea|0,o|0,470296,0)|0;la=C;Ca=Od(Ea|0,o|0,654183,0)|0;wa=C;t=Od(Ea|0,o|0,-997805,-1)|0;j=C;sa=Od(Ea|0,o|0,136657,0)|0;sa=Dd(xa|0,s|0,sa|0,C|0)|0;s=C;o=Od(Ea|0,o|0,-683901,-1)|0;o=Dd(Da|0,ia|0,o|0,C|0)|0;ia=C;Da=Od(ra|0,ca|0,666643,0)|0;Ea=C;xa=Od(ra|0,ca|0,470296,0)|0;ya=C;ta=Od(ra|0,ca|0,654183,0)|0;ua=C;na=Od(ra|0,ca|0,-997805,-1)|0;oa=C;ja=Od(ra|0,ca|0,136657,0)|0;ka=C;ca=Od(ra|0,ca|0,-683901,-1)|0;ca=Dd(sa|0,s|0,ca|0,C|0)|0;s=C;sa=Od(Q|0,M|0,666643,0)|0;va=Dd(sa|0,C|0,n|f|V&2031616|0,va|0)|0;V=C;f=Od(Q|0,M|0,470296,0)|0;n=C;sa=Od(Q|0,M|0,654183,0)|0;Ba=Dd(sa|0,C|0,Ba&2097151|0,0)|0;Z=Dd(Ba|0,C|0,H|0,Z|0)|0;ya=Dd(Z|0,C|0,xa|0,ya|0)|0;xa=C;Z=Od(Q|0,M|0,-997805,-1)|0;H=C;Ba=Od(Q|0,M|0,136657,0)|0;Ba=Dd(za|0,Aa|0,Ba|0,C|0)|0;wa=Dd(Ba|0,C|0,Ca|0,wa|0)|0;oa=Dd(wa|0,C|0,na|0,oa|0)|0;na=C;M=Od(Q|0,M|0,-683901,-1)|0;Q=C;wa=Dd(va|0,V|0,1048576,0)|0;wa=Ed(wa|0,C|0,21)|0;Ca=C;ga=Dd(f|0,n|0,ga&2097151|0,0)|0;Ea=Dd(ga|0,C|0,Da|0,Ea|0)|0;Ea=Dd(Ea|0,C|0,wa|0,Ca|0)|0;Da=C;Ca=Hd(wa|0,Ca|0,21)|0;Ca=Cd(va|0,V|0,Ca|0,C|0)|0;V=C;va=Dd(ya|0,xa|0,1048576,0)|0;va=Ed(va|0,C|0,21)|0;wa=C;H=Dd(y|0,x|0,Z|0,H|0)|0;la=Dd(H|0,C|0,ma|0,la|0)|0;ua=Dd(la|0,C|0,ta|0,ua|0)|0;ua=Dd(ua|0,C|0,va|0,wa|0)|0;ta=C;wa=Hd(va|0,wa|0,21)|0;va=C;la=Dd(oa|0,na|0,1048576,0)|0;la=Ed(la|0,C|0,21)|0;ma=C;Q=Dd(D|0,B|0,M|0,Q|0)|0;j=Dd(Q|0,C|0,t|0,j|0)|0;ka=Dd(j|0,C|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,la|0,ma|0)|0;ja=C;ma=Hd(la|0,ma|0,21)|0;la=C;j=Dd(ca|0,s|0,1048576,0)|0;j=Ed(j|0,C|0,21)|0;t=C;ia=Dd(o|0,ia|0,j|0,t|0)|0;o=C;t=Hd(j|0,t|0,21)|0;t=Cd(ca|0,s|0,t|0,C|0)|0;s=C;ca=Dd(ha|0,k|0,1048576,0)|0;ca=Ed(ca|0,C|0,21)|0;j=C;e=Dd(I|0,e|0,ca|0,j|0)|0;I=C;j=Hd(ca|0,j|0,21)|0;j=Cd(ha|0,k|0,j|0,C|0)|0;k=C;ha=Dd(L|0,fa|0,1048576,0)|0;ha=Ed(ha|0,C|0,21)|0;ca=C;R=Dd(_|0,R|0,ha|0,ca|0)|0;_=C;ca=Hd(ha|0,ca|0,21)|0;ca=Cd(L|0,fa|0,ca|0,C|0)|0;fa=C;L=Dd(Ea|0,Da|0,1048576,0)|0;L=Ed(L|0,C|0,21)|0;ha=C;Q=Hd(L|0,ha|0,21)|0;M=C;B=Dd(ua|0,ta|0,1048576,0)|0;B=Ed(B|0,C|0,21)|0;D=C;H=Hd(B|0,D|0,21)|0;Z=C;x=Dd(ka|0,ja|0,1048576,0)|0;x=Ed(x|0,C|0,21)|0;y=C;s=Dd(t|0,s|0,x|0,y|0)|0;t=C;y=Hd(x|0,y|0,21)|0;x=C;ga=Dd(ia|0,o|0,1048576,0)|0;ga=Ed(ga|0,C|0,21)|0;n=C;k=Dd(j|0,k|0,ga|0,n|0)|0;j=C;n=Hd(ga|0,n|0,21)|0;n=Cd(ia|0,o|0,n|0,C|0)|0;o=C;ia=Dd(e|0,I|0,1048576,0)|0;ia=Ed(ia|0,C|0,21)|0;ga=C;fa=Dd(ca|0,fa|0,ia|0,ga|0)|0;ca=C;ga=Hd(ia|0,ga|0,21)|0;ga=Cd(e|0,I|0,ga|0,C|0)|0;I=C;e=Dd(R|0,_|0,1048576,0)|0;e=Ed(e|0,C|0,21)|0;ia=C;f=Hd(e|0,ia|0,21)|0;f=Cd(R|0,_|0,f|0,C|0)|0;_=C;R=Od(e|0,ia|0,666643,0)|0;R=Dd(Ca|0,V|0,R|0,C|0)|0;V=C;Ca=Od(e|0,ia|0,470296,0)|0;Ba=C;Aa=Od(e|0,ia|0,654183,0)|0;za=C;sa=Od(e|0,ia|0,-997805,-1)|0;ra=C;qa=Od(e|0,ia|0,136657,0)|0;pa=C;ia=Od(e|0,ia|0,-683901,-1)|0;e=C;W=Ed(R|0,V|0,21)|0;da=C;Ba=Dd(Ea|0,Da|0,Ca|0,Ba|0)|0;Ba=Dd(Ba|0,C|0,W|0,da|0)|0;M=Cd(Ba|0,C|0,Q|0,M|0)|0;Q=C;da=Hd(W|0,da|0,21)|0;da=Cd(R|0,V|0,da|0,C|0)|0;V=C;R=Ed(M|0,Q|0,21)|0;W=C;xa=Dd(Aa|0,za|0,ya|0,xa|0)|0;va=Cd(xa|0,C|0,wa|0,va|0)|0;ha=Dd(va|0,C|0,L|0,ha|0)|0;ha=Dd(ha|0,C|0,R|0,W|0)|0;L=C;W=Hd(R|0,W|0,21)|0;W=Cd(M|0,Q|0,W|0,C|0)|0;Q=C;M=Ed(ha|0,L|0,21)|0;R=C;ra=Dd(ua|0,ta|0,sa|0,ra|0)|0;Z=Cd(ra|0,C|0,H|0,Z|0)|0;Z=Dd(Z|0,C|0,M|0,R|0)|0;H=C;R=Hd(M|0,R|0,21)|0;R=Cd(ha|0,L|0,R|0,C|0)|0;L=C;ha=Ed(Z|0,H|0,21)|0;M=C;na=Dd(qa|0,pa|0,oa|0,na|0)|0;la=Cd(na|0,C|0,ma|0,la|0)|0;D=Dd(la|0,C|0,B|0,D|0)|0;D=Dd(D|0,C|0,ha|0,M|0)|0;B=C;M=Hd(ha|0,M|0,21)|0;M=Cd(Z|0,H|0,M|0,C|0)|0;H=C;Z=Ed(D|0,B|0,21)|0;ha=C;e=Dd(ka|0,ja|0,ia|0,e|0)|0;x=Cd(e|0,C|0,y|0,x|0)|0;x=Dd(x|0,C|0,Z|0,ha|0)|0;y=C;ha=Hd(Z|0,ha|0,21)|0;ha=Cd(D|0,B|0,ha|0,C|0)|0;B=C;D=Ed(x|0,y|0,21)|0;Z=C;t=Dd(s|0,t|0,D|0,Z|0)|0;s=C;Z=Hd(D|0,Z|0,21)|0;Z=Cd(x|0,y|0,Z|0,C|0)|0;y=C;x=Ed(t|0,s|0,21)|0;D=C;o=Dd(x|0,D|0,n|0,o|0)|0;n=C;D=Hd(x|0,D|0,21)|0;D=Cd(t|0,s|0,D|0,C|0)|0;s=C;t=Ed(o|0,n|0,21)|0;x=C;j=Dd(k|0,j|0,t|0,x|0)|0;k=C;x=Hd(t|0,x|0,21)|0;x=Cd(o|0,n|0,x|0,C|0)|0;n=C;o=Ed(j|0,k|0,21)|0;t=C;I=Dd(o|0,t|0,ga|0,I|0)|0;ga=C;t=Hd(o|0,t|0,21)|0;t=Cd(j|0,k|0,t|0,C|0)|0;k=C;j=Ed(I|0,ga|0,21)|0;o=C;ca=Dd(fa|0,ca|0,j|0,o|0)|0;fa=C;o=Hd(j|0,o|0,21)|0;o=Cd(I|0,ga|0,o|0,C|0)|0;ga=C;I=Ed(ca|0,fa|0,21)|0;j=C;_=Dd(I|0,j|0,f|0,_|0)|0;f=C;j=Hd(I|0,j|0,21)|0;j=Cd(ca|0,fa|0,j|0,C|0)|0;fa=C;ca=Ed(_|0,f|0,21)|0;I=C;e=Hd(ca|0,I|0,21)|0;e=Cd(_|0,f|0,e|0,C|0)|0;f=C;_=Od(ca|0,I|0,666643,0)|0;V=Dd(_|0,C|0,da|0,V|0)|0;da=C;_=Od(ca|0,I|0,470296,0)|0;_=Dd(W|0,Q|0,_|0,C|0)|0;Q=C;W=Od(ca|0,I|0,654183,0)|0;W=Dd(R|0,L|0,W|0,C|0)|0;L=C;R=Od(ca|0,I|0,-997805,-1)|0;R=Dd(M|0,H|0,R|0,C|0)|0;H=C;M=Od(ca|0,I|0,136657,0)|0;M=Dd(ha|0,B|0,M|0,C|0)|0;B=C;I=Od(ca|0,I|0,-683901,-1)|0;I=Dd(Z|0,y|0,I|0,C|0)|0;y=C;Z=Ed(V|0,da|0,21)|0;ca=C;Q=Dd(_|0,Q|0,Z|0,ca|0)|0;_=C;ca=Hd(Z|0,ca|0,21)|0;ca=Cd(V|0,da|0,ca|0,C|0)|0;da=C;V=Ed(Q|0,_|0,21)|0;Z=C;L=Dd(W|0,L|0,V|0,Z|0)|0;W=C;Z=Hd(V|0,Z|0,21)|0;Z=Cd(Q|0,_|0,Z|0,C|0)|0;_=C;Q=Ed(L|0,W|0,21)|0;V=C;H=Dd(R|0,H|0,Q|0,V|0)|0;R=C;V=Hd(Q|0,V|0,21)|0;V=Cd(L|0,W|0,V|0,C|0)|0;W=C;L=Ed(H|0,R|0,21)|0;Q=C;B=Dd(M|0,B|0,L|0,Q|0)|0;M=C;Q=Hd(L|0,Q|0,21)|0;Q=Cd(H|0,R|0,Q|0,C|0)|0;R=C;H=Ed(B|0,M|0,21)|0;L=C;y=Dd(I|0,y|0,H|0,L|0)|0;I=C;L=Hd(H|0,L|0,21)|0;L=Cd(B|0,M|0,L|0,C|0)|0;M=C;B=Ed(y|0,I|0,21)|0;H=C;s=Dd(B|0,H|0,D|0,s|0)|0;D=C;H=Hd(B|0,H|0,21)|0;H=Cd(y|0,I|0,H|0,C|0)|0;I=C;y=Ed(s|0,D|0,21)|0;B=C;n=Dd(y|0,B|0,x|0,n|0)|0;x=C;B=Hd(y|0,B|0,21)|0;B=Cd(s|0,D|0,B|0,C|0)|0;D=C;s=Ed(n|0,x|0,21)|0;y=C;k=Dd(s|0,y|0,t|0,k|0)|0;t=C;y=Hd(s|0,y|0,21)|0;y=Cd(n|0,x|0,y|0,C|0)|0;x=C;n=Ed(k|0,t|0,21)|0;s=C;ga=Dd(n|0,s|0,o|0,ga|0)|0;o=C;s=Hd(n|0,s|0,21)|0;s=Cd(k|0,t|0,s|0,C|0)|0;t=C;k=Ed(ga|0,o|0,21)|0;n=C;fa=Dd(k|0,n|0,j|0,fa|0)|0;j=C;n=Hd(k|0,n|0,21)|0;n=Cd(ga|0,o|0,n|0,C|0)|0;o=C;ga=Ed(fa|0,j|0,21)|0;k=C;f=Dd(ga|0,k|0,e|0,f|0)|0;e=C;k=Hd(ga|0,k|0,21)|0;k=Cd(fa|0,j|0,k|0,C|0)|0;j=C;a[b>>0]=ca;b=Gd(ca|0,da|0,8)|0;a[ea>>0]=b;b=Gd(ca|0,da|0,16)|0;da=C;ca=Hd(Z|0,_|0,5)|0;a[ba>>0]=ca|b;b=Gd(Z|0,_|0,3)|0;a[aa>>0]=b;b=Gd(Z|0,_|0,11)|0;a[$>>0]=b;b=Gd(Z|0,_|0,19)|0;_=C;Z=Hd(V|0,W|0,2)|0;a[Y>>0]=Z|b;b=Gd(V|0,W|0,6)|0;a[X>>0]=b;b=Gd(V|0,W|0,14)|0;W=C;V=Hd(Q|0,R|0,7)|0;a[U>>0]=V|b;b=Gd(Q|0,R|0,1)|0;a[T>>0]=b;b=Gd(Q|0,R|0,9)|0;a[S>>0]=b;b=Gd(Q|0,R|0,17)|0;R=C;Q=Hd(L|0,M|0,4)|0;a[P>>0]=Q|b;b=Gd(L|0,M|0,4)|0;a[O>>0]=b;b=Gd(L|0,M|0,12)|0;a[N>>0]=b;b=Gd(L|0,M|0,20)|0;M=C;L=Hd(H|0,I|0,1)|0;a[K>>0]=L|b;b=Gd(H|0,I|0,7)|0;a[J>>0]=b;b=Gd(H|0,I|0,15)|0;I=C;H=Hd(B|0,D|0,6)|0;a[G>>0]=H|b;b=Gd(B|0,D|0,2)|0;a[F>>0]=b;b=Gd(B|0,D|0,10)|0;a[E>>0]=b;b=Gd(B|0,D|0,18)|0;D=C;B=Hd(y|0,x|0,3)|0;a[A>>0]=B|b;b=Gd(y|0,x|0,5)|0;a[z>>0]=b;b=Gd(y|0,x|0,13)|0;a[w>>0]=b;a[v>>0]=s;b=Gd(s|0,t|0,8)|0;a[u>>0]=b;b=Gd(s|0,t|0,16)|0;t=C;s=Hd(n|0,o|0,5)|0;a[r>>0]=s|b;b=Gd(n|0,o|0,3)|0;a[q>>0]=b;b=Gd(n|0,o|0,11)|0;a[p>>0]=b;b=Gd(n|0,o|0,19)|0;o=C;n=Hd(k|0,j|0,2)|0;a[m>>0]=n|b;b=Gd(k|0,j|0,6)|0;a[l>>0]=b;j=Gd(k|0,j|0,14)|0;k=C;b=Hd(f|0,e|0,7)|0;a[i>>0]=j|b;b=Gd(f|0,e|0,1)|0;a[h>>0]=b;b=Gd(f|0,e|0,9)|0;a[g>>0]=b;b=Gd(f|0,e|0,17)|0;a[c>>0]=b;return}function Xc(b,e,f,g,h,j){b=b|0;e=e|0;f=f|0;g=g|0;h=h|0;j=j|0;var k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0,xa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha=0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa=0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0,db=0,eb=0,fb=0,gb=0,hb=0,ib=0,jb=0,kb=0,lb=0,mb=0,nb=0,ob=0,pb=0,qb=0,rb=0,sb=0,tb=0,ub=0,vb=0,wb=0,xb=0,yb=0,zb=0,Ab=0,Bb=0,Cb=0,Db=0,Eb=0,Hb=0,Ib=0,Jb=0,Kb=0,Lb=0,Mb=0,Nb=0,Ob=0,Pb=0,Qb=0,Rb=0,Sb=0,Tb=0,Ub=0,Vb=0,Wb=0,Xb=0,Yb=0,Zb=0,_b=0,$b=0,ac=0,bc=0,cc=0,dc=0,ec=0,fc=0,gc=0,hc=0,ic=0,jc=0,kc=0,lc=0,mc=0,nc=0,oc=0,pc=0,qc=0,rc=0,sc=0,tc=0,uc=0,vc=0,wc=0,xc=0,yc=0,zc=0,Ac=0,Bc=0,Cc=0,Dc=0,Ec=0;z=i;p=i=i+63&-64;i=i+896|0;v=p+208|0;u=p+656|0;w=p+616|0;x=p+576|0;s=p;q=p+824|0;t=p+760|0;r=p+696|0;p=p+416|0;k=v+64|0;y=v;A=8;B=y+64|0;do{c[y>>2]=c[A>>2];y=y+4|0;A=A+4|0}while((y|0)<(B|0));y=v+72|0;c[y>>2]=256;c[y+4>>2]=0;y=k;c[y>>2]=0;c[y+4>>2]=0;y=v+80|0;A=j;B=y+32|0;do{a[y>>0]=a[A>>0]|0;y=y+1|0;A=A+1|0}while((y|0)<(B|0));Gb(v,q);a[q>>0]=(d[q>>0]|0)&248;k=q+31|0;a[k>>0]=(d[k>>0]|0)&63|64;l=s+64|0;y=l;c[y>>2]=0;c[y+4>>2]=0;y=s;A=8;B=y+64|0;do{c[y>>2]=c[A>>2];y=y+4|0;A=A+4|0}while((y|0)<(B|0));m=s+72|0;n=m;c[n>>2]=256;c[n+4>>2]=0;n=l;c[n>>2]=0;c[n+4>>2]=0;n=s+80|0;y=n;A=q+32|0;B=y+32|0;do{a[y>>0]=a[A>>0]|0;y=y+1|0;A=A+1|0}while((y|0)<(B|0));Fb(s,f,g,h);Gb(s,t);o=b+32|0;Jd(o|0,j+32|0,32)|0;Wc(t);Rc(p,t);Ic(u,p+80|0);Jc(w,p,u);Jc(x,p+40|0,u);Lc(b,x);Lc(v,w);y=b+31|0;a[y>>0]=(d[y>>0]|0)^(d[v>>0]|0)<<7;y=l;c[y>>2]=0;c[y+4>>2]=0;y=s;A=8;B=y+64|0;do{c[y>>2]=c[A>>2];y=y+4|0;A=A+4|0}while((y|0)<(B|0));y=m;c[y>>2]=512;c[y+4>>2]=0;y=l;c[y>>2]=0;c[y+4>>2]=0;y=n;A=b;B=y+64|0;do{a[y>>0]=a[A>>0]|0;y=y+1|0;A=A+1|0}while((y|0)<(B|0));Fb(s,f,g,h);Gb(s,r);Wc(r);J=a[r+2>>0]|0;Ta=d[r>>0]|0;xb=Hd(d[r+1>>0]|0|0,0,8)|0;qb=C;J=J&255;kb=Hd(J|0,0,16)|0;kb=xb|Ta|kb&2031616;Ta=Hd(d[r+3>>0]|0|0,0,8)|0;xb=C;F=Hd(d[r+4>>0]|0|0,0,16)|0;xb=xb|C;ub=d[r+5>>0]|0;db=Hd(ub|0,0,24)|0;xb=Gd(Ta|J|F|db|0,xb|C|0,5)|0;xb=xb&2097151;db=a[r+7>>0]|0;F=Hd(d[r+6>>0]|0|0,0,8)|0;J=C;db=db&255;Ta=Hd(db|0,0,16)|0;J=Gd(F|ub|Ta|0,J|C|0,2)|0;J=J&2097151;Ta=Hd(d[r+8>>0]|0|0,0,8)|0;ub=C;F=Hd(d[r+9>>0]|0|0,0,16)|0;ub=ub|C;v=d[r+10>>0]|0;Sa=Hd(v|0,0,24)|0;ub=Gd(Ta|db|F|Sa|0,ub|C|0,7)|0;ub=ub&2097151;Sa=Hd(d[r+11>>0]|0|0,0,8)|0;F=C;db=Hd(d[r+12>>0]|0|0,0,16)|0;F=F|C;Ta=d[r+13>>0]|0;y=Hd(Ta|0,0,24)|0;F=Gd(Sa|v|db|y|0,F|C|0,4)|0;F=F&2097151;y=a[r+15>>0]|0;db=Hd(d[r+14>>0]|0|0,0,8)|0;v=C;y=y&255;Sa=Hd(y|0,0,16)|0;v=Gd(db|Ta|Sa|0,v|C|0,1)|0;v=v&2097151;Sa=Hd(d[r+16>>0]|0|0,0,8)|0;Ta=C;db=Hd(d[r+17>>0]|0|0,0,16)|0;Ta=Ta|C;Bc=d[r+18>>0]|0;ja=Hd(Bc|0,0,24)|0;Ta=Gd(Sa|y|db|ja|0,Ta|C|0,6)|0;Ta=Ta&2097151;ja=a[r+20>>0]|0;db=Hd(d[r+19>>0]|0|0,0,8)|0;y=C;ja=Hd(ja&255|0,0,16)|0;y=Gd(db|Bc|ja|0,y|C|0,3)|0;ja=C;Bc=a[r+23>>0]|0;db=d[r+21>>0]|0;Sa=Hd(d[r+22>>0]|0|0,0,8)|0;sb=C;Bc=Bc&255;Qa=Hd(Bc|0,0,16)|0;Qa=Sa|db|Qa&2031616;db=Hd(d[r+24>>0]|0|0,0,8)|0;Sa=C;m=Hd(d[r+25>>0]|0|0,0,16)|0;Sa=Sa|C;p=d[r+26>>0]|0;s=Hd(p|0,0,24)|0;Sa=Gd(db|Bc|m|s|0,Sa|C|0,5)|0;Sa=Sa&2097151;s=a[r+28>>0]|0;m=Hd(d[r+27>>0]|0|0,0,8)|0;Bc=C;s=s&255;db=Hd(s|0,0,16)|0;Bc=Gd(m|p|db|0,Bc|C|0,2)|0;Bc=Bc&2097151;db=Hd(d[r+29>>0]|0|0,0,8)|0;p=C;m=Hd(d[r+30>>0]|0|0,0,16)|0;p=p|C;Ka=Hd(d[r+31>>0]|0|0,0,24)|0;p=Gd(db|s|m|Ka|0,p|C|0,7)|0;Ka=C;m=a[q+2>>0]|0;s=d[q>>0]|0;db=Hd(d[q+1>>0]|0|0,0,8)|0;ia=C;m=m&255;ha=Hd(m|0,0,16)|0;ha=db|s|ha&2031616;s=Hd(d[q+3>>0]|0|0,0,8)|0;db=C;la=Hd(d[q+4>>0]|0|0,0,16)|0;db=db|C;h=d[q+5>>0]|0;yc=Hd(h|0,0,24)|0;db=Gd(s|m|la|yc|0,db|C|0,5)|0;db=db&2097151;yc=a[q+7>>0]|0;la=Hd(d[q+6>>0]|0|0,0,8)|0;m=C;yc=yc&255;s=Hd(yc|0,0,16)|0;m=Gd(la|h|s|0,m|C|0,2)|0;m=m&2097151;s=Hd(d[q+8>>0]|0|0,0,8)|0;h=C;la=Hd(d[q+9>>0]|0|0,0,16)|0;h=h|C;_a=d[q+10>>0]|0;Pa=Hd(_a|0,0,24)|0;h=Gd(s|yc|la|Pa|0,h|C|0,7)|0;h=h&2097151;Pa=Hd(d[q+11>>0]|0|0,0,8)|0;la=C;yc=Hd(d[q+12>>0]|0|0,0,16)|0;la=la|C;s=d[q+13>>0]|0;Ec=Hd(s|0,0,24)|0;la=Gd(Pa|_a|yc|Ec|0,la|C|0,4)|0;la=la&2097151;Ec=a[q+15>>0]|0;yc=Hd(d[q+14>>0]|0|0,0,8)|0;_a=C;Ec=Ec&255;Pa=Hd(Ec|0,0,16)|0;_a=Gd(yc|s|Pa|0,_a|C|0,1)|0;_a=_a&2097151;Pa=Hd(d[q+16>>0]|0|0,0,8)|0;s=C;yc=Hd(d[q+17>>0]|0|0,0,16)|0;s=s|C;R=d[q+18>>0]|0;Bb=Hd(R|0,0,24)|0;s=Gd(Pa|Ec|yc|Bb|0,s|C|0,6)|0;s=s&2097151;Bb=a[q+20>>0]|0;yc=Hd(d[q+19>>0]|0|0,0,8)|0;Ec=C;Bb=Hd(Bb&255|0,0,16)|0;Ec=Gd(yc|R|Bb|0,Ec|C|0,3)|0;Bb=C;R=a[q+23>>0]|0;yc=d[q+21>>0]|0;Pa=Hd(d[q+22>>0]|0|0,0,8)|0;Da=C;R=R&255;ua=Hd(R|0,0,16)|0;ua=Pa|yc|ua&2031616;yc=Hd(d[q+24>>0]|0|0,0,8)|0;Pa=C;Ma=Hd(d[q+25>>0]|0|0,0,16)|0;Pa=Pa|C;D=d[q+26>>0]|0;zc=Hd(D|0,0,24)|0;Pa=Gd(yc|R|Ma|zc|0,Pa|C|0,5)|0;Pa=Pa&2097151;zc=a[q+28>>0]|0;Ma=Hd(d[q+27>>0]|0|0,0,8)|0;R=C;zc=zc&255;yc=Hd(zc|0,0,16)|0;R=Gd(Ma|D|yc|0,R|C|0,2)|0;R=R&2097151;yc=Hd(d[q+29>>0]|0|0,0,8)|0;D=C;Ma=Hd(d[q+30>>0]|0|0,0,16)|0;D=D|C;Ia=Hd(d[k>>0]|0|0,0,24)|0;D=Gd(yc|zc|Ma|Ia|0,D|C|0,7)|0;Ia=C;Ma=a[t+2>>0]|0;zc=d[t>>0]|0;yc=Hd(d[t+1>>0]|0|0,0,8)|0;ba=C;Ma=Ma&255;Ac=Hd(Ma|0,0,16)|0;Xa=Hd(d[t+3>>0]|0|0,0,8)|0;Ea=C;Ga=Hd(d[t+4>>0]|0|0,0,16)|0;Ea=Ea|C;pb=d[t+5>>0]|0;za=Hd(pb|0,0,24)|0;Ea=Gd(Xa|Ma|Ga|za|0,Ea|C|0,5)|0;za=a[t+7>>0]|0;Ga=Hd(d[t+6>>0]|0|0,0,8)|0;Ma=C;za=za&255;Xa=Hd(za|0,0,16)|0;Ma=Gd(Ga|pb|Xa|0,Ma|C|0,2)|0;Xa=Hd(d[t+8>>0]|0|0,0,8)|0;pb=C;Ga=Hd(d[t+9>>0]|0|0,0,16)|0;pb=pb|C;X=d[t+10>>0]|0;O=Hd(X|0,0,24)|0;pb=Gd(Xa|za|Ga|O|0,pb|C|0,7)|0;O=Hd(d[t+11>>0]|0|0,0,8)|0;Ga=C;za=Hd(d[t+12>>0]|0|0,0,16)|0;Ga=Ga|C;Xa=d[t+13>>0]|0;H=Hd(Xa|0,0,24)|0;Ga=Gd(O|X|za|H|0,Ga|C|0,4)|0;H=a[t+15>>0]|0;za=Hd(d[t+14>>0]|0|0,0,8)|0;X=C;H=H&255;O=Hd(H|0,0,16)|0;X=Gd(za|Xa|O|0,X|C|0,1)|0;O=Hd(d[t+16>>0]|0|0,0,8)|0;Xa=C;za=Hd(d[t+17>>0]|0|0,0,16)|0;Xa=Xa|C;U=d[t+18>>0]|0;w=Hd(U|0,0,24)|0;Xa=Gd(O|H|za|w|0,Xa|C|0,6)|0;w=a[t+20>>0]|0;za=Hd(d[t+19>>0]|0|0,0,8)|0;H=C;w=Hd(w&255|0,0,16)|0;H=Gd(za|U|w|0,H|C|0,3)|0;w=C;U=a[t+23>>0]|0;za=d[t+21>>0]|0;O=Hd(d[t+22>>0]|0|0,0,8)|0;da=C;U=U&255;ea=Hd(U|0,0,16)|0;Ba=Hd(d[t+24>>0]|0|0,0,8)|0;N=C;Ha=Hd(d[t+25>>0]|0|0,0,16)|0;N=N|C;A=d[t+26>>0]|0;ta=Hd(A|0,0,24)|0;N=Gd(Ba|U|Ha|ta|0,N|C|0,5)|0;ta=a[t+28>>0]|0;Ha=Hd(d[t+27>>0]|0|0,0,8)|0;U=C;ta=ta&255;Ba=Hd(ta|0,0,16)|0;U=Gd(Ha|A|Ba|0,U|C|0,2)|0;Ba=Hd(d[t+29>>0]|0|0,0,8)|0;A=C;Ha=Hd(d[t+30>>0]|0|0,0,16)|0;A=A|C;j=Hd(d[t+31>>0]|0|0,0,24)|0;A=Gd(Ba|ta|Ha|j|0,A|C|0,7)|0;j=C;Ha=Od(ha|0,ia|0,kb|0,qb|0)|0;Ha=Dd(yc|zc|Ac&2031616|0,ba|0,Ha|0,C|0)|0;ba=C;Ac=Od(db|0,0,kb|0,qb|0)|0;zc=C;yc=Od(ha|0,ia|0,xb|0,0)|0;ta=C;Ba=Od(m|0,0,kb|0,qb|0)|0;La=C;Ca=Od(db|0,0,xb|0,0)|0;tc=C;pa=Od(ha|0,ia|0,J|0,0)|0;pa=Dd(Ca|0,tc|0,pa|0,C|0)|0;La=Dd(pa|0,C|0,Ba|0,La|0)|0;Ma=Dd(La|0,C|0,Ma&2097151|0,0)|0;La=C;Ba=Od(h|0,0,kb|0,qb|0)|0;pa=C;tc=Od(m|0,0,xb|0,0)|0;Ca=C;xc=Od(db|0,0,J|0,0)|0;wc=C;vc=Od(ha|0,ia|0,ub|0,0)|0;uc=C;Oa=Od(la|0,0,kb|0,qb|0)|0;Fa=C;kc=Od(h|0,0,xb|0,0)|0;Y=C;mc=Od(m|0,0,J|0,0)|0;Na=C;nc=Od(db|0,0,ub|0,0)|0;oc=C;lc=Od(ha|0,ia|0,F|0,0)|0;lc=Dd(nc|0,oc|0,lc|0,C|0)|0;Na=Dd(lc|0,C|0,mc|0,Na|0)|0;Y=Dd(Na|0,C|0,kc|0,Y|0)|0;Fa=Dd(Y|0,C|0,Oa|0,Fa|0)|0;Ga=Dd(Fa|0,C|0,Ga&2097151|0,0)|0;Fa=C;Oa=Od(_a|0,0,kb|0,qb|0)|0;Y=C;kc=Od(la|0,0,xb|0,0)|0;Na=C;mc=Od(h|0,0,J|0,0)|0;lc=C;oc=Od(m|0,0,ub|0,0)|0;nc=C;sc=Od(db|0,0,F|0,0)|0;rc=C;qc=Od(ha|0,ia|0,v|0,0)|0;pc=C;ca=Od(s|0,0,kb|0,qb|0)|0;Ya=C;Zb=Od(_a|0,0,xb|0,0)|0;ka=C;$b=Od(la|0,0,J|0,0)|0;Yb=C;bc=Od(h|0,0,ub|0,0)|0;_b=C;dc=Od(m|0,0,F|0,0)|0;ac=C;ec=Od(db|0,0,v|0,0)|0;fc=C;cc=Od(ha|0,ia|0,Ta|0,0)|0;cc=Dd(ec|0,fc|0,cc|0,C|0)|0;ac=Dd(cc|0,C|0,dc|0,ac|0)|0;_b=Dd(ac|0,C|0,bc|0,_b|0)|0;Yb=Dd(_b|0,C|0,$b|0,Yb|0)|0;ka=Dd(Yb|0,C|0,Zb|0,ka|0)|0;Ya=Dd(ka|0,C|0,ca|0,Ya|0)|0;Xa=Dd(Ya|0,C|0,Xa&2097151|0,0)|0;Ya=C;ca=Od(Ec|0,Bb|0,kb|0,qb|0)|0;ka=C;Zb=Od(s|0,0,xb|0,0)|0;Yb=C;$b=Od(_a|0,0,J|0,0)|0;_b=C;bc=Od(la|0,0,ub|0,0)|0;ac=C;dc=Od(h|0,0,F|0,0)|0;cc=C;fc=Od(m|0,0,v|0,0)|0;ec=C;jc=Od(db|0,0,Ta|0,0)|0;ic=C;hc=Od(ha|0,ia|0,y|0,ja|0)|0;gc=C;Aa=Od(ua|0,Da|0,kb|0,qb|0)|0;Hb=C;Ib=Od(Ec|0,Bb|0,xb|0,0)|0;Jb=C;Kb=Od(s|0,0,J|0,0)|0;Lb=C;Mb=Od(_a|0,0,ub|0,0)|0;Nb=C;Ob=Od(la|0,0,F|0,0)|0;Pb=C;Qb=Od(h|0,0,v|0,0)|0;Rb=C;Sb=Od(m|0,0,Ta|0,0)|0;Tb=C;Vb=Od(db|0,0,y|0,ja|0)|0;Wb=C;Xb=Od(ha|0,ia|0,Qa|0,sb|0)|0;Xb=Dd(Vb|0,Wb|0,Xb|0,C|0)|0;Tb=Dd(Xb|0,C|0,Sb|0,Tb|0)|0;Rb=Dd(Tb|0,C|0,Qb|0,Rb|0)|0;Pb=Dd(Rb|0,C|0,Ob|0,Pb|0)|0;Nb=Dd(Pb|0,C|0,Mb|0,Nb|0)|0;Lb=Dd(Nb|0,C|0,Kb|0,Lb|0)|0;Jb=Dd(Lb|0,C|0,Ib|0,Jb|0)|0;Hb=Dd(Jb|0,C|0,Aa|0,Hb|0)|0;da=Dd(Hb|0,C|0,O|za|ea&2031616|0,da|0)|0;ea=C;za=Od(Pa|0,0,kb|0,qb|0)|0;O=C;Hb=Od(ua|0,Da|0,xb|0,0)|0;Aa=C;Jb=Od(Ec|0,Bb|0,J|0,0)|0;Ib=C;Lb=Od(s|0,0,ub|0,0)|0;Kb=C;Nb=Od(_a|0,0,F|0,0)|0;Mb=C;Pb=Od(la|0,0,v|0,0)|0;Ob=C;Rb=Od(h|0,0,Ta|0,0)|0;Qb=C;Tb=Od(m|0,0,y|0,ja|0)|0;Sb=C;Xb=Od(db|0,0,Qa|0,sb|0)|0;Wb=C;Vb=Od(ha|0,ia|0,Sa|0,0)|0;Ub=C;V=Od(R|0,0,kb|0,qb|0)|0;T=C;hb=Od(Pa|0,0,xb|0,0)|0;W=C;I=Od(ua|0,Da|0,J|0,0)|0;ib=C;vb=Od(Ec|0,Bb|0,ub|0,0)|0;E=C;Q=Od(s|0,0,F|0,0)|0;wb=C;Va=Od(_a|0,0,v|0,0)|0;K=C;nb=Od(la|0,0,Ta|0,0)|0;Wa=C;$=Od(h|0,0,y|0,ja|0)|0;ob=C;bb=Od(m|0,0,Qa|0,sb|0)|0;aa=C;Db=Od(db|0,0,Sa|0,0)|0;Eb=C;cb=Od(ha|0,ia|0,Bc|0,0)|0;cb=Dd(Db|0,Eb|0,cb|0,C|0)|0;aa=Dd(cb|0,C|0,bb|0,aa|0)|0;ob=Dd(aa|0,C|0,$|0,ob|0)|0;Wa=Dd(ob|0,C|0,nb|0,Wa|0)|0;K=Dd(Wa|0,C|0,Va|0,K|0)|0;wb=Dd(K|0,C|0,Q|0,wb|0)|0;E=Dd(wb|0,C|0,vb|0,E|0)|0;ib=Dd(E|0,C|0,I|0,ib|0)|0;W=Dd(ib|0,C|0,hb|0,W|0)|0;T=Dd(W|0,C|0,V|0,T|0)|0;U=Dd(T|0,C|0,U&2097151|0,0)|0;T=C;qb=Od(D|0,Ia|0,kb|0,qb|0)|0;kb=C;V=Od(R|0,0,xb|0,0)|0;W=C;hb=Od(Pa|0,0,J|0,0)|0;ib=C;I=Od(ua|0,Da|0,ub|0,0)|0;E=C;vb=Od(Ec|0,Bb|0,F|0,0)|0;wb=C;Q=Od(s|0,0,v|0,0)|0;K=C;Va=Od(_a|0,0,Ta|0,0)|0;Wa=C;nb=Od(la|0,0,y|0,ja|0)|0;ob=C;$=Od(h|0,0,Qa|0,sb|0)|0;aa=C;bb=Od(m|0,0,Sa|0,0)|0;cb=C;Eb=Od(db|0,0,Bc|0,0)|0;Db=C;ia=Od(ha|0,ia|0,p|0,Ka|0)|0;ha=C;xb=Od(D|0,Ia|0,xb|0,0)|0;yb=C;lb=Od(R|0,0,J|0,0)|0;G=C;ma=Od(Pa|0,0,ub|0,0)|0;mb=C;oa=Od(ua|0,Da|0,F|0,0)|0;ga=C;zb=Od(Ec|0,Bb|0,v|0,0)|0;rb=C;sa=Od(s|0,0,Ta|0,0)|0;Ab=C;xa=Od(_a|0,0,y|0,ja|0)|0;ra=C;Ua=Od(la|0,0,Qa|0,sb|0)|0;wa=C;eb=Od(h|0,0,Sa|0,0)|0;na=C;tb=Od(m|0,0,Bc|0,0)|0;l=C;db=Od(db|0,0,p|0,Ka|0)|0;db=Dd(tb|0,l|0,db|0,C|0)|0;na=Dd(db|0,C|0,eb|0,na|0)|0;wa=Dd(na|0,C|0,Ua|0,wa|0)|0;ra=Dd(wa|0,C|0,xa|0,ra|0)|0;Ab=Dd(ra|0,C|0,sa|0,Ab|0)|0;rb=Dd(Ab|0,C|0,zb|0,rb|0)|0;ga=Dd(rb|0,C|0,oa|0,ga|0)|0;mb=Dd(ga|0,C|0,ma|0,mb|0)|0;G=Dd(mb|0,C|0,lb|0,G|0)|0;yb=Dd(G|0,C|0,xb|0,yb|0)|0;xb=C;J=Od(D|0,Ia|0,J|0,0)|0;G=C;lb=Od(R|0,0,ub|0,0)|0;mb=C;ma=Od(Pa|0,0,F|0,0)|0;ga=C;oa=Od(ua|0,Da|0,v|0,0)|0;rb=C;zb=Od(Ec|0,Bb|0,Ta|0,0)|0;Ab=C;sa=Od(s|0,0,y|0,ja|0)|0;ra=C;xa=Od(_a|0,0,Qa|0,sb|0)|0;wa=C;Ua=Od(la|0,0,Sa|0,0)|0;na=C;eb=Od(h|0,0,Bc|0,0)|0;db=C;m=Od(m|0,0,p|0,Ka|0)|0;l=C;ub=Od(D|0,Ia|0,ub|0,0)|0;tb=C;fb=Od(R|0,0,F|0,0)|0;g=C;L=Od(Pa|0,0,v|0,0)|0;gb=C;r=Od(ua|0,Da|0,Ta|0,0)|0;n=C;fa=Od(Ec|0,Bb|0,y|0,ja|0)|0;x=C;qa=Od(s|0,0,Qa|0,sb|0)|0;k=C;va=Od(_a|0,0,Sa|0,0)|0;M=C;Cb=Od(la|0,0,Bc|0,0)|0;f=C;h=Od(h|0,0,p|0,Ka|0)|0;h=Dd(Cb|0,f|0,h|0,C|0)|0;M=Dd(h|0,C|0,va|0,M|0)|0;k=Dd(M|0,C|0,qa|0,k|0)|0;x=Dd(k|0,C|0,fa|0,x|0)|0;n=Dd(x|0,C|0,r|0,n|0)|0;gb=Dd(n|0,C|0,L|0,gb|0)|0;g=Dd(gb|0,C|0,fb|0,g|0)|0;tb=Dd(g|0,C|0,ub|0,tb|0)|0;ub=C;F=Od(D|0,Ia|0,F|0,0)|0;g=C;fb=Od(R|0,0,v|0,0)|0;gb=C;L=Od(Pa|0,0,Ta|0,0)|0;n=C;r=Od(ua|0,Da|0,y|0,ja|0)|0;x=C;fa=Od(Ec|0,Bb|0,Qa|0,sb|0)|0;k=C;qa=Od(s|0,0,Sa|0,0)|0;M=C;va=Od(_a|0,0,Bc|0,0)|0;h=C;la=Od(la|0,0,p|0,Ka|0)|0;f=C;v=Od(D|0,Ia|0,v|0,0)|0;Cb=C;B=Od(R|0,0,Ta|0,0)|0;S=C;_=Od(Pa|0,0,y|0,ja|0)|0;Ra=C;ab=Od(ua|0,Da|0,Qa|0,sb|0)|0;Z=C;Za=Od(Ec|0,Bb|0,Sa|0,0)|0;$a=C;P=Od(s|0,0,Bc|0,0)|0;u=C;_a=Od(_a|0,0,p|0,Ka|0)|0;_a=Dd(P|0,u|0,_a|0,C|0)|0;$a=Dd(_a|0,C|0,Za|0,$a|0)|0;Z=Dd($a|0,C|0,ab|0,Z|0)|0;Ra=Dd(Z|0,C|0,_|0,Ra|0)|0;S=Dd(Ra|0,C|0,B|0,S|0)|0;Cb=Dd(S|0,C|0,v|0,Cb|0)|0;v=C;Ta=Od(D|0,Ia|0,Ta|0,0)|0;S=C;B=Od(R|0,0,y|0,ja|0)|0;Ra=C;_=Od(Pa|0,0,Qa|0,sb|0)|0;Z=C;ab=Od(ua|0,Da|0,Sa|0,0)|0;$a=C;Za=Od(Ec|0,Bb|0,Bc|0,0)|0;_a=C;s=Od(s|0,0,p|0,Ka|0)|0;u=C;ja=Od(D|0,Ia|0,y|0,ja|0)|0;y=C;P=Od(R|0,0,Qa|0,sb|0)|0;Ja=C;ya=Od(Pa|0,0,Sa|0,0)|0;jb=C;Cc=Od(ua|0,Da|0,Bc|0,0)|0;Dc=C;Bb=Od(Ec|0,Bb|0,p|0,Ka|0)|0;Bb=Dd(Cc|0,Dc|0,Bb|0,C|0)|0;jb=Dd(Bb|0,C|0,ya|0,jb|0)|0;Ja=Dd(jb|0,C|0,P|0,Ja|0)|0;y=Dd(Ja|0,C|0,ja|0,y|0)|0;ja=C;sb=Od(D|0,Ia|0,Qa|0,sb|0)|0;Qa=C;Ja=Od(R|0,0,Sa|0,0)|0;P=C;jb=Od(Pa|0,0,Bc|0,0)|0;ya=C;Da=Od(ua|0,Da|0,p|0,Ka|0)|0;ua=C;Sa=Od(D|0,Ia|0,Sa|0,0)|0;Bb=C;Dc=Od(R|0,0,Bc|0,0)|0;Cc=C;Pa=Od(Pa|0,0,p|0,Ka|0)|0;Pa=Dd(Dc|0,Cc|0,Pa|0,C|0)|0;Bb=Dd(Pa|0,C|0,Sa|0,Bb|0)|0;Sa=C;Bc=Od(D|0,Ia|0,Bc|0,0)|0;Pa=C;R=Od(R|0,0,p|0,Ka|0)|0;R=Dd(Bc|0,Pa|0,R|0,C|0)|0;Pa=C;Ka=Od(D|0,Ia|0,p|0,Ka|0)|0;p=C;Ia=Dd(Ha|0,ba|0,1048576,0)|0;Ia=Gd(Ia|0,C|0,21)|0;D=C;ta=Dd(Ac|0,zc|0,yc|0,ta|0)|0;ta=Dd(ta|0,C|0,Ia|0,D|0)|0;Ea=Dd(ta|0,C|0,Ea&2097151|0,0)|0;ta=C;D=Hd(Ia|0,D|0,21)|0;D=Cd(Ha|0,ba|0,D|0,C|0)|0;ba=C;Ha=Dd(Ma|0,La|0,1048576,0)|0;Ha=Gd(Ha|0,C|0,21)|0;Ia=C;uc=Dd(xc|0,wc|0,vc|0,uc|0)|0;Ca=Dd(uc|0,C|0,tc|0,Ca|0)|0;pa=Dd(Ca|0,C|0,Ba|0,pa|0)|0;pb=Dd(pa|0,C|0,pb&2097151|0,0)|0;pb=Dd(pb|0,C|0,Ha|0,Ia|0)|0;pa=C;Ia=Hd(Ha|0,Ia|0,21)|0;Ha=C;Ba=Dd(Ga|0,Fa|0,1048576,0)|0;Ba=Ed(Ba|0,C|0,21)|0;Ca=C;pc=Dd(sc|0,rc|0,qc|0,pc|0)|0;nc=Dd(pc|0,C|0,oc|0,nc|0)|0;lc=Dd(nc|0,C|0,mc|0,lc|0)|0;Na=Dd(lc|0,C|0,kc|0,Na|0)|0;Y=Dd(Na|0,C|0,Oa|0,Y|0)|0;X=Dd(Y|0,C|0,X&2097151|0,0)|0;X=Dd(X|0,C|0,Ba|0,Ca|0)|0;Y=C;Ca=Hd(Ba|0,Ca|0,21)|0;Ba=C;Oa=Dd(Xa|0,Ya|0,1048576,0)|0;Oa=Ed(Oa|0,C|0,21)|0;Na=C;gc=Dd(jc|0,ic|0,hc|0,gc|0)|0;ec=Dd(gc|0,C|0,fc|0,ec|0)|0;cc=Dd(ec|0,C|0,dc|0,cc|0)|0;ac=Dd(cc|0,C|0,bc|0,ac|0)|0;_b=Dd(ac|0,C|0,$b|0,_b|0)|0;Yb=Dd(_b|0,C|0,Zb|0,Yb|0)|0;ka=Dd(Yb|0,C|0,ca|0,ka|0)|0;w=Dd(ka|0,C|0,H|0,w|0)|0;w=Dd(w|0,C|0,Oa|0,Na|0)|0;H=C;Na=Hd(Oa|0,Na|0,21)|0;Oa=C;ka=Dd(da|0,ea|0,1048576,0)|0;ka=Ed(ka|0,C|0,21)|0;ca=C;Ub=Dd(Xb|0,Wb|0,Vb|0,Ub|0)|0;Sb=Dd(Ub|0,C|0,Tb|0,Sb|0)|0;Qb=Dd(Sb|0,C|0,Rb|0,Qb|0)|0;Ob=Dd(Qb|0,C|0,Pb|0,Ob|0)|0;Mb=Dd(Ob|0,C|0,Nb|0,Mb|0)|0;Kb=Dd(Mb|0,C|0,Lb|0,Kb|0)|0;Ib=Dd(Kb|0,C|0,Jb|0,Ib|0)|0;Aa=Dd(Ib|0,C|0,Hb|0,Aa|0)|0;O=Dd(Aa|0,C|0,za|0,O|0)|0;N=Dd(O|0,C|0,N&2097151|0,0)|0;N=Dd(N|0,C|0,ka|0,ca|0)|0;O=C;ca=Hd(ka|0,ca|0,21)|0;ka=C;za=Dd(U|0,T|0,1048576,0)|0;za=Ed(za|0,C|0,21)|0;Aa=C;ha=Dd(Eb|0,Db|0,ia|0,ha|0)|0;cb=Dd(ha|0,C|0,bb|0,cb|0)|0;aa=Dd(cb|0,C|0,$|0,aa|0)|0;ob=Dd(aa|0,C|0,nb|0,ob|0)|0;Wa=Dd(ob|0,C|0,Va|0,Wa|0)|0;K=Dd(Wa|0,C|0,Q|0,K|0)|0;wb=Dd(K|0,C|0,vb|0,wb|0)|0;E=Dd(wb|0,C|0,I|0,E|0)|0;ib=Dd(E|0,C|0,hb|0,ib|0)|0;W=Dd(ib|0,C|0,V|0,W|0)|0;kb=Dd(W|0,C|0,qb|0,kb|0)|0;j=Dd(kb|0,C|0,A|0,j|0)|0;j=Dd(j|0,C|0,za|0,Aa|0)|0;A=C;Aa=Hd(za|0,Aa|0,21)|0;za=C;kb=Dd(yb|0,xb|0,1048576,0)|0;kb=Ed(kb|0,C|0,21)|0;qb=C;l=Dd(eb|0,db|0,m|0,l|0)|0;na=Dd(l|0,C|0,Ua|0,na|0)|0;wa=Dd(na|0,C|0,xa|0,wa|0)|0;ra=Dd(wa|0,C|0,sa|0,ra|0)|0;Ab=Dd(ra|0,C|0,zb|0,Ab|0)|0;rb=Dd(Ab|0,C|0,oa|0,rb|0)|0;ga=Dd(rb|0,C|0,ma|0,ga|0)|0;mb=Dd(ga|0,C|0,lb|0,mb|0)|0;G=Dd(mb|0,C|0,J|0,G|0)|0;G=Dd(G|0,C|0,kb|0,qb|0)|0;J=C;qb=Hd(kb|0,qb|0,21)|0;kb=C;mb=Dd(tb|0,ub|0,1048576,0)|0;mb=Ed(mb|0,C|0,21)|0;lb=C;f=Dd(va|0,h|0,la|0,f|0)|0;M=Dd(f|0,C|0,qa|0,M|0)|0;k=Dd(M|0,C|0,fa|0,k|0)|0;x=Dd(k|0,C|0,r|0,x|0)|0;n=Dd(x|0,C|0,L|0,n|0)|0;gb=Dd(n|0,C|0,fb|0,gb|0)|0;g=Dd(gb|0,C|0,F|0,g|0)|0;g=Dd(g|0,C|0,mb|0,lb|0)|0;F=C;lb=Hd(mb|0,lb|0,21)|0;mb=C;gb=Dd(Cb|0,v|0,1048576,0)|0;gb=Ed(gb|0,C|0,21)|0;fb=C;u=Dd(Za|0,_a|0,s|0,u|0)|0;$a=Dd(u|0,C|0,ab|0,$a|0)|0;Z=Dd($a|0,C|0,_|0,Z|0)|0;Ra=Dd(Z|0,C|0,B|0,Ra|0)|0;S=Dd(Ra|0,C|0,Ta|0,S|0)|0;S=Dd(S|0,C|0,gb|0,fb|0)|0;Ta=C;fb=Hd(gb|0,fb|0,21)|0;gb=C;Ra=Dd(y|0,ja|0,1048576,0)|0;Ra=Ed(Ra|0,C|0,21)|0;B=C;ua=Dd(jb|0,ya|0,Da|0,ua|0)|0;P=Dd(ua|0,C|0,Ja|0,P|0)|0;Qa=Dd(P|0,C|0,sb|0,Qa|0)|0;Qa=Dd(Qa|0,C|0,Ra|0,B|0)|0;sb=C;B=Hd(Ra|0,B|0,21)|0;B=Cd(y|0,ja|0,B|0,C|0)|0;ja=C;y=Dd(Bb|0,Sa|0,1048576,0)|0;y=Ed(y|0,C|0,21)|0;Ra=C;Pa=Dd(R|0,Pa|0,y|0,Ra|0)|0;R=C;Ra=Hd(y|0,Ra|0,21)|0;Ra=Cd(Bb|0,Sa|0,Ra|0,C|0)|0;Sa=C;Bb=Dd(Ka|0,p|0,1048576,0)|0;Bb=Ed(Bb|0,C|0,21)|0;y=C;P=Hd(Bb|0,y|0,21)|0;P=Cd(Ka|0,p|0,P|0,C|0)|0;p=C;Ka=Dd(Ea|0,ta|0,1048576,0)|0;Ka=Gd(Ka|0,C|0,21)|0;Ja=C;ua=Hd(Ka|0,Ja|0,21)|0;ua=Cd(Ea|0,ta|0,ua|0,C|0)|0;ta=C;Ea=Dd(pb|0,pa|0,1048576,0)|0;Ea=Ed(Ea|0,C|0,21)|0;Da=C;ya=Hd(Ea|0,Da|0,21)|0;ya=Cd(pb|0,pa|0,ya|0,C|0)|0;pa=C;pb=Dd(X|0,Y|0,1048576,0)|0;pb=Ed(pb|0,C|0,21)|0;jb=C;Z=Hd(pb|0,jb|0,21)|0;_=C;$a=Dd(w|0,H|0,1048576,0)|0;$a=Ed($a|0,C|0,21)|0;ab=C;u=Hd($a|0,ab|0,21)|0;s=C;_a=Dd(N|0,O|0,1048576,0)|0;_a=Ed(_a|0,C|0,21)|0;Za=C;n=Hd(_a|0,Za|0,21)|0;L=C;x=Dd(j|0,A|0,1048576,0)|0;x=Ed(x|0,C|0,21)|0;r=C;k=Hd(x|0,r|0,21)|0;fa=C;M=Dd(G|0,J|0,1048576,0)|0;M=Ed(M|0,C|0,21)|0;qa=C;f=Hd(M|0,qa|0,21)|0;la=C;h=Dd(g|0,F|0,1048576,0)|0;h=Ed(h|0,C|0,21)|0;va=C;ga=Hd(h|0,va|0,21)|0;ma=C;rb=Dd(S|0,Ta|0,1048576,0)|0;rb=Ed(rb|0,C|0,21)|0;oa=C;ja=Dd(rb|0,oa|0,B|0,ja|0)|0;B=C;oa=Hd(rb|0,oa|0,21)|0;oa=Cd(S|0,Ta|0,oa|0,C|0)|0;Ta=C;S=Dd(Qa|0,sb|0,1048576,0)|0;S=Ed(S|0,C|0,21)|0;rb=C;Sa=Dd(S|0,rb|0,Ra|0,Sa|0)|0;Ra=C;rb=Hd(S|0,rb|0,21)|0;rb=Cd(Qa|0,sb|0,rb|0,C|0)|0;sb=C;Qa=Dd(Pa|0,R|0,1048576,0)|0;Qa=Ed(Qa|0,C|0,21)|0;S=C;p=Dd(Qa|0,S|0,P|0,p|0)|0;P=C;S=Hd(Qa|0,S|0,21)|0;S=Cd(Pa|0,R|0,S|0,C|0)|0;R=C;Pa=Od(Bb|0,y|0,666643,0)|0;Qa=C;Ab=Od(Bb|0,y|0,470296,0)|0;zb=C;ra=Od(Bb|0,y|0,654183,0)|0;sa=C;wa=Od(Bb|0,y|0,-997805,-1)|0;xa=C;na=Od(Bb|0,y|0,136657,0)|0;Ua=C;y=Od(Bb|0,y|0,-683901,-1)|0;y=Dd(Cb|0,v|0,y|0,C|0)|0;gb=Cd(y|0,C|0,fb|0,gb|0)|0;va=Dd(gb|0,C|0,h|0,va|0)|0;h=C;gb=Od(p|0,P|0,666643,0)|0;fb=C;y=Od(p|0,P|0,470296,0)|0;v=C;Cb=Od(p|0,P|0,654183,0)|0;Bb=C;l=Od(p|0,P|0,-997805,-1)|0;m=C;db=Od(p|0,P|0,136657,0)|0;eb=C;P=Od(p|0,P|0,-683901,-1)|0;p=C;W=Od(S|0,R|0,666643,0)|0;V=C;ib=Od(S|0,R|0,470296,0)|0;hb=C;E=Od(S|0,R|0,654183,0)|0;I=C;wb=Od(S|0,R|0,-997805,-1)|0;vb=C;K=Od(S|0,R|0,136657,0)|0;Q=C;R=Od(S|0,R|0,-683901,-1)|0;S=C;xa=Dd(tb|0,ub|0,wa|0,xa|0)|0;eb=Dd(xa|0,C|0,db|0,eb|0)|0;S=Dd(eb|0,C|0,R|0,S|0)|0;mb=Cd(S|0,C|0,lb|0,mb|0)|0;qa=Dd(mb|0,C|0,M|0,qa|0)|0;M=C;mb=Od(Sa|0,Ra|0,666643,0)|0;lb=C;S=Od(Sa|0,Ra|0,470296,0)|0;R=C;eb=Od(Sa|0,Ra|0,654183,0)|0;db=C;xa=Od(Sa|0,Ra|0,-997805,-1)|0;wa=C;ub=Od(Sa|0,Ra|0,136657,0)|0;tb=C;Ra=Od(Sa|0,Ra|0,-683901,-1)|0;Sa=C;Wa=Od(rb|0,sb|0,666643,0)|0;Va=C;ob=Od(rb|0,sb|0,470296,0)|0;nb=C;aa=Od(rb|0,sb|0,654183,0)|0;$=C;cb=Od(rb|0,sb|0,-997805,-1)|0;bb=C;ha=Od(rb|0,sb|0,136657,0)|0;ia=C;sb=Od(rb|0,sb|0,-683901,-1)|0;rb=C;zb=Dd(Cb|0,Bb|0,Ab|0,zb|0)|0;xb=Dd(zb|0,C|0,yb|0,xb|0)|0;vb=Dd(xb|0,C|0,wb|0,vb|0)|0;tb=Dd(vb|0,C|0,ub|0,tb|0)|0;rb=Dd(tb|0,C|0,sb|0,rb|0)|0;kb=Cd(rb|0,C|0,qb|0,kb|0)|0;r=Dd(kb|0,C|0,x|0,r|0)|0;x=C;kb=Od(ja|0,B|0,666643,0)|0;kb=Dd(pb|0,jb|0,kb|0,C|0)|0;Ya=Dd(kb|0,C|0,Xa|0,Ya|0)|0;Oa=Cd(Ya|0,C|0,Na|0,Oa|0)|0;Na=C;Ya=Od(ja|0,B|0,470296,0)|0;Xa=C;kb=Od(ja|0,B|0,654183,0)|0;jb=C;lb=Dd(ob|0,nb|0,mb|0,lb|0)|0;jb=Dd(lb|0,C|0,kb|0,jb|0)|0;ab=Dd(jb|0,C|0,$a|0,ab|0)|0;ea=Dd(ab|0,C|0,da|0,ea|0)|0;ka=Cd(ea|0,C|0,ca|0,ka|0)|0;ca=C;ea=Od(ja|0,B|0,-997805,-1)|0;da=C;ab=Od(ja|0,B|0,136657,0)|0;$a=C;fb=Dd(ib|0,hb|0,gb|0,fb|0)|0;db=Dd(fb|0,C|0,eb|0,db|0)|0;bb=Dd(db|0,C|0,cb|0,bb|0)|0;$a=Dd(bb|0,C|0,ab|0,$a|0)|0;Za=Dd($a|0,C|0,_a|0,Za|0)|0;T=Dd(Za|0,C|0,U|0,T|0)|0;za=Cd(T|0,C|0,Aa|0,za|0)|0;Aa=C;B=Od(ja|0,B|0,-683901,-1)|0;ja=C;T=Dd(Oa|0,Na|0,1048576,0)|0;T=Ed(T|0,C|0,21)|0;U=C;Va=Dd(Ya|0,Xa|0,Wa|0,Va|0)|0;H=Dd(Va|0,C|0,w|0,H|0)|0;s=Cd(H|0,C|0,u|0,s|0)|0;s=Dd(s|0,C|0,T|0,U|0)|0;u=C;U=Hd(T|0,U|0,21)|0;T=C;H=Dd(ka|0,ca|0,1048576,0)|0;H=Ed(H|0,C|0,21)|0;w=C;V=Dd(S|0,R|0,W|0,V|0)|0;$=Dd(V|0,C|0,aa|0,$|0)|0;da=Dd($|0,C|0,ea|0,da|0)|0;O=Dd(da|0,C|0,N|0,O|0)|0;L=Cd(O|0,C|0,n|0,L|0)|0;L=Dd(L|0,C|0,H|0,w|0)|0;n=C;w=Hd(H|0,w|0,21)|0;H=C;O=Dd(za|0,Aa|0,1048576,0)|0;O=Ed(O|0,C|0,21)|0;N=C;Qa=Dd(y|0,v|0,Pa|0,Qa|0)|0;I=Dd(Qa|0,C|0,E|0,I|0)|0;wa=Dd(I|0,C|0,xa|0,wa|0)|0;ia=Dd(wa|0,C|0,ha|0,ia|0)|0;ja=Dd(ia|0,C|0,B|0,ja|0)|0;A=Dd(ja|0,C|0,j|0,A|0)|0;fa=Cd(A|0,C|0,k|0,fa|0)|0;fa=Dd(fa|0,C|0,O|0,N|0)|0;k=C;N=Hd(O|0,N|0,21)|0;O=C;A=Dd(r|0,x|0,1048576,0)|0;A=Ed(A|0,C|0,21)|0;j=C;sa=Dd(l|0,m|0,ra|0,sa|0)|0;Q=Dd(sa|0,C|0,K|0,Q|0)|0;Sa=Dd(Q|0,C|0,Ra|0,Sa|0)|0;J=Dd(Sa|0,C|0,G|0,J|0)|0;la=Cd(J|0,C|0,f|0,la|0)|0;la=Dd(la|0,C|0,A|0,j|0)|0;f=C;j=Hd(A|0,j|0,21)|0;j=Cd(r|0,x|0,j|0,C|0)|0;x=C;r=Dd(qa|0,M|0,1048576,0)|0;r=Ed(r|0,C|0,21)|0;A=C;Ua=Dd(P|0,p|0,na|0,Ua|0)|0;F=Dd(Ua|0,C|0,g|0,F|0)|0;ma=Cd(F|0,C|0,ga|0,ma|0)|0;ma=Dd(ma|0,C|0,r|0,A|0)|0;ga=C;A=Hd(r|0,A|0,21)|0;A=Cd(qa|0,M|0,A|0,C|0)|0;M=C;qa=Dd(va|0,h|0,1048576,0)|0;qa=Ed(qa|0,C|0,21)|0;r=C;Ta=Dd(qa|0,r|0,oa|0,Ta|0)|0;oa=C;r=Hd(qa|0,r|0,21)|0;r=Cd(va|0,h|0,r|0,C|0)|0;h=C;va=Dd(s|0,u|0,1048576,0)|0;va=Ed(va|0,C|0,21)|0;qa=C;F=Hd(va|0,qa|0,21)|0;g=C;Ua=Dd(L|0,n|0,1048576,0)|0;Ua=Ed(Ua|0,C|0,21)|0;na=C;p=Hd(Ua|0,na|0,21)|0;P=C;J=Dd(fa|0,k|0,1048576,0)|0;J=Ed(J|0,C|0,21)|0;G=C;x=Dd(J|0,G|0,j|0,x|0)|0;j=C;G=Hd(J|0,G|0,21)|0;G=Cd(fa|0,k|0,G|0,C|0)|0;k=C;fa=Dd(la|0,f|0,1048576,0)|0;fa=Ed(fa|0,C|0,21)|0;J=C;M=Dd(fa|0,J|0,A|0,M|0)|0;A=C;J=Hd(fa|0,J|0,21)|0;J=Cd(la|0,f|0,J|0,C|0)|0;f=C;la=Dd(ma|0,ga|0,1048576,0)|0;la=Ed(la|0,C|0,21)|0;fa=C;h=Dd(la|0,fa|0,r|0,h|0)|0;r=C;fa=Hd(la|0,fa|0,21)|0;fa=Cd(ma|0,ga|0,fa|0,C|0)|0;ga=C;ma=Od(Ta|0,oa|0,666643,0)|0;la=C;Sa=Od(Ta|0,oa|0,470296,0)|0;Ra=C;Q=Od(Ta|0,oa|0,654183,0)|0;K=C;sa=Od(Ta|0,oa|0,-997805,-1)|0;ra=C;m=Od(Ta|0,oa|0,136657,0)|0;l=C;oa=Od(Ta|0,oa|0,-683901,-1)|0;oa=Dd(Ua|0,na|0,oa|0,C|0)|0;Aa=Dd(oa|0,C|0,za|0,Aa|0)|0;O=Cd(Aa|0,C|0,N|0,O|0)|0;N=C;Aa=Od(h|0,r|0,666643,0)|0;za=C;oa=Od(h|0,r|0,470296,0)|0;na=C;Ua=Od(h|0,r|0,654183,0)|0;Ta=C;ja=Od(h|0,r|0,-997805,-1)|0;B=C;ia=Od(h|0,r|0,136657,0)|0;ha=C;r=Od(h|0,r|0,-683901,-1)|0;h=C;wa=Od(fa|0,ga|0,666643,0)|0;wa=Dd(ya|0,pa|0,wa|0,C|0)|0;pa=C;ya=Od(fa|0,ga|0,470296,0)|0;xa=C;I=Od(fa|0,ga|0,654183,0)|0;E=C;Qa=Od(fa|0,ga|0,-997805,-1)|0;Pa=C;v=Od(fa|0,ga|0,136657,0)|0;y=C;ga=Od(fa|0,ga|0,-683901,-1)|0;fa=C;ra=Dd(ia|0,ha|0,sa|0,ra|0)|0;fa=Dd(ra|0,C|0,ga|0,fa|0)|0;qa=Dd(fa|0,C|0,va|0,qa|0)|0;ca=Dd(qa|0,C|0,ka|0,ca|0)|0;H=Cd(ca|0,C|0,w|0,H|0)|0;w=C;ca=Od(M|0,A|0,666643,0)|0;ka=C;qa=Od(M|0,A|0,470296,0)|0;qa=Dd(wa|0,pa|0,qa|0,C|0)|0;pa=C;wa=Od(M|0,A|0,654183,0)|0;va=C;fa=Od(M|0,A|0,-997805,-1)|0;ga=C;ra=Od(M|0,A|0,136657,0)|0;sa=C;A=Od(M|0,A|0,-683901,-1)|0;M=C;ha=Od(J|0,f|0,666643,0)|0;ia=C;da=Od(J|0,f|0,470296,0)|0;ea=C;$=Od(J|0,f|0,654183,0)|0;aa=C;V=Od(J|0,f|0,-997805,-1)|0;W=C;R=Od(J|0,f|0,136657,0)|0;S=C;f=Od(J|0,f|0,-683901,-1)|0;J=C;Ra=Dd(Ua|0,Ta|0,Sa|0,Ra|0)|0;Pa=Dd(Ra|0,C|0,Qa|0,Pa|0)|0;Na=Dd(Pa|0,C|0,Oa|0,Na|0)|0;T=Cd(Na|0,C|0,U|0,T|0)|0;sa=Dd(T|0,C|0,ra|0,sa|0)|0;J=Dd(sa|0,C|0,f|0,J|0)|0;f=C;sa=Od(x|0,j|0,666643,0)|0;ba=Dd(sa|0,C|0,D|0,ba|0)|0;D=C;sa=Od(x|0,j|0,470296,0)|0;ra=C;T=Od(x|0,j|0,654183,0)|0;U=C;Ja=Dd(Ma|0,La|0,Ka|0,Ja|0)|0;Ha=Cd(Ja|0,C|0,Ia|0,Ha|0)|0;ka=Dd(Ha|0,C|0,ca|0,ka|0)|0;U=Dd(ka|0,C|0,T|0,U|0)|0;ea=Dd(U|0,C|0,da|0,ea|0)|0;da=C;U=Od(x|0,j|0,-997805,-1)|0;T=C;ka=Od(x|0,j|0,136657,0)|0;ca=C;Da=Dd(Ga|0,Fa|0,Ea|0,Da|0)|0;Ba=Cd(Da|0,C|0,Ca|0,Ba|0)|0;za=Dd(Ba|0,C|0,Aa|0,za|0)|0;xa=Dd(za|0,C|0,ya|0,xa|0)|0;va=Dd(xa|0,C|0,wa|0,va|0)|0;ca=Dd(va|0,C|0,ka|0,ca|0)|0;W=Dd(ca|0,C|0,V|0,W|0)|0;V=C;j=Od(x|0,j|0,-683901,-1)|0;x=C;ca=Dd(ba|0,D|0,1048576,0)|0;ca=Ed(ca|0,C|0,21)|0;ka=C;ra=Dd(ua|0,ta|0,sa|0,ra|0)|0;ia=Dd(ra|0,C|0,ha|0,ia|0)|0;ia=Dd(ia|0,C|0,ca|0,ka|0)|0;ha=C;ka=Hd(ca|0,ka|0,21)|0;ka=Cd(ba|0,D|0,ka|0,C|0)|0;D=C;ba=Dd(ea|0,da|0,1048576,0)|0;ba=Ed(ba|0,C|0,21)|0;ca=C;T=Dd(qa|0,pa|0,U|0,T|0)|0;aa=Dd(T|0,C|0,$|0,aa|0)|0;aa=Dd(aa|0,C|0,ba|0,ca|0)|0;$=C;ca=Hd(ba|0,ca|0,21)|0;ba=C;T=Dd(W|0,V|0,1048576,0)|0;T=Ed(T|0,C|0,21)|0;U=C;la=Dd(oa|0,na|0,ma|0,la|0)|0;E=Dd(la|0,C|0,I|0,E|0)|0;Y=Dd(E|0,C|0,X|0,Y|0)|0;_=Cd(Y|0,C|0,Z|0,_|0)|0;ga=Dd(_|0,C|0,fa|0,ga|0)|0;x=Dd(ga|0,C|0,j|0,x|0)|0;S=Dd(x|0,C|0,R|0,S|0)|0;S=Dd(S|0,C|0,T|0,U|0)|0;R=C;U=Hd(T|0,U|0,21)|0;T=C;x=Dd(J|0,f|0,1048576,0)|0;x=Ed(x|0,C|0,21)|0;j=C;K=Dd(ja|0,B|0,Q|0,K|0)|0;y=Dd(K|0,C|0,v|0,y|0)|0;u=Dd(y|0,C|0,s|0,u|0)|0;g=Cd(u|0,C|0,F|0,g|0)|0;M=Dd(g|0,C|0,A|0,M|0)|0;M=Dd(M|0,C|0,x|0,j|0)|0;A=C;j=Hd(x|0,j|0,21)|0;j=Cd(J|0,f|0,j|0,C|0)|0;f=C;J=Dd(H|0,w|0,1048576,0)|0;J=Ed(J|0,C|0,21)|0;x=C;l=Dd(r|0,h|0,m|0,l|0)|0;n=Dd(l|0,C|0,L|0,n|0)|0;n=Dd(n|0,C|0,J|0,x|0)|0;P=Cd(n|0,C|0,p|0,P|0)|0;p=C;x=Hd(J|0,x|0,21)|0;x=Cd(H|0,w|0,x|0,C|0)|0;w=C;H=Dd(O|0,N|0,1048576,0)|0;H=Ed(H|0,C|0,21)|0;J=C;k=Dd(G|0,k|0,H|0,J|0)|0;G=C;J=Hd(H|0,J|0,21)|0;H=C;n=Dd(ia|0,ha|0,1048576,0)|0;n=Ed(n|0,C|0,21)|0;L=C;l=Hd(n|0,L|0,21)|0;m=C;h=Dd(aa|0,$|0,1048576,0)|0;h=Ed(h|0,C|0,21)|0;r=C;g=Hd(h|0,r|0,21)|0;F=C;u=Dd(S|0,R|0,1048576,0)|0;u=Ed(u|0,C|0,21)|0;s=C;f=Dd(j|0,f|0,u|0,s|0)|0;j=C;s=Hd(u|0,s|0,21)|0;u=C;y=Dd(M|0,A|0,1048576,0)|0;y=Ed(y|0,C|0,21)|0;v=C;w=Dd(x|0,w|0,y|0,v|0)|0;x=C;v=Hd(y|0,v|0,21)|0;v=Cd(M|0,A|0,v|0,C|0)|0;A=C;M=Dd(P|0,p|0,1048576,0)|0;M=Ed(M|0,C|0,21)|0;y=C;K=Hd(M|0,y|0,21)|0;K=Cd(P|0,p|0,K|0,C|0)|0;p=C;P=Dd(k|0,G|0,1048576,0)|0;P=Ed(P|0,C|0,21)|0;Q=C;B=Hd(P|0,Q|0,21)|0;B=Cd(k|0,G|0,B|0,C|0)|0;G=C;k=Od(P|0,Q|0,666643,0)|0;k=Dd(ka|0,D|0,k|0,C|0)|0;D=C;ka=Od(P|0,Q|0,470296,0)|0;ja=C;ga=Od(P|0,Q|0,654183,0)|0;fa=C;_=Od(P|0,Q|0,-997805,-1)|0;Z=C;Y=Od(P|0,Q|0,136657,0)|0;X=C;Q=Od(P|0,Q|0,-683901,-1)|0;P=C;E=Ed(k|0,D|0,21)|0;I=C;ha=Dd(ka|0,ja|0,ia|0,ha|0)|0;m=Cd(ha|0,C|0,l|0,m|0)|0;m=Dd(m|0,C|0,E|0,I|0)|0;l=C;I=Hd(E|0,I|0,21)|0;I=Cd(k|0,D|0,I|0,C|0)|0;D=C;k=Ed(m|0,l|0,21)|0;E=C;da=Dd(ga|0,fa|0,ea|0,da|0)|0;ba=Cd(da|0,C|0,ca|0,ba|0)|0;L=Dd(ba|0,C|0,n|0,L|0)|0;L=Dd(L|0,C|0,k|0,E|0)|0;n=C;E=Hd(k|0,E|0,21)|0;E=Cd(m|0,l|0,E|0,C|0)|0;l=C;m=Ed(L|0,n|0,21)|0;k=C;Z=Dd(aa|0,$|0,_|0,Z|0)|0;F=Cd(Z|0,C|0,g|0,F|0)|0;F=Dd(F|0,C|0,m|0,k|0)|0;g=C;k=Hd(m|0,k|0,21)|0;k=Cd(L|0,n|0,k|0,C|0)|0;n=C;L=Ed(F|0,g|0,21)|0;m=C;V=Dd(Y|0,X|0,W|0,V|0)|0;T=Cd(V|0,C|0,U|0,T|0)|0;r=Dd(T|0,C|0,h|0,r|0)|0;r=Dd(r|0,C|0,L|0,m|0)|0;h=C;m=Hd(L|0,m|0,21)|0;m=Cd(F|0,g|0,m|0,C|0)|0;g=C;F=Ed(r|0,h|0,21)|0;L=C;P=Dd(S|0,R|0,Q|0,P|0)|0;u=Cd(P|0,C|0,s|0,u|0)|0;u=Dd(u|0,C|0,F|0,L|0)|0;s=C;L=Hd(F|0,L|0,21)|0;L=Cd(r|0,h|0,L|0,C|0)|0;h=C;r=Ed(u|0,s|0,21)|0;F=C;j=Dd(f|0,j|0,r|0,F|0)|0;f=C;F=Hd(r|0,F|0,21)|0;F=Cd(u|0,s|0,F|0,C|0)|0;s=C;u=Ed(j|0,f|0,21)|0;r=C;A=Dd(u|0,r|0,v|0,A|0)|0;v=C;r=Hd(u|0,r|0,21)|0;r=Cd(j|0,f|0,r|0,C|0)|0;f=C;j=Ed(A|0,v|0,21)|0;u=C;x=Dd(w|0,x|0,j|0,u|0)|0;w=C;u=Hd(j|0,u|0,21)|0;u=Cd(A|0,v|0,u|0,C|0)|0;v=C;A=Ed(x|0,w|0,21)|0;j=C;p=Dd(A|0,j|0,K|0,p|0)|0;K=C;j=Hd(A|0,j|0,21)|0;j=Cd(x|0,w|0,j|0,C|0)|0;w=C;x=Ed(p|0,K|0,21)|0;A=C;y=Dd(O|0,N|0,M|0,y|0)|0;H=Cd(y|0,C|0,J|0,H|0)|0;H=Dd(H|0,C|0,x|0,A|0)|0;J=C;A=Hd(x|0,A|0,21)|0;A=Cd(p|0,K|0,A|0,C|0)|0;K=C;p=Ed(H|0,J|0,21)|0;x=C;G=Dd(p|0,x|0,B|0,G|0)|0;B=C;x=Hd(p|0,x|0,21)|0;x=Cd(H|0,J|0,x|0,C|0)|0;J=C;H=Ed(G|0,B|0,21)|0;p=C;y=Hd(H|0,p|0,21)|0;y=Cd(G|0,B|0,y|0,C|0)|0;B=C;G=Od(H|0,p|0,666643,0)|0;D=Dd(G|0,C|0,I|0,D|0)|0;I=C;G=Od(H|0,p|0,470296,0)|0;G=Dd(E|0,l|0,G|0,C|0)|0;l=C;E=Od(H|0,p|0,654183,0)|0;E=Dd(k|0,n|0,E|0,C|0)|0;n=C;k=Od(H|0,p|0,-997805,-1)|0;k=Dd(m|0,g|0,k|0,C|0)|0;g=C;m=Od(H|0,p|0,136657,0)|0;m=Dd(L|0,h|0,m|0,C|0)|0;h=C;p=Od(H|0,p|0,-683901,-1)|0;p=Dd(F|0,s|0,p|0,C|0)|0;s=C;F=Ed(D|0,I|0,21)|0;H=C;l=Dd(G|0,l|0,F|0,H|0)|0;G=C;H=Hd(F|0,H|0,21)|0;H=Cd(D|0,I|0,H|0,C|0)|0;I=C;D=Ed(l|0,G|0,21)|0;F=C;n=Dd(E|0,n|0,D|0,F|0)|0;E=C;F=Hd(D|0,F|0,21)|0;F=Cd(l|0,G|0,F|0,C|0)|0;G=C;l=Ed(n|0,E|0,21)|0;D=C;g=Dd(k|0,g|0,l|0,D|0)|0;k=C;D=Hd(l|0,D|0,21)|0;D=Cd(n|0,E|0,D|0,C|0)|0;E=C;n=Ed(g|0,k|0,21)|0;l=C;h=Dd(m|0,h|0,n|0,l|0)|0;m=C;l=Hd(n|0,l|0,21)|0;l=Cd(g|0,k|0,l|0,C|0)|0;k=C;g=Ed(h|0,m|0,21)|0;n=C;s=Dd(p|0,s|0,g|0,n|0)|0;p=C;n=Hd(g|0,n|0,21)|0;n=Cd(h|0,m|0,n|0,C|0)|0;m=C;h=Ed(s|0,p|0,21)|0;g=C;f=Dd(h|0,g|0,r|0,f|0)|0;r=C;g=Hd(h|0,g|0,21)|0;g=Cd(s|0,p|0,g|0,C|0)|0;p=C;s=Ed(f|0,r|0,21)|0;h=C;v=Dd(s|0,h|0,u|0,v|0)|0;u=C;h=Hd(s|0,h|0,21)|0;h=Cd(f|0,r|0,h|0,C|0)|0;r=C;f=Ed(v|0,u|0,21)|0;s=C;w=Dd(f|0,s|0,j|0,w|0)|0;j=C;s=Hd(f|0,s|0,21)|0;s=Cd(v|0,u|0,s|0,C|0)|0;u=C;v=Ed(w|0,j|0,21)|0;f=C;K=Dd(v|0,f|0,A|0,K|0)|0;A=C;f=Hd(v|0,f|0,21)|0;f=Cd(w|0,j|0,f|0,C|0)|0;j=C;w=Ed(K|0,A|0,21)|0;v=C;J=Dd(w|0,v|0,x|0,J|0)|0;x=C;v=Hd(w|0,v|0,21)|0;v=Cd(K|0,A|0,v|0,C|0)|0;A=C;K=Ed(J|0,x|0,21)|0;w=C;B=Dd(K|0,w|0,y|0,B|0)|0;y=C;w=Hd(K|0,w|0,21)|0;w=Cd(J|0,x|0,w|0,C|0)|0;x=C;a[o>>0]=H;o=Gd(H|0,I|0,8)|0;a[b+33>>0]=o;o=Gd(H|0,I|0,16)|0;I=C;H=Hd(F|0,G|0,5)|0;a[b+34>>0]=H|o;o=Gd(F|0,G|0,3)|0;a[b+35>>0]=o;o=Gd(F|0,G|0,11)|0;a[b+36>>0]=o;o=Gd(F|0,G|0,19)|0;G=C;F=Hd(D|0,E|0,2)|0;a[b+37>>0]=F|o;o=Gd(D|0,E|0,6)|0;a[b+38>>0]=o;o=Gd(D|0,E|0,14)|0;E=C;D=Hd(l|0,k|0,7)|0;a[b+39>>0]=D|o;o=Gd(l|0,k|0,1)|0;a[b+40>>0]=o;o=Gd(l|0,k|0,9)|0;a[b+41>>0]=o;o=Gd(l|0,k|0,17)|0;k=C;l=Hd(n|0,m|0,4)|0;a[b+42>>0]=l|o;o=Gd(n|0,m|0,4)|0;a[b+43>>0]=o;o=Gd(n|0,m|0,12)|0;a[b+44>>0]=o;o=Gd(n|0,m|0,20)|0;m=C;n=Hd(g|0,p|0,1)|0;a[b+45>>0]=n|o;o=Gd(g|0,p|0,7)|0;a[b+46>>0]=o;p=Gd(g|0,p|0,15)|0;o=C;g=Hd(h|0,r|0,6)|0;a[b+47>>0]=g|p;p=Gd(h|0,r|0,2)|0;a[b+48>>0]=p;p=Gd(h|0,r|0,10)|0;a[b+49>>0]=p;r=Gd(h|0,r|0,18)|0;h=C;p=Hd(s|0,u|0,3)|0;a[b+50>>0]=p|r;r=Gd(s|0,u|0,5)|0;a[b+51>>0]=r;u=Gd(s|0,u|0,13)|0;a[b+52>>0]=u;a[b+53>>0]=f;u=Gd(f|0,j|0,8)|0;a[b+54>>0]=u;j=Gd(f|0,j|0,16)|0;f=C;u=Hd(v|0,A|0,5)|0;a[b+55>>0]=u|j;j=Gd(v|0,A|0,3)|0;a[b+56>>0]=j;j=Gd(v|0,A|0,11)|0;a[b+57>>0]=j;A=Gd(v|0,A|0,19)|0;v=C;j=Hd(w|0,x|0,2)|0;a[b+58>>0]=j|A;A=Gd(w|0,x|0,6)|0;a[b+59>>0]=A;x=Gd(w|0,x|0,14)|0;w=C;A=Hd(B|0,y|0,7)|0;a[b+60>>0]=x|A;A=Gd(B|0,y|0,1)|0;a[b+61>>0]=A;A=Gd(B|0,y|0,9)|0;a[b+62>>0]=A;y=Gd(B|0,y|0,17)|0;a[b+63>>0]=y;y=q;B=y+64|0;do{a[y>>0]=0;y=y+1|0}while((y|0)<(B|0));y=t;B=y+64|0;do{a[y>>0]=0;y=y+1|0}while((y|0)<(B|0));if(!e){i=z;return}Ec=e;c[Ec>>2]=64;c[Ec+4>>2]=0;i=z;return}function Yc(b,c){b=b|0;c=c|0;return ((((a[c+1>>0]^a[b+1>>0]|a[c>>0]^a[b>>0]|a[c+2>>0]^a[b+2>>0]|a[c+3>>0]^a[b+3>>0]|a[c+4>>0]^a[b+4>>0]|a[c+5>>0]^a[b+5>>0]|a[c+6>>0]^a[b+6>>0]|a[c+7>>0]^a[b+7>>0]|a[c+8>>0]^a[b+8>>0]|a[c+9>>0]^a[b+9>>0]|a[c+10>>0]^a[b+10>>0]|a[c+11>>0]^a[b+11>>0]|a[c+12>>0]^a[b+12>>0]|a[c+13>>0]^a[b+13>>0]|a[c+14>>0]^a[b+14>>0]|a[c+15>>0]^a[b+15>>0]|a[c+16>>0]^a[b+16>>0]|a[c+17>>0]^a[b+17>>0]|a[c+18>>0]^a[b+18>>0]|a[c+19>>0]^a[b+19>>0]|a[c+20>>0]^a[b+20>>0]|a[c+21>>0]^a[b+21>>0]|a[c+22>>0]^a[b+22>>0]|a[c+23>>0]^a[b+23>>0]|a[c+24>>0]^a[b+24>>0]|a[c+25>>0]^a[b+25>>0]|a[c+26>>0]^a[b+26>>0]|a[c+27>>0]^a[b+27>>0]|a[c+28>>0]^a[b+28>>0]|a[c+29>>0]^a[b+29>>0]|a[c+30>>0]^a[b+30>>0]|a[c+31>>0]^a[b+31>>0])&255)+511|0)>>>8&1)+-1|0}function Zc(a){a=a|0;c[7976]=a;return 0}function _c(){return Ba(0)|0}function $c(){Ba(1);return}function ad(a){a=a|0;var b=0,d=0;b=c[7976]|0;if((b|0)!=0?(d=c[b+12>>2]|0,(d|0)!=0):0){a=Ea[d&31](a)|0;return a|0}if(a>>>0<2){a=0;return a|0}b=((0-a|0)>>>0)%(a>>>0)|0;do d=Ba(0)|0;while(d>>>0>>0);a=(d>>>0)%(a>>>0)|0;return a|0}function bd(b,c){b=b|0;c=c|0;var d=0;if(!c)return;else d=0;do{a[b+d>>0]=Ba(0)|0;d=d+1|0}while((d|0)!=(c|0));return}function cd(){var a=0;a=c[7976]|0;if(!a){a=0;return a|0}a=c[a+20>>2]|0;if(!a){a=0;return a|0}a=Da[a&31]()|0;return a|0}function dd(){var a=0,b=0;if(c[7977]|0){b=1;return b|0}Ba(1);a=na(30)|0;if((a|0)>0)c[7978]=a;else a=c[7978]|0;if(a>>>0<16)ra();else b=0;do{Ba(0)|0;b=b+1|0}while((b|0)!=16);c[7977]=1;b=0;return b|0}function ed(a,b){a=a|0;b=b|0;Fd(a|0,0,b|0)|0;return}function fd(b,c,e,f){b=b|0;c=c|0;e=e|0;f=f|0;var g=0,h=0,i=0,j=0;g=f<<1;if(!(f>>>0<2147483647&g>>>0>>0))ra();if(!f){f=0;f=b+f|0;a[f>>0]=0;return b|0}else c=0;do{j=d[e+c>>0]|0;i=j&15;j=j>>>4;h=c<<1;a[b+h>>0]=j+87+((j+65526|0)>>>8&217);a[b+(h|1)>>0]=((i<<8)+22272+(i+65526&55552)|0)>>>8;c=c+1|0}while((c|0)!=(f|0));j=b+g|0;a[j>>0]=0;return b|0}function gd(b,e,f,g,h,i,j){b=b|0;e=e|0;f=f|0;g=g|0;h=h|0;i=i|0;j=j|0;var k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0;a:do if(!g){n=0;l=0;o=0;k=0}else{b:do if(!h){n=0;r=0;l=0;k=0;while(1){p=d[f+l>>0]|0;m=p^48;o=(m+65526|0)>>>8;p=(p&223)+201|0;q=p&255;q=(q+65526^q+65520)>>>8;if(!((q|o)&255)){o=0;break a}m=q&p|o&m;if(n>>>0>=e>>>0){m=k;break b}if(!(k<<24>>24))m=m<<4&255;else{a[b+n>>0]=m|r&255;n=n+1|0;m=r}k=(k&255^255)&255;l=l+1|0;if(l>>>0>>0)r=m;else{o=0;break a}}}else{n=0;u=0;l=0;k=0;while(1){t=k<<24>>24==0;c:do if(!t){q=d[f+l>>0]|0;m=q^48;o=(m+65526|0)>>>8;q=(q&223)+201|0;p=q&255;p=(p+65526^p+65520)>>>8;if(!((p|o)&255)){o=0;break a}}else while(1){q=a[f+l>>0]|0;r=q&255;m=r^48;o=(m+65526|0)>>>8;s=(r&223)+201|0;p=s&255;p=(p+65526^p+65520)>>>8;if((p|o)&255){q=s;break c}s=ud(h,r)|0;if((s|0)==0?1:(a[s>>0]|0)!=q<<24>>24){o=0;k=0;break a}l=l+1|0;if(l>>>0>=g>>>0){o=0;k=0;break a}}while(0);m=p&q|o&m;if(n>>>0>=e>>>0){m=k;break b}if(t)m=m<<4&255;else{a[b+n>>0]=m|u&255;n=n+1|0;m=u}k=(k&255^255)&255;l=l+1|0;if(l>>>0>>0)u=m;else{o=0;break a}}}while(0);if(!(c[7979]|0))k=31964;else k=c[(oa()|0)+60>>2]|0;c[k>>2]=34;o=-1;k=m}while(0);if(j)c[j>>2]=f+(((k<<24>>24!=0)<<31>>31)+l);if(!i)return o|0;c[i>>2]=n;return o|0}function hd(){return 33779}function id(){return 8}function jd(){return 0}function kd(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0,xa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha=0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa=0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0,db=0,eb=0,fb=0,gb=0,hb=0,ib=0,jb=0,kb=0,lb=0,mb=0,nb=0,ob=0,pb=0,qb=0,rb=0,sb=0,tb=0,ub=0,vb=0,wb=0,xb=0,yb=0,zb=0,Ab=0,Bb=0,Cb=0,Db=0,Eb=0,Fb=0,Gb=0,Hb=0,Ib=0,Jb=0,Kb=0,Lb=0,Mb=0,Nb=0,Ob=0,Pb=0,Qb=0,Rb=0,Sb=0,Tb=0,Ub=0,Vb=0,Wb=0,Xb=0,Yb=0,Zb=0,_b=0,$b=0,ac=0,bc=0,cc=0,dc=0,ec=0,fc=0,gc=0,hc=0,ic=0,jc=0,kc=0,lc=0,mc=0,nc=0,oc=0,pc=0,qc=0,rc=0,sc=0,tc=0,uc=0,vc=0,wc=0,xc=0,yc=0,zc=0,Ac=0,Bc=0,Cc=0,Dc=0,Ec=0,Fc=0,Gc=0,Hc=0,Ic=0,Jc=0,Kc=0,Lc=0,Mc=0,Nc=0,Oc=0,Pc=0,Qc=0,Rc=0,Sc=0;l=c[b>>2]|0;s=c[b+4>>2]|0;j=c[b+8>>2]|0;Rb=c[b+12>>2]|0;e=c[b+16>>2]|0;za=c[b+20>>2]|0;ya=c[b+24>>2]|0;zb=c[b+28>>2]|0;h=c[b+32>>2]|0;ga=c[b+36>>2]|0;H=c[d>>2]|0;J=c[d+4>>2]|0;F=c[d+8>>2]|0;D=c[d+12>>2]|0;A=c[d+16>>2]|0;y=c[d+20>>2]|0;w=c[d+24>>2]|0;u=c[d+28>>2]|0;k=c[d+32>>2]|0;t=c[d+36>>2]|0;Oc=J*19|0;bc=F*19|0;rb=D*19|0;Ha=A*19|0;jc=y*19|0;Db=w*19|0;Ta=u*19|0;Sc=k*19|0;Qc=t*19|0;p=s<<1;f=Rb<<1;M=za<<1;i=zb<<1;d=ga<<1;o=((l|0)<0)<<31>>31;I=((H|0)<0)<<31>>31;Mc=Od(H|0,I|0,l|0,o|0)|0;Lc=C;K=((J|0)<0)<<31>>31;wc=Od(J|0,K|0,l|0,o|0)|0;vc=C;G=((F|0)<0)<<31>>31;ub=Od(F|0,G|0,l|0,o|0)|0;tb=C;E=((D|0)<0)<<31>>31;Ka=Od(D|0,E|0,l|0,o|0)|0;Ja=C;B=((A|0)<0)<<31>>31;mc=Od(A|0,B|0,l|0,o|0)|0;lc=C;z=((y|0)<0)<<31>>31;Gb=Od(y|0,z|0,l|0,o|0)|0;Fb=C;x=((w|0)<0)<<31>>31;Wa=Od(w|0,x|0,l|0,o|0)|0;Va=C;v=((u|0)<0)<<31>>31;ja=Od(u|0,v|0,l|0,o|0)|0;ia=C;Pc=((k|0)<0)<<31>>31;P=Od(k|0,Pc|0,l|0,o|0)|0;O=C;o=Od(t|0,((t|0)<0)<<31>>31|0,l|0,o|0)|0;l=C;t=((s|0)<0)<<31>>31;dc=Od(H|0,I|0,s|0,t|0)|0;ec=C;n=((p|0)<0)<<31>>31;yb=Od(J|0,K|0,p|0,n|0)|0;xb=C;Ma=Od(F|0,G|0,s|0,t|0)|0;La=C;oc=Od(D|0,E|0,p|0,n|0)|0;nc=C;Ib=Od(A|0,B|0,s|0,t|0)|0;Hb=C;Ya=Od(y|0,z|0,p|0,n|0)|0;Xa=C;la=Od(w|0,x|0,s|0,t|0)|0;ka=C;R=Od(u|0,v|0,p|0,n|0)|0;Q=C;t=Od(k|0,Pc|0,s|0,t|0)|0;s=C;Pc=((Qc|0)<0)<<31>>31;n=Od(Qc|0,Pc|0,p|0,n|0)|0;p=C;k=((j|0)<0)<<31>>31;wb=Od(H|0,I|0,j|0,k|0)|0;vb=C;Qa=Od(J|0,K|0,j|0,k|0)|0;Pa=C;qc=Od(F|0,G|0,j|0,k|0)|0;pc=C;Kb=Od(D|0,E|0,j|0,k|0)|0;Jb=C;_a=Od(A|0,B|0,j|0,k|0)|0;Za=C;na=Od(y|0,z|0,j|0,k|0)|0;ma=C;T=Od(w|0,x|0,j|0,k|0)|0;S=C;v=Od(u|0,v|0,j|0,k|0)|0;u=C;Rc=((Sc|0)<0)<<31>>31;yc=Od(Sc|0,Rc|0,j|0,k|0)|0;xc=C;k=Od(Qc|0,Pc|0,j|0,k|0)|0;j=C;Sb=((Rb|0)<0)<<31>>31;Oa=Od(H|0,I|0,Rb|0,Sb|0)|0;Na=C;fa=((f|0)<0)<<31>>31;uc=Od(J|0,K|0,f|0,fa|0)|0;tc=C;Mb=Od(F|0,G|0,Rb|0,Sb|0)|0;Lb=C;ab=Od(D|0,E|0,f|0,fa|0)|0;$a=C;pa=Od(A|0,B|0,Rb|0,Sb|0)|0;oa=C;V=Od(y|0,z|0,f|0,fa|0)|0;U=C;x=Od(w|0,x|0,Rb|0,Sb|0)|0;w=C;Ua=((Ta|0)<0)<<31>>31;Ac=Od(Ta|0,Ua|0,f|0,fa|0)|0;zc=C;Sb=Od(Sc|0,Rc|0,Rb|0,Sb|0)|0;Rb=C;fa=Od(Qc|0,Pc|0,f|0,fa|0)|0;f=C;N=((e|0)<0)<<31>>31;sc=Od(H|0,I|0,e|0,N|0)|0;rc=C;Qb=Od(J|0,K|0,e|0,N|0)|0;Pb=C;cb=Od(F|0,G|0,e|0,N|0)|0;bb=C;ra=Od(D|0,E|0,e|0,N|0)|0;qa=C;X=Od(A|0,B|0,e|0,N|0)|0;W=C;z=Od(y|0,z|0,e|0,N|0)|0;y=C;Eb=((Db|0)<0)<<31>>31;Cc=Od(Db|0,Eb|0,e|0,N|0)|0;Bc=C;Ub=Od(Ta|0,Ua|0,e|0,N|0)|0;Tb=C;ib=Od(Sc|0,Rc|0,e|0,N|0)|0;hb=C;N=Od(Qc|0,Pc|0,e|0,N|0)|0;e=C;Aa=((za|0)<0)<<31>>31;Ob=Od(H|0,I|0,za|0,Aa|0)|0;Nb=C;b=((M|0)<0)<<31>>31;gb=Od(J|0,K|0,M|0,b|0)|0;fb=C;ta=Od(F|0,G|0,za|0,Aa|0)|0;sa=C;Z=Od(D|0,E|0,M|0,b|0)|0;Y=C;B=Od(A|0,B|0,za|0,Aa|0)|0;A=C;kc=((jc|0)<0)<<31>>31;Ec=Od(jc|0,kc|0,M|0,b|0)|0;Dc=C;Wb=Od(Db|0,Eb|0,za|0,Aa|0)|0;Vb=C;kb=Od(Ta|0,Ua|0,M|0,b|0)|0;jb=C;Aa=Od(Sc|0,Rc|0,za|0,Aa|0)|0;za=C;b=Od(Qc|0,Pc|0,M|0,b|0)|0;M=C;g=((ya|0)<0)<<31>>31;eb=Od(H|0,I|0,ya|0,g|0)|0;db=C;xa=Od(J|0,K|0,ya|0,g|0)|0;wa=C;$=Od(F|0,G|0,ya|0,g|0)|0;_=C;E=Od(D|0,E|0,ya|0,g|0)|0;D=C;Ia=((Ha|0)<0)<<31>>31;Gc=Od(Ha|0,Ia|0,ya|0,g|0)|0;Fc=C;Yb=Od(jc|0,kc|0,ya|0,g|0)|0;Xb=C;mb=Od(Db|0,Eb|0,ya|0,g|0)|0;lb=C;Ca=Od(Ta|0,Ua|0,ya|0,g|0)|0;Ba=C;m=Od(Sc|0,Rc|0,ya|0,g|0)|0;r=C;g=Od(Qc|0,Pc|0,ya|0,g|0)|0;ya=C;Ab=((zb|0)<0)<<31>>31;va=Od(H|0,I|0,zb|0,Ab|0)|0;ua=C;ea=((i|0)<0)<<31>>31;da=Od(J|0,K|0,i|0,ea|0)|0;ca=C;G=Od(F|0,G|0,zb|0,Ab|0)|0;F=C;sb=((rb|0)<0)<<31>>31;Ic=Od(rb|0,sb|0,i|0,ea|0)|0;Hc=C;_b=Od(Ha|0,Ia|0,zb|0,Ab|0)|0;Zb=C;ob=Od(jc|0,kc|0,i|0,ea|0)|0;nb=C;Ea=Od(Db|0,Eb|0,zb|0,Ab|0)|0;Da=C;gc=Od(Ta|0,Ua|0,i|0,ea|0)|0;fc=C;Ab=Od(Sc|0,Rc|0,zb|0,Ab|0)|0;zb=C;ea=Od(Qc|0,Pc|0,i|0,ea|0)|0;i=C;L=((h|0)<0)<<31>>31;ba=Od(H|0,I|0,h|0,L|0)|0;aa=C;K=Od(J|0,K|0,h|0,L|0)|0;J=C;cc=((bc|0)<0)<<31>>31;Kc=Od(bc|0,cc|0,h|0,L|0)|0;Jc=C;ac=Od(rb|0,sb|0,h|0,L|0)|0;$b=C;qb=Od(Ha|0,Ia|0,h|0,L|0)|0;pb=C;Ga=Od(jc|0,kc|0,h|0,L|0)|0;Fa=C;ic=Od(Db|0,Eb|0,h|0,L|0)|0;hc=C;Cb=Od(Ta|0,Ua|0,h|0,L|0)|0;Bb=C;Sa=Od(Sc|0,Rc|0,h|0,L|0)|0;Ra=C;L=Od(Qc|0,Pc|0,h|0,L|0)|0;h=C;ha=((ga|0)<0)<<31>>31;I=Od(H|0,I|0,ga|0,ha|0)|0;H=C;q=((d|0)<0)<<31>>31;Oc=Od(Oc|0,((Oc|0)<0)<<31>>31|0,d|0,q|0)|0;Nc=C;cc=Od(bc|0,cc|0,ga|0,ha|0)|0;bc=C;sb=Od(rb|0,sb|0,d|0,q|0)|0;rb=C;Ia=Od(Ha|0,Ia|0,ga|0,ha|0)|0;Ha=C;kc=Od(jc|0,kc|0,d|0,q|0)|0;jc=C;Eb=Od(Db|0,Eb|0,ga|0,ha|0)|0;Db=C;Ua=Od(Ta|0,Ua|0,d|0,q|0)|0;Ta=C;ha=Od(Sc|0,Rc|0,ga|0,ha|0)|0;ga=C;q=Od(Qc|0,Pc|0,d|0,q|0)|0;d=C;Lc=Dd(Oc|0,Nc|0,Mc|0,Lc|0)|0;Jc=Dd(Lc|0,C|0,Kc|0,Jc|0)|0;Hc=Dd(Jc|0,C|0,Ic|0,Hc|0)|0;Fc=Dd(Hc|0,C|0,Gc|0,Fc|0)|0;Dc=Dd(Fc|0,C|0,Ec|0,Dc|0)|0;Bc=Dd(Dc|0,C|0,Cc|0,Bc|0)|0;zc=Dd(Bc|0,C|0,Ac|0,zc|0)|0;xc=Dd(zc|0,C|0,yc|0,xc|0)|0;p=Dd(xc|0,C|0,n|0,p|0)|0;n=C;ec=Dd(wc|0,vc|0,dc|0,ec|0)|0;dc=C;rc=Dd(uc|0,tc|0,sc|0,rc|0)|0;pc=Dd(rc|0,C|0,qc|0,pc|0)|0;nc=Dd(pc|0,C|0,oc|0,nc|0)|0;lc=Dd(nc|0,C|0,mc|0,lc|0)|0;jc=Dd(lc|0,C|0,kc|0,jc|0)|0;hc=Dd(jc|0,C|0,ic|0,hc|0)|0;fc=Dd(hc|0,C|0,gc|0,fc|0)|0;r=Dd(fc|0,C|0,m|0,r|0)|0;M=Dd(r|0,C|0,b|0,M|0)|0;b=C;r=Dd(p|0,n|0,33554432,0)|0;r=Ed(r|0,C|0,26)|0;m=C;bc=Dd(ec|0,dc|0,cc|0,bc|0)|0;$b=Dd(bc|0,C|0,ac|0,$b|0)|0;Zb=Dd($b|0,C|0,_b|0,Zb|0)|0;Xb=Dd(Zb|0,C|0,Yb|0,Xb|0)|0;Vb=Dd(Xb|0,C|0,Wb|0,Vb|0)|0;Tb=Dd(Vb|0,C|0,Ub|0,Tb|0)|0;Rb=Dd(Tb|0,C|0,Sb|0,Rb|0)|0;j=Dd(Rb|0,C|0,k|0,j|0)|0;j=Dd(j|0,C|0,r|0,m|0)|0;k=C;m=Hd(r|0,m|0,26)|0;m=Cd(p|0,n|0,m|0,C|0)|0;n=C;p=Dd(M|0,b|0,33554432,0)|0;p=Ed(p|0,C|0,26)|0;r=C;Nb=Dd(Qb|0,Pb|0,Ob|0,Nb|0)|0;Lb=Dd(Nb|0,C|0,Mb|0,Lb|0)|0;Jb=Dd(Lb|0,C|0,Kb|0,Jb|0)|0;Hb=Dd(Jb|0,C|0,Ib|0,Hb|0)|0;Fb=Dd(Hb|0,C|0,Gb|0,Fb|0)|0;Db=Dd(Fb|0,C|0,Eb|0,Db|0)|0;Bb=Dd(Db|0,C|0,Cb|0,Bb|0)|0;zb=Dd(Bb|0,C|0,Ab|0,zb|0)|0;ya=Dd(zb|0,C|0,g|0,ya|0)|0;ya=Dd(ya|0,C|0,p|0,r|0)|0;g=C;r=Hd(p|0,r|0,26)|0;r=Cd(M|0,b|0,r|0,C|0)|0;b=C;M=Dd(j|0,k|0,16777216,0)|0;M=Ed(M|0,C|0,25)|0;p=C;vb=Dd(yb|0,xb|0,wb|0,vb|0)|0;tb=Dd(vb|0,C|0,ub|0,tb|0)|0;rb=Dd(tb|0,C|0,sb|0,rb|0)|0;pb=Dd(rb|0,C|0,qb|0,pb|0)|0;nb=Dd(pb|0,C|0,ob|0,nb|0)|0;lb=Dd(nb|0,C|0,mb|0,lb|0)|0;jb=Dd(lb|0,C|0,kb|0,jb|0)|0;hb=Dd(jb|0,C|0,ib|0,hb|0)|0;f=Dd(hb|0,C|0,fa|0,f|0)|0;f=Dd(f|0,C|0,M|0,p|0)|0;fa=C;p=Hd(M|0,p|0,25)|0;p=Cd(j|0,k|0,p|0,C|0)|0;k=C;j=Dd(ya|0,g|0,16777216,0)|0;j=Ed(j|0,C|0,25)|0;M=C;db=Dd(gb|0,fb|0,eb|0,db|0)|0;bb=Dd(db|0,C|0,cb|0,bb|0)|0;$a=Dd(bb|0,C|0,ab|0,$a|0)|0;Za=Dd($a|0,C|0,_a|0,Za|0)|0;Xa=Dd(Za|0,C|0,Ya|0,Xa|0)|0;Va=Dd(Xa|0,C|0,Wa|0,Va|0)|0;Ta=Dd(Va|0,C|0,Ua|0,Ta|0)|0;Ra=Dd(Ta|0,C|0,Sa|0,Ra|0)|0;i=Dd(Ra|0,C|0,ea|0,i|0)|0;i=Dd(i|0,C|0,j|0,M|0)|0;ea=C;M=Hd(j|0,M|0,25)|0;M=Cd(ya|0,g|0,M|0,C|0)|0;g=C;ya=Dd(f|0,fa|0,33554432,0)|0;ya=Ed(ya|0,C|0,26)|0;j=C;Na=Dd(Qa|0,Pa|0,Oa|0,Na|0)|0;La=Dd(Na|0,C|0,Ma|0,La|0)|0;Ja=Dd(La|0,C|0,Ka|0,Ja|0)|0;Ha=Dd(Ja|0,C|0,Ia|0,Ha|0)|0;Fa=Dd(Ha|0,C|0,Ga|0,Fa|0)|0;Da=Dd(Fa|0,C|0,Ea|0,Da|0)|0;Ba=Dd(Da|0,C|0,Ca|0,Ba|0)|0;za=Dd(Ba|0,C|0,Aa|0,za|0)|0;e=Dd(za|0,C|0,N|0,e|0)|0;e=Dd(e|0,C|0,ya|0,j|0)|0;N=C;j=Hd(ya|0,j|0,26)|0;j=Cd(f|0,fa|0,j|0,C|0)|0;fa=Dd(i|0,ea|0,33554432,0)|0;fa=Ed(fa|0,C|0,26)|0;f=C;ua=Dd(xa|0,wa|0,va|0,ua|0)|0;sa=Dd(ua|0,C|0,ta|0,sa|0)|0;qa=Dd(sa|0,C|0,ra|0,qa|0)|0;oa=Dd(qa|0,C|0,pa|0,oa|0)|0;ma=Dd(oa|0,C|0,na|0,ma|0)|0;ka=Dd(ma|0,C|0,la|0,ka|0)|0;ia=Dd(ka|0,C|0,ja|0,ia|0)|0;ga=Dd(ia|0,C|0,ha|0,ga|0)|0;h=Dd(ga|0,C|0,L|0,h|0)|0;h=Dd(h|0,C|0,fa|0,f|0)|0;L=C;f=Hd(fa|0,f|0,26)|0;f=Cd(i|0,ea|0,f|0,C|0)|0;ea=Dd(e|0,N|0,16777216,0)|0;ea=Ed(ea|0,C|0,25)|0;i=C;b=Dd(ea|0,i|0,r|0,b|0)|0;r=C;i=Hd(ea|0,i|0,25)|0;i=Cd(e|0,N|0,i|0,C|0)|0;N=Dd(h|0,L|0,16777216,0)|0;N=Ed(N|0,C|0,25)|0;e=C;aa=Dd(da|0,ca|0,ba|0,aa|0)|0;_=Dd(aa|0,C|0,$|0,_|0)|0;Y=Dd(_|0,C|0,Z|0,Y|0)|0;W=Dd(Y|0,C|0,X|0,W|0)|0;U=Dd(W|0,C|0,V|0,U|0)|0;S=Dd(U|0,C|0,T|0,S|0)|0;Q=Dd(S|0,C|0,R|0,Q|0)|0;O=Dd(Q|0,C|0,P|0,O|0)|0;d=Dd(O|0,C|0,q|0,d|0)|0;d=Dd(d|0,C|0,N|0,e|0)|0;q=C;e=Hd(N|0,e|0,25)|0;e=Cd(h|0,L|0,e|0,C|0)|0;L=Dd(b|0,r|0,33554432,0)|0;L=Ed(L|0,C|0,26)|0;h=C;g=Dd(M|0,g|0,L|0,h|0)|0;h=Hd(L|0,h|0,26)|0;h=Cd(b|0,r|0,h|0,C|0)|0;r=Dd(d|0,q|0,33554432,0)|0;r=Ed(r|0,C|0,26)|0;b=C;H=Dd(K|0,J|0,I|0,H|0)|0;F=Dd(H|0,C|0,G|0,F|0)|0;D=Dd(F|0,C|0,E|0,D|0)|0;A=Dd(D|0,C|0,B|0,A|0)|0;y=Dd(A|0,C|0,z|0,y|0)|0;w=Dd(y|0,C|0,x|0,w|0)|0;u=Dd(w|0,C|0,v|0,u|0)|0;s=Dd(u|0,C|0,t|0,s|0)|0;l=Dd(s|0,C|0,o|0,l|0)|0;l=Dd(l|0,C|0,r|0,b|0)|0;o=C;b=Hd(r|0,b|0,26)|0;b=Cd(d|0,q|0,b|0,C|0)|0;q=Dd(l|0,o|0,16777216,0)|0;q=Ed(q|0,C|0,25)|0;d=C;r=Od(q|0,d|0,19,0)|0;n=Dd(r|0,C|0,m|0,n|0)|0;m=C;d=Hd(q|0,d|0,25)|0;d=Cd(l|0,o|0,d|0,C|0)|0;o=Dd(n|0,m|0,33554432,0)|0;o=Ed(o|0,C|0,26)|0;l=C;k=Dd(p|0,k|0,o|0,l|0)|0;l=Hd(o|0,l|0,26)|0;l=Cd(n|0,m|0,l|0,C|0)|0;c[a>>2]=l;c[a+4>>2]=k;c[a+8>>2]=j;c[a+12>>2]=i;c[a+16>>2]=h;c[a+20>>2]=g;c[a+24>>2]=f;c[a+28>>2]=e;c[a+32>>2]=b;c[a+36>>2]=d;return}function ld(a,b){a=a|0;b=b|0;var d=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0,xa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha=0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa=0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0,db=0,eb=0,fb=0,gb=0;bb=c[b>>2]|0;ua=c[b+4>>2]|0;j=c[b+8>>2]|0;la=c[b+12>>2]|0;e=c[b+16>>2]|0;db=c[b+20>>2]|0;Y=c[b+24>>2]|0;La=c[b+28>>2]|0;h=c[b+32>>2]|0;b=c[b+36>>2]|0;l=bb<<1;p=ua<<1;Xa=j<<1;f=la<<1;na=e<<1;B=db<<1;m=Y<<1;i=La<<1;Ka=db*38|0;ra=Y*19|0;va=La*38|0;da=h*19|0;gb=b*38|0;cb=((bb|0)<0)<<31>>31;cb=Od(bb|0,cb|0,bb|0,cb|0)|0;bb=C;o=((l|0)<0)<<31>>31;ta=((ua|0)<0)<<31>>31;Ia=Od(l|0,o|0,ua|0,ta|0)|0;Ha=C;k=((j|0)<0)<<31>>31;Wa=Od(j|0,k|0,l|0,o|0)|0;Va=C;ma=((la|0)<0)<<31>>31;Ua=Od(la|0,ma|0,l|0,o|0)|0;Ta=C;D=((e|0)<0)<<31>>31;Oa=Od(e|0,D|0,l|0,o|0)|0;Na=C;eb=((db|0)<0)<<31>>31;ya=Od(db|0,eb|0,l|0,o|0)|0;xa=C;g=((Y|0)<0)<<31>>31;ga=Od(Y|0,g|0,l|0,o|0)|0;fa=C;Ma=((La|0)<0)<<31>>31;R=Od(La|0,Ma|0,l|0,o|0)|0;Q=C;A=((h|0)<0)<<31>>31;F=Od(h|0,A|0,l|0,o|0)|0;E=C;q=((b|0)<0)<<31>>31;o=Od(b|0,q|0,l|0,o|0)|0;l=C;n=((p|0)<0)<<31>>31;ta=Od(p|0,n|0,ua|0,ta|0)|0;ua=C;ba=Od(p|0,n|0,j|0,k|0)|0;ca=C;P=((f|0)<0)<<31>>31;Sa=Od(f|0,P|0,p|0,n|0)|0;Ra=C;Ca=Od(e|0,D|0,p|0,n|0)|0;Ba=C;d=((B|0)<0)<<31>>31;ia=Od(B|0,d|0,p|0,n|0)|0;ha=C;T=Od(Y|0,g|0,p|0,n|0)|0;S=C;O=((i|0)<0)<<31>>31;H=Od(i|0,O|0,p|0,n|0)|0;G=C;t=Od(h|0,A|0,p|0,n|0)|0;s=C;fb=((gb|0)<0)<<31>>31;n=Od(gb|0,fb|0,p|0,n|0)|0;p=C;Qa=Od(j|0,k|0,j|0,k|0)|0;Pa=C;Ya=((Xa|0)<0)<<31>>31;Aa=Od(Xa|0,Ya|0,la|0,ma|0)|0;za=C;ka=Od(e|0,D|0,Xa|0,Ya|0)|0;ja=C;X=Od(db|0,eb|0,Xa|0,Ya|0)|0;W=C;N=Od(Y|0,g|0,Xa|0,Ya|0)|0;M=C;v=Od(La|0,Ma|0,Xa|0,Ya|0)|0;u=C;ea=((da|0)<0)<<31>>31;Ya=Od(da|0,ea|0,Xa|0,Ya|0)|0;Xa=C;k=Od(gb|0,fb|0,j|0,k|0)|0;j=C;ma=Od(f|0,P|0,la|0,ma|0)|0;la=C;V=Od(f|0,P|0,e|0,D|0)|0;U=C;J=Od(B|0,d|0,f|0,P|0)|0;I=C;z=Od(Y|0,g|0,f|0,P|0)|0;y=C;wa=((va|0)<0)<<31>>31;_a=Od(va|0,wa|0,f|0,P|0)|0;Za=C;Ea=Od(da|0,ea|0,f|0,P|0)|0;Da=C;P=Od(gb|0,fb|0,f|0,P|0)|0;f=C;L=Od(e|0,D|0,e|0,D|0)|0;K=C;oa=((na|0)<0)<<31>>31;x=Od(na|0,oa|0,db|0,eb|0)|0;w=C;sa=((ra|0)<0)<<31>>31;ab=Od(ra|0,sa|0,na|0,oa|0)|0;$a=C;Ga=Od(va|0,wa|0,e|0,D|0)|0;Fa=C;oa=Od(da|0,ea|0,na|0,oa|0)|0;na=C;D=Od(gb|0,fb|0,e|0,D|0)|0;e=C;eb=Od(Ka|0,((Ka|0)<0)<<31>>31|0,db|0,eb|0)|0;db=C;Ka=Od(ra|0,sa|0,B|0,d|0)|0;Ja=C;qa=Od(va|0,wa|0,B|0,d|0)|0;pa=C;_=Od(da|0,ea|0,B|0,d|0)|0;Z=C;d=Od(gb|0,fb|0,B|0,d|0)|0;B=C;sa=Od(ra|0,sa|0,Y|0,g|0)|0;ra=C;aa=Od(va|0,wa|0,Y|0,g|0)|0;$=C;m=Od(da|0,ea|0,m|0,((m|0)<0)<<31>>31|0)|0;r=C;g=Od(gb|0,fb|0,Y|0,g|0)|0;Y=C;Ma=Od(va|0,wa|0,La|0,Ma|0)|0;La=C;wa=Od(da|0,ea|0,i|0,O|0)|0;va=C;O=Od(gb|0,fb|0,i|0,O|0)|0;i=C;ea=Od(da|0,ea|0,h|0,A|0)|0;da=C;A=Od(gb|0,fb|0,h|0,A|0)|0;h=C;q=Od(gb|0,fb|0,b|0,q|0)|0;b=C;bb=Dd(eb|0,db|0,cb|0,bb|0)|0;$a=Dd(bb|0,C|0,ab|0,$a|0)|0;Za=Dd($a|0,C|0,_a|0,Za|0)|0;Xa=Dd(Za|0,C|0,Ya|0,Xa|0)|0;p=Dd(Xa|0,C|0,n|0,p|0)|0;n=C;ua=Dd(Wa|0,Va|0,ta|0,ua|0)|0;ta=C;ca=Dd(Ua|0,Ta|0,ba|0,ca|0)|0;ba=C;Pa=Dd(Sa|0,Ra|0,Qa|0,Pa|0)|0;Na=Dd(Pa|0,C|0,Oa|0,Na|0)|0;La=Dd(Na|0,C|0,Ma|0,La|0)|0;r=Dd(La|0,C|0,m|0,r|0)|0;B=Dd(r|0,C|0,d|0,B|0)|0;d=C;r=Dd(p|0,n|0,33554432,0)|0;r=Ed(r|0,C|0,26)|0;m=C;Ha=Dd(Ka|0,Ja|0,Ia|0,Ha|0)|0;Fa=Dd(Ha|0,C|0,Ga|0,Fa|0)|0;Da=Dd(Fa|0,C|0,Ea|0,Da|0)|0;j=Dd(Da|0,C|0,k|0,j|0)|0;j=Dd(j|0,C|0,r|0,m|0)|0;k=C;m=Hd(r|0,m|0,26)|0;m=Cd(p|0,n|0,m|0,C|0)|0;n=C;p=Dd(B|0,d|0,33554432,0)|0;p=Ed(p|0,C|0,26)|0;r=C;za=Dd(Ca|0,Ba|0,Aa|0,za|0)|0;xa=Dd(za|0,C|0,ya|0,xa|0)|0;va=Dd(xa|0,C|0,wa|0,va|0)|0;Y=Dd(va|0,C|0,g|0,Y|0)|0;Y=Dd(Y|0,C|0,p|0,r|0)|0;g=C;r=Hd(p|0,r|0,26)|0;r=Cd(B|0,d|0,r|0,C|0)|0;d=C;B=Dd(j|0,k|0,16777216,0)|0;B=Ed(B|0,C|0,25)|0;p=C;ra=Dd(ua|0,ta|0,sa|0,ra|0)|0;pa=Dd(ra|0,C|0,qa|0,pa|0)|0;na=Dd(pa|0,C|0,oa|0,na|0)|0;f=Dd(na|0,C|0,P|0,f|0)|0;f=Dd(f|0,C|0,B|0,p|0)|0;P=C;p=Hd(B|0,p|0,25)|0;p=Cd(j|0,k|0,p|0,C|0)|0;k=C;j=Dd(Y|0,g|0,16777216,0)|0;j=Ed(j|0,C|0,25)|0;B=C;ja=Dd(ma|0,la|0,ka|0,ja|0)|0;ha=Dd(ja|0,C|0,ia|0,ha|0)|0;fa=Dd(ha|0,C|0,ga|0,fa|0)|0;da=Dd(fa|0,C|0,ea|0,da|0)|0;i=Dd(da|0,C|0,O|0,i|0)|0;i=Dd(i|0,C|0,j|0,B|0)|0;O=C;B=Hd(j|0,B|0,25)|0;B=Cd(Y|0,g|0,B|0,C|0)|0;g=C;Y=Dd(f|0,P|0,33554432,0)|0;Y=Ed(Y|0,C|0,26)|0;j=C;$=Dd(ca|0,ba|0,aa|0,$|0)|0;Z=Dd($|0,C|0,_|0,Z|0)|0;e=Dd(Z|0,C|0,D|0,e|0)|0;e=Dd(e|0,C|0,Y|0,j|0)|0;D=C;j=Hd(Y|0,j|0,26)|0;j=Cd(f|0,P|0,j|0,C|0)|0;P=Dd(i|0,O|0,33554432,0)|0;P=Ed(P|0,C|0,26)|0;f=C;U=Dd(X|0,W|0,V|0,U|0)|0;S=Dd(U|0,C|0,T|0,S|0)|0;Q=Dd(S|0,C|0,R|0,Q|0)|0;h=Dd(Q|0,C|0,A|0,h|0)|0;h=Dd(h|0,C|0,P|0,f|0)|0;A=C;f=Hd(P|0,f|0,26)|0;f=Cd(i|0,O|0,f|0,C|0)|0;O=Dd(e|0,D|0,16777216,0)|0;O=Ed(O|0,C|0,25)|0;i=C;d=Dd(O|0,i|0,r|0,d|0)|0;r=C;i=Hd(O|0,i|0,25)|0;i=Cd(e|0,D|0,i|0,C|0)|0;D=Dd(h|0,A|0,16777216,0)|0;D=Ed(D|0,C|0,25)|0;e=C;K=Dd(N|0,M|0,L|0,K|0)|0;I=Dd(K|0,C|0,J|0,I|0)|0;G=Dd(I|0,C|0,H|0,G|0)|0;E=Dd(G|0,C|0,F|0,E|0)|0;b=Dd(E|0,C|0,q|0,b|0)|0;b=Dd(b|0,C|0,D|0,e|0)|0;q=C;e=Hd(D|0,e|0,25)|0;e=Cd(h|0,A|0,e|0,C|0)|0;A=Dd(d|0,r|0,33554432,0)|0;A=Ed(A|0,C|0,26)|0;h=C;g=Dd(B|0,g|0,A|0,h|0)|0;h=Hd(A|0,h|0,26)|0;h=Cd(d|0,r|0,h|0,C|0)|0;r=Dd(b|0,q|0,33554432,0)|0;r=Ed(r|0,C|0,26)|0;d=C;w=Dd(z|0,y|0,x|0,w|0)|0;u=Dd(w|0,C|0,v|0,u|0)|0;s=Dd(u|0,C|0,t|0,s|0)|0;l=Dd(s|0,C|0,o|0,l|0)|0;l=Dd(l|0,C|0,r|0,d|0)|0;o=C;d=Hd(r|0,d|0,26)|0;d=Cd(b|0,q|0,d|0,C|0)|0;q=Dd(l|0,o|0,16777216,0)|0;q=Ed(q|0,C|0,25)|0;b=C;r=Od(q|0,b|0,19,0)|0;n=Dd(r|0,C|0,m|0,n|0)|0;m=C;b=Hd(q|0,b|0,25)|0;b=Cd(l|0,o|0,b|0,C|0)|0;o=Dd(n|0,m|0,33554432,0)|0;o=Ed(o|0,C|0,26)|0;l=C;k=Dd(p|0,k|0,o|0,l|0)|0;l=Hd(o|0,l|0,26)|0;l=Cd(n|0,m|0,l|0,C|0)|0;c[a>>2]=l;c[a+4>>2]=k;c[a+8>>2]=j;c[a+12>>2]=i;c[a+16>>2]=h;c[a+20>>2]=g;c[a+24>>2]=f;c[a+28>>2]=e;c[a+32>>2]=d;c[a+36>>2]=b;return}function md(b,e,f){b=b|0;e=e|0;f=f|0;var g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0,xa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha=0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa=0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0,db=0,eb=0,fb=0,gb=0,hb=0,ib=0,jb=0,kb=0,lb=0,mb=0,nb=0;Ya=i;Oa=i=i+63&-64;i=i+480|0;Ta=Oa+400|0;Ua=Oa+360|0;Va=Oa+320|0;Sa=Oa+280|0;Ma=Oa+440|0;Pa=Oa+240|0;Wa=Oa+200|0;Xa=Oa+160|0;Qa=Oa+120|0;Ra=Oa+80|0;Na=Oa+40|0;h=Ma;g=h+32|0;do{a[h>>0]=a[e>>0]|0;h=h+1|0;e=e+1|0}while((h|0)<(g|0));a[Ma>>0]=(d[Ma>>0]|0)&248;m=Ma+31|0;a[m>>0]=(d[m>>0]|0)&63|64;m=d[f>>0]|0;Da=Hd(d[f+1>>0]|0|0,0,8)|0;j=C;va=Hd(d[f+2>>0]|0|0,0,16)|0;j=j|C;Aa=Hd(d[f+3>>0]|0|0,0,24)|0;j=j|C;k=a[f+6>>0]|0;l=d[f+4>>0]|0;ya=Hd(d[f+5>>0]|0|0,0,8)|0;za=C;k=Hd(k&255|0,0,16)|0;za=Hd(ya|l|k|0,za|C|0,6)|0;k=C;l=a[f+9>>0]|0;ya=d[f+7>>0]|0;n=Hd(d[f+8>>0]|0|0,0,8)|0;Ea=C;l=Hd(l&255|0,0,16)|0;Ea=Hd(n|ya|l|0,Ea|C|0,5)|0;l=C;ya=a[f+12>>0]|0;n=d[f+10>>0]|0;Ga=Hd(d[f+11>>0]|0|0,0,8)|0;xa=C;ya=Hd(ya&255|0,0,16)|0;xa=Hd(Ga|n|ya|0,xa|C|0,3)|0;ya=C;n=a[f+15>>0]|0;Ga=d[f+13>>0]|0;h=Hd(d[f+14>>0]|0|0,0,8)|0;Ia=C;n=Hd(n&255|0,0,16)|0;Ia=Hd(h|Ga|n|0,Ia|C|0,2)|0;n=C;Ga=d[f+16>>0]|0;h=Hd(d[f+17>>0]|0|0,0,8)|0;Ca=C;p=Hd(d[f+18>>0]|0|0,0,16)|0;Ca=Ca|C;Ba=Hd(d[f+19>>0]|0|0,0,24)|0;Ba=h|Ga|p|Ba;Ca=Ca|C;p=a[f+22>>0]|0;Ga=d[f+20>>0]|0;h=Hd(d[f+21>>0]|0|0,0,8)|0;g=C;p=Hd(p&255|0,0,16)|0;g=Hd(h|Ga|p|0,g|C|0,7)|0;p=C;Ga=a[f+25>>0]|0;h=d[f+23>>0]|0;q=Hd(d[f+24>>0]|0|0,0,8)|0;Fa=C;Ga=Hd(Ga&255|0,0,16)|0;Fa=Hd(q|h|Ga|0,Fa|C|0,5)|0;Ga=C;h=a[f+28>>0]|0;q=d[f+26>>0]|0;Ka=Hd(d[f+27>>0]|0|0,0,8)|0;La=C;h=Hd(h&255|0,0,16)|0;La=Hd(Ka|q|h|0,La|C|0,4)|0;h=C;q=a[f+31>>0]|0;Ka=d[f+29>>0]|0;f=Hd(d[f+30>>0]|0|0,0,8)|0;Ja=C;q=Hd(q&255|0,0,16)|0;Ja=Hd(f|Ka|q|0,Ja|C|0,2)|0;Ja=Ja&33554428;q=Dd(Ja|0,0,16777216,0)|0;q=Gd(q|0,C|0,25)|0;Ka=C;f=Cd(0,0,q|0,Ka|0)|0;j=Dd(f&19|0,0,Da|m|va|Aa|0,j|0)|0;Aa=C;Ka=Hd(q|0,Ka|0,25)|0;q=C;f=Dd(za|0,k|0,16777216,0)|0;f=Gd(f|0,C|0,25)|0;va=C;l=Dd(Ea|0,l|0,f|0,va|0)|0;Ea=C;va=Hd(f|0,va|0,25)|0;va=Cd(za|0,k|0,va|0,C|0)|0;f=C;k=Dd(xa|0,ya|0,16777216,0)|0;k=Gd(k|0,C|0,25)|0;za=C;n=Dd(Ia|0,n|0,k|0,za|0)|0;Ia=C;za=Hd(k|0,za|0,25)|0;k=C;m=Dd(Ba|0,Ca|0,16777216,0)|0;m=Gd(m|0,C|0,25)|0;Da=C;p=Dd(g|0,p|0,m|0,Da|0)|0;g=C;Da=Hd(m|0,Da|0,25)|0;m=C;o=Dd(Fa|0,Ga|0,16777216,0)|0;o=Gd(o|0,C|0,25)|0;Ha=C;h=Dd(La|0,h|0,o|0,Ha|0)|0;La=C;Ha=Hd(o|0,Ha|0,25)|0;o=C;wa=Dd(j|0,Aa|0,33554432,0)|0;wa=Ed(wa|0,C|0,26)|0;e=C;f=Dd(va|0,f|0,wa|0,e|0)|0;e=Hd(wa|0,e|0,26)|0;e=Cd(j|0,Aa|0,e|0,C|0)|0;Aa=Dd(l|0,Ea|0,33554432,0)|0;Aa=Ed(Aa|0,C|0,26)|0;j=C;ya=Dd(Aa|0,j|0,xa|0,ya|0)|0;k=Cd(ya|0,C|0,za|0,k|0)|0;j=Hd(Aa|0,j|0,26)|0;j=Cd(l|0,Ea|0,j|0,C|0)|0;Ea=Dd(n|0,Ia|0,33554432,0)|0;Ea=Ed(Ea|0,C|0,26)|0;l=C;Ca=Dd(Ea|0,l|0,Ba|0,Ca|0)|0;m=Cd(Ca|0,C|0,Da|0,m|0)|0;l=Hd(Ea|0,l|0,26)|0;l=Cd(n|0,Ia|0,l|0,C|0)|0;Ia=Dd(p|0,g|0,33554432,0)|0;Ia=Ed(Ia|0,C|0,26)|0;n=C;Ga=Dd(Ia|0,n|0,Fa|0,Ga|0)|0;o=Cd(Ga|0,C|0,Ha|0,o|0)|0;n=Hd(Ia|0,n|0,26)|0;n=Cd(p|0,g|0,n|0,C|0)|0;g=Dd(h|0,La|0,33554432,0)|0;g=Ed(g|0,C|0,26)|0;p=C;Ja=Dd(Ja|0,0,g|0,p|0)|0;q=Cd(Ja|0,C|0,Ka|0,q|0)|0;p=Hd(g|0,p|0,26)|0;p=Cd(h|0,La|0,p|0,C|0)|0;c[Pa>>2]=e;c[Pa+4>>2]=f;c[Pa+8>>2]=j;c[Pa+12>>2]=k;c[Pa+16>>2]=l;c[Pa+20>>2]=m;c[Pa+24>>2]=n;c[Pa+28>>2]=o;c[Pa+32>>2]=p;c[Pa+36>>2]=q;c[Wa>>2]=1;La=Wa+4|0;h=La;g=h+36|0;do{c[h>>2]=0;h=h+4|0}while((h|0)<(g|0));h=Xa;g=h+40|0;do{c[h>>2]=0;h=h+4|0}while((h|0)<(g|0));c[Qa>>2]=e;ta=Qa+4|0;c[ta>>2]=f;ua=Qa+8|0;c[ua>>2]=j;va=Qa+12|0;c[va>>2]=k;wa=Qa+16|0;c[wa>>2]=l;xa=Qa+20|0;c[xa>>2]=m;ya=Qa+24|0;c[ya>>2]=n;za=Qa+28|0;c[za>>2]=o;Aa=Qa+32|0;c[Aa>>2]=p;Ba=Qa+36|0;c[Ba>>2]=q;c[Ra>>2]=1;Ca=Ra+4|0;h=Ca;g=h+36|0;do{c[h>>2]=0;h=h+4|0}while((h|0)<(g|0));Da=Wa+8|0;Ea=Wa+12|0;Fa=Wa+16|0;Ga=Wa+20|0;Ha=Wa+24|0;Ia=Wa+28|0;Ja=Wa+32|0;Ka=Wa+36|0;M=Xa+4|0;N=Xa+8|0;O=Xa+12|0;P=Xa+16|0;Q=Xa+20|0;R=Xa+24|0;S=Xa+28|0;T=Xa+32|0;U=Xa+36|0;V=Ra+8|0;W=Ra+12|0;X=Ra+16|0;Y=Ra+20|0;Z=Ra+24|0;_=Ra+28|0;$=Ra+32|0;aa=Ra+36|0;ba=Na+4|0;ca=Na+8|0;da=Na+12|0;ea=Na+16|0;fa=Na+20|0;ga=Na+24|0;ha=Na+28|0;ia=Na+32|0;ja=Na+36|0;ka=Oa+4|0;la=Oa+8|0;ma=Oa+12|0;na=Oa+16|0;oa=Oa+20|0;pa=Oa+24|0;qa=Oa+28|0;ra=Oa+32|0;sa=Oa+36|0;L=1;K=0;J=0;I=0;H=0;G=0;F=0;E=0;D=0;h=0;r=0;s=0;t=0;u=0;v=0;w=0;x=0;y=0;z=0;A=254;B=0;while(1){g=(d[Ma+((A|0)/8|0)>>0]|0)>>>(A&7)&1;nb=0-(g^B)|0;bb=(e^L)&nb;ab=(f^K)&nb;$a=(j^J)&nb;_a=(k^I)&nb;Za=(l^H)&nb;kb=(m^G)&nb;mb=(n^F)&nb;B=(o^E)&nb;jb=(p^D)&nb;lb=(q^h)&nb;c[Wa>>2]=bb^L;c[La>>2]=ab^K;c[Da>>2]=$a^J;c[Ea>>2]=_a^I;c[Fa>>2]=Za^H;c[Ga>>2]=kb^G;c[Ha>>2]=mb^F;c[Ia>>2]=B^E;c[Ja>>2]=jb^D;c[Ka>>2]=lb^h;bb=bb^e;c[Qa>>2]=bb;ab=ab^f;c[ta>>2]=ab;$a=$a^j;c[ua>>2]=$a;_a=_a^k;c[va>>2]=_a;Za=Za^l;c[wa>>2]=Za;I=kb^m;c[xa>>2]=I;E=mb^n;c[ya>>2]=E;l=B^o;c[za>>2]=l;j=jb^p;c[Aa>>2]=j;f=lb^q;c[Ba>>2]=f;K=c[U>>2]|0;lb=c[Ra>>2]|0;jb=c[Ca>>2]|0;B=c[V>>2]|0;p=c[W>>2]|0;q=c[X>>2]|0;D=c[Y>>2]|0;F=c[Z>>2]|0;H=c[_>>2]|0;J=c[$>>2]|0;L=c[aa>>2]|0;mb=(lb^r)&nb;kb=(jb^s)&nb;ib=(B^t)&nb;hb=(p^u)&nb;gb=(q^v)&nb;fb=(D^w)&nb;eb=(F^x)&nb;db=(H^y)&nb;cb=(J^z)&nb;o=(L^K)&nb;e=mb^r;c[Xa>>2]=e;h=kb^s;c[M>>2]=h;k=ib^t;c[N>>2]=k;m=hb^u;c[O>>2]=m;n=gb^v;c[P>>2]=n;r=fb^w;c[Q>>2]=r;v=eb^x;c[R>>2]=v;x=db^y;c[S>>2]=x;G=cb^z;c[T>>2]=G;K=o^K;c[U>>2]=K;s=mb^lb;c[Ra>>2]=s;u=kb^jb;c[Ca>>2]=u;B=ib^B;c[V>>2]=B;p=hb^p;c[W>>2]=p;q=gb^q;c[X>>2]=q;D=fb^D;c[Y>>2]=D;F=eb^F;c[Z>>2]=F;H=db^H;c[_>>2]=H;J=cb^J;c[$>>2]=J;L=o^L;c[aa>>2]=L;c[Na>>2]=bb-s;c[ba>>2]=ab-u;c[ca>>2]=$a-B;c[da>>2]=_a-p;c[ea>>2]=Za-q;c[fa>>2]=I-D;c[ga>>2]=E-F;c[ha>>2]=l-H;c[ia>>2]=j-J;c[ja>>2]=f-L;f=c[Wa>>2]|0;j=c[La>>2]|0;l=c[Da>>2]|0;w=c[Ea>>2]|0;o=c[Fa>>2]|0;t=c[Ga>>2]|0;z=c[Ha>>2]|0;E=c[Ia>>2]|0;I=c[Ja>>2]|0;y=c[Ka>>2]|0;c[Oa>>2]=f-e;c[ka>>2]=j-h;c[la>>2]=l-k;c[ma>>2]=w-m;c[na>>2]=o-n;c[oa>>2]=t-r;c[pa>>2]=z-v;c[qa>>2]=E-x;c[ra>>2]=I-G;c[sa>>2]=y-K;c[Wa>>2]=e+f;c[La>>2]=h+j;c[Da>>2]=k+l;c[Ea>>2]=m+w;c[Fa>>2]=n+o;c[Ga>>2]=r+t;c[Ha>>2]=v+z;c[Ia>>2]=x+E;c[Ja>>2]=G+I;c[Ka>>2]=K+y;u=u+(c[ta>>2]|0)|0;B=B+(c[ua>>2]|0)|0;p=p+(c[va>>2]|0)|0;q=q+(c[wa>>2]|0)|0;D=D+(c[xa>>2]|0)|0;F=F+(c[ya>>2]|0)|0;H=H+(c[za>>2]|0)|0;J=J+(c[Aa>>2]|0)|0;L=L+(c[Ba>>2]|0)|0;c[Xa>>2]=s+(c[Qa>>2]|0);c[M>>2]=u;c[N>>2]=B;c[O>>2]=p;c[P>>2]=q;c[Q>>2]=D;c[R>>2]=F;c[S>>2]=H;c[T>>2]=J;c[U>>2]=L;kd(Ra,Na,Wa);kd(Xa,Xa,Oa);ld(Na,Oa);ld(Oa,Wa);L=c[Ra>>2]|0;J=c[Ca>>2]|0;H=c[V>>2]|0;F=c[W>>2]|0;D=c[X>>2]|0;q=c[Y>>2]|0;p=c[Z>>2]|0;B=c[_>>2]|0;u=c[$>>2]|0;s=c[aa>>2]|0;y=c[Xa>>2]|0;K=c[M>>2]|0;I=c[N>>2]|0;G=c[O>>2]|0;E=c[P>>2]|0;z=c[Q>>2]|0;x=c[R>>2]|0;v=c[S>>2]|0;t=c[T>>2]|0;r=c[U>>2]|0;c[Qa>>2]=y+L;c[ta>>2]=K+J;c[ua>>2]=I+H;c[va>>2]=G+F;c[wa>>2]=E+D;c[xa>>2]=z+q;c[ya>>2]=x+p;c[za>>2]=v+B;c[Aa>>2]=t+u;c[Ba>>2]=r+s;c[Xa>>2]=L-y;c[M>>2]=J-K;c[N>>2]=H-I;c[O>>2]=F-G;c[P>>2]=D-E;c[Q>>2]=q-z;c[R>>2]=p-x;c[S>>2]=B-v;c[T>>2]=u-t;c[U>>2]=s-r;kd(Wa,Oa,Na);r=(c[Oa>>2]|0)-(c[Na>>2]|0)|0;s=(c[ka>>2]|0)-(c[ba>>2]|0)|0;t=(c[la>>2]|0)-(c[ca>>2]|0)|0;u=(c[ma>>2]|0)-(c[da>>2]|0)|0;v=(c[na>>2]|0)-(c[ea>>2]|0)|0;B=(c[oa>>2]|0)-(c[fa>>2]|0)|0;x=(c[pa>>2]|0)-(c[ga>>2]|0)|0;p=(c[qa>>2]|0)-(c[ha>>2]|0)|0;z=(c[ra>>2]|0)-(c[ia>>2]|0)|0;q=(c[sa>>2]|0)-(c[ja>>2]|0)|0;c[Oa>>2]=r;c[ka>>2]=s;c[la>>2]=t;c[ma>>2]=u;c[na>>2]=v;c[oa>>2]=B;c[pa>>2]=x;c[qa>>2]=p;c[ra>>2]=z;c[sa>>2]=q;ld(Xa,Xa);r=Od(r|0,((r|0)<0)<<31>>31|0,121666,0)|0;E=C;s=Od(s|0,((s|0)<0)<<31>>31|0,121666,0)|0;D=C;t=Od(t|0,((t|0)<0)<<31>>31|0,121666,0)|0;G=C;u=Od(u|0,((u|0)<0)<<31>>31|0,121666,0)|0;F=C;v=Od(v|0,((v|0)<0)<<31>>31|0,121666,0)|0;I=C;B=Od(B|0,((B|0)<0)<<31>>31|0,121666,0)|0;H=C;x=Od(x|0,((x|0)<0)<<31>>31|0,121666,0)|0;K=C;p=Od(p|0,((p|0)<0)<<31>>31|0,121666,0)|0;J=C;z=Od(z|0,((z|0)<0)<<31>>31|0,121666,0)|0;y=C;q=Od(q|0,((q|0)<0)<<31>>31|0,121666,0)|0;L=C;o=Dd(q|0,L|0,16777216,0)|0;o=Ed(o|0,C|0,25)|0;w=C;n=Od(o|0,w|0,19,0)|0;E=Dd(n|0,C|0,r|0,E|0)|0;r=C;w=Hd(o|0,w|0,25)|0;w=Cd(q|0,L|0,w|0,C|0)|0;L=C;q=Dd(s|0,D|0,16777216,0)|0;q=Ed(q|0,C|0,25)|0;o=C;G=Dd(q|0,o|0,t|0,G|0)|0;t=C;o=Hd(q|0,o|0,25)|0;o=Cd(s|0,D|0,o|0,C|0)|0;D=C;s=Dd(u|0,F|0,16777216,0)|0;s=Ed(s|0,C|0,25)|0;q=C;I=Dd(s|0,q|0,v|0,I|0)|0;v=C;q=Hd(s|0,q|0,25)|0;q=Cd(u|0,F|0,q|0,C|0)|0;F=C;u=Dd(B|0,H|0,16777216,0)|0;u=Ed(u|0,C|0,25)|0;s=C;K=Dd(u|0,s|0,x|0,K|0)|0;x=C;s=Hd(u|0,s|0,25)|0;s=Cd(B|0,H|0,s|0,C|0)|0;H=C;B=Dd(p|0,J|0,16777216,0)|0;B=Ed(B|0,C|0,25)|0;u=C;y=Dd(B|0,u|0,z|0,y|0)|0;z=C;u=Hd(B|0,u|0,25)|0;u=Cd(p|0,J|0,u|0,C|0)|0;J=C;p=Dd(E|0,r|0,33554432,0)|0;p=Ed(p|0,C|0,26)|0;B=C;D=Dd(o|0,D|0,p|0,B|0)|0;B=Hd(p|0,B|0,26)|0;B=Cd(E|0,r|0,B|0,C|0)|0;r=Dd(G|0,t|0,33554432,0)|0;r=Ed(r|0,C|0,26)|0;E=C;F=Dd(q|0,F|0,r|0,E|0)|0;E=Hd(r|0,E|0,26)|0;E=Cd(G|0,t|0,E|0,C|0)|0;t=Dd(I|0,v|0,33554432,0)|0;t=Ed(t|0,C|0,26)|0;G=C;H=Dd(s|0,H|0,t|0,G|0)|0;G=Hd(t|0,G|0,26)|0;G=Cd(I|0,v|0,G|0,C|0)|0;v=Dd(K|0,x|0,33554432,0)|0;v=Ed(v|0,C|0,26)|0;I=C;J=Dd(u|0,J|0,v|0,I|0)|0;I=Hd(v|0,I|0,26)|0;I=Cd(K|0,x|0,I|0,C|0)|0;x=Dd(y|0,z|0,33554432,0)|0;x=Ed(x|0,C|0,26)|0;K=C;L=Dd(w|0,L|0,x|0,K|0)|0;K=Hd(x|0,K|0,26)|0;K=Cd(y|0,z|0,K|0,C|0)|0;c[Ra>>2]=B;c[Ca>>2]=D;c[V>>2]=E;c[W>>2]=F;c[X>>2]=G;c[Y>>2]=H;c[Z>>2]=I;c[_>>2]=J;c[$>>2]=K;c[aa>>2]=L;ld(Qa,Qa);D=D+(c[ba>>2]|0)|0;E=E+(c[ca>>2]|0)|0;F=F+(c[da>>2]|0)|0;G=G+(c[ea>>2]|0)|0;H=H+(c[fa>>2]|0)|0;I=I+(c[ga>>2]|0)|0;J=J+(c[ha>>2]|0)|0;K=K+(c[ia>>2]|0)|0;L=L+(c[ja>>2]|0)|0;c[Na>>2]=B+(c[Na>>2]|0);c[ba>>2]=D;c[ca>>2]=E;c[da>>2]=F;c[ea>>2]=G;c[fa>>2]=H;c[ga>>2]=I;c[ha>>2]=J;c[ia>>2]=K;c[ja>>2]=L;kd(Ra,Pa,Xa);kd(Xa,Oa,Na);if((A|0)<=0)break;e=c[Qa>>2]|0;L=c[Wa>>2]|0;f=c[ta>>2]|0;K=c[La>>2]|0;j=c[ua>>2]|0;J=c[Da>>2]|0;k=c[va>>2]|0;I=c[Ea>>2]|0;l=c[wa>>2]|0;H=c[Fa>>2]|0;m=c[xa>>2]|0;G=c[Ga>>2]|0;n=c[ya>>2]|0;F=c[Ha>>2]|0;o=c[za>>2]|0;E=c[Ia>>2]|0;p=c[Aa>>2]|0;D=c[Ja>>2]|0;q=c[Ba>>2]|0;h=c[Ka>>2]|0;r=c[Xa>>2]|0;s=c[M>>2]|0;t=c[N>>2]|0;u=c[O>>2]|0;v=c[P>>2]|0;w=c[Q>>2]|0;x=c[R>>2]|0;y=c[S>>2]|0;z=c[T>>2]|0;A=A+-1|0;B=g}ka=c[Wa>>2]|0;la=c[La>>2]|0;ma=c[Da>>2]|0;na=c[Ea>>2]|0;oa=c[Fa>>2]|0;pa=c[Ga>>2]|0;qa=c[Ha>>2]|0;ra=c[Ia>>2]|0;sa=c[Ja>>2]|0;lb=c[Ka>>2]|0;hb=c[Qa>>2]|0;db=c[ta>>2]|0;$a=c[ua>>2]|0;Pa=c[va>>2]|0;mb=c[wa>>2]|0;ib=c[xa>>2]|0;eb=c[ya>>2]|0;ab=c[za>>2]|0;Oa=c[Aa>>2]|0;Ma=c[Ba>>2]|0;nb=0-g|0;jb=(hb^ka)&nb;fb=(db^la)&nb;bb=($a^ma)&nb;Za=(Pa^na)&nb;e=(mb^oa)&nb;kb=(ib^pa)&nb;gb=(eb^qa)&nb;cb=(ab^ra)&nb;_a=(Oa^sa)&nb;Na=(Ma^lb)&nb;c[Wa>>2]=jb^ka;c[La>>2]=fb^la;c[Da>>2]=bb^ma;c[Ea>>2]=Za^na;c[Fa>>2]=e^oa;c[Ga>>2]=kb^pa;c[Ha>>2]=gb^qa;c[Ia>>2]=cb^ra;c[Ja>>2]=_a^sa;c[Ka>>2]=Na^lb;c[Qa>>2]=jb^hb;c[ta>>2]=fb^db;c[ua>>2]=bb^$a;c[va>>2]=Za^Pa;c[wa>>2]=e^mb;c[xa>>2]=kb^ib;c[ya>>2]=gb^eb;c[za>>2]=cb^ab;c[Aa>>2]=_a^Oa;c[Ba>>2]=Na^Ma;va=c[Xa>>2]|0;wa=c[M>>2]|0;xa=c[N>>2]|0;ya=c[O>>2]|0;za=c[P>>2]|0;Aa=c[Q>>2]|0;Ba=c[R>>2]|0;Ma=c[S>>2]|0;Na=c[T>>2]|0;Oa=c[U>>2]|0;Qa=c[Ra>>2]|0;_a=c[Ca>>2]|0;ab=c[V>>2]|0;cb=c[W>>2]|0;eb=c[X>>2]|0;gb=c[Y>>2]|0;ib=c[Z>>2]|0;kb=c[_>>2]|0;mb=c[$>>2]|0;e=c[aa>>2]|0;Pa=(Qa^va)&nb;Za=(_a^wa)&nb;$a=(ab^xa)&nb;bb=(cb^ya)&nb;db=(eb^za)&nb;fb=(gb^Aa)&nb;hb=(ib^Ba)&nb;jb=(kb^Ma)&nb;lb=(mb^Na)&nb;nb=(e^Oa)&nb;c[Xa>>2]=Pa^va;c[M>>2]=Za^wa;c[N>>2]=$a^xa;c[O>>2]=bb^ya;c[P>>2]=db^za;c[Q>>2]=fb^Aa;c[R>>2]=hb^Ba;c[S>>2]=jb^Ma;c[T>>2]=lb^Na;c[U>>2]=nb^Oa;c[Ra>>2]=Pa^Qa;c[Ca>>2]=Za^_a;c[V>>2]=$a^ab;c[W>>2]=bb^cb;c[X>>2]=db^eb;c[Y>>2]=fb^gb;c[Z>>2]=hb^ib;c[_>>2]=jb^kb;c[$>>2]=lb^mb;c[aa>>2]=nb^e;ld(Ta,Xa);ld(Ua,Ta);ld(Ua,Ua);kd(Ua,Xa,Ua);kd(Ta,Ta,Ua);ld(Va,Ta);kd(Ua,Ua,Va);ld(Va,Ua);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);kd(Ua,Va,Ua);ld(Va,Ua);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);kd(Va,Va,Ua);ld(Sa,Va);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);kd(Va,Sa,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);kd(Ua,Va,Ua);ld(Va,Ua);e=1;do{ld(Va,Va);e=e+1|0}while((e|0)!=50);kd(Va,Va,Ua);ld(Sa,Va);e=1;do{ld(Sa,Sa);e=e+1|0}while((e|0)!=100);kd(Va,Sa,Va);ld(Va,Va);e=1;do{ld(Va,Va);e=e+1|0}while((e|0)!=50);kd(Ua,Va,Ua);ld(Ua,Ua);ld(Ua,Ua);ld(Ua,Ua);ld(Ua,Ua);ld(Ua,Ua);kd(Xa,Ua,Ta);kd(Wa,Wa,Xa);eb=c[Wa>>2]|0;fb=c[La>>2]|0;gb=c[Da>>2]|0;hb=c[Ea>>2]|0;ib=c[Fa>>2]|0;jb=c[Ga>>2]|0;kb=c[Ha>>2]|0;lb=c[Ia>>2]|0;nb=c[Ja>>2]|0;mb=c[Ka>>2]|0;eb=(((((((((((((mb*19|0)+16777216>>25)+eb>>26)+fb>>25)+gb>>26)+hb>>25)+ib>>26)+jb>>25)+kb>>26)+lb>>25)+nb>>26)+mb>>25)*19|0)+eb|0;db=eb>>26;fb=db+fb|0;db=eb-(db<<26)|0;eb=fb>>25;gb=eb+gb|0;eb=fb-(eb<<25)|0;fb=gb>>26;hb=fb+hb|0;fb=gb-(fb<<26)|0;gb=hb>>25;ib=gb+ib|0;gb=hb-(gb<<25)|0;hb=ib>>26;jb=hb+jb|0;hb=ib-(hb<<26)|0;ib=jb>>25;kb=ib+kb|0;ib=jb-(ib<<25)|0;jb=kb>>26;lb=jb+lb|0;jb=kb-(jb<<26)|0;kb=lb>>25;nb=kb+nb|0;kb=lb-(kb<<25)|0;lb=nb>>26;mb=lb+mb|0;lb=nb-(lb<<26)|0;nb=mb&33554431;a[b>>0]=db;a[b+1>>0]=db>>>8;a[b+2>>0]=db>>>16;a[b+3>>0]=eb<<2|db>>>24;a[b+4>>0]=eb>>>6;a[b+5>>0]=eb>>>14;a[b+6>>0]=fb<<3|eb>>>22;a[b+7>>0]=fb>>>5;a[b+8>>0]=fb>>>13;a[b+9>>0]=gb<<5|fb>>>21;a[b+10>>0]=gb>>>3;a[b+11>>0]=gb>>>11;a[b+12>>0]=hb<<6|gb>>>19;a[b+13>>0]=hb>>>2;a[b+14>>0]=hb>>>10;a[b+15>>0]=hb>>>18;a[b+16>>0]=ib;a[b+17>>0]=ib>>>8;a[b+18>>0]=ib>>>16;a[b+19>>0]=jb<<1|ib>>>24;a[b+20>>0]=jb>>>7;a[b+21>>0]=jb>>>15;a[b+22>>0]=kb<<3|jb>>>23;a[b+23>>0]=kb>>>5;a[b+24>>0]=kb>>>13;a[b+25>>0]=lb<<4|kb>>>21;a[b+26>>0]=lb>>>4;a[b+27>>0]=lb>>>12;a[b+28>>0]=lb>>>20|nb<<6;a[b+29>>0]=mb>>>2;a[b+30>>0]=mb>>>10;a[b+31>>0]=nb>>>18;i=Ya;return}function nd(b,e,f,g,h,j,k,l){b=b|0;e=e|0;f=f|0;g=g|0;h=h|0;j=j|0;k=k|0;l=l|0;var m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0;D=i;B=i=i+63&-64;i=i+112|0;v=B;A=B+48|0;B=B+16|0;if((f|0)==0&(g|0)==0){i=D;return}n=B;m=n+32|0;do{a[n>>0]=a[l>>0]|0;n=n+1|0;l=l+1|0}while((n|0)<(m|0));s=h;p=s;s=s+4|0;s=d[s>>0]|d[s+1>>0]<<8|d[s+2>>0]<<16|d[s+3>>0]<<24;o=v;c[o>>2]=d[p>>0]|d[p+1>>0]<<8|d[p+2>>0]<<16|d[p+3>>0]<<24;c[o+4>>2]=s;o=v+8|0;a[o>>0]=j;s=Gd(j|0,k|0,8)|0;p=v+9|0;a[p>>0]=s;s=Gd(j|0,k|0,16)|0;q=v+10|0;a[q>>0]=s;s=Gd(j|0,k|0,24)|0;r=v+11|0;a[r>>0]=s;s=v+12|0;a[s>>0]=k;n=Gd(j|0,k|0,40)|0;t=v+13|0;a[t>>0]=n;n=Gd(j|0,k|0,48)|0;u=v+14|0;a[u>>0]=n;k=Gd(j|0,k|0,56)|0;j=v+15|0;a[j>>0]=k;if(g>>>0>0|(g|0)==0&f>>>0>63){n=e;h=f;l=g;do{ob(A,v,B,33833);m=0;do{a[b+m>>0]=a[A+m>>0]^a[n+m>>0];m=m+1|0}while((m|0)!=64);f=c[o>>2]|0;g=(f&255)+1|0;a[o>>0]=g;g=(f>>>8&255)+(g>>>8)|0;a[p>>0]=g;g=(f>>>16&255)+(g>>>8)|0;a[q>>0]=g;g=(f>>>24)+(g>>>8)|0;a[r>>0]=g;f=c[s>>2]|0;g=(f&255)+(g>>>8)|0;a[s>>0]=g;g=(f>>>8&255)+(g>>>8)|0;a[t>>0]=g;g=(f>>>16&255)+(g>>>8)|0;a[u>>0]=g;a[j>>0]=(f>>>24)+(g>>>8);h=Dd(h|0,l|0,-64,-1)|0;l=C;b=b+64|0;n=n+64|0}while(l>>>0>0|(l|0)==0&h>>>0>63);if(!((h|0)==0&(l|0)==0)){x=b;y=h;z=n;w=8}}else{x=b;y=f;z=e;w=8}if((w|0)==8?(ob(A,v,B,33833),(y|0)!=0):0){l=0;do{a[x+l>>0]=a[A+l>>0]^a[z+l>>0];l=l+1|0}while((l|0)!=(y|0))}n=A;m=n+64|0;do{a[n>>0]=0;n=n+1|0}while((n|0)<(m|0));n=B;m=n+32|0;do{a[n>>0]=0;n=n+1|0}while((n|0)<(m|0));i=D;return}function od(){var a=0;if(!(c[7979]|0))a=31964;else a=c[(oa()|0)+60>>2]|0;return a|0}function pd(a){a=a|0;var b=0,d=0;d=i;b=i=i+63&-64;i=i+16|0;c[b>>2]=c[a+60>>2];a=pa(6,b|0)|0;if(a>>>0>4294963200){if(!(c[7979]|0))b=31964;else b=c[(oa()|0)+60>>2]|0;c[b>>2]=0-a;a=-1}i=d;return a|0}function qd(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0,h=0;g=i;e=i=i+63&-64;i=i+32|0;h=e;e=e+20|0;c[h>>2]=c[a+60>>2];c[h+4>>2]=0;c[h+8>>2]=b;c[h+12>>2]=e;c[h+16>>2]=d;b=ya(140,h|0)|0;if(b>>>0<=4294963200)if((b|0)<0)f=7;else a=c[e>>2]|0;else{if(!(c[7979]|0))a=31964;else a=c[(oa()|0)+60>>2]|0;c[a>>2]=0-b;f=7}if((f|0)==7){c[e>>2]=-1;a=-1}i=g;return a|0}function rd(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0;q=i;k=i=i+63&-64;i=i+48|0;n=k+16|0;m=k;k=k+32|0;o=a+28|0;g=c[o>>2]|0;c[k>>2]=g;p=a+20|0;g=(c[p>>2]|0)-g|0;c[k+4>>2]=g;c[k+8>>2]=b;c[k+12>>2]=d;j=a+60|0;l=a+44|0;f=2;g=g+d|0;while(1){if(!(c[7979]|0)){c[n>>2]=c[j>>2];c[n+4>>2]=k;c[n+8>>2]=f;b=Aa(146,n|0)|0;if(b>>>0>4294963200){if(!(c[7979]|0))e=31964;else e=c[(oa()|0)+60>>2]|0;c[e>>2]=0-b;b=-1}}else{ua(18,a|0);c[m>>2]=c[j>>2];c[m+4>>2]=k;c[m+8>>2]=f;b=Aa(146,m|0)|0;if(b>>>0>4294963200){if(!(c[7979]|0))e=31964;else e=c[(oa()|0)+60>>2]|0;c[e>>2]=0-b;b=-1}la(0)}if((g|0)==(b|0)){b=13;break}if((b|0)<0){b=15;break}g=g-b|0;e=c[k+4>>2]|0;if(b>>>0<=e>>>0)if((f|0)==2){c[o>>2]=(c[o>>2]|0)+b;h=e;e=k;f=2}else{h=e;e=k}else{h=c[l>>2]|0;c[o>>2]=h;c[p>>2]=h;h=c[k+12>>2]|0;b=b-e|0;e=k+8|0;f=f+-1|0}c[e>>2]=(c[e>>2]|0)+b;c[e+4>>2]=h-b;k=e}if((b|0)==13){n=c[l>>2]|0;c[a+16>>2]=n+(c[a+48>>2]|0);a=n;c[o>>2]=a;c[p>>2]=a}else if((b|0)==15){c[a+16>>2]=0;c[o>>2]=0;c[p>>2]=0;c[a>>2]=c[a>>2]|32;if((f|0)==2)d=0;else d=d-(c[k+4>>2]|0)|0}i=q;return d|0}function sd(b,d,e){b=b|0;d=d|0;e=e|0;var f=0,g=0,h=0;g=i;h=i=i+63&-64;i=i+80|0;f=h;c[b+36>>2]=20;if((c[b>>2]&64|0)==0?(c[f>>2]=c[b+60>>2],c[f+4>>2]=21505,c[f+8>>2]=h+12,(wa(54,f|0)|0)!=0):0)a[b+75>>0]=-1;h=rd(b,d,e)|0;i=g;return h|0}function td(a){a=a|0;var b=0;if(!a){if(!(c[7990]|0))a=0;else a=td(c[7990]|0)|0;ma(31944);b=c[7985]|0;if(b)do{if((c[b+20>>2]|0)>>>0>(c[b+28>>2]|0)>>>0)a=xd(b)|0|a;b=c[b+56>>2]|0}while((b|0)!=0);xa(31944)}else a=xd(a)|0;return a|0}function ud(b,d){b=b|0;d=d|0;var e=0,f=0,g=0;f=d&255;a:do if(!f)b=b+(vd(b)|0)|0;else{if(b&3){e=d&255;do{g=a[b>>0]|0;if(g<<24>>24==0?1:g<<24>>24==e<<24>>24)break a;b=b+1|0}while((b&3|0)!=0)}f=_(f,16843009)|0;e=c[b>>2]|0;b:do if(!((e&-2139062144^-2139062144)&e+-16843009))do{g=e^f;if((g&-2139062144^-2139062144)&g+-16843009)break b;b=b+4|0;e=c[b>>2]|0}while(((e&-2139062144^-2139062144)&e+-16843009|0)==0);while(0);e=d&255;while(1){g=a[b>>0]|0;if(g<<24>>24==0?1:g<<24>>24==e<<24>>24)break;else b=b+1|0}}while(0);return b|0}function vd(b){b=b|0;var d=0,e=0,f=0;f=b;a:do if(!(f&3))e=4;else{d=b;b=f;while(1){if(!(a[d>>0]|0))break a;d=d+1|0;b=d;if(!(b&3)){b=d;e=4;break}}}while(0);if((e|0)==4){while(1){d=c[b>>2]|0;if(!((d&-2139062144^-2139062144)&d+-16843009))b=b+4|0;else break}if((d&255)<<24>>24)do b=b+1|0;while((a[b>>0]|0)!=0)}return b-f|0}function wd(a){a=a|0;return}function xd(a){a=a|0;var b=0,d=0,e=0,f=0,g=0,h=0;b=a+20|0;g=a+28|0;if((c[b>>2]|0)>>>0>(c[g>>2]|0)>>>0?(Fa[c[a+36>>2]&31](a,0,0)|0,(c[b>>2]|0)==0):0)b=-1;else{h=a+4|0;d=c[h>>2]|0;e=a+8|0;f=c[e>>2]|0;if(d>>>0>>0)Fa[c[a+40>>2]&31](a,d-f|0,1)|0;c[a+16>>2]=0;c[g>>2]=0;c[b>>2]=0;c[e>>2]=0;c[h>>2]=0;b=0}return b|0} function Hb(a,b){a=a|0;b=b|0;var e=0,f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0;h=i;g=i=i+63&-64;i=i+640|0;e=0;do{j=b+(e<<3)|0;o=d[j+7>>0]|0;p=Hd(d[j+6>>0]|0|0,0,8)|0;f=C;n=Hd(d[j+5>>0]|0|0,0,16)|0;f=f|C;m=Hd(d[j+4>>0]|0|0,0,24)|0;f=f|C|(d[j+3>>0]|0);l=Hd(d[j+2>>0]|0|0,0,40)|0;f=f|C;k=Hd(d[j+1>>0]|0|0,0,48)|0;k=Dd(p|o|n|m|l|0,f|0,k|0,C|0)|0;f=C;j=Hd(d[j>>0]|0|0,0,56)|0;j=Dd(k|0,f|0,j|0,C|0)|0;f=g+(e<<3)|0;c[f>>2]=j;c[f+4>>2]=C;e=e+1|0}while((e|0)!=16);e=g;b=c[e>>2]|0;e=c[e+4>>2]|0;f=16;do{s=g+(f+-2<<3)|0;w=c[s>>2]|0;s=c[s+4>>2]|0;r=Gd(w|0,s|0,19)|0;j=C;q=Hd(w|0,s|0,45)|0;j=j|C;u=Gd(w|0,s|0,61)|0;v=C;t=Hd(w|0,s|0,3)|0;v=v|C;s=Gd(w|0,s|0,6)|0;j=v^C^j;v=g+(f+-7<<3)|0;w=c[v>>2]|0;v=c[v+4>>2]|0;n=g+(f+-15<<3)|0;y=b;b=c[n>>2]|0;x=e;e=c[n+4>>2]|0;n=Gd(b|0,e|0,1)|0;o=C;p=Hd(b|0,e|0,63)|0;o=o|C;k=Gd(b|0,e|0,8)|0;z=C;l=Hd(b|0,e|0,56)|0;z=z|C;m=Gd(b|0,e|0,7)|0;o=z^C^o;v=Dd(y|0,x|0,w|0,v|0)|0;j=Dd(v|0,C|0,(u|t)^s^(r|q)|0,j|0)|0;o=Dd(j|0,C|0,(k|l)^m^(n|p)|0,o|0)|0;p=g+(f<<3)|0;c[p>>2]=o;c[p+4>>2]=C;f=f+1|0}while((f|0)!=80);K=a;I=c[K>>2]|0;K=c[K+4>>2]|0;e=a+8|0;A=e;B=c[A>>2]|0;A=c[A+4>>2]|0;k=a+16|0;f=k;b=c[f>>2]|0;f=c[f+4>>2]|0;n=a+24|0;l=n;j=c[l>>2]|0;l=c[l+4>>2]|0;q=a+32|0;m=q;p=c[m>>2]|0;m=c[m+4>>2]|0;t=a+40|0;o=t;s=c[o>>2]|0;o=c[o+4>>2]|0;w=a+48|0;r=w;v=c[r>>2]|0;r=c[r+4>>2]|0;z=a+56|0;u=z;y=c[u>>2]|0;u=c[u+4>>2]|0;H=Gd(p|0,m|0,14)|0;D=C;x=Hd(p|0,m|0,50)|0;D=D|C;M=Gd(p|0,m|0,18)|0;E=C;L=Hd(p|0,m|0,46)|0;E=D^(E|C);D=Gd(p|0,m|0,41)|0;G=C;J=Hd(p|0,m|0,23)|0;G=E^(G|C);E=g;F=c[E>>2]|0;E=c[E+4>>2]|0;u=Dd(y|0,u|0,-685199838,1116352408)|0;E=Dd(u|0,C|0,F|0,E|0)|0;G=Dd(E|0,C|0,(H|x)^(M|L)^(D|J)|0,G|0)|0;G=Dd(G|0,C|0,(v^s)&p^v|0,(r^o)&m^r|0)|0;J=C;D=Gd(I|0,K|0,28)|0;L=C;M=Hd(I|0,K|0,36)|0;L=L|C;x=Gd(I|0,K|0,34)|0;H=C;E=Hd(I|0,K|0,30)|0;H=L^(H|C);L=Gd(I|0,K|0,39)|0;F=C;u=Hd(I|0,K|0,25)|0;F=Dd((b|B)&I|b&B|0,(f|A)&K|f&A|0,(D|M)^(x|E)^(L|u)|0,H^(F|C)|0)|0;H=C;l=Dd(j|0,l|0,G|0,J|0)|0;j=C;J=Dd(F|0,H|0,G|0,J|0)|0;G=C;H=Gd(l|0,j|0,14)|0;F=C;u=Hd(l|0,j|0,50)|0;F=F|C;L=Gd(l|0,j|0,18)|0;E=C;x=Hd(l|0,j|0,46)|0;E=F^(E|C);F=Gd(l|0,j|0,41)|0;M=C;D=Hd(l|0,j|0,23)|0;M=E^(M|C);E=g+8|0;y=c[E>>2]|0;E=c[E+4>>2]|0;r=Dd(v|0,r|0,602891725,1899447441)|0;E=Dd(r|0,C|0,y|0,E|0)|0;M=Dd(E|0,C|0,(H|u)^(L|x)^(F|D)|0,M|0)|0;M=Dd(M|0,C|0,(s^p)&l^s|0,(o^m)&j^o|0)|0;D=C;F=Gd(J|0,G|0,28)|0;x=C;L=Hd(J|0,G|0,36)|0;x=x|C;u=Gd(J|0,G|0,34)|0;H=C;E=Hd(J|0,G|0,30)|0;H=x^(H|C);x=Gd(J|0,G|0,39)|0;y=C;r=Hd(J|0,G|0,25)|0;y=Dd((B|I)&J|B&I|0,(A|K)&G|A&K|0,(F|L)^(u|E)^(x|r)|0,H^(y|C)|0)|0;H=C;f=Dd(b|0,f|0,M|0,D|0)|0;b=C;D=Dd(y|0,H|0,M|0,D|0)|0;M=C;H=Gd(f|0,b|0,14)|0;y=C;r=Hd(f|0,b|0,50)|0;y=y|C;x=Gd(f|0,b|0,18)|0;E=C;u=Hd(f|0,b|0,46)|0;E=y^(E|C);y=Gd(f|0,b|0,41)|0;L=C;F=Hd(f|0,b|0,23)|0;L=E^(L|C);E=g+16|0;v=c[E>>2]|0;E=c[E+4>>2]|0;o=Dd(s|0,o|0,-330482897,-1245643825)|0;E=Dd(o|0,C|0,v|0,E|0)|0;L=Dd(E|0,C|0,(H|r)^(x|u)^(y|F)|0,L|0)|0;L=Dd(L|0,C|0,(p^l)&f^p|0,(m^j)&b^m|0)|0;F=C;y=Gd(D|0,M|0,28)|0;u=C;x=Hd(D|0,M|0,36)|0;u=u|C;r=Gd(D|0,M|0,34)|0;H=C;E=Hd(D|0,M|0,30)|0;H=u^(H|C);u=Gd(D|0,M|0,39)|0;v=C;o=Hd(D|0,M|0,25)|0;v=Dd((I|J)&D|I&J|0,(K|G)&M|K&G|0,(y|x)^(r|E)^(u|o)|0,H^(v|C)|0)|0;H=C;A=Dd(B|0,A|0,L|0,F|0)|0;B=C;F=Dd(v|0,H|0,L|0,F|0)|0;L=C;H=Gd(A|0,B|0,14)|0;v=C;o=Hd(A|0,B|0,50)|0;v=v|C;u=Gd(A|0,B|0,18)|0;E=C;r=Hd(A|0,B|0,46)|0;E=v^(E|C);v=Gd(A|0,B|0,41)|0;x=C;y=Hd(A|0,B|0,23)|0;x=E^(x|C);E=g+24|0;s=c[E>>2]|0;E=c[E+4>>2]|0;m=Dd(p|0,m|0,-2121671748,-373957723)|0;E=Dd(m|0,C|0,s|0,E|0)|0;x=Dd(E|0,C|0,(H|o)^(u|r)^(v|y)|0,x|0)|0;x=Dd(x|0,C|0,(l^f)&A^l|0,(j^b)&B^j|0)|0;y=C;v=Gd(F|0,L|0,28)|0;r=C;u=Hd(F|0,L|0,36)|0;r=r|C;o=Gd(F|0,L|0,34)|0;H=C;E=Hd(F|0,L|0,30)|0;H=r^(H|C);r=Gd(F|0,L|0,39)|0;s=C;m=Hd(F|0,L|0,25)|0;s=Dd((J|D)&F|J&D|0,(G|M)&L|G&M|0,(v|u)^(o|E)^(r|m)|0,H^(s|C)|0)|0;H=C;K=Dd(I|0,K|0,x|0,y|0)|0;I=C;y=Dd(s|0,H|0,x|0,y|0)|0;x=C;H=Gd(K|0,I|0,14)|0;s=C;m=Hd(K|0,I|0,50)|0;s=s|C;r=Gd(K|0,I|0,18)|0;E=C;o=Hd(K|0,I|0,46)|0;E=s^(E|C);s=Gd(K|0,I|0,41)|0;u=C;v=Hd(K|0,I|0,23)|0;u=E^(u|C);E=g+32|0;p=c[E>>2]|0;E=c[E+4>>2]|0;j=Dd(l|0,j|0,-213338824,961987163)|0;E=Dd(j|0,C|0,p|0,E|0)|0;u=Dd(E|0,C|0,(H|m)^(r|o)^(s|v)|0,u|0)|0;u=Dd(u|0,C|0,(f^A)&K^f|0,(b^B)&I^b|0)|0;v=C;s=Gd(y|0,x|0,28)|0;o=C;r=Hd(y|0,x|0,36)|0;o=o|C;m=Gd(y|0,x|0,34)|0;H=C;E=Hd(y|0,x|0,30)|0;H=o^(H|C);o=Gd(y|0,x|0,39)|0;p=C;j=Hd(y|0,x|0,25)|0;p=Dd((D|F)&y|D&F|0,(M|L)&x|M&L|0,(s|r)^(m|E)^(o|j)|0,H^(p|C)|0)|0;H=C;G=Dd(J|0,G|0,u|0,v|0)|0;J=C;v=Dd(p|0,H|0,u|0,v|0)|0;u=C;H=Gd(G|0,J|0,14)|0;p=C;j=Hd(G|0,J|0,50)|0;p=p|C;o=Gd(G|0,J|0,18)|0;E=C;m=Hd(G|0,J|0,46)|0;E=p^(E|C);p=Gd(G|0,J|0,41)|0;r=C;s=Hd(G|0,J|0,23)|0;r=E^(r|C);E=g+40|0;l=c[E>>2]|0;E=c[E+4>>2]|0;b=Dd(f|0,b|0,-1241133031,1508970993)|0;E=Dd(b|0,C|0,l|0,E|0)|0;r=Dd(E|0,C|0,(H|j)^(o|m)^(p|s)|0,r|0)|0;r=Dd(r|0,C|0,(A^K)&G^A|0,(B^I)&J^B|0)|0;s=C;p=Gd(v|0,u|0,28)|0;m=C;o=Hd(v|0,u|0,36)|0;m=m|C;j=Gd(v|0,u|0,34)|0;H=C;E=Hd(v|0,u|0,30)|0;H=m^(H|C);m=Gd(v|0,u|0,39)|0;l=C;b=Hd(v|0,u|0,25)|0;l=Dd((F|y)&v|F&y|0,(L|x)&u|L&x|0,(p|o)^(j|E)^(m|b)|0,H^(l|C)|0)|0;H=C;M=Dd(D|0,M|0,r|0,s|0)|0;D=C;s=Dd(l|0,H|0,r|0,s|0)|0;r=C;H=Gd(M|0,D|0,14)|0;l=C;b=Hd(M|0,D|0,50)|0;l=l|C;m=Gd(M|0,D|0,18)|0;E=C;j=Hd(M|0,D|0,46)|0;E=l^(E|C);l=Gd(M|0,D|0,41)|0;o=C;p=Hd(M|0,D|0,23)|0;o=E^(o|C);E=g+48|0;f=c[E>>2]|0;E=c[E+4>>2]|0;B=Dd(A|0,B|0,-1357295717,-1841331548)|0;E=Dd(B|0,C|0,f|0,E|0)|0;o=Dd(E|0,C|0,(H|b)^(m|j)^(l|p)|0,o|0)|0;o=Dd(o|0,C|0,(K^G)&M^K|0,(I^J)&D^I|0)|0;p=C;l=Gd(s|0,r|0,28)|0;j=C;m=Hd(s|0,r|0,36)|0;j=j|C;b=Gd(s|0,r|0,34)|0;H=C;E=Hd(s|0,r|0,30)|0;H=j^(H|C);j=Gd(s|0,r|0,39)|0;f=C;B=Hd(s|0,r|0,25)|0;f=Dd((y|v)&s|y&v|0,(x|u)&r|x&u|0,(l|m)^(b|E)^(j|B)|0,H^(f|C)|0)|0;H=C;L=Dd(F|0,L|0,o|0,p|0)|0;F=C;p=Dd(f|0,H|0,o|0,p|0)|0;o=C;H=Gd(L|0,F|0,14)|0;f=C;B=Hd(L|0,F|0,50)|0;f=f|C;j=Gd(L|0,F|0,18)|0;E=C;b=Hd(L|0,F|0,46)|0;E=f^(E|C);f=Gd(L|0,F|0,41)|0;m=C;l=Hd(L|0,F|0,23)|0;m=E^(m|C);E=g+56|0;A=c[E>>2]|0;E=c[E+4>>2]|0;I=Dd(K|0,I|0,-630357736,-1424204075)|0;E=Dd(I|0,C|0,A|0,E|0)|0;m=Dd(E|0,C|0,(H|B)^(j|b)^(f|l)|0,m|0)|0;m=Dd(m|0,C|0,(G^M)&L^G|0,(J^D)&F^J|0)|0;l=C;f=Gd(p|0,o|0,28)|0;b=C;j=Hd(p|0,o|0,36)|0;b=b|C;B=Gd(p|0,o|0,34)|0;H=C;E=Hd(p|0,o|0,30)|0;H=b^(H|C);b=Gd(p|0,o|0,39)|0;A=C;I=Hd(p|0,o|0,25)|0;A=Dd((v|s)&p|v&s|0,(u|r)&o|u&r|0,(f|j)^(B|E)^(b|I)|0,H^(A|C)|0)|0;H=C;x=Dd(y|0,x|0,m|0,l|0)|0;y=C;l=Dd(A|0,H|0,m|0,l|0)|0;m=C;H=Gd(x|0,y|0,14)|0;A=C;I=Hd(x|0,y|0,50)|0;A=A|C;b=Gd(x|0,y|0,18)|0;E=C;B=Hd(x|0,y|0,46)|0;E=A^(E|C);A=Gd(x|0,y|0,41)|0;j=C;f=Hd(x|0,y|0,23)|0;j=E^(j|C);E=g+64|0;K=c[E>>2]|0;E=c[E+4>>2]|0;J=Dd(G|0,J|0,-1560083902,-670586216)|0;E=Dd(J|0,C|0,K|0,E|0)|0;j=Dd(E|0,C|0,(H|I)^(b|B)^(A|f)|0,j|0)|0;j=Dd(j|0,C|0,(M^L)&x^M|0,(D^F)&y^D|0)|0;f=C;A=Gd(l|0,m|0,28)|0;B=C;b=Hd(l|0,m|0,36)|0;B=B|C;I=Gd(l|0,m|0,34)|0;H=C;E=Hd(l|0,m|0,30)|0;H=B^(H|C);B=Gd(l|0,m|0,39)|0;K=C;J=Hd(l|0,m|0,25)|0;K=Dd((s|p)&l|s&p|0,(r|o)&m|r&o|0,(A|b)^(I|E)^(B|J)|0,H^(K|C)|0)|0;H=C;u=Dd(v|0,u|0,j|0,f|0)|0;v=C;f=Dd(K|0,H|0,j|0,f|0)|0;j=C;H=Gd(u|0,v|0,14)|0;K=C;J=Hd(u|0,v|0,50)|0;K=K|C;B=Gd(u|0,v|0,18)|0;E=C;I=Hd(u|0,v|0,46)|0;E=K^(E|C);K=Gd(u|0,v|0,41)|0;b=C;A=Hd(u|0,v|0,23)|0;b=E^(b|C);E=g+72|0;G=c[E>>2]|0;E=c[E+4>>2]|0;D=Dd(M|0,D|0,1164996542,310598401)|0;E=Dd(D|0,C|0,G|0,E|0)|0;b=Dd(E|0,C|0,(H|J)^(B|I)^(K|A)|0,b|0)|0;b=Dd(b|0,C|0,(L^x)&u^L|0,(F^y)&v^F|0)|0;A=C;K=Gd(f|0,j|0,28)|0;I=C;B=Hd(f|0,j|0,36)|0;I=I|C;J=Gd(f|0,j|0,34)|0;H=C;E=Hd(f|0,j|0,30)|0;H=I^(H|C);I=Gd(f|0,j|0,39)|0;G=C;D=Hd(f|0,j|0,25)|0;G=Dd((p|l)&f|p&l|0,(o|m)&j|o&m|0,(K|B)^(J|E)^(I|D)|0,H^(G|C)|0)|0;H=C;r=Dd(s|0,r|0,b|0,A|0)|0;s=C;A=Dd(G|0,H|0,b|0,A|0)|0;b=C;H=Gd(r|0,s|0,14)|0;G=C;D=Hd(r|0,s|0,50)|0;G=G|C;I=Gd(r|0,s|0,18)|0;E=C;J=Hd(r|0,s|0,46)|0;E=G^(E|C);G=Gd(r|0,s|0,41)|0;B=C;K=Hd(r|0,s|0,23)|0;B=E^(B|C);E=g+80|0;M=c[E>>2]|0;E=c[E+4>>2]|0;F=Dd(L|0,F|0,1323610764,607225278)|0;E=Dd(F|0,C|0,M|0,E|0)|0;B=Dd(E|0,C|0,(H|D)^(I|J)^(G|K)|0,B|0)|0;B=Dd(B|0,C|0,(x^u)&r^x|0,(y^v)&s^y|0)|0;K=C;G=Gd(A|0,b|0,28)|0;J=C;I=Hd(A|0,b|0,36)|0;J=J|C;D=Gd(A|0,b|0,34)|0;H=C;E=Hd(A|0,b|0,30)|0;H=J^(H|C);J=Gd(A|0,b|0,39)|0;M=C;F=Hd(A|0,b|0,25)|0;M=Dd((l|f)&A|l&f|0,(m|j)&b|m&j|0,(G|I)^(D|E)^(J|F)|0,H^(M|C)|0)|0;H=C;o=Dd(p|0,o|0,B|0,K|0)|0;p=C;K=Dd(M|0,H|0,B|0,K|0)|0;B=C;H=Gd(o|0,p|0,14)|0;M=C;F=Hd(o|0,p|0,50)|0;M=M|C;J=Gd(o|0,p|0,18)|0;E=C;D=Hd(o|0,p|0,46)|0;E=M^(E|C);M=Gd(o|0,p|0,41)|0;I=C;G=Hd(o|0,p|0,23)|0;I=E^(I|C);E=g+88|0;L=c[E>>2]|0;E=c[E+4>>2]|0;y=Dd(x|0,y|0,-704662302,1426881987)|0;E=Dd(y|0,C|0,L|0,E|0)|0;I=Dd(E|0,C|0,(H|F)^(J|D)^(M|G)|0,I|0)|0;I=Dd(I|0,C|0,(u^r)&o^u|0,(v^s)&p^v|0)|0;G=C;M=Gd(K|0,B|0,28)|0;D=C;J=Hd(K|0,B|0,36)|0;D=D|C;F=Gd(K|0,B|0,34)|0;H=C;E=Hd(K|0,B|0,30)|0;H=D^(H|C);D=Gd(K|0,B|0,39)|0;L=C;y=Hd(K|0,B|0,25)|0;L=Dd((f|A)&K|f&A|0,(j|b)&B|j&b|0,(M|J)^(F|E)^(D|y)|0,H^(L|C)|0)|0;H=C;m=Dd(l|0,m|0,I|0,G|0)|0;l=C;G=Dd(L|0,H|0,I|0,G|0)|0;I=C;H=Gd(m|0,l|0,14)|0;L=C;y=Hd(m|0,l|0,50)|0;L=L|C;D=Gd(m|0,l|0,18)|0;E=C;F=Hd(m|0,l|0,46)|0;E=L^(E|C);L=Gd(m|0,l|0,41)|0;J=C;M=Hd(m|0,l|0,23)|0;J=E^(J|C);E=g+96|0;x=c[E>>2]|0;E=c[E+4>>2]|0;v=Dd(u|0,v|0,-226784913,1925078388)|0;E=Dd(v|0,C|0,x|0,E|0)|0;J=Dd(E|0,C|0,(H|y)^(D|F)^(L|M)|0,J|0)|0;J=Dd(J|0,C|0,(r^o)&m^r|0,(s^p)&l^s|0)|0;M=C;L=Gd(G|0,I|0,28)|0;F=C;D=Hd(G|0,I|0,36)|0;F=F|C;y=Gd(G|0,I|0,34)|0;H=C;E=Hd(G|0,I|0,30)|0;H=F^(H|C);F=Gd(G|0,I|0,39)|0;x=C;v=Hd(G|0,I|0,25)|0;x=Dd((A|K)&G|A&K|0,(b|B)&I|b&B|0,(L|D)^(y|E)^(F|v)|0,H^(x|C)|0)|0;H=C;j=Dd(f|0,j|0,J|0,M|0)|0;f=C;M=Dd(x|0,H|0,J|0,M|0)|0;J=C;H=Gd(j|0,f|0,14)|0;x=C;v=Hd(j|0,f|0,50)|0;x=x|C;F=Gd(j|0,f|0,18)|0;E=C;y=Hd(j|0,f|0,46)|0;E=x^(E|C);x=Gd(j|0,f|0,41)|0;D=C;L=Hd(j|0,f|0,23)|0;D=E^(D|C);E=g+104|0;u=c[E>>2]|0;E=c[E+4>>2]|0;s=Dd(r|0,s|0,991336113,-2132889090)|0;E=Dd(s|0,C|0,u|0,E|0)|0;D=Dd(E|0,C|0,(H|v)^(F|y)^(x|L)|0,D|0)|0;D=Dd(D|0,C|0,(o^m)&j^o|0,(p^l)&f^p|0)|0;L=C;x=Gd(M|0,J|0,28)|0;y=C;F=Hd(M|0,J|0,36)|0;y=y|C;v=Gd(M|0,J|0,34)|0;H=C;E=Hd(M|0,J|0,30)|0;H=y^(H|C);y=Gd(M|0,J|0,39)|0;u=C;s=Hd(M|0,J|0,25)|0;u=Dd((K|G)&M|K&G|0,(B|I)&J|B&I|0,(x|F)^(v|E)^(y|s)|0,H^(u|C)|0)|0;H=C;b=Dd(A|0,b|0,D|0,L|0)|0;A=C;L=Dd(u|0,H|0,D|0,L|0)|0;D=C;H=Gd(b|0,A|0,14)|0;u=C;s=Hd(b|0,A|0,50)|0;u=u|C;y=Gd(b|0,A|0,18)|0;E=C;v=Hd(b|0,A|0,46)|0;E=u^(E|C);u=Gd(b|0,A|0,41)|0;F=C;x=Hd(b|0,A|0,23)|0;F=E^(F|C);E=g+112|0;r=c[E>>2]|0;E=c[E+4>>2]|0;p=Dd(o|0,p|0,633803317,-1680079193)|0;E=Dd(p|0,C|0,r|0,E|0)|0;F=Dd(E|0,C|0,(H|s)^(y|v)^(u|x)|0,F|0)|0;F=Dd(F|0,C|0,(m^j)&b^m|0,(l^f)&A^l|0)|0;x=C;u=Gd(L|0,D|0,28)|0;v=C;y=Hd(L|0,D|0,36)|0;v=v|C;s=Gd(L|0,D|0,34)|0;H=C;E=Hd(L|0,D|0,30)|0;H=v^(H|C);v=Gd(L|0,D|0,39)|0;r=C;p=Hd(L|0,D|0,25)|0;r=Dd((G|M)&L|G&M|0,(I|J)&D|I&J|0,(u|y)^(s|E)^(v|p)|0,H^(r|C)|0)|0;H=C;B=Dd(K|0,B|0,F|0,x|0)|0;K=C;x=Dd(r|0,H|0,F|0,x|0)|0;F=C;H=Gd(B|0,K|0,14)|0;r=C;p=Hd(B|0,K|0,50)|0;r=r|C;v=Gd(B|0,K|0,18)|0;E=C;s=Hd(B|0,K|0,46)|0;E=r^(E|C);r=Gd(B|0,K|0,41)|0;y=C;u=Hd(B|0,K|0,23)|0;y=E^(y|C);E=g+120|0;o=c[E>>2]|0;E=c[E+4>>2]|0;l=Dd(m|0,l|0,-815192428,-1046744716)|0;E=Dd(l|0,C|0,o|0,E|0)|0;y=Dd(E|0,C|0,(H|p)^(v|s)^(r|u)|0,y|0)|0;y=Dd(y|0,C|0,(j^b)&B^j|0,(f^A)&K^f|0)|0;u=C;r=Gd(x|0,F|0,28)|0;s=C;v=Hd(x|0,F|0,36)|0;s=s|C;p=Gd(x|0,F|0,34)|0;H=C;E=Hd(x|0,F|0,30)|0;H=s^(H|C);s=Gd(x|0,F|0,39)|0;o=C;l=Hd(x|0,F|0,25)|0;o=Dd((M|L)&x|M&L|0,(J|D)&F|J&D|0,(r|v)^(p|E)^(s|l)|0,H^(o|C)|0)|0;H=C;I=Dd(G|0,I|0,y|0,u|0)|0;G=C;u=Dd(o|0,H|0,y|0,u|0)|0;y=C;H=Gd(I|0,G|0,14)|0;o=C;l=Hd(I|0,G|0,50)|0;o=o|C;s=Gd(I|0,G|0,18)|0;E=C;p=Hd(I|0,G|0,46)|0;E=o^(E|C);o=Gd(I|0,G|0,41)|0;v=C;r=Hd(I|0,G|0,23)|0;v=E^(v|C);E=g+128|0;m=c[E>>2]|0;E=c[E+4>>2]|0;f=Dd(j|0,f|0,-1628353838,-459576895)|0;E=Dd(f|0,C|0,m|0,E|0)|0;v=Dd(E|0,C|0,(H|l)^(s|p)^(o|r)|0,v|0)|0;v=Dd(v|0,C|0,(b^B)&I^b|0,(A^K)&G^A|0)|0;r=C;o=Gd(u|0,y|0,28)|0;p=C;s=Hd(u|0,y|0,36)|0;p=p|C;l=Gd(u|0,y|0,34)|0;H=C;E=Hd(u|0,y|0,30)|0;H=p^(H|C);p=Gd(u|0,y|0,39)|0;m=C;f=Hd(u|0,y|0,25)|0;m=Dd((L|x)&u|L&x|0,(D|F)&y|D&F|0,(o|s)^(l|E)^(p|f)|0,H^(m|C)|0)|0;H=C;J=Dd(M|0,J|0,v|0,r|0)|0;M=C;r=Dd(m|0,H|0,v|0,r|0)|0;v=C;H=Gd(J|0,M|0,14)|0;m=C;f=Hd(J|0,M|0,50)|0;m=m|C;p=Gd(J|0,M|0,18)|0;E=C;l=Hd(J|0,M|0,46)|0;E=m^(E|C);m=Gd(J|0,M|0,41)|0;s=C;o=Hd(J|0,M|0,23)|0;s=E^(s|C);E=g+136|0;j=c[E>>2]|0;E=c[E+4>>2]|0;A=Dd(b|0,A|0,944711139,-272742522)|0;E=Dd(A|0,C|0,j|0,E|0)|0;s=Dd(E|0,C|0,(H|f)^(p|l)^(m|o)|0,s|0)|0;s=Dd(s|0,C|0,(B^I)&J^B|0,(K^G)&M^K|0)|0;o=C;m=Gd(r|0,v|0,28)|0;l=C;p=Hd(r|0,v|0,36)|0;l=l|C;f=Gd(r|0,v|0,34)|0;H=C;E=Hd(r|0,v|0,30)|0;H=l^(H|C);l=Gd(r|0,v|0,39)|0;j=C;A=Hd(r|0,v|0,25)|0;j=Dd((x|u)&r|x&u|0,(F|y)&v|F&y|0,(m|p)^(f|E)^(l|A)|0,H^(j|C)|0)|0;H=C;D=Dd(L|0,D|0,s|0,o|0)|0;L=C;o=Dd(j|0,H|0,s|0,o|0)|0;s=C;H=Gd(D|0,L|0,14)|0;j=C;A=Hd(D|0,L|0,50)|0;j=j|C;l=Gd(D|0,L|0,18)|0;E=C;f=Hd(D|0,L|0,46)|0;E=j^(E|C);j=Gd(D|0,L|0,41)|0;p=C;m=Hd(D|0,L|0,23)|0;p=E^(p|C);E=g+144|0;b=c[E>>2]|0;E=c[E+4>>2]|0;K=Dd(B|0,K|0,-1953704523,264347078)|0;E=Dd(K|0,C|0,b|0,E|0)|0;p=Dd(E|0,C|0,(H|A)^(l|f)^(j|m)|0,p|0)|0;p=Dd(p|0,C|0,(I^J)&D^I|0,(G^M)&L^G|0)|0;m=C;j=Gd(o|0,s|0,28)|0;f=C;l=Hd(o|0,s|0,36)|0;f=f|C;A=Gd(o|0,s|0,34)|0;H=C;E=Hd(o|0,s|0,30)|0;H=f^(H|C);f=Gd(o|0,s|0,39)|0;b=C;K=Hd(o|0,s|0,25)|0;b=Dd((u|r)&o|u&r|0,(y|v)&s|y&v|0,(j|l)^(A|E)^(f|K)|0,H^(b|C)|0)|0;H=C;F=Dd(x|0,F|0,p|0,m|0)|0;x=C;m=Dd(b|0,H|0,p|0,m|0)|0;p=C;H=Gd(F|0,x|0,14)|0;b=C;K=Hd(F|0,x|0,50)|0;b=b|C;f=Gd(F|0,x|0,18)|0;E=C;A=Hd(F|0,x|0,46)|0;E=b^(E|C);b=Gd(F|0,x|0,41)|0;l=C;j=Hd(F|0,x|0,23)|0;l=E^(l|C);E=g+152|0;B=c[E>>2]|0;E=c[E+4>>2]|0;G=Dd(I|0,G|0,2007800933,604807628)|0;E=Dd(G|0,C|0,B|0,E|0)|0;l=Dd(E|0,C|0,(H|K)^(f|A)^(b|j)|0,l|0)|0;l=Dd(l|0,C|0,(J^D)&F^J|0,(M^L)&x^M|0)|0;j=C;b=Gd(m|0,p|0,28)|0;A=C;f=Hd(m|0,p|0,36)|0;A=A|C;K=Gd(m|0,p|0,34)|0;H=C;E=Hd(m|0,p|0,30)|0;H=A^(H|C);A=Gd(m|0,p|0,39)|0;B=C;G=Hd(m|0,p|0,25)|0;B=Dd((r|o)&m|r&o|0,(v|s)&p|v&s|0,(b|f)^(K|E)^(A|G)|0,H^(B|C)|0)|0;H=C;y=Dd(u|0,y|0,l|0,j|0)|0;u=C;j=Dd(B|0,H|0,l|0,j|0)|0;l=C;H=Gd(y|0,u|0,14)|0;B=C;G=Hd(y|0,u|0,50)|0;B=B|C;A=Gd(y|0,u|0,18)|0;E=C;K=Hd(y|0,u|0,46)|0;E=B^(E|C);B=Gd(y|0,u|0,41)|0;f=C;b=Hd(y|0,u|0,23)|0;f=E^(f|C);E=g+160|0;I=c[E>>2]|0;E=c[E+4>>2]|0;M=Dd(J|0,M|0,1495990901,770255983)|0;E=Dd(M|0,C|0,I|0,E|0)|0;f=Dd(E|0,C|0,(H|G)^(A|K)^(B|b)|0,f|0)|0;f=Dd(f|0,C|0,(D^F)&y^D|0,(L^x)&u^L|0)|0;b=C;B=Gd(j|0,l|0,28)|0;K=C;A=Hd(j|0,l|0,36)|0;K=K|C;G=Gd(j|0,l|0,34)|0;H=C;E=Hd(j|0,l|0,30)|0;H=K^(H|C);K=Gd(j|0,l|0,39)|0;I=C;M=Hd(j|0,l|0,25)|0;I=Dd((o|m)&j|o&m|0,(s|p)&l|s&p|0,(B|A)^(G|E)^(K|M)|0,H^(I|C)|0)|0;H=C;v=Dd(r|0,v|0,f|0,b|0)|0;r=C;b=Dd(I|0,H|0,f|0,b|0)|0;f=C;H=Gd(v|0,r|0,14)|0;I=C;M=Hd(v|0,r|0,50)|0;I=I|C;K=Gd(v|0,r|0,18)|0;E=C;G=Hd(v|0,r|0,46)|0;E=I^(E|C);I=Gd(v|0,r|0,41)|0;A=C;B=Hd(v|0,r|0,23)|0;A=E^(A|C);E=g+168|0;J=c[E>>2]|0;E=c[E+4>>2]|0;L=Dd(D|0,L|0,1856431235,1249150122)|0;E=Dd(L|0,C|0,J|0,E|0)|0;A=Dd(E|0,C|0,(H|M)^(K|G)^(I|B)|0,A|0)|0;A=Dd(A|0,C|0,(F^y)&v^F|0,(x^u)&r^x|0)|0;B=C;I=Gd(b|0,f|0,28)|0;G=C;K=Hd(b|0,f|0,36)|0;G=G|C;M=Gd(b|0,f|0,34)|0;H=C;E=Hd(b|0,f|0,30)|0;H=G^(H|C);G=Gd(b|0,f|0,39)|0;J=C;L=Hd(b|0,f|0,25)|0;J=Dd((m|j)&b|m&j|0,(p|l)&f|p&l|0,(I|K)^(M|E)^(G|L)|0,H^(J|C)|0)|0;H=C;s=Dd(o|0,s|0,A|0,B|0)|0;o=C;B=Dd(J|0,H|0,A|0,B|0)|0;A=C;H=Gd(s|0,o|0,14)|0;J=C;L=Hd(s|0,o|0,50)|0;J=J|C;G=Gd(s|0,o|0,18)|0;E=C;M=Hd(s|0,o|0,46)|0;E=J^(E|C);J=Gd(s|0,o|0,41)|0;K=C;I=Hd(s|0,o|0,23)|0;K=E^(K|C);E=g+176|0;D=c[E>>2]|0;E=c[E+4>>2]|0;x=Dd(F|0,x|0,-1119749164,1555081692)|0;E=Dd(x|0,C|0,D|0,E|0)|0;K=Dd(E|0,C|0,(H|L)^(G|M)^(J|I)|0,K|0)|0;K=Dd(K|0,C|0,(y^v)&s^y|0,(u^r)&o^u|0)|0;I=C;J=Gd(B|0,A|0,28)|0;M=C;G=Hd(B|0,A|0,36)|0;M=M|C;L=Gd(B|0,A|0,34)|0;H=C;E=Hd(B|0,A|0,30)|0;H=M^(H|C);M=Gd(B|0,A|0,39)|0;D=C;x=Hd(B|0,A|0,25)|0;D=Dd((j|b)&B|j&b|0,(l|f)&A|l&f|0,(J|G)^(L|E)^(M|x)|0,H^(D|C)|0)|0;H=C;p=Dd(m|0,p|0,K|0,I|0)|0;m=C;I=Dd(D|0,H|0,K|0,I|0)|0;K=C;H=Gd(p|0,m|0,14)|0;D=C;x=Hd(p|0,m|0,50)|0;D=D|C;M=Gd(p|0,m|0,18)|0;E=C;L=Hd(p|0,m|0,46)|0;E=D^(E|C);D=Gd(p|0,m|0,41)|0;G=C;J=Hd(p|0,m|0,23)|0;G=E^(G|C);E=g+184|0;F=c[E>>2]|0;E=c[E+4>>2]|0;u=Dd(y|0,u|0,-2096016459,1996064986)|0;E=Dd(u|0,C|0,F|0,E|0)|0;G=Dd(E|0,C|0,(H|x)^(M|L)^(D|J)|0,G|0)|0;G=Dd(G|0,C|0,(v^s)&p^v|0,(r^o)&m^r|0)|0;J=C;D=Gd(I|0,K|0,28)|0;L=C;M=Hd(I|0,K|0,36)|0;L=L|C;x=Gd(I|0,K|0,34)|0;H=C;E=Hd(I|0,K|0,30)|0;H=L^(H|C);L=Gd(I|0,K|0,39)|0;F=C;u=Hd(I|0,K|0,25)|0;F=Dd((b|B)&I|b&B|0,(f|A)&K|f&A|0,(D|M)^(x|E)^(L|u)|0,H^(F|C)|0)|0;H=C;l=Dd(j|0,l|0,G|0,J|0)|0;j=C;J=Dd(F|0,H|0,G|0,J|0)|0;G=C;H=Gd(l|0,j|0,14)|0;F=C;u=Hd(l|0,j|0,50)|0;F=F|C;L=Gd(l|0,j|0,18)|0;E=C;x=Hd(l|0,j|0,46)|0;E=F^(E|C);F=Gd(l|0,j|0,41)|0;M=C;D=Hd(l|0,j|0,23)|0;M=E^(M|C);E=g+192|0;y=c[E>>2]|0;E=c[E+4>>2]|0;r=Dd(v|0,r|0,-295247957,-1740746414)|0;E=Dd(r|0,C|0,y|0,E|0)|0;M=Dd(E|0,C|0,(H|u)^(L|x)^(F|D)|0,M|0)|0;M=Dd(M|0,C|0,(s^p)&l^s|0,(o^m)&j^o|0)|0;D=C;F=Gd(J|0,G|0,28)|0;x=C;L=Hd(J|0,G|0,36)|0;x=x|C;u=Gd(J|0,G|0,34)|0;H=C;E=Hd(J|0,G|0,30)|0;H=x^(H|C);x=Gd(J|0,G|0,39)|0;y=C;r=Hd(J|0,G|0,25)|0;y=Dd((B|I)&J|B&I|0,(A|K)&G|A&K|0,(F|L)^(u|E)^(x|r)|0,H^(y|C)|0)|0;H=C;f=Dd(b|0,f|0,M|0,D|0)|0;b=C;D=Dd(y|0,H|0,M|0,D|0)|0;M=C;H=Gd(f|0,b|0,14)|0;y=C;r=Hd(f|0,b|0,50)|0;y=y|C;x=Gd(f|0,b|0,18)|0;E=C;u=Hd(f|0,b|0,46)|0;E=y^(E|C);y=Gd(f|0,b|0,41)|0;L=C;F=Hd(f|0,b|0,23)|0;L=E^(L|C);E=g+200|0;v=c[E>>2]|0;E=c[E+4>>2]|0;o=Dd(s|0,o|0,766784016,-1473132947)|0;E=Dd(o|0,C|0,v|0,E|0)|0;L=Dd(E|0,C|0,(H|r)^(x|u)^(y|F)|0,L|0)|0;L=Dd(L|0,C|0,(p^l)&f^p|0,(m^j)&b^m|0)|0;F=C;y=Gd(D|0,M|0,28)|0;u=C;x=Hd(D|0,M|0,36)|0;u=u|C;r=Gd(D|0,M|0,34)|0;H=C;E=Hd(D|0,M|0,30)|0;H=u^(H|C);u=Gd(D|0,M|0,39)|0;v=C;o=Hd(D|0,M|0,25)|0;v=Dd((I|J)&D|I&J|0,(K|G)&M|K&G|0,(y|x)^(r|E)^(u|o)|0,H^(v|C)|0)|0;H=C;A=Dd(B|0,A|0,L|0,F|0)|0;B=C;F=Dd(v|0,H|0,L|0,F|0)|0;L=C;H=Gd(A|0,B|0,14)|0;v=C;o=Hd(A|0,B|0,50)|0;v=v|C;u=Gd(A|0,B|0,18)|0;E=C;r=Hd(A|0,B|0,46)|0;E=v^(E|C);v=Gd(A|0,B|0,41)|0;x=C;y=Hd(A|0,B|0,23)|0;x=E^(x|C);E=g+208|0;s=c[E>>2]|0;E=c[E+4>>2]|0;m=Dd(p|0,m|0,-1728372417,-1341970488)|0;E=Dd(m|0,C|0,s|0,E|0)|0;x=Dd(E|0,C|0,(H|o)^(u|r)^(v|y)|0,x|0)|0;x=Dd(x|0,C|0,(l^f)&A^l|0,(j^b)&B^j|0)|0;y=C;v=Gd(F|0,L|0,28)|0;r=C;u=Hd(F|0,L|0,36)|0;r=r|C;o=Gd(F|0,L|0,34)|0;H=C;E=Hd(F|0,L|0,30)|0;H=r^(H|C);r=Gd(F|0,L|0,39)|0;s=C;m=Hd(F|0,L|0,25)|0;s=Dd((J|D)&F|J&D|0,(G|M)&L|G&M|0,(v|u)^(o|E)^(r|m)|0,H^(s|C)|0)|0;H=C;K=Dd(I|0,K|0,x|0,y|0)|0;I=C;y=Dd(s|0,H|0,x|0,y|0)|0;x=C;H=Gd(K|0,I|0,14)|0;s=C;m=Hd(K|0,I|0,50)|0;s=s|C;r=Gd(K|0,I|0,18)|0;E=C;o=Hd(K|0,I|0,46)|0;E=s^(E|C);s=Gd(K|0,I|0,41)|0;u=C;v=Hd(K|0,I|0,23)|0;u=E^(u|C);E=g+216|0;p=c[E>>2]|0;E=c[E+4>>2]|0;j=Dd(l|0,j|0,-1091629340,-1084653625)|0;E=Dd(j|0,C|0,p|0,E|0)|0;u=Dd(E|0,C|0,(H|m)^(r|o)^(s|v)|0,u|0)|0;u=Dd(u|0,C|0,(f^A)&K^f|0,(b^B)&I^b|0)|0;v=C;s=Gd(y|0,x|0,28)|0;o=C;r=Hd(y|0,x|0,36)|0;o=o|C;m=Gd(y|0,x|0,34)|0;H=C;E=Hd(y|0,x|0,30)|0;H=o^(H|C);o=Gd(y|0,x|0,39)|0;p=C;j=Hd(y|0,x|0,25)|0;p=Dd((D|F)&y|D&F|0,(M|L)&x|M&L|0,(s|r)^(m|E)^(o|j)|0,H^(p|C)|0)|0;H=C;G=Dd(J|0,G|0,u|0,v|0)|0;J=C;v=Dd(p|0,H|0,u|0,v|0)|0;u=C;H=Gd(G|0,J|0,14)|0;p=C;j=Hd(G|0,J|0,50)|0;p=p|C;o=Gd(G|0,J|0,18)|0;E=C;m=Hd(G|0,J|0,46)|0;E=p^(E|C);p=Gd(G|0,J|0,41)|0;r=C;s=Hd(G|0,J|0,23)|0;r=E^(r|C);E=g+224|0;l=c[E>>2]|0;E=c[E+4>>2]|0;b=Dd(f|0,b|0,1034457026,-958395405)|0;E=Dd(b|0,C|0,l|0,E|0)|0;r=Dd(E|0,C|0,(H|j)^(o|m)^(p|s)|0,r|0)|0;r=Dd(r|0,C|0,(A^K)&G^A|0,(B^I)&J^B|0)|0;s=C;p=Gd(v|0,u|0,28)|0;m=C;o=Hd(v|0,u|0,36)|0;m=m|C;j=Gd(v|0,u|0,34)|0;H=C;E=Hd(v|0,u|0,30)|0;H=m^(H|C);m=Gd(v|0,u|0,39)|0;l=C;b=Hd(v|0,u|0,25)|0;l=Dd((F|y)&v|F&y|0,(L|x)&u|L&x|0,(p|o)^(j|E)^(m|b)|0,H^(l|C)|0)|0;H=C;M=Dd(D|0,M|0,r|0,s|0)|0;D=C;s=Dd(l|0,H|0,r|0,s|0)|0;r=C;H=Gd(M|0,D|0,14)|0;l=C;b=Hd(M|0,D|0,50)|0;l=l|C;m=Gd(M|0,D|0,18)|0;E=C;j=Hd(M|0,D|0,46)|0;E=l^(E|C);l=Gd(M|0,D|0,41)|0;o=C;p=Hd(M|0,D|0,23)|0;o=E^(o|C);E=g+232|0;f=c[E>>2]|0;E=c[E+4>>2]|0;B=Dd(A|0,B|0,-1828018395,-710438585)|0;E=Dd(B|0,C|0,f|0,E|0)|0;o=Dd(E|0,C|0,(H|b)^(m|j)^(l|p)|0,o|0)|0;o=Dd(o|0,C|0,(K^G)&M^K|0,(I^J)&D^I|0)|0;p=C;l=Gd(s|0,r|0,28)|0;j=C;m=Hd(s|0,r|0,36)|0;j=j|C;b=Gd(s|0,r|0,34)|0;H=C;E=Hd(s|0,r|0,30)|0;H=j^(H|C);j=Gd(s|0,r|0,39)|0;f=C;B=Hd(s|0,r|0,25)|0;f=Dd((y|v)&s|y&v|0,(x|u)&r|x&u|0,(l|m)^(b|E)^(j|B)|0,H^(f|C)|0)|0;H=C;L=Dd(F|0,L|0,o|0,p|0)|0;F=C;p=Dd(f|0,H|0,o|0,p|0)|0;o=C;H=Gd(L|0,F|0,14)|0;f=C;B=Hd(L|0,F|0,50)|0;f=f|C;j=Gd(L|0,F|0,18)|0;E=C;b=Hd(L|0,F|0,46)|0;E=f^(E|C);f=Gd(L|0,F|0,41)|0;m=C;l=Hd(L|0,F|0,23)|0;m=E^(m|C);E=g+240|0;A=c[E>>2]|0;E=c[E+4>>2]|0;I=Dd(K|0,I|0,-536640913,113926993)|0;E=Dd(I|0,C|0,A|0,E|0)|0;m=Dd(E|0,C|0,(H|B)^(j|b)^(f|l)|0,m|0)|0;m=Dd(m|0,C|0,(G^M)&L^G|0,(J^D)&F^J|0)|0;l=C;f=Gd(p|0,o|0,28)|0;b=C;j=Hd(p|0,o|0,36)|0;b=b|C;B=Gd(p|0,o|0,34)|0;H=C;E=Hd(p|0,o|0,30)|0;H=b^(H|C);b=Gd(p|0,o|0,39)|0;A=C;I=Hd(p|0,o|0,25)|0;A=Dd((v|s)&p|v&s|0,(u|r)&o|u&r|0,(f|j)^(B|E)^(b|I)|0,H^(A|C)|0)|0;H=C;x=Dd(y|0,x|0,m|0,l|0)|0;y=C;l=Dd(A|0,H|0,m|0,l|0)|0;m=C;H=Gd(x|0,y|0,14)|0;A=C;I=Hd(x|0,y|0,50)|0;A=A|C;b=Gd(x|0,y|0,18)|0;E=C;B=Hd(x|0,y|0,46)|0;E=A^(E|C);A=Gd(x|0,y|0,41)|0;j=C;f=Hd(x|0,y|0,23)|0;j=E^(j|C);E=g+248|0;K=c[E>>2]|0;E=c[E+4>>2]|0;J=Dd(G|0,J|0,168717936,338241895)|0;E=Dd(J|0,C|0,K|0,E|0)|0;j=Dd(E|0,C|0,(H|I)^(b|B)^(A|f)|0,j|0)|0;j=Dd(j|0,C|0,(M^L)&x^M|0,(D^F)&y^D|0)|0;f=C;A=Gd(l|0,m|0,28)|0;B=C;b=Hd(l|0,m|0,36)|0;B=B|C;I=Gd(l|0,m|0,34)|0;H=C;E=Hd(l|0,m|0,30)|0;H=B^(H|C);B=Gd(l|0,m|0,39)|0;K=C;J=Hd(l|0,m|0,25)|0;K=Dd((s|p)&l|s&p|0,(r|o)&m|r&o|0,(A|b)^(I|E)^(B|J)|0,H^(K|C)|0)|0;H=C;u=Dd(v|0,u|0,j|0,f|0)|0;v=C;f=Dd(K|0,H|0,j|0,f|0)|0;j=C;H=Gd(u|0,v|0,14)|0;K=C;J=Hd(u|0,v|0,50)|0;K=K|C;B=Gd(u|0,v|0,18)|0;E=C;I=Hd(u|0,v|0,46)|0;E=K^(E|C);K=Gd(u|0,v|0,41)|0;b=C;A=Hd(u|0,v|0,23)|0;b=E^(b|C);E=g+256|0;G=c[E>>2]|0;E=c[E+4>>2]|0;D=Dd(M|0,D|0,1188179964,666307205)|0;E=Dd(D|0,C|0,G|0,E|0)|0;b=Dd(E|0,C|0,(H|J)^(B|I)^(K|A)|0,b|0)|0;b=Dd(b|0,C|0,(L^x)&u^L|0,(F^y)&v^F|0)|0;A=C;K=Gd(f|0,j|0,28)|0;I=C;B=Hd(f|0,j|0,36)|0;I=I|C;J=Gd(f|0,j|0,34)|0;H=C;E=Hd(f|0,j|0,30)|0;H=I^(H|C);I=Gd(f|0,j|0,39)|0;G=C;D=Hd(f|0,j|0,25)|0;G=Dd((p|l)&f|p&l|0,(o|m)&j|o&m|0,(K|B)^(J|E)^(I|D)|0,H^(G|C)|0)|0;H=C;r=Dd(s|0,r|0,b|0,A|0)|0;s=C;A=Dd(G|0,H|0,b|0,A|0)|0;b=C;H=Gd(r|0,s|0,14)|0;G=C;D=Hd(r|0,s|0,50)|0;G=G|C;I=Gd(r|0,s|0,18)|0;E=C;J=Hd(r|0,s|0,46)|0;E=G^(E|C);G=Gd(r|0,s|0,41)|0;B=C;K=Hd(r|0,s|0,23)|0;B=E^(B|C);E=g+264|0;M=c[E>>2]|0;E=c[E+4>>2]|0;F=Dd(L|0,F|0,1546045734,773529912)|0;E=Dd(F|0,C|0,M|0,E|0)|0;B=Dd(E|0,C|0,(H|D)^(I|J)^(G|K)|0,B|0)|0;B=Dd(B|0,C|0,(x^u)&r^x|0,(y^v)&s^y|0)|0;K=C;G=Gd(A|0,b|0,28)|0;J=C;I=Hd(A|0,b|0,36)|0;J=J|C;D=Gd(A|0,b|0,34)|0;H=C;E=Hd(A|0,b|0,30)|0;H=J^(H|C);J=Gd(A|0,b|0,39)|0;M=C;F=Hd(A|0,b|0,25)|0;M=Dd((l|f)&A|l&f|0,(m|j)&b|m&j|0,(G|I)^(D|E)^(J|F)|0,H^(M|C)|0)|0;H=C;o=Dd(p|0,o|0,B|0,K|0)|0;p=C;K=Dd(M|0,H|0,B|0,K|0)|0;B=C;H=Gd(o|0,p|0,14)|0;M=C;F=Hd(o|0,p|0,50)|0;M=M|C;J=Gd(o|0,p|0,18)|0;E=C;D=Hd(o|0,p|0,46)|0;E=M^(E|C);M=Gd(o|0,p|0,41)|0;I=C;G=Hd(o|0,p|0,23)|0;I=E^(I|C);E=g+272|0;L=c[E>>2]|0;E=c[E+4>>2]|0;y=Dd(x|0,y|0,1522805485,1294757372)|0;E=Dd(y|0,C|0,L|0,E|0)|0;I=Dd(E|0,C|0,(H|F)^(J|D)^(M|G)|0,I|0)|0;I=Dd(I|0,C|0,(u^r)&o^u|0,(v^s)&p^v|0)|0;G=C;M=Gd(K|0,B|0,28)|0;D=C;J=Hd(K|0,B|0,36)|0;D=D|C;F=Gd(K|0,B|0,34)|0;H=C;E=Hd(K|0,B|0,30)|0;H=D^(H|C);D=Gd(K|0,B|0,39)|0;L=C;y=Hd(K|0,B|0,25)|0;L=Dd((f|A)&K|f&A|0,(j|b)&B|j&b|0,(M|J)^(F|E)^(D|y)|0,H^(L|C)|0)|0;H=C;m=Dd(l|0,m|0,I|0,G|0)|0;l=C;G=Dd(L|0,H|0,I|0,G|0)|0;I=C;H=Gd(m|0,l|0,14)|0;L=C;y=Hd(m|0,l|0,50)|0;L=L|C;D=Gd(m|0,l|0,18)|0;E=C;F=Hd(m|0,l|0,46)|0;E=L^(E|C);L=Gd(m|0,l|0,41)|0;J=C;M=Hd(m|0,l|0,23)|0;J=E^(J|C);E=g+280|0;x=c[E>>2]|0;E=c[E+4>>2]|0;v=Dd(u|0,v|0,-1651133473,1396182291)|0;E=Dd(v|0,C|0,x|0,E|0)|0;J=Dd(E|0,C|0,(H|y)^(D|F)^(L|M)|0,J|0)|0;J=Dd(J|0,C|0,(r^o)&m^r|0,(s^p)&l^s|0)|0;M=C;L=Gd(G|0,I|0,28)|0;F=C;D=Hd(G|0,I|0,36)|0;F=F|C;y=Gd(G|0,I|0,34)|0;H=C;E=Hd(G|0,I|0,30)|0;H=F^(H|C);F=Gd(G|0,I|0,39)|0;x=C;v=Hd(G|0,I|0,25)|0;x=Dd((A|K)&G|A&K|0,(b|B)&I|b&B|0,(L|D)^(y|E)^(F|v)|0,H^(x|C)|0)|0;H=C;j=Dd(f|0,j|0,J|0,M|0)|0;f=C;M=Dd(x|0,H|0,J|0,M|0)|0;J=C;H=Gd(j|0,f|0,14)|0;x=C;v=Hd(j|0,f|0,50)|0;x=x|C;F=Gd(j|0,f|0,18)|0;E=C;y=Hd(j|0,f|0,46)|0;E=x^(E|C);x=Gd(j|0,f|0,41)|0;D=C;L=Hd(j|0,f|0,23)|0;D=E^(D|C);E=g+288|0;u=c[E>>2]|0;E=c[E+4>>2]|0;s=Dd(r|0,s|0,-1951439906,1695183700)|0;E=Dd(s|0,C|0,u|0,E|0)|0;D=Dd(E|0,C|0,(H|v)^(F|y)^(x|L)|0,D|0)|0;D=Dd(D|0,C|0,(o^m)&j^o|0,(p^l)&f^p|0)|0;L=C;x=Gd(M|0,J|0,28)|0;y=C;F=Hd(M|0,J|0,36)|0;y=y|C;v=Gd(M|0,J|0,34)|0;H=C;E=Hd(M|0,J|0,30)|0;H=y^(H|C);y=Gd(M|0,J|0,39)|0;u=C;s=Hd(M|0,J|0,25)|0;u=Dd((K|G)&M|K&G|0,(B|I)&J|B&I|0,(x|F)^(v|E)^(y|s)|0,H^(u|C)|0)|0;H=C;b=Dd(A|0,b|0,D|0,L|0)|0;A=C;L=Dd(u|0,H|0,D|0,L|0)|0;D=C;H=Gd(b|0,A|0,14)|0;u=C;s=Hd(b|0,A|0,50)|0;u=u|C;y=Gd(b|0,A|0,18)|0;E=C;v=Hd(b|0,A|0,46)|0;E=u^(E|C);u=Gd(b|0,A|0,41)|0;F=C;x=Hd(b|0,A|0,23)|0;F=E^(F|C);E=g+296|0;r=c[E>>2]|0;E=c[E+4>>2]|0;p=Dd(o|0,p|0,1014477480,1986661051)|0;E=Dd(p|0,C|0,r|0,E|0)|0;F=Dd(E|0,C|0,(H|s)^(y|v)^(u|x)|0,F|0)|0;F=Dd(F|0,C|0,(m^j)&b^m|0,(l^f)&A^l|0)|0;x=C;u=Gd(L|0,D|0,28)|0;v=C;y=Hd(L|0,D|0,36)|0;v=v|C;s=Gd(L|0,D|0,34)|0;H=C;E=Hd(L|0,D|0,30)|0;H=v^(H|C);v=Gd(L|0,D|0,39)|0;r=C;p=Hd(L|0,D|0,25)|0;r=Dd((G|M)&L|G&M|0,(I|J)&D|I&J|0,(u|y)^(s|E)^(v|p)|0,H^(r|C)|0)|0;H=C;B=Dd(K|0,B|0,F|0,x|0)|0;K=C;x=Dd(r|0,H|0,F|0,x|0)|0;F=C;H=Gd(B|0,K|0,14)|0;r=C;p=Hd(B|0,K|0,50)|0;r=r|C;v=Gd(B|0,K|0,18)|0;E=C;s=Hd(B|0,K|0,46)|0;E=r^(E|C);r=Gd(B|0,K|0,41)|0;y=C;u=Hd(B|0,K|0,23)|0;y=E^(y|C);E=g+304|0;o=c[E>>2]|0;E=c[E+4>>2]|0;l=Dd(m|0,l|0,1206759142,-2117940946)|0;E=Dd(l|0,C|0,o|0,E|0)|0;y=Dd(E|0,C|0,(H|p)^(v|s)^(r|u)|0,y|0)|0;y=Dd(y|0,C|0,(j^b)&B^j|0,(f^A)&K^f|0)|0;u=C;r=Gd(x|0,F|0,28)|0;s=C;v=Hd(x|0,F|0,36)|0;s=s|C;p=Gd(x|0,F|0,34)|0;H=C;E=Hd(x|0,F|0,30)|0;H=s^(H|C);s=Gd(x|0,F|0,39)|0;o=C;l=Hd(x|0,F|0,25)|0;o=Dd((M|L)&x|M&L|0,(J|D)&F|J&D|0,(r|v)^(p|E)^(s|l)|0,H^(o|C)|0)|0;H=C;I=Dd(G|0,I|0,y|0,u|0)|0;G=C;u=Dd(o|0,H|0,y|0,u|0)|0;y=C;H=Gd(I|0,G|0,14)|0;o=C;l=Hd(I|0,G|0,50)|0;o=o|C;s=Gd(I|0,G|0,18)|0;E=C;p=Hd(I|0,G|0,46)|0;E=o^(E|C);o=Gd(I|0,G|0,41)|0;v=C;r=Hd(I|0,G|0,23)|0;v=E^(v|C);E=g+312|0;m=c[E>>2]|0;E=c[E+4>>2]|0;f=Dd(j|0,f|0,344077627,-1838011259)|0;E=Dd(f|0,C|0,m|0,E|0)|0;v=Dd(E|0,C|0,(H|l)^(s|p)^(o|r)|0,v|0)|0;v=Dd(v|0,C|0,(b^B)&I^b|0,(A^K)&G^A|0)|0;r=C;o=Gd(u|0,y|0,28)|0;p=C;s=Hd(u|0,y|0,36)|0;p=p|C;l=Gd(u|0,y|0,34)|0;H=C;E=Hd(u|0,y|0,30)|0;H=p^(H|C);p=Gd(u|0,y|0,39)|0;m=C;f=Hd(u|0,y|0,25)|0;m=Dd((L|x)&u|L&x|0,(D|F)&y|D&F|0,(o|s)^(l|E)^(p|f)|0,H^(m|C)|0)|0;H=C;J=Dd(M|0,J|0,v|0,r|0)|0;M=C;r=Dd(m|0,H|0,v|0,r|0)|0;v=C;H=Gd(J|0,M|0,14)|0;m=C;f=Hd(J|0,M|0,50)|0;m=m|C;p=Gd(J|0,M|0,18)|0;E=C;l=Hd(J|0,M|0,46)|0;E=m^(E|C);m=Gd(J|0,M|0,41)|0;s=C;o=Hd(J|0,M|0,23)|0;s=E^(s|C);E=g+320|0;j=c[E>>2]|0;E=c[E+4>>2]|0;A=Dd(b|0,A|0,1290863460,-1564481375)|0;E=Dd(A|0,C|0,j|0,E|0)|0;s=Dd(E|0,C|0,(H|f)^(p|l)^(m|o)|0,s|0)|0;s=Dd(s|0,C|0,(B^I)&J^B|0,(K^G)&M^K|0)|0;o=C;m=Gd(r|0,v|0,28)|0;l=C;p=Hd(r|0,v|0,36)|0;l=l|C;f=Gd(r|0,v|0,34)|0;H=C;E=Hd(r|0,v|0,30)|0;H=l^(H|C);l=Gd(r|0,v|0,39)|0;j=C;A=Hd(r|0,v|0,25)|0;j=Dd((x|u)&r|x&u|0,(F|y)&v|F&y|0,(m|p)^(f|E)^(l|A)|0,H^(j|C)|0)|0;H=C;D=Dd(L|0,D|0,s|0,o|0)|0;L=C;o=Dd(j|0,H|0,s|0,o|0)|0;s=C;H=Gd(D|0,L|0,14)|0;j=C;A=Hd(D|0,L|0,50)|0;j=j|C;l=Gd(D|0,L|0,18)|0;E=C;f=Hd(D|0,L|0,46)|0;E=j^(E|C);j=Gd(D|0,L|0,41)|0;p=C;m=Hd(D|0,L|0,23)|0;p=E^(p|C);E=g+328|0;b=c[E>>2]|0;E=c[E+4>>2]|0;K=Dd(B|0,K|0,-1136513023,-1474664885)|0;E=Dd(K|0,C|0,b|0,E|0)|0;p=Dd(E|0,C|0,(H|A)^(l|f)^(j|m)|0,p|0)|0;p=Dd(p|0,C|0,(I^J)&D^I|0,(G^M)&L^G|0)|0;m=C;j=Gd(o|0,s|0,28)|0;f=C;l=Hd(o|0,s|0,36)|0;f=f|C;A=Gd(o|0,s|0,34)|0;H=C;E=Hd(o|0,s|0,30)|0;H=f^(H|C);f=Gd(o|0,s|0,39)|0;b=C;K=Hd(o|0,s|0,25)|0;b=Dd((u|r)&o|u&r|0,(y|v)&s|y&v|0,(j|l)^(A|E)^(f|K)|0,H^(b|C)|0)|0;H=C;F=Dd(x|0,F|0,p|0,m|0)|0;x=C;m=Dd(b|0,H|0,p|0,m|0)|0;p=C;H=Gd(F|0,x|0,14)|0;b=C;K=Hd(F|0,x|0,50)|0;b=b|C;f=Gd(F|0,x|0,18)|0;E=C;A=Hd(F|0,x|0,46)|0;E=b^(E|C);b=Gd(F|0,x|0,41)|0;l=C;j=Hd(F|0,x|0,23)|0;l=E^(l|C);E=g+336|0;B=c[E>>2]|0;E=c[E+4>>2]|0;G=Dd(I|0,G|0,-789014639,-1035236496)|0;E=Dd(G|0,C|0,B|0,E|0)|0;l=Dd(E|0,C|0,(H|K)^(f|A)^(b|j)|0,l|0)|0;l=Dd(l|0,C|0,(J^D)&F^J|0,(M^L)&x^M|0)|0;j=C;b=Gd(m|0,p|0,28)|0;A=C;f=Hd(m|0,p|0,36)|0;A=A|C;K=Gd(m|0,p|0,34)|0;H=C;E=Hd(m|0,p|0,30)|0;H=A^(H|C);A=Gd(m|0,p|0,39)|0;B=C;G=Hd(m|0,p|0,25)|0;B=Dd((r|o)&m|r&o|0,(v|s)&p|v&s|0,(b|f)^(K|E)^(A|G)|0,H^(B|C)|0)|0;H=C;y=Dd(u|0,y|0,l|0,j|0)|0;u=C;j=Dd(B|0,H|0,l|0,j|0)|0;l=C;H=Gd(y|0,u|0,14)|0;B=C;G=Hd(y|0,u|0,50)|0;B=B|C;A=Gd(y|0,u|0,18)|0;E=C;K=Hd(y|0,u|0,46)|0;E=B^(E|C);B=Gd(y|0,u|0,41)|0;f=C;b=Hd(y|0,u|0,23)|0;f=E^(f|C);E=g+344|0;I=c[E>>2]|0;E=c[E+4>>2]|0;M=Dd(J|0,M|0,106217008,-949202525)|0;E=Dd(M|0,C|0,I|0,E|0)|0;f=Dd(E|0,C|0,(H|G)^(A|K)^(B|b)|0,f|0)|0;f=Dd(f|0,C|0,(D^F)&y^D|0,(L^x)&u^L|0)|0;b=C;B=Gd(j|0,l|0,28)|0;K=C;A=Hd(j|0,l|0,36)|0;K=K|C;G=Gd(j|0,l|0,34)|0;H=C;E=Hd(j|0,l|0,30)|0;H=K^(H|C);K=Gd(j|0,l|0,39)|0;I=C;M=Hd(j|0,l|0,25)|0;I=Dd((o|m)&j|o&m|0,(s|p)&l|s&p|0,(B|A)^(G|E)^(K|M)|0,H^(I|C)|0)|0;H=C;v=Dd(r|0,v|0,f|0,b|0)|0;r=C;b=Dd(I|0,H|0,f|0,b|0)|0;f=C;H=Gd(v|0,r|0,14)|0;I=C;M=Hd(v|0,r|0,50)|0;I=I|C;K=Gd(v|0,r|0,18)|0;E=C;G=Hd(v|0,r|0,46)|0;E=I^(E|C);I=Gd(v|0,r|0,41)|0;A=C;B=Hd(v|0,r|0,23)|0;A=E^(A|C);E=g+352|0;J=c[E>>2]|0;E=c[E+4>>2]|0;L=Dd(D|0,L|0,-688958952,-778901479)|0;E=Dd(L|0,C|0,J|0,E|0)|0;A=Dd(E|0,C|0,(H|M)^(K|G)^(I|B)|0,A|0)|0;A=Dd(A|0,C|0,(F^y)&v^F|0,(x^u)&r^x|0)|0;B=C;I=Gd(b|0,f|0,28)|0;G=C;K=Hd(b|0,f|0,36)|0;G=G|C;M=Gd(b|0,f|0,34)|0;H=C;E=Hd(b|0,f|0,30)|0;H=G^(H|C);G=Gd(b|0,f|0,39)|0;J=C;L=Hd(b|0,f|0,25)|0;J=Dd((m|j)&b|m&j|0,(p|l)&f|p&l|0,(I|K)^(M|E)^(G|L)|0,H^(J|C)|0)|0;H=C;s=Dd(o|0,s|0,A|0,B|0)|0;o=C;B=Dd(J|0,H|0,A|0,B|0)|0;A=C;H=Gd(s|0,o|0,14)|0;J=C;L=Hd(s|0,o|0,50)|0;J=J|C;G=Gd(s|0,o|0,18)|0;E=C;M=Hd(s|0,o|0,46)|0;E=J^(E|C);J=Gd(s|0,o|0,41)|0;K=C;I=Hd(s|0,o|0,23)|0;K=E^(K|C);E=g+360|0;D=c[E>>2]|0;E=c[E+4>>2]|0;x=Dd(F|0,x|0,1432725776,-694614492)|0;E=Dd(x|0,C|0,D|0,E|0)|0;K=Dd(E|0,C|0,(H|L)^(G|M)^(J|I)|0,K|0)|0;K=Dd(K|0,C|0,(y^v)&s^y|0,(u^r)&o^u|0)|0;I=C;J=Gd(B|0,A|0,28)|0;M=C;G=Hd(B|0,A|0,36)|0;M=M|C;L=Gd(B|0,A|0,34)|0;H=C;E=Hd(B|0,A|0,30)|0;H=M^(H|C);M=Gd(B|0,A|0,39)|0;D=C;x=Hd(B|0,A|0,25)|0;D=Dd((j|b)&B|j&b|0,(l|f)&A|l&f|0,(J|G)^(L|E)^(M|x)|0,H^(D|C)|0)|0;H=C;p=Dd(m|0,p|0,K|0,I|0)|0;m=C;I=Dd(D|0,H|0,K|0,I|0)|0;K=C;H=Gd(p|0,m|0,14)|0;D=C;x=Hd(p|0,m|0,50)|0;D=D|C;M=Gd(p|0,m|0,18)|0;E=C;L=Hd(p|0,m|0,46)|0;E=D^(E|C);D=Gd(p|0,m|0,41)|0;G=C;J=Hd(p|0,m|0,23)|0;G=E^(G|C);E=g+368|0;F=c[E>>2]|0;E=c[E+4>>2]|0;u=Dd(y|0,u|0,1467031594,-200395387)|0;E=Dd(u|0,C|0,F|0,E|0)|0;G=Dd(E|0,C|0,(H|x)^(M|L)^(D|J)|0,G|0)|0;G=Dd(G|0,C|0,(v^s)&p^v|0,(r^o)&m^r|0)|0;J=C;D=Gd(I|0,K|0,28)|0;L=C;M=Hd(I|0,K|0,36)|0;L=L|C;x=Gd(I|0,K|0,34)|0;H=C;E=Hd(I|0,K|0,30)|0;H=L^(H|C);L=Gd(I|0,K|0,39)|0;F=C;u=Hd(I|0,K|0,25)|0;F=Dd((b|B)&I|b&B|0,(f|A)&K|f&A|0,(D|M)^(x|E)^(L|u)|0,H^(F|C)|0)|0;H=C;l=Dd(j|0,l|0,G|0,J|0)|0;j=C;J=Dd(F|0,H|0,G|0,J|0)|0;G=C;H=Gd(l|0,j|0,14)|0;F=C;u=Hd(l|0,j|0,50)|0;F=F|C;L=Gd(l|0,j|0,18)|0;E=C;x=Hd(l|0,j|0,46)|0;E=F^(E|C);F=Gd(l|0,j|0,41)|0;M=C;D=Hd(l|0,j|0,23)|0;M=E^(M|C);E=g+376|0;y=c[E>>2]|0;E=c[E+4>>2]|0;r=Dd(v|0,r|0,851169720,275423344)|0;E=Dd(r|0,C|0,y|0,E|0)|0;M=Dd(E|0,C|0,(H|u)^(L|x)^(F|D)|0,M|0)|0;M=Dd(M|0,C|0,(s^p)&l^s|0,(o^m)&j^o|0)|0;D=C;F=Gd(J|0,G|0,28)|0;x=C;L=Hd(J|0,G|0,36)|0;x=x|C;u=Gd(J|0,G|0,34)|0;H=C;E=Hd(J|0,G|0,30)|0;H=x^(H|C);x=Gd(J|0,G|0,39)|0;y=C;r=Hd(J|0,G|0,25)|0;y=Dd((B|I)&J|B&I|0,(A|K)&G|A&K|0,(F|L)^(u|E)^(x|r)|0,H^(y|C)|0)|0;H=C;f=Dd(b|0,f|0,M|0,D|0)|0;b=C;D=Dd(y|0,H|0,M|0,D|0)|0;M=C;H=Gd(f|0,b|0,14)|0;y=C;r=Hd(f|0,b|0,50)|0;y=y|C;x=Gd(f|0,b|0,18)|0;E=C;u=Hd(f|0,b|0,46)|0;E=y^(E|C);y=Gd(f|0,b|0,41)|0;L=C;F=Hd(f|0,b|0,23)|0;L=E^(L|C);E=g+384|0;v=c[E>>2]|0;E=c[E+4>>2]|0;o=Dd(s|0,o|0,-1194143544,430227734)|0;E=Dd(o|0,C|0,v|0,E|0)|0;L=Dd(E|0,C|0,(H|r)^(x|u)^(y|F)|0,L|0)|0;L=Dd(L|0,C|0,(p^l)&f^p|0,(m^j)&b^m|0)|0;F=C;y=Gd(D|0,M|0,28)|0;u=C;x=Hd(D|0,M|0,36)|0;u=u|C;r=Gd(D|0,M|0,34)|0;H=C;E=Hd(D|0,M|0,30)|0;H=u^(H|C);u=Gd(D|0,M|0,39)|0;v=C;o=Hd(D|0,M|0,25)|0;v=Dd((I|J)&D|I&J|0,(K|G)&M|K&G|0,(y|x)^(r|E)^(u|o)|0,H^(v|C)|0)|0;H=C;A=Dd(B|0,A|0,L|0,F|0)|0;B=C;F=Dd(v|0,H|0,L|0,F|0)|0;L=C;H=Gd(A|0,B|0,14)|0;v=C;o=Hd(A|0,B|0,50)|0;v=v|C;u=Gd(A|0,B|0,18)|0;E=C;r=Hd(A|0,B|0,46)|0;E=v^(E|C);v=Gd(A|0,B|0,41)|0;x=C;y=Hd(A|0,B|0,23)|0;x=E^(x|C);E=g+392|0;s=c[E>>2]|0;E=c[E+4>>2]|0;m=Dd(p|0,m|0,1363258195,506948616)|0;E=Dd(m|0,C|0,s|0,E|0)|0;x=Dd(E|0,C|0,(H|o)^(u|r)^(v|y)|0,x|0)|0;x=Dd(x|0,C|0,(l^f)&A^l|0,(j^b)&B^j|0)|0;y=C;v=Gd(F|0,L|0,28)|0;r=C;u=Hd(F|0,L|0,36)|0;r=r|C;o=Gd(F|0,L|0,34)|0;H=C;E=Hd(F|0,L|0,30)|0;H=r^(H|C);r=Gd(F|0,L|0,39)|0;s=C;m=Hd(F|0,L|0,25)|0;s=Dd((J|D)&F|J&D|0,(G|M)&L|G&M|0,(v|u)^(o|E)^(r|m)|0,H^(s|C)|0)|0;H=C;K=Dd(I|0,K|0,x|0,y|0)|0;I=C;y=Dd(s|0,H|0,x|0,y|0)|0;x=C;H=Gd(K|0,I|0,14)|0;s=C;m=Hd(K|0,I|0,50)|0;s=s|C;r=Gd(K|0,I|0,18)|0;E=C;o=Hd(K|0,I|0,46)|0;E=s^(E|C);s=Gd(K|0,I|0,41)|0;u=C;v=Hd(K|0,I|0,23)|0;u=E^(u|C);E=g+400|0;p=c[E>>2]|0;E=c[E+4>>2]|0;j=Dd(l|0,j|0,-544281703,659060556)|0;E=Dd(j|0,C|0,p|0,E|0)|0;u=Dd(E|0,C|0,(H|m)^(r|o)^(s|v)|0,u|0)|0;u=Dd(u|0,C|0,(f^A)&K^f|0,(b^B)&I^b|0)|0;v=C;s=Gd(y|0,x|0,28)|0;o=C;r=Hd(y|0,x|0,36)|0;o=o|C;m=Gd(y|0,x|0,34)|0;H=C;E=Hd(y|0,x|0,30)|0;H=o^(H|C);o=Gd(y|0,x|0,39)|0;p=C;j=Hd(y|0,x|0,25)|0;p=Dd((D|F)&y|D&F|0,(M|L)&x|M&L|0,(s|r)^(m|E)^(o|j)|0,H^(p|C)|0)|0;H=C;G=Dd(J|0,G|0,u|0,v|0)|0;J=C;v=Dd(p|0,H|0,u|0,v|0)|0;u=C;H=Gd(G|0,J|0,14)|0;p=C;j=Hd(G|0,J|0,50)|0;p=p|C;o=Gd(G|0,J|0,18)|0;E=C;m=Hd(G|0,J|0,46)|0;E=p^(E|C);p=Gd(G|0,J|0,41)|0;r=C;s=Hd(G|0,J|0,23)|0;r=E^(r|C);E=g+408|0;l=c[E>>2]|0;E=c[E+4>>2]|0;b=Dd(f|0,b|0,-509917016,883997877)|0;E=Dd(b|0,C|0,l|0,E|0)|0;r=Dd(E|0,C|0,(H|j)^(o|m)^(p|s)|0,r|0)|0;r=Dd(r|0,C|0,(A^K)&G^A|0,(B^I)&J^B|0)|0;s=C;p=Gd(v|0,u|0,28)|0;m=C;o=Hd(v|0,u|0,36)|0;m=m|C;j=Gd(v|0,u|0,34)|0;H=C;E=Hd(v|0,u|0,30)|0;H=m^(H|C);m=Gd(v|0,u|0,39)|0;l=C;b=Hd(v|0,u|0,25)|0;l=Dd((F|y)&v|F&y|0,(L|x)&u|L&x|0,(p|o)^(j|E)^(m|b)|0,H^(l|C)|0)|0;H=C;M=Dd(D|0,M|0,r|0,s|0)|0;D=C;s=Dd(l|0,H|0,r|0,s|0)|0;r=C;H=Gd(M|0,D|0,14)|0;l=C;b=Hd(M|0,D|0,50)|0;l=l|C;m=Gd(M|0,D|0,18)|0;E=C;j=Hd(M|0,D|0,46)|0;E=l^(E|C);l=Gd(M|0,D|0,41)|0;o=C;p=Hd(M|0,D|0,23)|0;o=E^(o|C);E=g+416|0;f=c[E>>2]|0;E=c[E+4>>2]|0;B=Dd(A|0,B|0,-976659869,958139571)|0;E=Dd(B|0,C|0,f|0,E|0)|0;o=Dd(E|0,C|0,(H|b)^(m|j)^(l|p)|0,o|0)|0;o=Dd(o|0,C|0,(K^G)&M^K|0,(I^J)&D^I|0)|0;p=C;l=Gd(s|0,r|0,28)|0;j=C;m=Hd(s|0,r|0,36)|0;j=j|C;b=Gd(s|0,r|0,34)|0;H=C;E=Hd(s|0,r|0,30)|0;H=j^(H|C);j=Gd(s|0,r|0,39)|0;f=C;B=Hd(s|0,r|0,25)|0;f=Dd((y|v)&s|y&v|0,(x|u)&r|x&u|0,(l|m)^(b|E)^(j|B)|0,H^(f|C)|0)|0;H=C;L=Dd(F|0,L|0,o|0,p|0)|0;F=C;p=Dd(f|0,H|0,o|0,p|0)|0;o=C;H=Gd(L|0,F|0,14)|0;f=C;B=Hd(L|0,F|0,50)|0;f=f|C;j=Gd(L|0,F|0,18)|0;E=C;b=Hd(L|0,F|0,46)|0;E=f^(E|C);f=Gd(L|0,F|0,41)|0;m=C;l=Hd(L|0,F|0,23)|0;m=E^(m|C);E=g+424|0;A=c[E>>2]|0;E=c[E+4>>2]|0;I=Dd(K|0,I|0,-482243893,1322822218)|0;E=Dd(I|0,C|0,A|0,E|0)|0;m=Dd(E|0,C|0,(H|B)^(j|b)^(f|l)|0,m|0)|0;m=Dd(m|0,C|0,(G^M)&L^G|0,(J^D)&F^J|0)|0;l=C;f=Gd(p|0,o|0,28)|0;b=C;j=Hd(p|0,o|0,36)|0;b=b|C;B=Gd(p|0,o|0,34)|0;H=C;E=Hd(p|0,o|0,30)|0;H=b^(H|C);b=Gd(p|0,o|0,39)|0;A=C;I=Hd(p|0,o|0,25)|0;A=Dd((v|s)&p|v&s|0,(u|r)&o|u&r|0,(f|j)^(B|E)^(b|I)|0,H^(A|C)|0)|0;H=C;x=Dd(y|0,x|0,m|0,l|0)|0;y=C;l=Dd(A|0,H|0,m|0,l|0)|0;m=C;H=Gd(x|0,y|0,14)|0;A=C;I=Hd(x|0,y|0,50)|0;A=A|C;b=Gd(x|0,y|0,18)|0;E=C;B=Hd(x|0,y|0,46)|0;E=A^(E|C);A=Gd(x|0,y|0,41)|0;j=C;f=Hd(x|0,y|0,23)|0;j=E^(j|C);E=g+432|0;K=c[E>>2]|0;E=c[E+4>>2]|0;J=Dd(G|0,J|0,2003034995,1537002063)|0;E=Dd(J|0,C|0,K|0,E|0)|0;j=Dd(E|0,C|0,(H|I)^(b|B)^(A|f)|0,j|0)|0;j=Dd(j|0,C|0,(M^L)&x^M|0,(D^F)&y^D|0)|0;f=C;A=Gd(l|0,m|0,28)|0;B=C;b=Hd(l|0,m|0,36)|0;B=B|C;I=Gd(l|0,m|0,34)|0;H=C;E=Hd(l|0,m|0,30)|0;H=B^(H|C);B=Gd(l|0,m|0,39)|0;K=C;J=Hd(l|0,m|0,25)|0;K=Dd((s|p)&l|s&p|0,(r|o)&m|r&o|0,(A|b)^(I|E)^(B|J)|0,H^(K|C)|0)|0;H=C;u=Dd(v|0,u|0,j|0,f|0)|0;v=C;f=Dd(K|0,H|0,j|0,f|0)|0;j=C;H=Gd(u|0,v|0,14)|0;K=C;J=Hd(u|0,v|0,50)|0;K=K|C;B=Gd(u|0,v|0,18)|0;E=C;I=Hd(u|0,v|0,46)|0;E=K^(E|C);K=Gd(u|0,v|0,41)|0;b=C;A=Hd(u|0,v|0,23)|0;b=E^(b|C);E=g+440|0;G=c[E>>2]|0;E=c[E+4>>2]|0;D=Dd(M|0,D|0,-692930397,1747873779)|0;E=Dd(D|0,C|0,G|0,E|0)|0;b=Dd(E|0,C|0,(H|J)^(B|I)^(K|A)|0,b|0)|0;b=Dd(b|0,C|0,(L^x)&u^L|0,(F^y)&v^F|0)|0;A=C;K=Gd(f|0,j|0,28)|0;I=C;B=Hd(f|0,j|0,36)|0;I=I|C;J=Gd(f|0,j|0,34)|0;H=C;E=Hd(f|0,j|0,30)|0;H=I^(H|C);I=Gd(f|0,j|0,39)|0;G=C;D=Hd(f|0,j|0,25)|0;G=Dd((p|l)&f|p&l|0,(o|m)&j|o&m|0,(K|B)^(J|E)^(I|D)|0,H^(G|C)|0)|0;H=C;r=Dd(s|0,r|0,b|0,A|0)|0;s=C;A=Dd(G|0,H|0,b|0,A|0)|0;b=C;H=Gd(r|0,s|0,14)|0;G=C;D=Hd(r|0,s|0,50)|0;G=G|C;I=Gd(r|0,s|0,18)|0;E=C;J=Hd(r|0,s|0,46)|0;E=G^(E|C);G=Gd(r|0,s|0,41)|0;B=C;K=Hd(r|0,s|0,23)|0;B=E^(B|C);E=g+448|0;M=c[E>>2]|0;E=c[E+4>>2]|0;F=Dd(L|0,F|0,1575990012,1955562222)|0;E=Dd(F|0,C|0,M|0,E|0)|0;B=Dd(E|0,C|0,(H|D)^(I|J)^(G|K)|0,B|0)|0;B=Dd(B|0,C|0,(x^u)&r^x|0,(y^v)&s^y|0)|0;K=C;G=Gd(A|0,b|0,28)|0;J=C;I=Hd(A|0,b|0,36)|0;J=J|C;D=Gd(A|0,b|0,34)|0;H=C;E=Hd(A|0,b|0,30)|0;H=J^(H|C);J=Gd(A|0,b|0,39)|0;M=C;F=Hd(A|0,b|0,25)|0;M=Dd((l|f)&A|l&f|0,(m|j)&b|m&j|0,(G|I)^(D|E)^(J|F)|0,H^(M|C)|0)|0;H=C;o=Dd(p|0,o|0,B|0,K|0)|0;p=C;K=Dd(M|0,H|0,B|0,K|0)|0;B=C;H=Gd(o|0,p|0,14)|0;M=C;F=Hd(o|0,p|0,50)|0;M=M|C;J=Gd(o|0,p|0,18)|0;E=C;D=Hd(o|0,p|0,46)|0;E=M^(E|C);M=Gd(o|0,p|0,41)|0;I=C;G=Hd(o|0,p|0,23)|0;I=E^(I|C);E=g+456|0;L=c[E>>2]|0;E=c[E+4>>2]|0;y=Dd(x|0,y|0,1125592928,2024104815)|0;E=Dd(y|0,C|0,L|0,E|0)|0;I=Dd(E|0,C|0,(H|F)^(J|D)^(M|G)|0,I|0)|0;I=Dd(I|0,C|0,(u^r)&o^u|0,(v^s)&p^v|0)|0;G=C;M=Gd(K|0,B|0,28)|0;D=C;J=Hd(K|0,B|0,36)|0;D=D|C;F=Gd(K|0,B|0,34)|0;H=C;E=Hd(K|0,B|0,30)|0;H=D^(H|C);D=Gd(K|0,B|0,39)|0;L=C;y=Hd(K|0,B|0,25)|0;L=Dd((f|A)&K|f&A|0,(j|b)&B|j&b|0,(M|J)^(F|E)^(D|y)|0,H^(L|C)|0)|0;H=C;m=Dd(l|0,m|0,I|0,G|0)|0;l=C;G=Dd(L|0,H|0,I|0,G|0)|0;I=C;H=Gd(m|0,l|0,14)|0;L=C;y=Hd(m|0,l|0,50)|0;L=L|C;D=Gd(m|0,l|0,18)|0;E=C;F=Hd(m|0,l|0,46)|0;E=L^(E|C);L=Gd(m|0,l|0,41)|0;J=C;M=Hd(m|0,l|0,23)|0;J=E^(J|C);E=g+464|0;x=c[E>>2]|0;E=c[E+4>>2]|0;v=Dd(u|0,v|0,-1578062990,-2067236844)|0;E=Dd(v|0,C|0,x|0,E|0)|0;J=Dd(E|0,C|0,(H|y)^(D|F)^(L|M)|0,J|0)|0;J=Dd(J|0,C|0,(r^o)&m^r|0,(s^p)&l^s|0)|0;M=C;L=Gd(G|0,I|0,28)|0;F=C;D=Hd(G|0,I|0,36)|0;F=F|C;y=Gd(G|0,I|0,34)|0;H=C;E=Hd(G|0,I|0,30)|0;H=F^(H|C);F=Gd(G|0,I|0,39)|0;x=C;v=Hd(G|0,I|0,25)|0;x=Dd((A|K)&G|A&K|0,(b|B)&I|b&B|0,(L|D)^(y|E)^(F|v)|0,H^(x|C)|0)|0;H=C;j=Dd(f|0,j|0,J|0,M|0)|0;f=C;M=Dd(x|0,H|0,J|0,M|0)|0;J=C;H=Gd(j|0,f|0,14)|0;x=C;v=Hd(j|0,f|0,50)|0;x=x|C;F=Gd(j|0,f|0,18)|0;E=C;y=Hd(j|0,f|0,46)|0;E=x^(E|C);x=Gd(j|0,f|0,41)|0;D=C;L=Hd(j|0,f|0,23)|0;D=E^(D|C);E=g+472|0;u=c[E>>2]|0;E=c[E+4>>2]|0;s=Dd(r|0,s|0,442776044,-1933114872)|0;E=Dd(s|0,C|0,u|0,E|0)|0;D=Dd(E|0,C|0,(H|v)^(F|y)^(x|L)|0,D|0)|0;D=Dd(D|0,C|0,(o^m)&j^o|0,(p^l)&f^p|0)|0;L=C;x=Gd(M|0,J|0,28)|0;y=C;F=Hd(M|0,J|0,36)|0;y=y|C;v=Gd(M|0,J|0,34)|0;H=C;E=Hd(M|0,J|0,30)|0;H=y^(H|C);y=Gd(M|0,J|0,39)|0;u=C;s=Hd(M|0,J|0,25)|0;u=Dd((K|G)&M|K&G|0,(B|I)&J|B&I|0,(x|F)^(v|E)^(y|s)|0,H^(u|C)|0)|0;H=C;b=Dd(A|0,b|0,D|0,L|0)|0;A=C;L=Dd(u|0,H|0,D|0,L|0)|0;D=C;H=Gd(b|0,A|0,14)|0;u=C;s=Hd(b|0,A|0,50)|0;u=u|C;y=Gd(b|0,A|0,18)|0;E=C;v=Hd(b|0,A|0,46)|0;E=u^(E|C);u=Gd(b|0,A|0,41)|0;F=C;x=Hd(b|0,A|0,23)|0;F=E^(F|C);E=g+480|0;r=c[E>>2]|0;E=c[E+4>>2]|0;p=Dd(o|0,p|0,593698344,-1866530822)|0;E=Dd(p|0,C|0,r|0,E|0)|0;F=Dd(E|0,C|0,(H|s)^(y|v)^(u|x)|0,F|0)|0;F=Dd(F|0,C|0,(m^j)&b^m|0,(l^f)&A^l|0)|0;x=C;u=Gd(L|0,D|0,28)|0;v=C;y=Hd(L|0,D|0,36)|0;v=v|C;s=Gd(L|0,D|0,34)|0;H=C;E=Hd(L|0,D|0,30)|0;H=v^(H|C);v=Gd(L|0,D|0,39)|0;r=C;p=Hd(L|0,D|0,25)|0;r=Dd((G|M)&L|G&M|0,(I|J)&D|I&J|0,(u|y)^(s|E)^(v|p)|0,H^(r|C)|0)|0;H=C;B=Dd(K|0,B|0,F|0,x|0)|0;K=C;x=Dd(r|0,H|0,F|0,x|0)|0;F=C;H=Gd(B|0,K|0,14)|0;r=C;p=Hd(B|0,K|0,50)|0;r=r|C;v=Gd(B|0,K|0,18)|0;E=C;s=Hd(B|0,K|0,46)|0;E=r^(E|C);r=Gd(B|0,K|0,41)|0;y=C;u=Hd(B|0,K|0,23)|0;y=E^(y|C);E=g+488|0;o=c[E>>2]|0;E=c[E+4>>2]|0;l=Dd(m|0,l|0,-561857047,-1538233109)|0;E=Dd(l|0,C|0,o|0,E|0)|0;y=Dd(E|0,C|0,(H|p)^(v|s)^(r|u)|0,y|0)|0;y=Dd(y|0,C|0,(j^b)&B^j|0,(f^A)&K^f|0)|0;u=C;r=Gd(x|0,F|0,28)|0;s=C;v=Hd(x|0,F|0,36)|0;s=s|C;p=Gd(x|0,F|0,34)|0;H=C;E=Hd(x|0,F|0,30)|0;H=s^(H|C);s=Gd(x|0,F|0,39)|0;o=C;l=Hd(x|0,F|0,25)|0;o=Dd((M|L)&x|M&L|0,(J|D)&F|J&D|0,(r|v)^(p|E)^(s|l)|0,H^(o|C)|0)|0;H=C;I=Dd(G|0,I|0,y|0,u|0)|0;G=C;u=Dd(o|0,H|0,y|0,u|0)|0;y=C;H=Gd(I|0,G|0,14)|0;o=C;l=Hd(I|0,G|0,50)|0;o=o|C;s=Gd(I|0,G|0,18)|0;E=C;p=Hd(I|0,G|0,46)|0;E=o^(E|C);o=Gd(I|0,G|0,41)|0;v=C;r=Hd(I|0,G|0,23)|0;v=E^(v|C);E=g+496|0;m=c[E>>2]|0;E=c[E+4>>2]|0;f=Dd(j|0,f|0,-1295615723,-1090935817)|0;E=Dd(f|0,C|0,m|0,E|0)|0;v=Dd(E|0,C|0,(H|l)^(s|p)^(o|r)|0,v|0)|0;v=Dd(v|0,C|0,(b^B)&I^b|0,(A^K)&G^A|0)|0;r=C;o=Gd(u|0,y|0,28)|0;p=C;s=Hd(u|0,y|0,36)|0;p=p|C;l=Gd(u|0,y|0,34)|0;H=C;E=Hd(u|0,y|0,30)|0;H=p^(H|C);p=Gd(u|0,y|0,39)|0;m=C;f=Hd(u|0,y|0,25)|0;m=Dd((L|x)&u|L&x|0,(D|F)&y|D&F|0,(o|s)^(l|E)^(p|f)|0,H^(m|C)|0)|0;H=C;J=Dd(M|0,J|0,v|0,r|0)|0;M=C;r=Dd(m|0,H|0,v|0,r|0)|0;v=C;H=Gd(J|0,M|0,14)|0;m=C;f=Hd(J|0,M|0,50)|0;m=m|C;p=Gd(J|0,M|0,18)|0;E=C;l=Hd(J|0,M|0,46)|0;E=m^(E|C);m=Gd(J|0,M|0,41)|0;s=C;o=Hd(J|0,M|0,23)|0;s=E^(s|C);E=g+504|0;j=c[E>>2]|0;E=c[E+4>>2]|0;A=Dd(b|0,A|0,-479046869,-965641998)|0;E=Dd(A|0,C|0,j|0,E|0)|0;s=Dd(E|0,C|0,(H|f)^(p|l)^(m|o)|0,s|0)|0;s=Dd(s|0,C|0,(B^I)&J^B|0,(K^G)&M^K|0)|0;o=C;m=Gd(r|0,v|0,28)|0;l=C;p=Hd(r|0,v|0,36)|0;l=l|C;f=Gd(r|0,v|0,34)|0;H=C;E=Hd(r|0,v|0,30)|0;H=l^(H|C);l=Gd(r|0,v|0,39)|0;j=C;A=Hd(r|0,v|0,25)|0;j=Dd((x|u)&r|x&u|0,(F|y)&v|F&y|0,(m|p)^(f|E)^(l|A)|0,H^(j|C)|0)|0;H=C;D=Dd(L|0,D|0,s|0,o|0)|0;L=C;o=Dd(j|0,H|0,s|0,o|0)|0;s=C;H=Gd(D|0,L|0,14)|0;j=C;A=Hd(D|0,L|0,50)|0;j=j|C;l=Gd(D|0,L|0,18)|0;E=C;f=Hd(D|0,L|0,46)|0;E=j^(E|C);j=Gd(D|0,L|0,41)|0;p=C;m=Hd(D|0,L|0,23)|0;p=E^(p|C);E=g+512|0;b=c[E>>2]|0;E=c[E+4>>2]|0;K=Dd(B|0,K|0,-366583396,-903397682)|0;E=Dd(K|0,C|0,b|0,E|0)|0;p=Dd(E|0,C|0,(H|A)^(l|f)^(j|m)|0,p|0)|0;p=Dd(p|0,C|0,(I^J)&D^I|0,(G^M)&L^G|0)|0;m=C;j=Gd(o|0,s|0,28)|0;f=C;l=Hd(o|0,s|0,36)|0;f=f|C;A=Gd(o|0,s|0,34)|0;H=C;E=Hd(o|0,s|0,30)|0;H=f^(H|C);f=Gd(o|0,s|0,39)|0;b=C;K=Hd(o|0,s|0,25)|0;b=Dd((u|r)&o|u&r|0,(y|v)&s|y&v|0,(j|l)^(A|E)^(f|K)|0,H^(b|C)|0)|0;H=C;F=Dd(x|0,F|0,p|0,m|0)|0;x=C;m=Dd(b|0,H|0,p|0,m|0)|0;p=C;H=Gd(F|0,x|0,14)|0;b=C;K=Hd(F|0,x|0,50)|0;b=b|C;f=Gd(F|0,x|0,18)|0;E=C;A=Hd(F|0,x|0,46)|0;E=b^(E|C);b=Gd(F|0,x|0,41)|0;l=C;j=Hd(F|0,x|0,23)|0;l=E^(l|C);E=g+520|0;B=c[E>>2]|0;E=c[E+4>>2]|0;G=Dd(I|0,G|0,566280711,-779700025)|0;E=Dd(G|0,C|0,B|0,E|0)|0;l=Dd(E|0,C|0,(H|K)^(f|A)^(b|j)|0,l|0)|0;l=Dd(l|0,C|0,(J^D)&F^J|0,(M^L)&x^M|0)|0;j=C;b=Gd(m|0,p|0,28)|0;A=C;f=Hd(m|0,p|0,36)|0;A=A|C;K=Gd(m|0,p|0,34)|0;H=C;E=Hd(m|0,p|0,30)|0;H=A^(H|C);A=Gd(m|0,p|0,39)|0;B=C;G=Hd(m|0,p|0,25)|0;B=Dd((r|o)&m|r&o|0,(v|s)&p|v&s|0,(b|f)^(K|E)^(A|G)|0,H^(B|C)|0)|0;H=C;y=Dd(u|0,y|0,l|0,j|0)|0;u=C;j=Dd(B|0,H|0,l|0,j|0)|0;l=C;H=Gd(y|0,u|0,14)|0;B=C;G=Hd(y|0,u|0,50)|0;B=B|C;A=Gd(y|0,u|0,18)|0;E=C;K=Hd(y|0,u|0,46)|0;E=B^(E|C);B=Gd(y|0,u|0,41)|0;f=C;b=Hd(y|0,u|0,23)|0;f=E^(f|C);E=g+528|0;I=c[E>>2]|0;E=c[E+4>>2]|0;M=Dd(J|0,M|0,-840897762,-354779690)|0;E=Dd(M|0,C|0,I|0,E|0)|0;f=Dd(E|0,C|0,(H|G)^(A|K)^(B|b)|0,f|0)|0;f=Dd(f|0,C|0,(D^F)&y^D|0,(L^x)&u^L|0)|0;b=C;B=Gd(j|0,l|0,28)|0;K=C;A=Hd(j|0,l|0,36)|0;K=K|C;G=Gd(j|0,l|0,34)|0;H=C;E=Hd(j|0,l|0,30)|0;H=K^(H|C);K=Gd(j|0,l|0,39)|0;I=C;M=Hd(j|0,l|0,25)|0;I=Dd((o|m)&j|o&m|0,(s|p)&l|s&p|0,(B|A)^(G|E)^(K|M)|0,H^(I|C)|0)|0;H=C;v=Dd(r|0,v|0,f|0,b|0)|0;r=C;b=Dd(I|0,H|0,f|0,b|0)|0;f=C;H=Gd(v|0,r|0,14)|0;I=C;M=Hd(v|0,r|0,50)|0;I=I|C;K=Gd(v|0,r|0,18)|0;E=C;G=Hd(v|0,r|0,46)|0;E=I^(E|C);I=Gd(v|0,r|0,41)|0;A=C;B=Hd(v|0,r|0,23)|0;A=E^(A|C);E=g+536|0;J=c[E>>2]|0;E=c[E+4>>2]|0;L=Dd(D|0,L|0,-294727304,-176337025)|0;E=Dd(L|0,C|0,J|0,E|0)|0;A=Dd(E|0,C|0,(H|M)^(K|G)^(I|B)|0,A|0)|0;A=Dd(A|0,C|0,(F^y)&v^F|0,(x^u)&r^x|0)|0;B=C;I=Gd(b|0,f|0,28)|0;G=C;K=Hd(b|0,f|0,36)|0;G=G|C;M=Gd(b|0,f|0,34)|0;H=C;E=Hd(b|0,f|0,30)|0;H=G^(H|C);G=Gd(b|0,f|0,39)|0;J=C;L=Hd(b|0,f|0,25)|0;J=Dd((m|j)&b|m&j|0,(p|l)&f|p&l|0,(I|K)^(M|E)^(G|L)|0,H^(J|C)|0)|0;H=C;s=Dd(o|0,s|0,A|0,B|0)|0;o=C;B=Dd(J|0,H|0,A|0,B|0)|0;A=C;H=Gd(s|0,o|0,14)|0;J=C;L=Hd(s|0,o|0,50)|0;J=J|C;G=Gd(s|0,o|0,18)|0;E=C;M=Hd(s|0,o|0,46)|0;E=J^(E|C);J=Gd(s|0,o|0,41)|0;K=C;I=Hd(s|0,o|0,23)|0;K=E^(K|C);E=g+544|0;D=c[E>>2]|0;E=c[E+4>>2]|0;x=Dd(F|0,x|0,1914138554,116418474)|0;E=Dd(x|0,C|0,D|0,E|0)|0;K=Dd(E|0,C|0,(H|L)^(G|M)^(J|I)|0,K|0)|0;K=Dd(K|0,C|0,(y^v)&s^y|0,(u^r)&o^u|0)|0;I=C;J=Gd(B|0,A|0,28)|0;M=C;G=Hd(B|0,A|0,36)|0;M=M|C;L=Gd(B|0,A|0,34)|0;H=C;E=Hd(B|0,A|0,30)|0;H=M^(H|C);M=Gd(B|0,A|0,39)|0;D=C;x=Hd(B|0,A|0,25)|0;D=Dd((j|b)&B|j&b|0,(l|f)&A|l&f|0,(J|G)^(L|E)^(M|x)|0,H^(D|C)|0)|0;H=C;p=Dd(m|0,p|0,K|0,I|0)|0;m=C;I=Dd(D|0,H|0,K|0,I|0)|0;K=C;H=Gd(p|0,m|0,14)|0;D=C;x=Hd(p|0,m|0,50)|0;D=D|C;M=Gd(p|0,m|0,18)|0;E=C;L=Hd(p|0,m|0,46)|0;E=D^(E|C);D=Gd(p|0,m|0,41)|0;G=C;J=Hd(p|0,m|0,23)|0;G=E^(G|C);E=g+552|0;F=c[E>>2]|0;E=c[E+4>>2]|0;u=Dd(y|0,u|0,-1563912026,174292421)|0;E=Dd(u|0,C|0,F|0,E|0)|0;G=Dd(E|0,C|0,(H|x)^(M|L)^(D|J)|0,G|0)|0;G=Dd(G|0,C|0,(v^s)&p^v|0,(r^o)&m^r|0)|0;J=C;D=Gd(I|0,K|0,28)|0;L=C;M=Hd(I|0,K|0,36)|0;L=L|C;x=Gd(I|0,K|0,34)|0;H=C;E=Hd(I|0,K|0,30)|0;H=L^(H|C);L=Gd(I|0,K|0,39)|0;F=C;u=Hd(I|0,K|0,25)|0;F=Dd((b|B)&I|b&B|0,(f|A)&K|f&A|0,(D|M)^(x|E)^(L|u)|0,H^(F|C)|0)|0;H=C;l=Dd(j|0,l|0,G|0,J|0)|0;j=C;J=Dd(F|0,H|0,G|0,J|0)|0;G=C;H=Gd(l|0,j|0,14)|0;F=C;u=Hd(l|0,j|0,50)|0;F=F|C;L=Gd(l|0,j|0,18)|0;E=C;x=Hd(l|0,j|0,46)|0;E=F^(E|C);F=Gd(l|0,j|0,41)|0;M=C;D=Hd(l|0,j|0,23)|0;M=E^(M|C);E=g+560|0;y=c[E>>2]|0;E=c[E+4>>2]|0;r=Dd(v|0,r|0,-1090974290,289380356)|0;E=Dd(r|0,C|0,y|0,E|0)|0;M=Dd(E|0,C|0,(H|u)^(L|x)^(F|D)|0,M|0)|0;M=Dd(M|0,C|0,(s^p)&l^s|0,(o^m)&j^o|0)|0;D=C;F=Gd(J|0,G|0,28)|0;x=C;L=Hd(J|0,G|0,36)|0;x=x|C;u=Gd(J|0,G|0,34)|0;H=C;E=Hd(J|0,G|0,30)|0;H=x^(H|C);x=Gd(J|0,G|0,39)|0;y=C;r=Hd(J|0,G|0,25)|0;y=Dd((B|I)&J|B&I|0,(A|K)&G|A&K|0,(F|L)^(u|E)^(x|r)|0,H^(y|C)|0)|0;H=C;f=Dd(b|0,f|0,M|0,D|0)|0;b=C;D=Dd(y|0,H|0,M|0,D|0)|0;M=C;H=Gd(f|0,b|0,14)|0;y=C;r=Hd(f|0,b|0,50)|0;y=y|C;x=Gd(f|0,b|0,18)|0;E=C;u=Hd(f|0,b|0,46)|0;E=y^(E|C);y=Gd(f|0,b|0,41)|0;L=C;F=Hd(f|0,b|0,23)|0;L=E^(L|C);E=g+568|0;v=c[E>>2]|0;E=c[E+4>>2]|0;o=Dd(s|0,o|0,320620315,460393269)|0;E=Dd(o|0,C|0,v|0,E|0)|0;L=Dd(E|0,C|0,(H|r)^(x|u)^(y|F)|0,L|0)|0;L=Dd(L|0,C|0,(p^l)&f^p|0,(m^j)&b^m|0)|0;F=C;y=Gd(D|0,M|0,28)|0;u=C;x=Hd(D|0,M|0,36)|0;u=u|C;r=Gd(D|0,M|0,34)|0;H=C;E=Hd(D|0,M|0,30)|0;H=u^(H|C);u=Gd(D|0,M|0,39)|0;v=C;o=Hd(D|0,M|0,25)|0;v=Dd((I|J)&D|I&J|0,(K|G)&M|K&G|0,(y|x)^(r|E)^(u|o)|0,H^(v|C)|0)|0;H=C;A=Dd(B|0,A|0,L|0,F|0)|0;B=C;F=Dd(v|0,H|0,L|0,F|0)|0;L=C;H=Gd(A|0,B|0,14)|0;v=C;o=Hd(A|0,B|0,50)|0;v=v|C;u=Gd(A|0,B|0,18)|0;E=C;r=Hd(A|0,B|0,46)|0;E=v^(E|C);v=Gd(A|0,B|0,41)|0;x=C;y=Hd(A|0,B|0,23)|0;x=E^(x|C);E=g+576|0;s=c[E>>2]|0;E=c[E+4>>2]|0;m=Dd(p|0,m|0,587496836,685471733)|0;E=Dd(m|0,C|0,s|0,E|0)|0;x=Dd(E|0,C|0,(H|o)^(u|r)^(v|y)|0,x|0)|0;x=Dd(x|0,C|0,(l^f)&A^l|0,(j^b)&B^j|0)|0;y=C;v=Gd(F|0,L|0,28)|0;r=C;u=Hd(F|0,L|0,36)|0;r=r|C;o=Gd(F|0,L|0,34)|0;H=C;E=Hd(F|0,L|0,30)|0;H=r^(H|C);r=Gd(F|0,L|0,39)|0;s=C;m=Hd(F|0,L|0,25)|0;s=Dd((J|D)&F|J&D|0,(G|M)&L|G&M|0,(v|u)^(o|E)^(r|m)|0,H^(s|C)|0)|0;H=C;K=Dd(I|0,K|0,x|0,y|0)|0;I=C;y=Dd(s|0,H|0,x|0,y|0)|0;x=C;H=Gd(K|0,I|0,14)|0;s=C;m=Hd(K|0,I|0,50)|0;s=s|C;r=Gd(K|0,I|0,18)|0;E=C;o=Hd(K|0,I|0,46)|0;E=s^(E|C);s=Gd(K|0,I|0,41)|0;u=C;v=Hd(K|0,I|0,23)|0;u=E^(u|C);E=g+584|0;p=c[E>>2]|0;E=c[E+4>>2]|0;j=Dd(l|0,j|0,1086792851,852142971)|0;E=Dd(j|0,C|0,p|0,E|0)|0;u=Dd(E|0,C|0,(H|m)^(r|o)^(s|v)|0,u|0)|0;u=Dd(u|0,C|0,(f^A)&K^f|0,(b^B)&I^b|0)|0;v=C;s=Gd(y|0,x|0,28)|0;o=C;r=Hd(y|0,x|0,36)|0;o=o|C;m=Gd(y|0,x|0,34)|0;H=C;E=Hd(y|0,x|0,30)|0;H=o^(H|C);o=Gd(y|0,x|0,39)|0;p=C;j=Hd(y|0,x|0,25)|0;p=Dd((D|F)&y|D&F|0,(M|L)&x|M&L|0,(s|r)^(m|E)^(o|j)|0,H^(p|C)|0)|0;H=C;G=Dd(J|0,G|0,u|0,v|0)|0;J=C;v=Dd(p|0,H|0,u|0,v|0)|0;u=C;H=Gd(G|0,J|0,14)|0;p=C;j=Hd(G|0,J|0,50)|0;p=p|C;o=Gd(G|0,J|0,18)|0;E=C;m=Hd(G|0,J|0,46)|0;E=p^(E|C);p=Gd(G|0,J|0,41)|0;r=C;s=Hd(G|0,J|0,23)|0;r=E^(r|C);E=g+592|0;l=c[E>>2]|0;E=c[E+4>>2]|0;b=Dd(f|0,b|0,365543100,1017036298)|0;E=Dd(b|0,C|0,l|0,E|0)|0;r=Dd(E|0,C|0,(H|j)^(o|m)^(p|s)|0,r|0)|0;r=Dd(r|0,C|0,(A^K)&G^A|0,(B^I)&J^B|0)|0;s=C;p=Gd(v|0,u|0,28)|0;m=C;o=Hd(v|0,u|0,36)|0;m=m|C;j=Gd(v|0,u|0,34)|0;H=C;E=Hd(v|0,u|0,30)|0;H=m^(H|C);m=Gd(v|0,u|0,39)|0;l=C;b=Hd(v|0,u|0,25)|0;l=Dd((F|y)&v|F&y|0,(L|x)&u|L&x|0,(p|o)^(j|E)^(m|b)|0,H^(l|C)|0)|0;H=C;M=Dd(D|0,M|0,r|0,s|0)|0;D=C;s=Dd(l|0,H|0,r|0,s|0)|0;r=C;H=Gd(M|0,D|0,14)|0;l=C;b=Hd(M|0,D|0,50)|0;l=l|C;m=Gd(M|0,D|0,18)|0;E=C;j=Hd(M|0,D|0,46)|0;E=l^(E|C);l=Gd(M|0,D|0,41)|0;o=C;p=Hd(M|0,D|0,23)|0;o=E^(o|C);E=g+600|0;f=c[E>>2]|0;E=c[E+4>>2]|0;B=Dd(A|0,B|0,-1676669620,1126000580)|0;E=Dd(B|0,C|0,f|0,E|0)|0;o=Dd(E|0,C|0,(H|b)^(m|j)^(l|p)|0,o|0)|0;o=Dd(o|0,C|0,(K^G)&M^K|0,(I^J)&D^I|0)|0;p=C;l=Gd(s|0,r|0,28)|0;j=C;m=Hd(s|0,r|0,36)|0;j=j|C;b=Gd(s|0,r|0,34)|0;H=C;E=Hd(s|0,r|0,30)|0;H=j^(H|C);j=Gd(s|0,r|0,39)|0;f=C;B=Hd(s|0,r|0,25)|0;f=Dd((y|v)&s|y&v|0,(x|u)&r|x&u|0,(l|m)^(b|E)^(j|B)|0,H^(f|C)|0)|0;H=C;L=Dd(F|0,L|0,o|0,p|0)|0;F=C;p=Dd(f|0,H|0,o|0,p|0)|0;o=C;H=Gd(L|0,F|0,14)|0;f=C;B=Hd(L|0,F|0,50)|0;f=f|C;j=Gd(L|0,F|0,18)|0;E=C;b=Hd(L|0,F|0,46)|0;E=f^(E|C);f=Gd(L|0,F|0,41)|0;m=C;l=Hd(L|0,F|0,23)|0;m=E^(m|C);E=g+608|0;A=c[E>>2]|0;E=c[E+4>>2]|0;I=Dd(K|0,I|0,-885112138,1288033470)|0;E=Dd(I|0,C|0,A|0,E|0)|0;m=Dd(E|0,C|0,(H|B)^(j|b)^(f|l)|0,m|0)|0;m=Dd(m|0,C|0,(G^M)&L^G|0,(J^D)&F^J|0)|0;l=C;f=Gd(p|0,o|0,28)|0;b=C;j=Hd(p|0,o|0,36)|0;b=b|C;B=Gd(p|0,o|0,34)|0;H=C;E=Hd(p|0,o|0,30)|0;H=b^(H|C);b=Gd(p|0,o|0,39)|0;A=C;I=Hd(p|0,o|0,25)|0;A=Dd((v|s)&p|v&s|0,(u|r)&o|u&r|0,(f|j)^(B|E)^(b|I)|0,H^(A|C)|0)|0;H=C;x=Dd(y|0,x|0,m|0,l|0)|0;y=C;l=Dd(A|0,H|0,m|0,l|0)|0;m=C;H=Gd(x|0,y|0,14)|0;A=C;I=Hd(x|0,y|0,50)|0;A=A|C;b=Gd(x|0,y|0,18)|0;E=C;B=Hd(x|0,y|0,46)|0;E=A^(E|C);A=Gd(x|0,y|0,41)|0;j=C;f=Hd(x|0,y|0,23)|0;j=E^(j|C);E=g+616|0;K=c[E>>2]|0;E=c[E+4>>2]|0;J=Dd(G|0,J|0,-60457430,1501505948)|0;E=Dd(J|0,C|0,K|0,E|0)|0;j=Dd(E|0,C|0,(H|I)^(b|B)^(A|f)|0,j|0)|0;j=Dd(j|0,C|0,(M^L)&x^M|0,(D^F)&y^D|0)|0;f=C;A=Gd(l|0,m|0,28)|0;B=C;b=Hd(l|0,m|0,36)|0;B=B|C;I=Gd(l|0,m|0,34)|0;H=C;E=Hd(l|0,m|0,30)|0;H=B^(H|C);B=Gd(l|0,m|0,39)|0;K=C;J=Hd(l|0,m|0,25)|0;K=Dd((s|p)&l|s&p|0,(r|o)&m|r&o|0,(A|b)^(I|E)^(B|J)|0,H^(K|C)|0)|0;H=C;u=Dd(v|0,u|0,j|0,f|0)|0;v=C;f=Dd(K|0,H|0,j|0,f|0)|0;j=C;H=Gd(u|0,v|0,14)|0;K=C;J=Hd(u|0,v|0,50)|0;K=K|C;B=Gd(u|0,v|0,18)|0;E=C;I=Hd(u|0,v|0,46)|0;E=K^(E|C);K=Gd(u|0,v|0,41)|0;b=C;A=Hd(u|0,v|0,23)|0;b=E^(b|C);E=g+624|0;G=c[E>>2]|0;E=c[E+4>>2]|0;D=Dd(M|0,D|0,987167468,1607167915)|0;E=Dd(D|0,C|0,G|0,E|0)|0;b=Dd(E|0,C|0,(H|J)^(B|I)^(K|A)|0,b|0)|0;b=Dd(b|0,C|0,(L^x)&u^L|0,(F^y)&v^F|0)|0;A=C;K=Gd(f|0,j|0,28)|0;I=C;B=Hd(f|0,j|0,36)|0;I=I|C;J=Gd(f|0,j|0,34)|0;H=C;E=Hd(f|0,j|0,30)|0;H=I^(H|C);I=Gd(f|0,j|0,39)|0;G=C;D=Hd(f|0,j|0,25)|0;G=Dd((p|l)&f|p&l|0,(o|m)&j|o&m|0,(K|B)^(J|E)^(I|D)|0,H^(G|C)|0)|0;H=C;r=Dd(s|0,r|0,b|0,A|0)|0;s=C;A=Dd(G|0,H|0,b|0,A|0)|0;b=C;H=Gd(r|0,s|0,14)|0;G=C;D=Hd(r|0,s|0,50)|0;G=G|C;I=Gd(r|0,s|0,18)|0;E=C;J=Hd(r|0,s|0,46)|0;E=G^(E|C);G=Gd(r|0,s|0,41)|0;B=C;K=Hd(r|0,s|0,23)|0;B=E^(B|C);g=g+632|0;E=c[g>>2]|0;g=c[g+4>>2]|0;F=Dd(L|0,F|0,1246189591,1816402316)|0;g=Dd(F|0,C|0,E|0,g|0)|0;g=Dd(g|0,C|0,(H|D)^(I|J)^(G|K)|0,B|0)|0;g=Dd(g|0,C|0,(x^u)&r^x|0,(y^v)&s^y|0)|0;B=C;K=Gd(A|0,b|0,28)|0;G=C;J=Hd(A|0,b|0,36)|0;G=G|C;I=Gd(A|0,b|0,34)|0;D=C;H=Hd(A|0,b|0,30)|0;D=G^(D|C);G=Gd(A|0,b|0,39)|0;E=C;F=Hd(A|0,b|0,25)|0;E=Dd((l|f)&A|l&f|0,(m|j)&b|m&j|0,(K|J)^(I|H)^(G|F)|0,D^(E|C)|0)|0;D=C;o=Dd(p|0,o|0,g|0,B|0)|0;p=C;B=Dd(E|0,D|0,g|0,B|0)|0;g=a;B=Dd(c[g>>2]|0,c[g+4>>2]|0,B|0,C|0)|0;g=a;c[g>>2]=B;c[g+4>>2]=C;g=e;g=Dd(c[g>>2]|0,c[g+4>>2]|0,A|0,b|0)|0;a=e;c[a>>2]=g;c[a+4>>2]=C;a=k;j=Dd(c[a>>2]|0,c[a+4>>2]|0,f|0,j|0)|0;c[k>>2]=j;c[k+4>>2]=C;k=n;m=Dd(c[k>>2]|0,c[k+4>>2]|0,l|0,m|0)|0;c[n>>2]=m;c[n+4>>2]=C;n=q;p=Dd(c[n>>2]|0,c[n+4>>2]|0,o|0,p|0)|0;c[q>>2]=p;c[q+4>>2]=C;q=t;s=Dd(c[q>>2]|0,c[q+4>>2]|0,r|0,s|0)|0;c[t>>2]=s;c[t+4>>2]=C;t=w;v=Dd(c[t>>2]|0,c[t+4>>2]|0,u|0,v|0)|0;c[w>>2]=v;c[w+4>>2]=C;w=z;y=Dd(c[w>>2]|0,c[w+4>>2]|0,x|0,y|0)|0;c[z>>2]=y;c[z+4>>2]=C;i=h;return}function Ib(){return 144}function Jb(){return 16}function Kb(){return 32}function Lb(a,b,c,d,e){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;var f=0,g=0;f=i;g=i=i+63&-64;i=i+144|0;Ub(g,e);Tb(g,b,c,d);Rb(g,a);i=f;return 0}function Mb(a,b,c,d,e){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;return Qb(a,b,c,d,e)|0}function Nb(a,b){a=a|0;b=b|0;Ub(a,b);return 0}function Ob(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;Tb(a,b,c,d);return 0}function Pb(a,b){a=a|0;b=b|0;Rb(a,b);return 0}function Qb(b,c,d,e,f){b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;var g=0,h=0,j=0;h=i;g=i=i+63&-64;i=i+160|0;j=g;g=g+144|0;Ub(j,f);Tb(j,c,d,e);Rb(j,g);i=h;return ((((a[g+1>>0]^a[b+1>>0]|a[g>>0]^a[b>>0]|a[g+2>>0]^a[b+2>>0]|a[g+3>>0]^a[b+3>>0]|a[g+4>>0]^a[b+4>>0]|a[g+5>>0]^a[b+5>>0]|a[g+6>>0]^a[b+6>>0]|a[g+7>>0]^a[b+7>>0]|a[g+8>>0]^a[b+8>>0]|a[g+9>>0]^a[b+9>>0]|a[g+10>>0]^a[b+10>>0]|a[g+11>>0]^a[b+11>>0]|a[g+12>>0]^a[b+12>>0]|a[g+13>>0]^a[b+13>>0]|a[g+14>>0]^a[b+14>>0]|a[g+15>>0]^a[b+15>>0])&255)+511|0)>>>8&1)+-1|0}function Rb(b,d){b=b|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0;h=b+56|0;g=c[h>>2]|0;h=c[h+4>>2]|0;if(!((g|0)==0&(h|0)==0)){e=b+64|0;a[e+g>>0]=1;f=Dd(g|0,h|0,1,0)|0;i=C;if(i>>>0<0|(i|0)==0&f>>>0<16){i=Cd(14,0,g|0,h|0)|0;Fd(b+(f+64)|0,0,i+1|0)|0}a[b+80>>0]=1;Sb(b,e,16,0)}i=c[b+24>>2]|0;p=(c[b+28>>2]|0)+(i>>>26)|0;e=p&67108863;n=(p>>>26)+(c[b+32>>2]|0)|0;m=n&67108863;f=(n>>>26)+(c[b+36>>2]|0)|0;h=((f>>>26)*5|0)+(c[b+20>>2]|0)|0;g=h&67108863;i=(h>>>26)+(i&67108863)|0;r=((g+5|0)>>>26)+i|0;q=r>>>26;o=(q+e|0)>>>26;k=(f|-67108864)+((o+m|0)>>>26)|0;l=(k>>>31)+-1|0;j=k>>31;i=r&67108863&l|j&i;e=q+p&67108863&l|j&e;m=o+n&67108863&l|j&m;g=Dd(h+5&67108863&l|j&g|i<<26|0,0,c[b+40>>2]|0,0)|0;h=C;i=Dd(i>>>6|e<<20|0,0,c[b+44>>2]|0,0)|0;h=Dd(i|0,C|0,h|0,0)|0;i=C;e=Dd(e>>>12|m<<14|0,0,c[b+48>>2]|0,0)|0;i=Dd(e|0,C|0,i|0,0)|0;e=C;f=Dd(m>>>18|(l&k|j&f)<<8|0,0,c[b+52>>2]|0,0)|0;e=Dd(f|0,C|0,e|0,0)|0;a[d>>0]=g;a[d+1>>0]=g>>>8;a[d+2>>0]=g>>>16;a[d+3>>0]=g>>>24;a[d+4>>0]=h;a[d+5>>0]=h>>>8;a[d+6>>0]=h>>>16;a[d+7>>0]=h>>>24;a[d+8>>0]=i;a[d+9>>0]=i>>>8;a[d+10>>0]=i>>>16;a[d+11>>0]=i>>>24;a[d+12>>0]=e;a[d+13>>0]=e>>>8;a[d+14>>0]=e>>>16;a[d+15>>0]=e>>>24;e=b+88|0;do{a[b>>0]=0;b=b+1|0}while((b|0)<(e|0));return}function Sb(b,e,f,g){b=b|0;e=e|0;f=f|0;g=g|0;var h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0;s=(a[b+80>>0]|0)!=0?0:16777216;t=c[b+4>>2]|0;u=c[b+8>>2]|0;m=c[b+12>>2]|0;n=c[b+16>>2]|0;v=b+20|0;l=c[v>>2]|0;w=b+24|0;k=c[w>>2]|0;x=b+28|0;j=c[x>>2]|0;y=b+32|0;i=c[y>>2]|0;z=b+36|0;h=c[z>>2]|0;if(!(g>>>0>0|(g|0)==0&f>>>0>15)){q=l;r=k;s=j;t=i;u=h;c[v>>2]=q;c[w>>2]=r;c[x>>2]=s;c[y>>2]=t;c[z>>2]=u;return}o=n*5|0;p=m*5|0;q=u*5|0;r=t*5|0;b=c[b>>2]|0;while(1){J=d[e+3>>0]|0;B=(d[e+1>>0]<<8|d[e>>0]|d[e+2>>0]<<16|J<<24&50331648)+l|0;H=d[e+6>>0]|0;J=((d[e+4>>0]<<8|J|d[e+5>>0]<<16|H<<24)>>>2&67108863)+k|0;G=d[e+9>>0]|0;H=((d[e+7>>0]<<8|H|d[e+8>>0]<<16|G<<24)>>>4&67108863)+j|0;G=((d[e+10>>0]<<8|G|d[e+11>>0]<<16|d[e+12>>0]<<24)>>>6)+i|0;l=(d[e+13>>0]|s|d[e+14>>0]<<8|d[e+15>>0]<<16)+h|0;k=Od(B|0,0,b|0,0)|0;j=C;A=Od(J|0,0,o|0,0)|0;j=Dd(A|0,C|0,k|0,j|0)|0;k=C;A=Od(H|0,0,p|0,0)|0;A=Dd(j|0,k|0,A|0,C|0)|0;k=C;j=Od(G|0,0,q|0,0)|0;j=Dd(A|0,k|0,j|0,C|0)|0;k=C;A=Od(l|0,0,r|0,0)|0;A=Dd(j|0,k|0,A|0,C|0)|0;k=C;j=Od(B|0,0,t|0,0)|0;i=C;F=Od(J|0,0,b|0,0)|0;i=Dd(F|0,C|0,j|0,i|0)|0;j=C;F=Od(H|0,0,o|0,0)|0;F=Dd(i|0,j|0,F|0,C|0)|0;j=C;i=Od(G|0,0,p|0,0)|0;i=Dd(F|0,j|0,i|0,C|0)|0;j=C;F=Od(l|0,0,q|0,0)|0;F=Dd(i|0,j|0,F|0,C|0)|0;j=C;i=Od(B|0,0,u|0,0)|0;h=C;E=Od(J|0,0,t|0,0)|0;h=Dd(E|0,C|0,i|0,h|0)|0;i=C;E=Od(H|0,0,b|0,0)|0;E=Dd(h|0,i|0,E|0,C|0)|0;i=C;h=Od(G|0,0,o|0,0)|0;h=Dd(E|0,i|0,h|0,C|0)|0;i=C;E=Od(l|0,0,p|0,0)|0;E=Dd(h|0,i|0,E|0,C|0)|0;i=C;h=Od(B|0,0,m|0,0)|0;I=C;D=Od(J|0,0,u|0,0)|0;I=Dd(D|0,C|0,h|0,I|0)|0;h=C;D=Od(H|0,0,t|0,0)|0;D=Dd(I|0,h|0,D|0,C|0)|0;h=C;I=Od(G|0,0,b|0,0)|0;I=Dd(D|0,h|0,I|0,C|0)|0;h=C;D=Od(l|0,0,o|0,0)|0;D=Dd(I|0,h|0,D|0,C|0)|0;h=C;B=Od(B|0,0,n|0,0)|0;I=C;J=Od(J|0,0,m|0,0)|0;I=Dd(J|0,C|0,B|0,I|0)|0;B=C;H=Od(H|0,0,u|0,0)|0;H=Dd(I|0,B|0,H|0,C|0)|0;B=C;G=Od(G|0,0,t|0,0)|0;G=Dd(H|0,B|0,G|0,C|0)|0;B=C;l=Od(l|0,0,b|0,0)|0;l=Dd(G|0,B|0,l|0,C|0)|0;B=C;k=Gd(A|0,k|0,26)|0;k=Dd(F|0,j|0,k|0,0)|0;j=Gd(k|0,C|0,26)|0;j=Dd(E|0,i|0,j|0,0)|0;i=Gd(j|0,C|0,26)|0;j=j&67108863;i=Dd(D|0,h|0,i|0,0)|0;h=Gd(i|0,C|0,26)|0;i=i&67108863;h=Dd(l|0,B|0,h|0,0)|0;B=Gd(h|0,C|0,26)|0;h=h&67108863;B=B*5|0;l=B+A&67108863;k=((B+(A&67108863)|0)>>>26)+(k&67108863)|0;f=Dd(f|0,g|0,-16,-1)|0;g=C;if(!(g>>>0>0|(g|0)==0&f>>>0>15))break;else e=e+16|0}c[v>>2]=l;c[w>>2]=k;c[x>>2]=j;c[y>>2]=i;c[z>>2]=h;return}function Tb(b,d,e,f){b=b|0;d=d|0;e=e|0;f=f|0;var g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0;n=b+56|0;g=n;h=c[g>>2]|0;g=c[g+4>>2]|0;do if(!((h|0)==0&(g|0)==0)){l=Cd(16,0,h|0,g|0)|0;m=C;k=m>>>0>f>>>0|(m|0)==(f|0)&l>>>0>e>>>0;l=k?e:l;m=k?f:m;if(!((l|0)==0&(m|0)==0)){j=b+64|0;k=0;i=0;do{o=a[d+k>>0]|0;g=Dd(h|0,g|0,k|0,i|0)|0;a[j+g>>0]=o;k=Dd(k|0,i|0,1,0)|0;i=C;g=n;h=c[g>>2]|0;g=c[g+4>>2]|0}while(i>>>0>>0|(i|0)==(m|0)&k>>>0>>0)}o=Dd(h|0,g|0,l|0,m|0)|0;k=C;j=n;c[j>>2]=o;c[j+4>>2]=k;if(k>>>0<0|(k|0)==0&o>>>0<16)return;else{e=Cd(e|0,f|0,l|0,m|0)|0;f=C;Sb(b,b+64|0,16,0);o=n;c[o>>2]=0;c[o+4>>2]=0;d=d+l|0;break}}while(0);if(f>>>0>0|(f|0)==0&e>>>0>15){i=e&-16;Sb(b,d,i,f);e=Cd(e|0,f|0,i|0,f|0)|0;d=d+i|0;i=C}else i=f;if((e|0)==0&(i|0)==0)return;f=b+64|0;g=0;h=0;do{b=a[d+g>>0]|0;o=n;o=Dd(c[o>>2]|0,c[o+4>>2]|0,g|0,h|0)|0;a[f+o>>0]=b;g=Dd(g|0,h|0,1,0)|0;h=C}while(h>>>0>>0|(h|0)==(i|0)&g>>>0>>0);b=n;b=Dd(c[b>>2]|0,c[b+4>>2]|0,e|0,i|0)|0;o=n;c[o>>2]=b;c[o+4>>2]=C;return}function Ub(b,e){b=b|0;e=e|0;var f=0,g=0;f=e+3|0;c[b>>2]=(d[e+1>>0]|0)<<8|(d[e>>0]|0)|(d[e+2>>0]|0)<<16|(d[f>>0]|0)<<24&50331648;g=e+6|0;c[b+4>>2]=((d[e+4>>0]|0)<<8|(d[f>>0]|0)|(d[e+5>>0]|0)<<16|(d[g>>0]|0)<<24)>>>2&67108611;f=e+9|0;c[b+8>>2]=((d[e+7>>0]|0)<<8|(d[g>>0]|0)|(d[e+8>>0]|0)<<16|(d[f>>0]|0)<<24)>>>4&67092735;c[b+12>>2]=((d[e+10>>0]|0)<<8|(d[f>>0]|0)|(d[e+11>>0]|0)<<16|(d[e+12>>0]|0)<<24)>>>6&66076671;c[b+16>>2]=(d[e+14>>0]|0)<<8|(d[e+13>>0]|0)|(d[e+15>>0]|0)<<16&983040;f=b+20|0;c[f>>2]=0;c[f+4>>2]=0;c[f+8>>2]=0;c[f+12>>2]=0;c[f+16>>2]=0;c[b+40>>2]=(d[e+17>>0]|0)<<8|(d[e+16>>0]|0)|(d[e+18>>0]|0)<<16|(d[e+19>>0]|0)<<24;c[b+44>>2]=(d[e+21>>0]|0)<<8|(d[e+20>>0]|0)|(d[e+22>>0]|0)<<16|(d[e+23>>0]|0)<<24;c[b+48>>2]=(d[e+25>>0]|0)<<8|(d[e+24>>0]|0)|(d[e+26>>0]|0)<<16|(d[e+27>>0]|0)<<24;c[b+52>>2]=(d[e+29>>0]|0)<<8|(d[e+28>>0]|0)|(d[e+30>>0]|0)<<16|(d[e+31>>0]|0)<<24;e=b+56|0;c[e>>2]=0;c[e+4>>2]=0;a[b+80>>0]=0;return}function Vb(b,e,f,g,h){b=b|0;e=e|0;f=f|0;g=g|0;h=h|0;var j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0;w=i;t=i=i+63&-64;i=i+48|0;j=t+8|0;u=t+4|0;if((a[g>>0]|0)!=36){h=0;i=w;return h|0}if((a[g+1>>0]|0)!=55){h=0;i=w;return h|0}if((a[g+2>>0]|0)!=36){h=0;i=w;return h|0}o=a[g+3>>0]|0;n=o&255;a:do if(1){l=65;k=34881;do{if((a[k>>0]|0)==o<<24>>24)break a;k=k+1|0;l=l+-1|0;m=(l|0)!=0}while(m&(k&3|0)!=0);if(!m){h=0;i=w;return h|0}}else{l=65;k=34881}while(0);b:do if((a[k>>0]|0)!=o<<24>>24){m=_(n,16843009)|0;c:do if(l>>>0>3)while(1){s=c[k>>2]^m;if((s&-2139062144^-2139062144)&s+-16843009)break c;k=k+4|0;l=l+-4|0;if(l>>>0<=3){v=12;break}}else v=12;while(0);if((v|0)==12)if(!l){h=0;i=w;return h|0}while(1){if((a[k>>0]|0)==o<<24>>24)break b;l=l+-1|0;if(!l){j=0;break}else k=k+1|0}i=w;return j|0}while(0);if((k|0)==0|(l|0)==0){h=0;i=w;return h|0}r=Hd(1,0,k-34881|0)|0;s=C;k=Xb(u,g+4|0)|0;if(!k){h=0;i=w;return h|0}q=Xb(t,k)|0;if(!q){h=0;i=w;return h|0}o=q;p=o-g|0;n=(o&3|0)==0;d:do if(n){k=q;v=22}else{l=q;k=o;while(1){if(!(a[l>>0]|0))break d;l=l+1|0;k=l;if(!(k&3)){k=l;v=22;break}}}while(0);if((v|0)==22){while(1){l=c[k>>2]|0;if(!((l&-2139062144^-2139062144)&l+-16843009))k=k+4|0;else break}if((l&255)<<24>>24)do k=k+1|0;while((a[k>>0]|0)!=0)}l=k-o+1|0;while(1){k=l+-1|0;if(!l){v=32;break}m=q+k|0;if((a[m>>0]|0)==36){v=30;break}else l=k}if((v|0)==30)if(!m)v=32;else l=l+-1|0;if((v|0)==32){e:do if(n){k=q;v=35}else{k=q;l=o;while(1){if(!(a[k>>0]|0)){k=l;break e}k=k+1|0;l=k;if(!(l&3)){v=35;break}}}while(0);if((v|0)==35){while(1){l=c[k>>2]|0;if(!((l&-2139062144^-2139062144)&l+-16843009))k=k+4|0;else break}if((l&255)<<24>>24)do k=k+1|0;while((a[k>>0]|0)!=0)}l=k-o|0}k=l+p|0;p=k+45|0;if(p>>>0>102|p>>>0>>0){h=0;i=w;return h|0}if(hc(b,e,f,q,l,r,s,c[u>>2]|0,c[t>>2]|0,j,32)|0){h=0;i=w;return h|0}Id(h|0,g|0,k|0)|0;s=h+k|0;r=s+1|0;a[s>>0]=36;s=r;r=h+102-r|0;k=0;f:while(1){if(k>>>0<32){p=0;q=k;k=0}else break;do{g=q;q=q+1|0;k=d[j+g>>0]<>>0<32&p>>>0<24);if(!p)k=s;else{l=k;m=r;n=s;o=0;while(1){if(!m){v=50;break f}k=n+1|0;a[n>>0]=a[34881+(l&63)>>0]|0;o=o+6|0;if(o>>>0>=p>>>0)break;else{l=l>>>6;m=m+-1|0;n=k}}}g=(k|0)==0;r=(g?0:s-k|0)+r|0;if(g){v=50;break}else{s=k;k=q}}if((v|0)==50){k=j+32|0;do{a[j>>0]=0;j=j+1|0}while((j|0)<(k|0));h=0;i=w;return h|0}k=j+32|0;do{a[j>>0]=0;j=j+1|0}while((j|0)<(k|0));if(!((s|0)!=0&s>>>0<(h+102|0)>>>0)){h=0;i=w;return h|0}a[s>>0]=0;i=w;return h|0}function Wb(a,b,d,e,f,g,h,j,k,l){a=a|0;b=b|0;d=d|0;e=e|0;f=f|0;g=g|0;h=h|0;j=j|0;k=k|0;l=l|0;var m=0,n=0;m=i;n=i=i+63&-64;i=i+16|0;c[n+4>>2]=0;c[n>>2]=0;c[n+8>>2]=0;f=hc(n,a,b,d,e,f,g,h,j,k,l)|0;g=c[n>>2]|0;if(!g){i=m;return f|0}zd(g);i=m;return f|0}function Xb(b,d){b=b|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0;i=a[d>>0]|0;h=i&255;a:do if(1){e=65;f=34881;do{if((a[f>>0]|0)==i<<24>>24)break a;f=f+1|0;e=e+-1|0;g=(e|0)!=0}while(g&(f&3|0)!=0);if(!g){d=0;n=0;c[b>>2]=n;return d|0}}else{e=65;f=34881}while(0);b:do if((a[f>>0]|0)!=i<<24>>24){g=_(h,16843009)|0;c:do if(e>>>0>3)while(1){m=c[f>>2]^g;if((m&-2139062144^-2139062144)&m+-16843009)break c;f=f+4|0;e=e+-4|0;if(e>>>0<=3){n=9;break}}else n=9;while(0);if((n|0)==9)if(!e){d=0;n=0;c[b>>2]=n;return d|0}while(1){if((a[f>>0]|0)==i<<24>>24)break b;e=e+-1|0;if(!e){e=0;f=0;break}else f=f+1|0}c[b>>2]=f;return e|0}while(0);if((f|0)==0|(e|0)==0){d=0;n=0;c[b>>2]=n;return d|0}j=a[d+1>>0]|0;i=j&255;d:do if(1){e=65;g=34881;do{if((a[g>>0]|0)==j<<24>>24)break d;g=g+1|0;e=e+-1|0;h=(e|0)!=0}while(h&(g&3|0)!=0);if(!h){d=0;n=0;c[b>>2]=n;return d|0}}else{e=65;g=34881}while(0);e:do if((a[g>>0]|0)!=j<<24>>24){h=_(i,16843009)|0;f:do if(e>>>0>3)while(1){m=c[g>>2]^h;if((m&-2139062144^-2139062144)&m+-16843009)break f;g=g+4|0;e=e+-4|0;if(e>>>0<=3){n=22;break}}else n=22;while(0);if((n|0)==22)if(!e){d=0;n=0;c[b>>2]=n;return d|0}while(1){if((a[g>>0]|0)==j<<24>>24)break e;e=e+-1|0;if(!e){e=0;f=0;break}else g=g+1|0}c[b>>2]=f;return e|0}while(0);if((g|0)==0|(e|0)==0){d=0;n=0;c[b>>2]=n;return d|0}k=a[d+2>>0]|0;j=k&255;g:do if(1){e=65;h=34881;do{if((a[h>>0]|0)==k<<24>>24)break g;h=h+1|0;e=e+-1|0;i=(e|0)!=0}while(i&(h&3|0)!=0);if(!i){d=0;n=0;c[b>>2]=n;return d|0}}else{e=65;h=34881}while(0);h:do if((a[h>>0]|0)!=k<<24>>24){i=_(j,16843009)|0;i:do if(e>>>0>3)while(1){m=c[h>>2]^i;if((m&-2139062144^-2139062144)&m+-16843009)break i;h=h+4|0;e=e+-4|0;if(e>>>0<=3){n=36;break}}else n=36;while(0);if((n|0)==36)if(!e){d=0;n=0;c[b>>2]=n;return d|0}while(1){if((a[h>>0]|0)==k<<24>>24)break h;e=e+-1|0;if(!e){e=0;f=0;break}else h=h+1|0}c[b>>2]=f;return e|0}while(0);if((h|0)==0|(e|0)==0){d=0;n=0;c[b>>2]=n;return d|0}l=a[d+3>>0]|0;k=l&255;j:do if(1){e=65;i=34881;do{if((a[i>>0]|0)==l<<24>>24)break j;i=i+1|0;e=e+-1|0;j=(e|0)!=0}while(j&(i&3|0)!=0);if(!j){d=0;n=0;c[b>>2]=n;return d|0}}else{e=65;i=34881}while(0);k:do if((a[i>>0]|0)==l<<24>>24)m=i;else{j=_(k,16843009)|0;l:do if(e>>>0>3)while(1){m=c[i>>2]^j;if((m&-2139062144^-2139062144)&m+-16843009)break l;i=i+4|0;e=e+-4|0;if(e>>>0<=3){n=49;break}}else n=49;while(0);if((n|0)==49)if(!e){d=0;n=0;c[b>>2]=n;return d|0}while(1){if((a[i>>0]|0)==l<<24>>24){m=i;break k}e=e+-1|0;if(!e){e=0;f=0;break}else i=i+1|0}c[b>>2]=f;return e|0}while(0);if((m|0)==0|(e|0)==0){d=0;n=0;c[b>>2]=n;return d|0}l=a[d+4>>0]|0;k=l&255;m:do if(1){i=65;e=34881;do{if((a[e>>0]|0)==l<<24>>24)break m;e=e+1|0;i=i+-1|0;j=(i|0)!=0}while(j&(e&3|0)!=0);if(!j){d=0;n=0;c[b>>2]=n;return d|0}}else{i=65;e=34881}while(0);n:do if((a[e>>0]|0)!=l<<24>>24){j=_(k,16843009)|0;o:do if(i>>>0>3)while(1){k=c[e>>2]^j;if((k&-2139062144^-2139062144)&k+-16843009)break o;e=e+4|0;i=i+-4|0;if(i>>>0<=3){n=62;break}}else n=62;while(0);if((n|0)==62)if(!i){d=0;n=0;c[b>>2]=n;return d|0}while(1){if((a[e>>0]|0)==l<<24>>24)break n;i=i+-1|0;if(!i){e=0;f=0;break}else e=e+1|0}c[b>>2]=f;return e|0}while(0);if((e|0)==0|(i|0)==0){d=0;n=0;c[b>>2]=n;return d|0}d=d+5|0;n=e-34881<<24|(m-34881<<18|(h-34881<<12|(g-34881<<6|f-34881)));c[b>>2]=n;return d|0}function Yb(b,d,e,f,g,h){b=b|0;d=d|0;e=e|0;f=f|0;g=g|0;h=h|0;var j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0;A=i;w=i=i+63&-64;i=i+560|0;r=w+488|0;z=w+456|0;v=w+208|0;x=w;y=w+416|0;w=w+424|0;n=v+32|0;if(d>>>0<=64){p=n;c[p>>2]=0;c[p+4>>2]=0;c[v>>2]=c[18];c[v+4>>2]=c[19];c[v+8>>2]=c[20];c[v+12>>2]=c[21];c[v+16>>2]=c[22];c[v+20>>2]=c[23];c[v+24>>2]=c[24];c[v+28>>2]=c[25];p=r;q=p+64|0;do{a[p>>0]=54;p=p+1|0}while((p|0)<(q|0));l=(d|0)==0;if(!l){j=d;k=n;a[r>>0]=a[b>>0]^54;if((j|0)==1)d=j;else{d=j;m=8}}else k=n}else{c[v>>2]=c[18];c[v+4>>2]=c[19];c[v+8>>2]=c[20];c[v+12>>2]=c[21];c[v+16>>2]=c[22];c[v+20>>2]=c[23];c[v+24>>2]=c[24];c[v+28>>2]=c[25];p=Hd(d|0,0,3)|0;l=n;c[l>>2]=p;c[l+4>>2]=C;l=v+40|0;p=l;m=b;q=p+64|0;do{a[p>>0]=a[m>>0]|0;p=p+1|0;m=m+1|0}while((p|0)<(q|0));Eb(v,l);j=b+64|0;k=Dd(d|0,0,-64,-1)|0;b=C;if(b>>>0>0|(b|0)==0&k>>>0>63){do{Eb(v,j);j=j+64|0;k=Dd(k|0,b|0,-64,-1)|0;b=C}while(b>>>0>0|(b|0)==0&k>>>0>63);b=k}else b=k;Id(l|0,j|0,b|0)|0;Db(v,z);p=n;c[p>>2]=0;c[p+4>>2]=0;c[v>>2]=c[18];c[v+4>>2]=c[19];c[v+8>>2]=c[20];c[v+12>>2]=c[21];c[v+16>>2]=c[22];c[v+20>>2]=c[23];c[v+24>>2]=c[24];c[v+28>>2]=c[25];p=r;q=p+64|0;do{a[p>>0]=54;p=p+1|0}while((p|0)<(q|0));a[r>>0]=a[z>>0]^54;d=32;b=z;k=n;l=0;m=8}if((m|0)==8){j=1;do{u=r+j|0;a[u>>0]=a[u>>0]^a[b+j>>0];j=j+1|0}while((j|0)!=(d|0))}o=k;c[o>>2]=512;c[o+4>>2]=0;o=v+40|0;p=o;m=r;q=p+64|0;do{a[p>>0]=a[m>>0]|0;p=p+1|0;m=m+1|0}while((p|0)<(q|0));Eb(v,o);n=v+104|0;m=v+136|0;p=m;c[p>>2]=0;c[p+4>>2]=0;c[n>>2]=c[18];c[n+4>>2]=c[19];c[n+8>>2]=c[20];c[n+12>>2]=c[21];c[n+16>>2]=c[22];c[n+20>>2]=c[23];c[n+24>>2]=c[24];c[n+28>>2]=c[25];p=r;q=p+64|0;do{a[p>>0]=92;p=p+1|0}while((p|0)<(q|0));if(!l?(a[r>>0]=a[b>>0]^92,(d|0)!=1):0){j=1;do{u=r+j|0;a[u>>0]=a[u>>0]^a[b+j>>0];j=j+1|0}while((j|0)!=(d|0))}j=m;c[j>>2]=512;c[j+4>>2]=0;j=v+144|0;p=j;m=r;q=p+64|0;do{a[p>>0]=a[m>>0]|0;p=p+1|0;m=m+1|0}while((p|0)<(q|0));Eb(n,j);do if(f){b=k;t=c[b>>2]|0;b=c[b+4>>2]|0;j=Gd(t|0,b|0,3)|0;j=j&63;u=Hd(f|0,0,3)|0;u=Dd(t|0,b|0,u|0,C|0)|0;b=k;c[b>>2]=u;c[b+4>>2]=C;b=64-j|0;j=v+40+j|0;if(b>>>0>f>>>0){Id(j|0,e|0,f|0)|0;break}Id(j|0,e|0,b|0)|0;Eb(v,o);j=e+b|0;k=Cd(f|0,0,b|0,0)|0;b=C;if(b>>>0>0|(b|0)==0&k>>>0>63){do{Eb(v,j);j=j+64|0;k=Dd(k|0,b|0,-64,-1)|0;b=C}while(b>>>0>0|(b|0)==0&k>>>0>63);b=k}else b=k;Id(o|0,j|0,b|0)|0}while(0);if(!h){i=A;return}l=y+3|0;d=y+2|0;n=y+1|0;o=x+32|0;r=x+104|0;e=x+136|0;f=x+144|0;s=x+40|0;t=0;u=0;do{u=u+1|0;a[l>>0]=u;a[d>>0]=u>>>8;a[n>>0]=u>>>16;a[y>>0]=u>>>24;Id(x|0,v|0,208)|0;q=o;b=c[q>>2]|0;q=c[q+4>>2]|0;j=Gd(b|0,q|0,3)|0;j=j&63;q=Dd(b|0,q|0,32,0)|0;b=o;c[b>>2]=q;c[b+4>>2]=C;b=64-j|0;j=x+40+j|0;if(b>>>0>4){q=c[y>>2]|0;a[j>>0]=q;a[j+1>>0]=q>>8;a[j+2>>0]=q>>16;a[j+3>>0]=q>>24}else{Id(j|0,y|0,b|0)|0;Eb(x,s);j=y+b|0;k=Cd(4,0,b|0,0)|0;b=C;if(b>>>0>0|(b|0)==0&k>>>0>63){do{Eb(x,j);j=j+64|0;k=Dd(k|0,b|0,-64,-1)|0;b=C}while(b>>>0>0|(b|0)==0&k>>>0>63);b=k}else b=k;Id(s|0,j|0,b|0)|0}Db(x,z);q=e;b=c[q>>2]|0;q=c[q+4>>2]|0;j=Gd(b|0,q|0,3)|0;j=j&63;q=Dd(b|0,q|0,256,0)|0;b=e;c[b>>2]=q;c[b+4>>2]=C;b=64-j|0;j=x+144+j|0;if(b>>>0>32){p=j;m=z;q=p+32|0;do{a[p>>0]=a[m>>0]|0;p=p+1|0;m=m+1|0}while((p|0)<(q|0))}else{Id(j|0,z|0,b|0)|0;Eb(r,f);j=z+b|0;k=Cd(32,0,b|0,0)|0;b=C;if(b>>>0>0|(b|0)==0&k>>>0>63){do{Eb(r,j);j=j+64|0;k=Dd(k|0,b|0,-64,-1)|0;b=C}while(b>>>0>0|(b|0)==0&k>>>0>63);b=k}else b=k;Id(f|0,j|0,b|0)|0}Db(r,w);q=h-t|0;Id(g+t|0,w|0,(q>>>0>32?32:q)|0)|0;t=u<<5}while(t>>>0>>0);i=A;return}function Zb(){return 32}function _b(){return 102}function $b(){return 32984}function ac(){return 524288}function bc(){return 16777216}function cc(){return 33554432}function dc(){return 1073741824}function ec(a,b,d,e,f,g,h,j,k,l){a=a|0;b=b|0;d=d|0;e=e|0;f=f|0;g=g|0;h=h|0;j=j|0;k=k|0;l=l|0;var m=0,n=0,o=0,p=0;o=i;n=i=i+63&-64;i=i+16|0;Fd(a|0,0,b|0)|0;m=g|d;if(m>>>0>0|(m|0)==0&(f|b)>>>0>4294967295){if(!(c[7979]|0))d=31964;else d=c[(oa()|0)+60>>2]|0;c[d>>2]=27;n=-1;i=o;return n|0}g=k>>>0<0|(k|0)==0&j>>>0<32768;m=g?32768:j;k=g?0:k;a:do if(k>>>0<0|(k|0)==0&m>>>0>>5>>>0){g=Gd(m|0,k|0,6)|0;j=C;k=1;while(1){m=Hd(1,0,k|0)|0;l=C;d=k+1|0;if(l>>>0>j>>>0|(l|0)==(j|0)&m>>>0>g>>>0){d=k;g=1;break a}if(d>>>0<63)k=d;else{g=1;break}}}else{g=l>>>11;j=1;while(1){l=Hd(1,0,j|0)|0;p=C;d=j+1|0;if(p>>>0>0|(p|0)==0&l>>>0>g>>>0){d=j;break}if(d>>>0<63)j=d;else break}g=Gd(m|0,k|0,2)|0;g=Gd(g|0,C|0,d|0)|0;p=C;m=p>>>0>0|(p|0)==0&g>>>0>1073741823;g=m?1073741823:g;g=g>>>3}while(0);d=Hd(1,0,d|0)|0;c[n+4>>2]=0;c[n>>2]=0;c[n+8>>2]=0;g=hc(n,e,f,h,32,d,C,8,g,a,b)|0;d=c[n>>2]|0;if(d)zd(d);p=g;i=o;return p|0}function fc(b,e,f,g,h,j,k){b=b|0;e=e|0;f=f|0;g=g|0;h=h|0;j=j|0;k=k|0;var l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0;w=i;v=i=i+63&-64;i=i+112|0;t=v+72|0;u=v+12|0;l=b;m=l+102|0;do{a[l>>0]=0;l=l+1|0}while((l|0)<(m|0));if(g>>>0>0|(g|0)==0&f>>>0>4294967295){if(!(c[7979]|0))g=31964;else g=c[(oa()|0)+60>>2]|0;c[g>>2]=27;v=-1;i=w;return v|0}m=j>>>0<0|(j|0)==0&h>>>0<32768;n=m?32768:h;m=m?0:j;a:do if(m>>>0<0|(m|0)==0&n>>>0>>5>>>0){h=Gd(n|0,m|0,6)|0;l=C;m=1;while(1){k=Hd(1,0,m|0)|0;n=C;g=m+1|0;if(n>>>0>l>>>0|(n|0)==(l|0)&k>>>0>h>>>0){g=m;h=1;break a}if(g>>>0<63)m=g;else{h=1;break}}}else{h=k>>>11;l=1;while(1){k=Hd(1,0,l|0)|0;j=C;g=l+1|0;if(j>>>0>0|(j|0)==0&k>>>0>h>>>0){g=l;break}if(g>>>0<63)l=g;else break}h=Gd(n|0,m|0,2)|0;h=Gd(h|0,C|0,g|0)|0;k=C;n=k>>>0>0|(k|0)==0&h>>>0>1073741823;h=n?1073741823:h;h=h>>>3}while(0);l=0;do{a[t+l>>0]=Ba(0)|0;l=l+1|0}while((l|0)!=32);b:do if((((((((g>>>0<=63?(k=Hd(h|0,0,3)|0,n=C,!(n>>>0>0|(n|0)==0&k>>>0>1073741823)):0)?(a[u>>0]=36,a[u+1>>0]=55,a[u+2>>0]=36,a[u+3>>0]=a[34881+g>>0]|0,a[u+4>>0]=54,k=u+5|0,o=u+9|0,a[k>>0]=46,a[k+1>>0]=46,a[k+2>>0]=46,a[k+3>>0]=46,(o|0)!=0):0)?(p=o,r=u+58|0,(r|0)!=(p|0)):0)?(q=r-p|0,a[o>>0]=a[34881+(h&63)>>0]|0,(q|0)!=1):0)?(a[u+10>>0]=a[34881+(h>>>6&63)>>0]|0,(q|0)!=2):0)?(a[u+11>>0]=a[34881+(h>>>12&63)>>0]|0,(q|0)!=3):0)?(a[u+12>>0]=a[34881+(h>>>18&63)>>0]|0,(q|0)!=4):0)?(s=u+14|0,a[u+13>>0]=a[34881+(h>>>24)>>0]|0,(s|0)!=0):0){p=s;o=r-s|0;g=0;while(1){if(g>>>0<32){n=0;k=g;g=0}else break;do{s=k;k=k+1|0;g=(d[t+s>>0]|0)<>>0<32&n>>>0<24);if(!n)g=p;else{h=g;l=o;m=p;j=0;while(1){if(!l)break b;g=m+1|0;a[m>>0]=a[34881+(h&63)>>0]|0;j=j+6|0;if(j>>>0>=n>>>0)break;else{h=h>>>6;l=l+-1|0;m=g}}}s=(g|0)==0;o=(s?0:p-g|0)+o|0;if(s)break b;else{p=g;g=k}}if(p>>>0<(u+58|0)>>>0){a[p>>0]=0;l=v+4|0;c[l>>2]=0;c[v>>2]=0;m=v+8|0;c[m>>2]=0;g=(Vb(v,e,f,u,b)|0)==0;h=c[v>>2]|0;if(h)zd(h);c[l>>2]=0;c[v>>2]=0;c[m>>2]=0;if(!g){v=0;i=w;return v|0}if(!(c[7979]|0))g=31964;else g=c[(oa()|0)+60>>2]|0;c[g>>2]=22;v=-1;i=w;return v|0}}while(0);if(!(c[7979]|0))g=31964;else g=c[(oa()|0)+60>>2]|0;c[g>>2]=22;v=-1;i=w;return v|0}function gc(b,d,e,f){b=b|0;d=d|0;e=e|0;f=f|0;var g=0,h=0,j=0,k=0,l=0,m=0;m=i;l=i=i+63&-64;i=i+128|0;f=l+12|0;a:do if(b&3){g=102;h=b;do{if(!(a[h>>0]|0)){k=5;break a}h=h+1|0;g=g+-1|0;j=(g|0)!=0}while(j&(h&3|0)!=0);if(j)k=5;else g=0}else{g=102;h=b;k=5}while(0);b:do if((k|0)==5)if(a[h>>0]|0){c:do if(g>>>0>3)while(1){j=c[h>>2]|0;if((j&-2139062144^-2139062144)&j+-16843009)break;h=h+4|0;g=g+-4|0;if(g>>>0<=3){k=10;break c}}else k=10;while(0);if((k|0)==10)if(!g){g=0;break}while(1){if(!(a[h>>0]|0))break b;h=h+1|0;g=g+-1|0;if(!g){g=0;break}}}while(0);if((((g|0)!=0?h:0)|0)!=(b+101|0)){b=-1;i=m;return b|0}j=l+4|0;c[j>>2]=0;c[l>>2]=0;k=l+8|0;c[k>>2]=0;g=(Vb(l,d,e,b,f)|0)==0;h=c[l>>2]|0;if(h)zd(h);c[j>>2]=0;c[l>>2]=0;c[k>>2]=0;if(g){b=-1;i=m;return b|0}else{g=0;h=0}do{g=a[b+h>>0]^a[f+h>>0]|g;h=h+1|0}while((h|0)!=102);h=(((g&255)+511|0)>>>8&1)+-1|0;g=f+102|0;do{a[f>>0]=0;f=f+1|0}while((f|0)<(g|0));b=h;i=m;return b|0}function hc(b,e,f,g,h,i,j,k,l,m,n){b=b|0;e=e|0;f=f|0;g=g|0;h=h|0;i=i|0;j=j|0;k=k|0;l=l|0;m=m|0;n=n|0;var o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0;J=Od(l|0,0,k|0,0)|0;I=C;if(I>>>0>0|(I|0)==0&J>>>0>1073741823){if(!(c[7979]|0))o=31964;else o=c[(oa()|0)+60>>2]|0;c[o>>2]=27;f=-1;return f|0}if(j>>>0>0|(j|0)==0&i>>>0>4294967295){if(!(c[7979]|0))o=31964;else o=c[(oa()|0)+60>>2]|0;c[o>>2]=27;f=-1;return f|0}G=Dd(i|0,j|0,-1,-1)|0;H=C;if(j>>>0<0|(j|0)==0&i>>>0<2|((G&i|0)!=0|(H&j|0)!=0)){if(!(c[7979]|0))o=31964;else o=c[(oa()|0)+60>>2]|0;c[o>>2]=22;f=-1;return f|0}if((k|0)==0|(l|0)==0){if(!(c[7979]|0))o=31964;else o=c[(oa()|0)+60>>2]|0;c[o>>2]=22;f=-1;return f|0}if(!(k>>>0>16777215?1:(33554431/(l>>>0)|0)>>>0>>0)?!(0>>0|(0==(j|0)?(33554431/(k>>>0)|0)>>>0>>0:0)):0){I=k<<7;J=_(I,l)|0;y=Od(I|0,0,i|0,j|0)|0;o=y+J|0;if(o>>>0>>0){if(!(c[7979]|0))o=31964;else o=c[(oa()|0)+60>>2]|0;c[o>>2]=12;f=-1;return f|0}F=k<<8|64;w=o+F|0;if(w>>>0>>0){if(!(c[7979]|0))o=31964;else o=c[(oa()|0)+60>>2]|0;c[o>>2]=12;f=-1;return f|0}x=b+8|0;do if((c[x>>2]|0)>>>0>>0){o=c[b>>2]|0;if(o)zd(o);v=b+4|0;c[v>>2]=0;c[b>>2]=0;c[x>>2]=0;do if(w>>>0<=4294967168){if(w>>>0>=4294967168){if(!(c[7979]|0))o=31964;else o=c[(oa()|0)+60>>2]|0;c[o>>2]=12;q=12;o=0;break}t=w|8;o=yd(t+76|0)|0;if(o){s=o+-8|0;do if(o&63){r=o+63&-64;F=r+-8|0;q=s;r=(F-q|0)>>>0>15?F:r+56|0;q=r-q|0;o=o+-4|0;F=c[o>>2]|0;p=(F&-8)-q|0;if(!(F&3)){c[r>>2]=(c[s>>2]|0)+q;c[r+4>>2]=p;break}else{F=r+4|0;c[F>>2]=p|c[F>>2]&1|2;E=r+p+4|0;c[E>>2]=c[E>>2]|1;c[o>>2]=q|c[o>>2]&1|2;c[F>>2]=c[F>>2]|1;Ad(s,q);break}}else r=s;while(0);o=r+4|0;p=c[o>>2]|0;if((p&3|0)!=0?(u=p&-8,u>>>0>(t+16|0)>>>0):0){F=u-t|0;E=r+t|0;c[o>>2]=t|p&1|2;c[E+4>>2]=F|3;D=E+F+4|0;c[D>>2]=c[D>>2]|1;Ad(E,F)}q=0;o=r+8|0}else{q=12;o=0}}else{q=12;o=0}while(0);if(!(c[7979]|0))p=31964;else p=c[(oa()|0)+60>>2]|0;c[p>>2]=q;if(!q){c[b>>2]=o;c[v>>2]=o;c[x>>2]=(o|0)!=0?w:0;if(!o)o=-1;else break;return o|0}else{c[b>>2]=0;c[v>>2]=0;c[x>>2]=0;f=-1;return f|0}}else o=c[b+4>>2]|0;while(0);F=o+J|0;E=F+y|0;Yb(e,f,g,h,o,J);t=k<<5;u=E+(t<<2)|0;v=E+(k<<6<<2)|0;w=(t|0)==0;x=(i|0)==0&(j|0)==0;b=t&1073741792;y=(b|0)==0;h=I+-64|0;g=E+h|0;h=u+h|0;z=h+4|0;A=g+4|0;D=0;do{B=o+(_(I,D)|0)|0;if(!w){p=0;do{s=B+(p<<2)|0;c[E+(p<<2)>>2]=(d[s+1>>0]|0)<<8|(d[s>>0]|0)|(d[s+2>>0]|0)<<16|(d[s+3>>0]|0)<<24;p=p+1|0}while((p|0)!=(t|0))}a:do if(!x){if(y){p=0;q=0;do{ic(E,u,v,k);ic(u,E,v,k);p=Dd(p|0,q|0,2,0)|0;q=C}while(q>>>0>>0|(q|0)==(j|0)&p>>>0>>0)}else{r=0;s=0;do{p=Od(r|0,s|0,t|0,0)|0;p=F+(p<<2)|0;q=0;do{c[p+(q<<2)>>2]=c[E+(q<<2)>>2];q=q+1|0}while((q|0)!=(b|0));ic(E,u,v,k);p=Od(r|1|0,s|0,t|0,0)|0;p=F+(p<<2)|0;q=0;do{c[p+(q<<2)>>2]=c[u+(q<<2)>>2];q=q+1|0}while((q|0)!=(b|0));ic(u,E,v,k);r=Dd(r|0,s|0,2,0)|0;s=C}while(s>>>0>>0|(s|0)==(j|0)&r>>>0>>0)}if(y){p=0;q=0;while(1){ic(E,u,v,k);ic(u,E,v,k);p=Dd(p|0,q|0,2,0)|0;q=C;if(!(q>>>0>>0|(q|0)==(j|0)&p>>>0>>0))break a}}else{r=0;s=0}do{p=Od(c[g>>2]&G|0,c[A>>2]&H|0,t|0,0)|0;p=F+(p<<2)|0;q=0;do{K=E+(q<<2)|0;c[K>>2]=c[K>>2]^c[p+(q<<2)>>2];q=q+1|0}while((q|0)!=(b|0));ic(E,u,v,k);p=Od(c[h>>2]&G|0,c[z>>2]&H|0,t|0,0)|0;p=F+(p<<2)|0;q=0;do{K=u+(q<<2)|0;c[K>>2]=c[K>>2]^c[p+(q<<2)>>2];q=q+1|0}while((q|0)!=(b|0));ic(u,E,v,k);r=Dd(r|0,s|0,2,0)|0;s=C}while(s>>>0>>0|(s|0)==(j|0)&r>>>0>>0)}while(0);if(!w){p=0;do{K=B+(p<<2)|0;s=c[E+(p<<2)>>2]|0;a[K>>0]=s;a[K+1>>0]=s>>>8;a[K+2>>0]=s>>>16;a[K+3>>0]=s>>>24;p=p+1|0}while((p|0)!=(t|0))}D=D+1|0}while((D|0)!=(l|0));Yb(e,f,o,J,m,n);K=0;return K|0}if(!(c[7979]|0))o=31964;else o=c[(oa()|0)+60>>2]|0;c[o>>2]=12;K=-1;return K|0}function ic(a,b,d,e){a=a|0;b=b|0;d=d|0;e=e|0;var f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0;w=e<<1;m=a+((e<<5)+-16<<2)|0;o=c[m>>2]|0;c[d>>2]=o;q=c[m+4>>2]|0;L=d+4|0;c[L>>2]=q;t=c[m+8>>2]|0;x=d+8|0;c[x>>2]=t;u=c[m+12>>2]|0;y=d+12|0;c[y>>2]=u;s=c[m+16>>2]|0;z=d+16|0;c[z>>2]=s;r=c[m+20>>2]|0;A=d+20|0;c[A>>2]=r;p=c[m+24>>2]|0;B=d+24|0;c[B>>2]=p;n=c[m+28>>2]|0;C=d+28|0;c[C>>2]=n;l=c[m+32>>2]|0;D=d+32|0;c[D>>2]=l;j=c[m+36>>2]|0;E=d+36|0;c[E>>2]=j;h=c[m+40>>2]|0;F=d+40|0;c[F>>2]=h;f=c[m+44>>2]|0;G=d+44|0;c[G>>2]=f;g=c[m+48>>2]|0;H=d+48|0;c[H>>2]=g;i=c[m+52>>2]|0;I=d+52|0;c[I>>2]=i;k=c[m+56>>2]|0;J=d+56|0;c[J>>2]=k;m=c[m+60>>2]|0;K=d+60|0;c[K>>2]=m;if(!w)return;v=e<<4;e=0;while(1){M=e<<4;N=a+(M<<2)|0;c[d>>2]=o^c[N>>2];c[L>>2]=q^c[N+4>>2];c[x>>2]=t^c[N+8>>2];c[y>>2]=u^c[N+12>>2];c[z>>2]=s^c[N+16>>2];c[A>>2]=r^c[N+20>>2];c[B>>2]=p^c[N+24>>2];c[C>>2]=n^c[N+28>>2];c[D>>2]=l^c[N+32>>2];c[E>>2]=j^c[N+36>>2];c[F>>2]=h^c[N+40>>2];c[G>>2]=f^c[N+44>>2];c[H>>2]=g^c[N+48>>2];c[I>>2]=i^c[N+52>>2];c[J>>2]=k^c[N+56>>2];c[K>>2]=m^c[N+60>>2];jc(d);u=e<<3;t=b+(u<<2)|0;c[t>>2]=c[d>>2];c[t+4>>2]=c[L>>2];c[t+8>>2]=c[x>>2];c[t+12>>2]=c[y>>2];c[t+16>>2]=c[z>>2];c[t+20>>2]=c[A>>2];c[t+24>>2]=c[B>>2];c[t+28>>2]=c[C>>2];c[t+32>>2]=c[D>>2];c[t+36>>2]=c[E>>2];c[t+40>>2]=c[F>>2];c[t+44>>2]=c[G>>2];c[t+48>>2]=c[H>>2];c[t+52>>2]=c[I>>2];c[t+56>>2]=c[J>>2];c[t+60>>2]=c[K>>2];t=a+((M|16)<<2)|0;c[d>>2]=c[d>>2]^c[t>>2];c[L>>2]=c[L>>2]^c[t+4>>2];c[x>>2]=c[x>>2]^c[t+8>>2];c[y>>2]=c[y>>2]^c[t+12>>2];c[z>>2]=c[z>>2]^c[t+16>>2];c[A>>2]=c[A>>2]^c[t+20>>2];c[B>>2]=c[B>>2]^c[t+24>>2];c[C>>2]=c[C>>2]^c[t+28>>2];c[D>>2]=c[D>>2]^c[t+32>>2];c[E>>2]=c[E>>2]^c[t+36>>2];c[F>>2]=c[F>>2]^c[t+40>>2];c[G>>2]=c[G>>2]^c[t+44>>2];c[H>>2]=c[H>>2]^c[t+48>>2];c[I>>2]=c[I>>2]^c[t+52>>2];c[J>>2]=c[J>>2]^c[t+56>>2];c[K>>2]=c[K>>2]^c[t+60>>2];jc(d);u=b+(u+v<<2)|0;c[u>>2]=c[d>>2];c[u+4>>2]=c[L>>2];c[u+8>>2]=c[x>>2];c[u+12>>2]=c[y>>2];c[u+16>>2]=c[z>>2];c[u+20>>2]=c[A>>2];c[u+24>>2]=c[B>>2];c[u+28>>2]=c[C>>2];c[u+32>>2]=c[D>>2];c[u+36>>2]=c[E>>2];c[u+40>>2]=c[F>>2];c[u+44>>2]=c[G>>2];c[u+48>>2]=c[H>>2];c[u+52>>2]=c[I>>2];c[u+56>>2]=c[J>>2];c[u+60>>2]=c[K>>2];e=e+2|0;if(e>>>0>=w>>>0)break;f=c[G>>2]|0;g=c[H>>2]|0;i=c[I>>2]|0;k=c[J>>2]|0;m=c[K>>2]|0;o=c[d>>2]|0;q=c[L>>2]|0;t=c[x>>2]|0;u=c[y>>2]|0;s=c[z>>2]|0;r=c[A>>2]|0;p=c[B>>2]|0;n=c[C>>2]|0;l=c[D>>2]|0;j=c[E>>2]|0;h=c[F>>2]|0}return}function jc(a){a=a|0;var b=0,d=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0;b=a+4|0;z=a+8|0;A=a+12|0;B=a+16|0;F=a+20|0;f=a+24|0;k=a+28|0;n=a+32|0;s=a+36|0;t=a+40|0;u=a+44|0;v=a+48|0;w=a+52|0;x=a+56|0;y=a+60|0;d=c[b>>2]|0;e=c[F>>2]|0;g=c[s>>2]|0;h=c[w>>2]|0;i=c[f>>2]|0;j=c[t>>2]|0;l=c[x>>2]|0;m=c[z>>2]|0;o=c[u>>2]|0;p=c[y>>2]|0;q=c[A>>2]|0;r=c[k>>2]|0;C=c[v>>2]|0;D=c[a>>2]|0;E=c[B>>2]|0;G=c[n>>2]|0;H=0;do{R=C+D|0;R=(R<<7|R>>>25)^E;O=R+D|0;O=(O<<9|O>>>23)^G;L=O+R|0;L=(L<<13|L>>>19)^C;U=L+O|0;U=(U<<18|U>>>14)^D;N=d+e|0;N=(N<<7|N>>>25)^g;K=N+e|0;K=(K<<9|K>>>23)^h;X=K+N|0;X=(X<<13|X>>>19)^d;Q=X+K|0;Q=(Q<<18|Q>>>14)^e;J=i+j|0;J=(J<<7|J>>>25)^l;W=J+j|0;W=(W<<9|W>>>23)^m;T=W+J|0;T=(T<<13|T>>>19)^i;M=T+W|0;M=(M<<18|M>>>14)^j;V=o+p|0;V=(V<<7|V>>>25)^q;S=V+p|0;S=(S<<9|S>>>23)^r;P=S+V|0;P=(P<<13|P>>>19)^o;I=P+S|0;I=(I<<18|I>>>14)^p;Y=V+U|0;d=(Y<<7|Y>>>25)^X;X=d+U|0;m=(X<<9|X>>>23)^W;W=m+d|0;q=(W<<13|W>>>19)^V;V=q+m|0;D=(V<<18|V>>>14)^U;U=R+Q|0;i=(U<<7|U>>>25)^T;T=i+Q|0;r=(T<<9|T>>>23)^S;S=r+i|0;E=(S<<13|S>>>19)^R;R=E+r|0;e=(R<<18|R>>>14)^Q;Q=N+M|0;o=(Q<<7|Q>>>25)^P;P=o+M|0;G=(P<<9|P>>>23)^O;O=G+o|0;g=(O<<13|O>>>19)^N;N=g+G|0;j=(N<<18|N>>>14)^M;M=J+I|0;C=(M<<7|M>>>25)^L;L=C+I|0;h=(L<<9|L>>>23)^K;K=h+C|0;l=(K<<13|K>>>19)^J;J=l+h|0;p=(J<<18|J>>>14)^I;H=H+2|0}while(H>>>0<8);c[a>>2]=(c[a>>2]|0)+D;c[b>>2]=(c[b>>2]|0)+d;c[z>>2]=(c[z>>2]|0)+m;c[A>>2]=(c[A>>2]|0)+q;c[B>>2]=(c[B>>2]|0)+E;c[F>>2]=(c[F>>2]|0)+e;c[f>>2]=(c[f>>2]|0)+i;c[k>>2]=(c[k>>2]|0)+r;c[n>>2]=(c[n>>2]|0)+G;c[s>>2]=(c[s>>2]|0)+g;c[t>>2]=(c[t>>2]|0)+j;c[u>>2]=(c[u>>2]|0)+o;c[v>>2]=(c[v>>2]|0)+C;c[w>>2]=(c[w>>2]|0)+h;c[x>>2]=(c[x>>2]|0)+l;c[y>>2]=(c[y>>2]|0)+p;return}function kc(){return 32}function lc(){return 32}function mc(a,b){a=a|0;b=b|0;md(a,b,33785);return 0}function nc(a,b,c){a=a|0;b=b|0;c=c|0;md(a,b,c);return 0}function oc(){return 32}function pc(){return 24}function qc(){return 16}function rc(b,c,d,e,f,g,h){b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;g=g|0;h=h|0;var j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0;r=i;q=i=i+63&-64;i=i+240|0;p=q;o=q+176|0;q=q+144|0;nb(q,g,h,32988);h=b;j=d;if(b>>>0>=d>>>0?0>>0|0==(f|0)&(h-j|0)>>>0>>0:0)k=5;else if(d>>>0>=b>>>0?0>>0|0==(f|0)&(j-h|0)>>>0>>0:0)k=5;if((k|0)==5){Jd(b|0,d|0,e|0)|0;d=b}h=o;k=h+32|0;do{a[h>>0]=0;h=h+1|0}while((h|0)<(k|0));l=f>>>0>0|(f|0)==0&e>>>0>32;m=l?32:e;n=l?0:f;h=(m|0)==0&(n|0)==0;if(!h){k=f>>>0<0|(f|0)==0&e>>>0<32;k=Dd((k?e:32)|0,(k?f:0)|0,-1,0)|0;Id(o+32|0,d|0,k+1|0)|0}k=Dd(m|0,n|0,32,0)|0;j=g+16|0;nd(o,o,k,C,j,0,0,q);Ub(p,o);if(!h){g=f>>>0<0|(f|0)==0&e>>>0<32;g=Dd((g?e:32)|0,(g?f:0)|0,-1,0)|0;Id(b|0,o+32|0,g+1|0)|0}h=o;k=h+64|0;do{a[h>>0]=0;h=h+1|0}while((h|0)<(k|0));if(!l){Tb(p,b,e,f);Rb(p,c);i=r;return 0}o=Cd(e|0,f|0,m|0,n|0)|0;nd(b+m|0,d+m|0,o,C,j,1,0,q);Tb(p,b,e,f);Rb(p,c);i=r;return 0}function sc(a,b,c,d,e,f){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;if(d>>>0>0|(d|0)==0&c>>>0>4294967279){e=-1;return e|0}rc(a+16|0,a,b,c,d,e,f)|0;e=0;return e|0}function tc(b,e,f,g,h,j,k){b=b|0;e=e|0;f=f|0;g=g|0;h=h|0;j=j|0;k=k|0;var l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0;t=i;s=i=i+63&-64;i=i+208|0;m=s;o=s+144|0;n=s+112|0;r=s+48|0;s=s+16|0;nb(s,j,k,32988);q=j+16|0;k=n;j=s;l=k+32|0;do{a[k>>0]=a[j>>0]|0;k=k+1|0;j=j+1|0}while((k|0)<(l|0));l=q;j=l;l=l+4|0;l=d[l>>0]|d[l+1>>0]<<8|d[l+2>>0]<<16|d[l+3>>0]<<24;k=m;c[k>>2]=d[j>>0]|d[j+1>>0]<<8|d[j+2>>0]<<16|d[j+3>>0]<<24;c[k+4>>2]=l;k=m+8|0;c[k>>2]=0;c[k+4>>2]=0;ob(o,m,n,33817);k=0;do{a[r+k>>0]=a[o+k>>0]|0;k=k+1|0}while((k|0)!=32);if(Qb(f,e,g,h,r)|0){k=s;l=k+32|0;do{a[k>>0]=0;k=k+1|0}while((k|0)<(l|0));s=-1;i=t;return s|0}k=e;j=b;if(e>>>0>=b>>>0?0>>0|0==(h|0)&(k-j|0)>>>0>>0:0)p=9;else if(b>>>0>=e>>>0?0>>0|0==(h|0)&(j-k|0)>>>0>>0:0)p=9;if((p|0)==9){Jd(b|0,e|0,g|0)|0;e=b}k=h>>>0>0|(h|0)==0&g>>>0>32;j=k?32:g;l=k?0:h;if((j|0)==0&(l|0)==0)nd(r,r,32,0,q,0,0,s);else{f=r+32|0;p=h>>>0<0|(h|0)==0&g>>>0<32;p=Dd((p?g:32)|0,(p?h:0)|0,-1,0)|0;p=p+1|0;Id(f|0,e|0,p|0)|0;o=Dd(j|0,l|0,32,0)|0;nd(r,r,o,C,q,0,0,s);Id(b|0,f|0,p|0)|0}if(k){r=Cd(g|0,h|0,j|0,l|0)|0;nd(b+j|0,e+j|0,r,C,q,1,0,s)}k=s;l=k+32|0;do{a[k>>0]=0;k=k+1|0}while((k|0)<(l|0));s=0;i=t;return s|0}function uc(a,b,c,d,e,f){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;if(d>>>0<0|(d|0)==0&c>>>0<16){e=-1;return e|0}d=Dd(c|0,d|0,-16,-1)|0;e=tc(a,b+16|0,b,d,C,e,f)|0;return e|0}function vc(){return 8}function wc(){return 16}function xc(b,c,e,f,g){b=b|0;c=c|0;e=e|0;f=f|0;g=g|0;var h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0;h=d[g>>0]|0;o=Hd(d[g+1>>0]|0|0,0,8)|0;n=C;j=Hd(d[g+2>>0]|0|0,0,16)|0;n=n|C;k=Hd(d[g+3>>0]|0|0,0,24)|0;n=n|C|(d[g+4>>0]|0);r=Hd(d[g+5>>0]|0|0,0,40)|0;n=n|C;i=Hd(d[g+6>>0]|0|0,0,48)|0;n=n|C;l=Hd(d[g+7>>0]|0|0,0,56)|0;l=o|h|j|k|r|i|l;n=n|C;i=d[g+8>>0]|0;r=Hd(d[g+9>>0]|0|0,0,8)|0;k=C;j=Hd(d[g+10>>0]|0|0,0,16)|0;k=k|C;h=Hd(d[g+11>>0]|0|0,0,24)|0;k=k|C|(d[g+12>>0]|0);o=Hd(d[g+13>>0]|0|0,0,40)|0;k=k|C;p=Hd(d[g+14>>0]|0|0,0,48)|0;k=k|C;m=Hd(d[g+15>>0]|0|0,0,56)|0;m=r|i|j|h|o|p|m;k=k|C;p=e&7;o=c+e+(0-p)|0;e=Hd(e|0,f|0,56)|0;g=C;h=m^2037671283;j=k^1952801890;i=l^1852142177;f=n^1819895653;m=m^1852075885;k=k^1685025377;l=l^1886610805;n=n^1936682341;if((o|0)!=(c|0)){do{x=d[c>>0]|0;y=Hd(d[c+1>>0]|0|0,0,8)|0;r=C;w=Hd(d[c+2>>0]|0|0,0,16)|0;r=r|C;t=Hd(d[c+3>>0]|0|0,0,24)|0;r=r|C|(d[c+4>>0]|0);u=Hd(d[c+5>>0]|0|0,0,40)|0;r=r|C;v=Hd(d[c+6>>0]|0|0,0,48)|0;r=r|C;s=Hd(d[c+7>>0]|0|0,0,56)|0;s=y|x|w|t|u|v|s;r=r|C;v=s^h;u=r^j;n=Dd(l|0,n|0,m|0,k|0)|0;l=C;t=Hd(m|0,k|0,13)|0;h=C;m=Gd(m|0,k|0,51)|0;m=(t|m)^n;h=(h|C)^l;f=Dd(v|0,u|0,i|0,f|0)|0;i=C;t=Hd(v|0,u|0,16)|0;j=C;u=Gd(v|0,u|0,48)|0;u=(t|u)^f;j=(j|C)^i;n=Dd(u|0,j|0,l|0,n|0)|0;l=C;t=Hd(u|0,j|0,21)|0;k=C;j=Gd(u|0,j|0,43)|0;j=(t|j)^n;k=(k|C)^l;i=Dd(f|0,i|0,m|0,h|0)|0;f=C;t=Hd(m|0,h|0,17)|0;u=C;h=Gd(m|0,h|0,47)|0;h=i^(t|h);u=f^(u|C);l=Dd(n|0,l|0,h|0,u|0)|0;n=C;t=Hd(h|0,u|0,13)|0;m=C;u=Gd(h|0,u|0,51)|0;u=(t|u)^l;m=(m|C)^n;i=Dd(j|0,k|0,f|0,i|0)|0;f=C;t=Hd(j|0,k|0,16)|0;h=C;k=Gd(j|0,k|0,48)|0;k=(t|k)^i;h=(h|C)^f;l=Dd(k|0,h|0,n|0,l|0)|0;n=C;t=Hd(k|0,h|0,21)|0;j=C;h=Gd(k|0,h|0,43)|0;h=(t|h)^l;j=(j|C)^n;f=Dd(i|0,f|0,u|0,m|0)|0;i=C;t=Hd(u|0,m|0,17)|0;k=C;m=Gd(u|0,m|0,47)|0;m=(t|m)^f;k=(k|C)^i;l=l^s;n=n^r;c=c+8|0}while((c|0)!=(o|0));c=o}switch(p|0){case 7:{e=Hd(d[c+6>>0]|0|0,0,48)|0|e;g=C|g;q=5;break}case 6:{q=5;break}case 5:{q=6;break}case 4:{q=7;break}case 3:{q=8;break}case 2:{q=9;break}case 1:{q=10;break}default:{}}if((q|0)==5){y=Hd(d[c+5>>0]|0|0,0,40)|0;g=C|g;e=y|e;q=6}if((q|0)==6){g=d[c+4>>0]|0|g;q=7}if((q|0)==7){y=Hd(d[c+3>>0]|0|0,0,24)|0;e=y|e;g=C|g;q=8}if((q|0)==8){y=Hd(d[c+2>>0]|0|0,0,16)|0;e=y|e;g=C|g;q=9}if((q|0)==9){y=Hd(d[c+1>>0]|0|0,0,8)|0;e=y|e;g=C|g;q=10}if((q|0)==10)e=d[c>>0]|0|e;y=e^h;r=g^j;s=Dd(l|0,n|0,m|0,k|0)|0;q=C;w=Hd(m|0,k|0,13)|0;t=C;x=Gd(m|0,k|0,51)|0;x=(w|x)^s;t=(t|C)^q;w=Dd(y|0,r|0,i|0,f|0)|0;v=C;u=Hd(y|0,r|0,16)|0;p=C;r=Gd(y|0,r|0,48)|0;r=(u|r)^w;p=(p|C)^v;s=Dd(r|0,p|0,q|0,s|0)|0;q=C;u=Hd(r|0,p|0,21)|0;y=C;p=Gd(r|0,p|0,43)|0;p=(u|p)^s;y=(y|C)^q;v=Dd(w|0,v|0,x|0,t|0)|0;w=C;u=Hd(x|0,t|0,17)|0;r=C;t=Gd(x|0,t|0,47)|0;t=v^(u|t);r=w^(r|C);q=Dd(s|0,q|0,t|0,r|0)|0;s=C;u=Hd(t|0,r|0,13)|0;x=C;r=Gd(t|0,r|0,51)|0;r=(u|r)^q;x=(x|C)^s;v=Dd(p|0,y|0,w|0,v|0)|0;w=C;u=Hd(p|0,y|0,16)|0;t=C;y=Gd(p|0,y|0,48)|0;y=(u|y)^v;t=(t|C)^w;q=Dd(y|0,t|0,s|0,q|0)|0;s=C;u=Hd(y|0,t|0,21)|0;p=C;t=Gd(y|0,t|0,43)|0;t=(u|t)^q;p=(p|C)^s;w=Dd(v|0,w|0,r|0,x|0)|0;v=C;u=Hd(r|0,x|0,17)|0;y=C;x=Gd(r|0,x|0,47)|0;x=(u|x)^w;y=(y|C)^v;s=Dd(q^e|0,s^g|0,x|0,y|0)|0;q=C;u=Hd(x|0,y|0,13)|0;r=C;y=Gd(x|0,y|0,51)|0;y=s^(u|y);r=q^(r|C);w=Dd(t|0,p|0,v^255|0,w|0)|0;v=C;u=Hd(t|0,p|0,16)|0;x=C;p=Gd(t|0,p|0,48)|0;p=(u|p)^w;x=(x|C)^v;s=Dd(p|0,x|0,q|0,s|0)|0;q=C;u=Hd(p|0,x|0,21)|0;t=C;x=Gd(p|0,x|0,43)|0;x=(u|x)^s;t=(t|C)^q;v=Dd(w|0,v|0,y|0,r|0)|0;w=C;u=Hd(y|0,r|0,17)|0;p=C;r=Gd(y|0,r|0,47)|0;r=(u|r)^v;p=(p|C)^w;q=Dd(s|0,q|0,r|0,p|0)|0;s=C;u=Hd(r|0,p|0,13)|0;y=C;p=Gd(r|0,p|0,51)|0;p=(u|p)^q;y=(y|C)^s;v=Dd(x|0,t|0,w|0,v|0)|0;w=C;u=Hd(x|0,t|0,16)|0;r=C;t=Gd(x|0,t|0,48)|0;t=(u|t)^v;r=(r|C)^w;q=Dd(t|0,r|0,s|0,q|0)|0;s=C;u=Hd(t|0,r|0,21)|0;x=C;r=Gd(t|0,r|0,43)|0;r=(u|r)^q;x=(x|C)^s;w=Dd(v|0,w|0,p|0,y|0)|0;v=C;u=Hd(p|0,y|0,17)|0;t=C;y=Gd(p|0,y|0,47)|0;y=(u|y)^w;t=(t|C)^v;s=Dd(q|0,s|0,y|0,t|0)|0;q=C;u=Hd(y|0,t|0,13)|0;p=C;t=Gd(y|0,t|0,51)|0;t=(u|t)^s;p=(p|C)^q;w=Dd(r|0,x|0,v|0,w|0)|0;v=C;u=Hd(r|0,x|0,16)|0;y=C;x=Gd(r|0,x|0,48)|0;x=(u|x)^w;y=(y|C)^v;s=Dd(x|0,y|0,q|0,s|0)|0;q=C;u=Hd(x|0,y|0,21)|0;r=C;y=Gd(x|0,y|0,43)|0;y=(u|y)^s;r=(r|C)^q;v=Dd(w|0,v|0,t|0,p|0)|0;w=C;u=Hd(t|0,p|0,17)|0;x=C;p=Gd(t|0,p|0,47)|0;p=(u|p)^v;x=(x|C)^w;q=Dd(s|0,q|0,p|0,x|0)|0;s=C;u=Hd(p|0,x|0,13)|0;t=C;x=Gd(p|0,x|0,51)|0;q=(u|x)^q;s=(t|C)^s;v=Dd(y|0,r|0,w|0,v|0)|0;w=C;t=Hd(y|0,r|0,16)|0;x=C;r=Gd(y|0,r|0,48)|0;r=(t|r)^v;x=(x|C)^w;t=Hd(r|0,x|0,21)|0;y=C;x=Gd(r|0,x|0,43)|0;y=y|C;w=Dd(v|0,w|0,q|0,s|0)|0;v=C;r=Hd(q|0,s|0,17)|0;u=C;s=Gd(q|0,s|0,47)|0;x=(r|s)^w^v^(t|x);y=(u|C)^v^w^y;a[b>>0]=x;a[b+1>>0]=x>>>8;a[b+2>>0]=x>>>16;a[b+3>>0]=x>>>24;a[b+4>>0]=y;w=Gd(x|0,y|0,40)|0;a[b+5>>0]=w;w=Gd(x|0,y|0,48)|0;a[b+6>>0]=w;y=Gd(x|0,y|0,56)|0;a[b+7>>0]=y;return 0}function yc(){return 64}function zc(){return 32}function Ac(){return 32}function Bc(){return 64}function Cc(b,e,f){b=b|0;e=e|0;f=f|0;var g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0;o=i;h=i=i+63&-64;i=i+496|0;k=h;j=h+448|0;l=h+408|0;m=h+368|0;h=h+208|0;g=k+64|0;n=k;p=8;q=n+64|0;do{c[n>>2]=c[p>>2];n=n+4|0;p=p+4|0}while((n|0)<(q|0));n=k+72|0;c[n>>2]=256;c[n+4>>2]=0;n=g;c[n>>2]=0;c[n+4>>2]=0;n=k+80|0;p=f;q=n+32|0;do{a[n>>0]=a[p>>0]|0;n=n+1|0;p=p+1|0}while((n|0)<(q|0));Gb(k,e);a[e>>0]=(d[e>>0]|0)&248;q=e+31|0;a[q>>0]=(d[q>>0]|0)&63|64;Rc(h,e);Ic(j,h+80|0);Jc(l,h,j);Jc(m,h+40|0,j);Lc(b,m);Lc(k,l);q=b+31|0;a[q>>0]=(d[q>>0]|0)^(d[k>>0]|0)<<7;Jd(e|0,f|0,32)|0;Jd(e+32|0,b|0,32)|0;i=o;return 0}function Dc(b,e){b=b|0;e=e|0;var f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0;q=i;n=i=i+63&-64;i=i+528|0;m=n;l=n+448|0;o=n+408|0;p=n+368|0;k=n+208|0;n=n+488|0;f=0;do{a[n+f>>0]=Ba(0)|0;f=f+1|0}while((f|0)!=32);f=m+64|0;g=m;h=8;j=g+64|0;do{c[g>>2]=c[h>>2];g=g+4|0;h=h+4|0}while((g|0)<(j|0));g=m+72|0;c[g>>2]=256;c[g+4>>2]=0;g=f;c[g>>2]=0;c[g+4>>2]=0;g=m+80|0;h=n;j=g+32|0;do{a[g>>0]=a[h>>0]|0;g=g+1|0;h=h+1|0}while((g|0)<(j|0));Gb(m,e);a[e>>0]=(d[e>>0]|0)&248;g=e+31|0;a[g>>0]=(d[g>>0]|0)&63|64;Rc(k,e);Ic(l,k+80|0);Jc(o,k,l);Jc(p,k+40|0,l);Lc(b,p);Lc(m,o);g=b+31|0;a[g>>0]=(d[g>>0]|0)^(d[m>>0]|0)<<7;g=e;h=n;j=g+32|0;do{a[g>>0]=a[h>>0]|0;g=g+1|0;h=h+1|0}while((g|0)<(j|0));Jd(e+32|0,b|0,32)|0;i=q;return 0}function Ec(a,b,d,e,f,g){a=a|0;b=b|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,j=0,k=0;h=i;j=i=i+63&-64;i=i+16|0;k=a+64|0;Jd(k|0,d|0,e|0)|0;Xc(a,j,k,e,f,g);g=j;d=(b|0)!=0;if((c[g>>2]|0)==64&(c[g+4>>2]|0)==0){if(!d){k=0;i=h;return k|0}j=Dd(e|0,f|0,64,0)|0;k=b;c[k>>2]=j;c[k+4>>2]=C;k=0;i=h;return k|0}else{if(d){k=b;c[k>>2]=0;c[k+4>>2]=0}k=Dd(e|0,f|0,64,0)|0;Fd(a|0,0,k|0)|0;k=-1;i=h;return k|0}return 0}function Fc(a,b,d,e,f,g){a=a|0;b=b|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0;e=Dd(e|0,f|0,-64,-1)|0;f=C;do if(!(f>>>0>0|(f|0)==0&e>>>0>4294967231)){h=d+64|0;if(Vc(d,h,e,f,g)|0){Fd(a|0,0,e|0)|0;break}if(b){d=b;c[d>>2]=e;c[d+4>>2]=f}Jd(a|0,h|0,e|0)|0;d=0;return d|0}while(0);if(!b){d=-1;return d|0}d=b;c[d>>2]=0;c[d+4>>2]=0;d=-1;return d|0}function Gc(a,b,c,d,e,f){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;Xc(a,b,c,d,e,f);return 0}function Hc(a,b,c,d,e){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;return Vc(a,b,c,d,e)|0}function Ic(a,b){a=a|0;b=b|0;var c=0,d=0,e=0,f=0,g=0;g=i;c=i=i+63&-64;i=i+160|0;d=c+120|0;e=c+80|0;f=c+40|0;Kc(d,b);Kc(e,d);Kc(e,e);Jc(e,b,e);Jc(d,d,e);Kc(f,d);Jc(e,e,f);Kc(f,e);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Jc(e,f,e);Kc(f,e);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Jc(f,f,e);Kc(c,f);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Jc(f,c,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Jc(e,f,e);Kc(f,e);b=1;do{Kc(f,f);b=b+1|0}while((b|0)!=50);Jc(f,f,e);Kc(c,f);b=1;do{Kc(c,c);b=b+1|0}while((b|0)!=100);Jc(f,c,f);Kc(f,f);b=1;do{Kc(f,f);b=b+1|0}while((b|0)!=50);Jc(e,f,e);Kc(e,e);Kc(e,e);Kc(e,e);Kc(e,e);Kc(e,e);Jc(a,e,d);i=g;return}function Jc(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0,xa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha=0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa=0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0,db=0,eb=0,fb=0,gb=0,hb=0,ib=0,jb=0,kb=0,lb=0,mb=0,nb=0,ob=0,pb=0,qb=0,rb=0,sb=0,tb=0,ub=0,vb=0,wb=0,xb=0,yb=0,zb=0,Ab=0,Bb=0,Cb=0,Db=0,Eb=0,Fb=0,Gb=0,Hb=0,Ib=0,Jb=0,Kb=0,Lb=0,Mb=0,Nb=0,Ob=0,Pb=0,Qb=0,Rb=0,Sb=0,Tb=0,Ub=0,Vb=0,Wb=0,Xb=0,Yb=0,Zb=0,_b=0,$b=0,ac=0,bc=0,cc=0,dc=0,ec=0,fc=0,gc=0,hc=0,ic=0,jc=0,kc=0,lc=0,mc=0,nc=0,oc=0,pc=0,qc=0,rc=0,sc=0,tc=0,uc=0,vc=0,wc=0,xc=0,yc=0,zc=0,Ac=0,Bc=0,Cc=0,Dc=0,Ec=0,Fc=0,Gc=0,Hc=0,Ic=0,Jc=0,Kc=0,Lc=0,Mc=0,Nc=0,Oc=0,Pc=0,Qc=0,Rc=0,Sc=0;l=c[b>>2]|0;s=c[b+4>>2]|0;j=c[b+8>>2]|0;Rb=c[b+12>>2]|0;e=c[b+16>>2]|0;za=c[b+20>>2]|0;ya=c[b+24>>2]|0;zb=c[b+28>>2]|0;h=c[b+32>>2]|0;ga=c[b+36>>2]|0;H=c[d>>2]|0;J=c[d+4>>2]|0;F=c[d+8>>2]|0;D=c[d+12>>2]|0;A=c[d+16>>2]|0;y=c[d+20>>2]|0;w=c[d+24>>2]|0;u=c[d+28>>2]|0;k=c[d+32>>2]|0;t=c[d+36>>2]|0;Oc=J*19|0;bc=F*19|0;rb=D*19|0;Ha=A*19|0;jc=y*19|0;Db=w*19|0;Ta=u*19|0;Sc=k*19|0;Qc=t*19|0;p=s<<1;f=Rb<<1;M=za<<1;i=zb<<1;d=ga<<1;o=((l|0)<0)<<31>>31;I=((H|0)<0)<<31>>31;Mc=Od(H|0,I|0,l|0,o|0)|0;Lc=C;K=((J|0)<0)<<31>>31;wc=Od(J|0,K|0,l|0,o|0)|0;vc=C;G=((F|0)<0)<<31>>31;ub=Od(F|0,G|0,l|0,o|0)|0;tb=C;E=((D|0)<0)<<31>>31;Ka=Od(D|0,E|0,l|0,o|0)|0;Ja=C;B=((A|0)<0)<<31>>31;mc=Od(A|0,B|0,l|0,o|0)|0;lc=C;z=((y|0)<0)<<31>>31;Gb=Od(y|0,z|0,l|0,o|0)|0;Fb=C;x=((w|0)<0)<<31>>31;Wa=Od(w|0,x|0,l|0,o|0)|0;Va=C;v=((u|0)<0)<<31>>31;ja=Od(u|0,v|0,l|0,o|0)|0;ia=C;Pc=((k|0)<0)<<31>>31;P=Od(k|0,Pc|0,l|0,o|0)|0;O=C;o=Od(t|0,((t|0)<0)<<31>>31|0,l|0,o|0)|0;l=C;t=((s|0)<0)<<31>>31;dc=Od(H|0,I|0,s|0,t|0)|0;ec=C;n=((p|0)<0)<<31>>31;yb=Od(J|0,K|0,p|0,n|0)|0;xb=C;Ma=Od(F|0,G|0,s|0,t|0)|0;La=C;oc=Od(D|0,E|0,p|0,n|0)|0;nc=C;Ib=Od(A|0,B|0,s|0,t|0)|0;Hb=C;Ya=Od(y|0,z|0,p|0,n|0)|0;Xa=C;la=Od(w|0,x|0,s|0,t|0)|0;ka=C;R=Od(u|0,v|0,p|0,n|0)|0;Q=C;t=Od(k|0,Pc|0,s|0,t|0)|0;s=C;Pc=((Qc|0)<0)<<31>>31;n=Od(Qc|0,Pc|0,p|0,n|0)|0;p=C;k=((j|0)<0)<<31>>31;wb=Od(H|0,I|0,j|0,k|0)|0;vb=C;Qa=Od(J|0,K|0,j|0,k|0)|0;Pa=C;qc=Od(F|0,G|0,j|0,k|0)|0;pc=C;Kb=Od(D|0,E|0,j|0,k|0)|0;Jb=C;_a=Od(A|0,B|0,j|0,k|0)|0;Za=C;na=Od(y|0,z|0,j|0,k|0)|0;ma=C;T=Od(w|0,x|0,j|0,k|0)|0;S=C;v=Od(u|0,v|0,j|0,k|0)|0;u=C;Rc=((Sc|0)<0)<<31>>31;yc=Od(Sc|0,Rc|0,j|0,k|0)|0;xc=C;k=Od(Qc|0,Pc|0,j|0,k|0)|0;j=C;Sb=((Rb|0)<0)<<31>>31;Oa=Od(H|0,I|0,Rb|0,Sb|0)|0;Na=C;fa=((f|0)<0)<<31>>31;uc=Od(J|0,K|0,f|0,fa|0)|0;tc=C;Mb=Od(F|0,G|0,Rb|0,Sb|0)|0;Lb=C;ab=Od(D|0,E|0,f|0,fa|0)|0;$a=C;pa=Od(A|0,B|0,Rb|0,Sb|0)|0;oa=C;V=Od(y|0,z|0,f|0,fa|0)|0;U=C;x=Od(w|0,x|0,Rb|0,Sb|0)|0;w=C;Ua=((Ta|0)<0)<<31>>31;Ac=Od(Ta|0,Ua|0,f|0,fa|0)|0;zc=C;Sb=Od(Sc|0,Rc|0,Rb|0,Sb|0)|0;Rb=C;fa=Od(Qc|0,Pc|0,f|0,fa|0)|0;f=C;N=((e|0)<0)<<31>>31;sc=Od(H|0,I|0,e|0,N|0)|0;rc=C;Qb=Od(J|0,K|0,e|0,N|0)|0;Pb=C;cb=Od(F|0,G|0,e|0,N|0)|0;bb=C;ra=Od(D|0,E|0,e|0,N|0)|0;qa=C;X=Od(A|0,B|0,e|0,N|0)|0;W=C;z=Od(y|0,z|0,e|0,N|0)|0;y=C;Eb=((Db|0)<0)<<31>>31;Cc=Od(Db|0,Eb|0,e|0,N|0)|0;Bc=C;Ub=Od(Ta|0,Ua|0,e|0,N|0)|0;Tb=C;ib=Od(Sc|0,Rc|0,e|0,N|0)|0;hb=C;N=Od(Qc|0,Pc|0,e|0,N|0)|0;e=C;Aa=((za|0)<0)<<31>>31;Ob=Od(H|0,I|0,za|0,Aa|0)|0;Nb=C;b=((M|0)<0)<<31>>31;gb=Od(J|0,K|0,M|0,b|0)|0;fb=C;ta=Od(F|0,G|0,za|0,Aa|0)|0;sa=C;Z=Od(D|0,E|0,M|0,b|0)|0;Y=C;B=Od(A|0,B|0,za|0,Aa|0)|0;A=C;kc=((jc|0)<0)<<31>>31;Ec=Od(jc|0,kc|0,M|0,b|0)|0;Dc=C;Wb=Od(Db|0,Eb|0,za|0,Aa|0)|0;Vb=C;kb=Od(Ta|0,Ua|0,M|0,b|0)|0;jb=C;Aa=Od(Sc|0,Rc|0,za|0,Aa|0)|0;za=C;b=Od(Qc|0,Pc|0,M|0,b|0)|0;M=C;g=((ya|0)<0)<<31>>31;eb=Od(H|0,I|0,ya|0,g|0)|0;db=C;xa=Od(J|0,K|0,ya|0,g|0)|0;wa=C;$=Od(F|0,G|0,ya|0,g|0)|0;_=C;E=Od(D|0,E|0,ya|0,g|0)|0;D=C;Ia=((Ha|0)<0)<<31>>31;Gc=Od(Ha|0,Ia|0,ya|0,g|0)|0;Fc=C;Yb=Od(jc|0,kc|0,ya|0,g|0)|0;Xb=C;mb=Od(Db|0,Eb|0,ya|0,g|0)|0;lb=C;Ca=Od(Ta|0,Ua|0,ya|0,g|0)|0;Ba=C;m=Od(Sc|0,Rc|0,ya|0,g|0)|0;r=C;g=Od(Qc|0,Pc|0,ya|0,g|0)|0;ya=C;Ab=((zb|0)<0)<<31>>31;va=Od(H|0,I|0,zb|0,Ab|0)|0;ua=C;ea=((i|0)<0)<<31>>31;da=Od(J|0,K|0,i|0,ea|0)|0;ca=C;G=Od(F|0,G|0,zb|0,Ab|0)|0;F=C;sb=((rb|0)<0)<<31>>31;Ic=Od(rb|0,sb|0,i|0,ea|0)|0;Hc=C;_b=Od(Ha|0,Ia|0,zb|0,Ab|0)|0;Zb=C;ob=Od(jc|0,kc|0,i|0,ea|0)|0;nb=C;Ea=Od(Db|0,Eb|0,zb|0,Ab|0)|0;Da=C;gc=Od(Ta|0,Ua|0,i|0,ea|0)|0;fc=C;Ab=Od(Sc|0,Rc|0,zb|0,Ab|0)|0;zb=C;ea=Od(Qc|0,Pc|0,i|0,ea|0)|0;i=C;L=((h|0)<0)<<31>>31;ba=Od(H|0,I|0,h|0,L|0)|0;aa=C;K=Od(J|0,K|0,h|0,L|0)|0;J=C;cc=((bc|0)<0)<<31>>31;Kc=Od(bc|0,cc|0,h|0,L|0)|0;Jc=C;ac=Od(rb|0,sb|0,h|0,L|0)|0;$b=C;qb=Od(Ha|0,Ia|0,h|0,L|0)|0;pb=C;Ga=Od(jc|0,kc|0,h|0,L|0)|0;Fa=C;ic=Od(Db|0,Eb|0,h|0,L|0)|0;hc=C;Cb=Od(Ta|0,Ua|0,h|0,L|0)|0;Bb=C;Sa=Od(Sc|0,Rc|0,h|0,L|0)|0;Ra=C;L=Od(Qc|0,Pc|0,h|0,L|0)|0;h=C;ha=((ga|0)<0)<<31>>31;I=Od(H|0,I|0,ga|0,ha|0)|0;H=C;q=((d|0)<0)<<31>>31;Oc=Od(Oc|0,((Oc|0)<0)<<31>>31|0,d|0,q|0)|0;Nc=C;cc=Od(bc|0,cc|0,ga|0,ha|0)|0;bc=C;sb=Od(rb|0,sb|0,d|0,q|0)|0;rb=C;Ia=Od(Ha|0,Ia|0,ga|0,ha|0)|0;Ha=C;kc=Od(jc|0,kc|0,d|0,q|0)|0;jc=C;Eb=Od(Db|0,Eb|0,ga|0,ha|0)|0;Db=C;Ua=Od(Ta|0,Ua|0,d|0,q|0)|0;Ta=C;ha=Od(Sc|0,Rc|0,ga|0,ha|0)|0;ga=C;q=Od(Qc|0,Pc|0,d|0,q|0)|0;d=C;Lc=Dd(Oc|0,Nc|0,Mc|0,Lc|0)|0;Jc=Dd(Lc|0,C|0,Kc|0,Jc|0)|0;Hc=Dd(Jc|0,C|0,Ic|0,Hc|0)|0;Fc=Dd(Hc|0,C|0,Gc|0,Fc|0)|0;Dc=Dd(Fc|0,C|0,Ec|0,Dc|0)|0;Bc=Dd(Dc|0,C|0,Cc|0,Bc|0)|0;zc=Dd(Bc|0,C|0,Ac|0,zc|0)|0;xc=Dd(zc|0,C|0,yc|0,xc|0)|0;p=Dd(xc|0,C|0,n|0,p|0)|0;n=C;ec=Dd(wc|0,vc|0,dc|0,ec|0)|0;dc=C;rc=Dd(uc|0,tc|0,sc|0,rc|0)|0;pc=Dd(rc|0,C|0,qc|0,pc|0)|0;nc=Dd(pc|0,C|0,oc|0,nc|0)|0;lc=Dd(nc|0,C|0,mc|0,lc|0)|0;jc=Dd(lc|0,C|0,kc|0,jc|0)|0;hc=Dd(jc|0,C|0,ic|0,hc|0)|0;fc=Dd(hc|0,C|0,gc|0,fc|0)|0;r=Dd(fc|0,C|0,m|0,r|0)|0;M=Dd(r|0,C|0,b|0,M|0)|0;b=C;r=Dd(p|0,n|0,33554432,0)|0;r=Ed(r|0,C|0,26)|0;m=C;bc=Dd(ec|0,dc|0,cc|0,bc|0)|0;$b=Dd(bc|0,C|0,ac|0,$b|0)|0;Zb=Dd($b|0,C|0,_b|0,Zb|0)|0;Xb=Dd(Zb|0,C|0,Yb|0,Xb|0)|0;Vb=Dd(Xb|0,C|0,Wb|0,Vb|0)|0;Tb=Dd(Vb|0,C|0,Ub|0,Tb|0)|0;Rb=Dd(Tb|0,C|0,Sb|0,Rb|0)|0;j=Dd(Rb|0,C|0,k|0,j|0)|0;j=Dd(j|0,C|0,r|0,m|0)|0;k=C;m=Hd(r|0,m|0,26)|0;m=Cd(p|0,n|0,m|0,C|0)|0;n=C;p=Dd(M|0,b|0,33554432,0)|0;p=Ed(p|0,C|0,26)|0;r=C;Nb=Dd(Qb|0,Pb|0,Ob|0,Nb|0)|0;Lb=Dd(Nb|0,C|0,Mb|0,Lb|0)|0;Jb=Dd(Lb|0,C|0,Kb|0,Jb|0)|0;Hb=Dd(Jb|0,C|0,Ib|0,Hb|0)|0;Fb=Dd(Hb|0,C|0,Gb|0,Fb|0)|0;Db=Dd(Fb|0,C|0,Eb|0,Db|0)|0;Bb=Dd(Db|0,C|0,Cb|0,Bb|0)|0;zb=Dd(Bb|0,C|0,Ab|0,zb|0)|0;ya=Dd(zb|0,C|0,g|0,ya|0)|0;ya=Dd(ya|0,C|0,p|0,r|0)|0;g=C;r=Hd(p|0,r|0,26)|0;r=Cd(M|0,b|0,r|0,C|0)|0;b=C;M=Dd(j|0,k|0,16777216,0)|0;M=Ed(M|0,C|0,25)|0;p=C;vb=Dd(yb|0,xb|0,wb|0,vb|0)|0;tb=Dd(vb|0,C|0,ub|0,tb|0)|0;rb=Dd(tb|0,C|0,sb|0,rb|0)|0;pb=Dd(rb|0,C|0,qb|0,pb|0)|0;nb=Dd(pb|0,C|0,ob|0,nb|0)|0;lb=Dd(nb|0,C|0,mb|0,lb|0)|0;jb=Dd(lb|0,C|0,kb|0,jb|0)|0;hb=Dd(jb|0,C|0,ib|0,hb|0)|0;f=Dd(hb|0,C|0,fa|0,f|0)|0;f=Dd(f|0,C|0,M|0,p|0)|0;fa=C;p=Hd(M|0,p|0,25)|0;p=Cd(j|0,k|0,p|0,C|0)|0;k=C;j=Dd(ya|0,g|0,16777216,0)|0;j=Ed(j|0,C|0,25)|0;M=C;db=Dd(gb|0,fb|0,eb|0,db|0)|0;bb=Dd(db|0,C|0,cb|0,bb|0)|0;$a=Dd(bb|0,C|0,ab|0,$a|0)|0;Za=Dd($a|0,C|0,_a|0,Za|0)|0;Xa=Dd(Za|0,C|0,Ya|0,Xa|0)|0;Va=Dd(Xa|0,C|0,Wa|0,Va|0)|0;Ta=Dd(Va|0,C|0,Ua|0,Ta|0)|0;Ra=Dd(Ta|0,C|0,Sa|0,Ra|0)|0;i=Dd(Ra|0,C|0,ea|0,i|0)|0;i=Dd(i|0,C|0,j|0,M|0)|0;ea=C;M=Hd(j|0,M|0,25)|0;M=Cd(ya|0,g|0,M|0,C|0)|0;g=C;ya=Dd(f|0,fa|0,33554432,0)|0;ya=Ed(ya|0,C|0,26)|0;j=C;Na=Dd(Qa|0,Pa|0,Oa|0,Na|0)|0;La=Dd(Na|0,C|0,Ma|0,La|0)|0;Ja=Dd(La|0,C|0,Ka|0,Ja|0)|0;Ha=Dd(Ja|0,C|0,Ia|0,Ha|0)|0;Fa=Dd(Ha|0,C|0,Ga|0,Fa|0)|0;Da=Dd(Fa|0,C|0,Ea|0,Da|0)|0;Ba=Dd(Da|0,C|0,Ca|0,Ba|0)|0;za=Dd(Ba|0,C|0,Aa|0,za|0)|0;e=Dd(za|0,C|0,N|0,e|0)|0;e=Dd(e|0,C|0,ya|0,j|0)|0;N=C;j=Hd(ya|0,j|0,26)|0;j=Cd(f|0,fa|0,j|0,C|0)|0;fa=Dd(i|0,ea|0,33554432,0)|0;fa=Ed(fa|0,C|0,26)|0;f=C;ua=Dd(xa|0,wa|0,va|0,ua|0)|0;sa=Dd(ua|0,C|0,ta|0,sa|0)|0;qa=Dd(sa|0,C|0,ra|0,qa|0)|0;oa=Dd(qa|0,C|0,pa|0,oa|0)|0;ma=Dd(oa|0,C|0,na|0,ma|0)|0;ka=Dd(ma|0,C|0,la|0,ka|0)|0;ia=Dd(ka|0,C|0,ja|0,ia|0)|0;ga=Dd(ia|0,C|0,ha|0,ga|0)|0;h=Dd(ga|0,C|0,L|0,h|0)|0;h=Dd(h|0,C|0,fa|0,f|0)|0;L=C;f=Hd(fa|0,f|0,26)|0;f=Cd(i|0,ea|0,f|0,C|0)|0;ea=Dd(e|0,N|0,16777216,0)|0;ea=Ed(ea|0,C|0,25)|0;i=C;b=Dd(ea|0,i|0,r|0,b|0)|0;r=C;i=Hd(ea|0,i|0,25)|0;i=Cd(e|0,N|0,i|0,C|0)|0;N=Dd(h|0,L|0,16777216,0)|0;N=Ed(N|0,C|0,25)|0;e=C;aa=Dd(da|0,ca|0,ba|0,aa|0)|0;_=Dd(aa|0,C|0,$|0,_|0)|0;Y=Dd(_|0,C|0,Z|0,Y|0)|0;W=Dd(Y|0,C|0,X|0,W|0)|0;U=Dd(W|0,C|0,V|0,U|0)|0;S=Dd(U|0,C|0,T|0,S|0)|0;Q=Dd(S|0,C|0,R|0,Q|0)|0;O=Dd(Q|0,C|0,P|0,O|0)|0;d=Dd(O|0,C|0,q|0,d|0)|0;d=Dd(d|0,C|0,N|0,e|0)|0;q=C;e=Hd(N|0,e|0,25)|0;e=Cd(h|0,L|0,e|0,C|0)|0;L=Dd(b|0,r|0,33554432,0)|0;L=Ed(L|0,C|0,26)|0;h=C;g=Dd(M|0,g|0,L|0,h|0)|0;h=Hd(L|0,h|0,26)|0;h=Cd(b|0,r|0,h|0,C|0)|0;r=Dd(d|0,q|0,33554432,0)|0;r=Ed(r|0,C|0,26)|0;b=C;H=Dd(K|0,J|0,I|0,H|0)|0;F=Dd(H|0,C|0,G|0,F|0)|0;D=Dd(F|0,C|0,E|0,D|0)|0;A=Dd(D|0,C|0,B|0,A|0)|0;y=Dd(A|0,C|0,z|0,y|0)|0;w=Dd(y|0,C|0,x|0,w|0)|0;u=Dd(w|0,C|0,v|0,u|0)|0;s=Dd(u|0,C|0,t|0,s|0)|0;l=Dd(s|0,C|0,o|0,l|0)|0;l=Dd(l|0,C|0,r|0,b|0)|0;o=C;b=Hd(r|0,b|0,26)|0;b=Cd(d|0,q|0,b|0,C|0)|0;q=Dd(l|0,o|0,16777216,0)|0;q=Ed(q|0,C|0,25)|0;d=C;r=Od(q|0,d|0,19,0)|0;n=Dd(r|0,C|0,m|0,n|0)|0;m=C;d=Hd(q|0,d|0,25)|0;d=Cd(l|0,o|0,d|0,C|0)|0;o=Dd(n|0,m|0,33554432,0)|0;o=Ed(o|0,C|0,26)|0;l=C;k=Dd(p|0,k|0,o|0,l|0)|0;l=Hd(o|0,l|0,26)|0;l=Cd(n|0,m|0,l|0,C|0)|0;c[a>>2]=l;c[a+4>>2]=k;c[a+8>>2]=j;c[a+12>>2]=i;c[a+16>>2]=h;c[a+20>>2]=g;c[a+24>>2]=f;c[a+28>>2]=e;c[a+32>>2]=b;c[a+36>>2]=d;return}function Kc(a,b){a=a|0;b=b|0;var d=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0,xa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha=0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa=0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0,db=0,eb=0,fb=0,gb=0;bb=c[b>>2]|0;ua=c[b+4>>2]|0;j=c[b+8>>2]|0;la=c[b+12>>2]|0;e=c[b+16>>2]|0;db=c[b+20>>2]|0;Y=c[b+24>>2]|0;La=c[b+28>>2]|0;h=c[b+32>>2]|0;b=c[b+36>>2]|0;l=bb<<1;p=ua<<1;Xa=j<<1;f=la<<1;na=e<<1;B=db<<1;m=Y<<1;i=La<<1;Ka=db*38|0;ra=Y*19|0;va=La*38|0;da=h*19|0;gb=b*38|0;cb=((bb|0)<0)<<31>>31;cb=Od(bb|0,cb|0,bb|0,cb|0)|0;bb=C;o=((l|0)<0)<<31>>31;ta=((ua|0)<0)<<31>>31;Ia=Od(l|0,o|0,ua|0,ta|0)|0;Ha=C;k=((j|0)<0)<<31>>31;Wa=Od(j|0,k|0,l|0,o|0)|0;Va=C;ma=((la|0)<0)<<31>>31;Ua=Od(la|0,ma|0,l|0,o|0)|0;Ta=C;D=((e|0)<0)<<31>>31;Oa=Od(e|0,D|0,l|0,o|0)|0;Na=C;eb=((db|0)<0)<<31>>31;ya=Od(db|0,eb|0,l|0,o|0)|0;xa=C;g=((Y|0)<0)<<31>>31;ga=Od(Y|0,g|0,l|0,o|0)|0;fa=C;Ma=((La|0)<0)<<31>>31;R=Od(La|0,Ma|0,l|0,o|0)|0;Q=C;A=((h|0)<0)<<31>>31;F=Od(h|0,A|0,l|0,o|0)|0;E=C;q=((b|0)<0)<<31>>31;o=Od(b|0,q|0,l|0,o|0)|0;l=C;n=((p|0)<0)<<31>>31;ta=Od(p|0,n|0,ua|0,ta|0)|0;ua=C;ba=Od(p|0,n|0,j|0,k|0)|0;ca=C;P=((f|0)<0)<<31>>31;Sa=Od(f|0,P|0,p|0,n|0)|0;Ra=C;Ca=Od(e|0,D|0,p|0,n|0)|0;Ba=C;d=((B|0)<0)<<31>>31;ia=Od(B|0,d|0,p|0,n|0)|0;ha=C;T=Od(Y|0,g|0,p|0,n|0)|0;S=C;O=((i|0)<0)<<31>>31;H=Od(i|0,O|0,p|0,n|0)|0;G=C;t=Od(h|0,A|0,p|0,n|0)|0;s=C;fb=((gb|0)<0)<<31>>31;n=Od(gb|0,fb|0,p|0,n|0)|0;p=C;Qa=Od(j|0,k|0,j|0,k|0)|0;Pa=C;Ya=((Xa|0)<0)<<31>>31;Aa=Od(Xa|0,Ya|0,la|0,ma|0)|0;za=C;ka=Od(e|0,D|0,Xa|0,Ya|0)|0;ja=C;X=Od(db|0,eb|0,Xa|0,Ya|0)|0;W=C;N=Od(Y|0,g|0,Xa|0,Ya|0)|0;M=C;v=Od(La|0,Ma|0,Xa|0,Ya|0)|0;u=C;ea=((da|0)<0)<<31>>31;Ya=Od(da|0,ea|0,Xa|0,Ya|0)|0;Xa=C;k=Od(gb|0,fb|0,j|0,k|0)|0;j=C;ma=Od(f|0,P|0,la|0,ma|0)|0;la=C;V=Od(f|0,P|0,e|0,D|0)|0;U=C;J=Od(B|0,d|0,f|0,P|0)|0;I=C;z=Od(Y|0,g|0,f|0,P|0)|0;y=C;wa=((va|0)<0)<<31>>31;_a=Od(va|0,wa|0,f|0,P|0)|0;Za=C;Ea=Od(da|0,ea|0,f|0,P|0)|0;Da=C;P=Od(gb|0,fb|0,f|0,P|0)|0;f=C;L=Od(e|0,D|0,e|0,D|0)|0;K=C;oa=((na|0)<0)<<31>>31;x=Od(na|0,oa|0,db|0,eb|0)|0;w=C;sa=((ra|0)<0)<<31>>31;ab=Od(ra|0,sa|0,na|0,oa|0)|0;$a=C;Ga=Od(va|0,wa|0,e|0,D|0)|0;Fa=C;oa=Od(da|0,ea|0,na|0,oa|0)|0;na=C;D=Od(gb|0,fb|0,e|0,D|0)|0;e=C;eb=Od(Ka|0,((Ka|0)<0)<<31>>31|0,db|0,eb|0)|0;db=C;Ka=Od(ra|0,sa|0,B|0,d|0)|0;Ja=C;qa=Od(va|0,wa|0,B|0,d|0)|0;pa=C;_=Od(da|0,ea|0,B|0,d|0)|0;Z=C;d=Od(gb|0,fb|0,B|0,d|0)|0;B=C;sa=Od(ra|0,sa|0,Y|0,g|0)|0;ra=C;aa=Od(va|0,wa|0,Y|0,g|0)|0;$=C;m=Od(da|0,ea|0,m|0,((m|0)<0)<<31>>31|0)|0;r=C;g=Od(gb|0,fb|0,Y|0,g|0)|0;Y=C;Ma=Od(va|0,wa|0,La|0,Ma|0)|0;La=C;wa=Od(da|0,ea|0,i|0,O|0)|0;va=C;O=Od(gb|0,fb|0,i|0,O|0)|0;i=C;ea=Od(da|0,ea|0,h|0,A|0)|0;da=C;A=Od(gb|0,fb|0,h|0,A|0)|0;h=C;q=Od(gb|0,fb|0,b|0,q|0)|0;b=C;bb=Dd(eb|0,db|0,cb|0,bb|0)|0;$a=Dd(bb|0,C|0,ab|0,$a|0)|0;Za=Dd($a|0,C|0,_a|0,Za|0)|0;Xa=Dd(Za|0,C|0,Ya|0,Xa|0)|0;p=Dd(Xa|0,C|0,n|0,p|0)|0;n=C;ua=Dd(Wa|0,Va|0,ta|0,ua|0)|0;ta=C;ca=Dd(Ua|0,Ta|0,ba|0,ca|0)|0;ba=C;Pa=Dd(Sa|0,Ra|0,Qa|0,Pa|0)|0;Na=Dd(Pa|0,C|0,Oa|0,Na|0)|0;La=Dd(Na|0,C|0,Ma|0,La|0)|0;r=Dd(La|0,C|0,m|0,r|0)|0;B=Dd(r|0,C|0,d|0,B|0)|0;d=C;r=Dd(p|0,n|0,33554432,0)|0;r=Ed(r|0,C|0,26)|0;m=C;Ha=Dd(Ka|0,Ja|0,Ia|0,Ha|0)|0;Fa=Dd(Ha|0,C|0,Ga|0,Fa|0)|0;Da=Dd(Fa|0,C|0,Ea|0,Da|0)|0;j=Dd(Da|0,C|0,k|0,j|0)|0;j=Dd(j|0,C|0,r|0,m|0)|0;k=C;m=Hd(r|0,m|0,26)|0;m=Cd(p|0,n|0,m|0,C|0)|0;n=C;p=Dd(B|0,d|0,33554432,0)|0;p=Ed(p|0,C|0,26)|0;r=C;za=Dd(Ca|0,Ba|0,Aa|0,za|0)|0;xa=Dd(za|0,C|0,ya|0,xa|0)|0;va=Dd(xa|0,C|0,wa|0,va|0)|0;Y=Dd(va|0,C|0,g|0,Y|0)|0;Y=Dd(Y|0,C|0,p|0,r|0)|0;g=C;r=Hd(p|0,r|0,26)|0;r=Cd(B|0,d|0,r|0,C|0)|0;d=C;B=Dd(j|0,k|0,16777216,0)|0;B=Ed(B|0,C|0,25)|0;p=C;ra=Dd(ua|0,ta|0,sa|0,ra|0)|0;pa=Dd(ra|0,C|0,qa|0,pa|0)|0;na=Dd(pa|0,C|0,oa|0,na|0)|0;f=Dd(na|0,C|0,P|0,f|0)|0;f=Dd(f|0,C|0,B|0,p|0)|0;P=C;p=Hd(B|0,p|0,25)|0;p=Cd(j|0,k|0,p|0,C|0)|0;k=C;j=Dd(Y|0,g|0,16777216,0)|0;j=Ed(j|0,C|0,25)|0;B=C;ja=Dd(ma|0,la|0,ka|0,ja|0)|0;ha=Dd(ja|0,C|0,ia|0,ha|0)|0;fa=Dd(ha|0,C|0,ga|0,fa|0)|0;da=Dd(fa|0,C|0,ea|0,da|0)|0;i=Dd(da|0,C|0,O|0,i|0)|0;i=Dd(i|0,C|0,j|0,B|0)|0;O=C;B=Hd(j|0,B|0,25)|0;B=Cd(Y|0,g|0,B|0,C|0)|0;g=C;Y=Dd(f|0,P|0,33554432,0)|0;Y=Ed(Y|0,C|0,26)|0;j=C;$=Dd(ca|0,ba|0,aa|0,$|0)|0;Z=Dd($|0,C|0,_|0,Z|0)|0;e=Dd(Z|0,C|0,D|0,e|0)|0;e=Dd(e|0,C|0,Y|0,j|0)|0;D=C;j=Hd(Y|0,j|0,26)|0;j=Cd(f|0,P|0,j|0,C|0)|0;P=Dd(i|0,O|0,33554432,0)|0;P=Ed(P|0,C|0,26)|0;f=C;U=Dd(X|0,W|0,V|0,U|0)|0;S=Dd(U|0,C|0,T|0,S|0)|0;Q=Dd(S|0,C|0,R|0,Q|0)|0;h=Dd(Q|0,C|0,A|0,h|0)|0;h=Dd(h|0,C|0,P|0,f|0)|0;A=C;f=Hd(P|0,f|0,26)|0;f=Cd(i|0,O|0,f|0,C|0)|0;O=Dd(e|0,D|0,16777216,0)|0;O=Ed(O|0,C|0,25)|0;i=C;d=Dd(O|0,i|0,r|0,d|0)|0;r=C;i=Hd(O|0,i|0,25)|0;i=Cd(e|0,D|0,i|0,C|0)|0;D=Dd(h|0,A|0,16777216,0)|0;D=Ed(D|0,C|0,25)|0;e=C;K=Dd(N|0,M|0,L|0,K|0)|0;I=Dd(K|0,C|0,J|0,I|0)|0;G=Dd(I|0,C|0,H|0,G|0)|0;E=Dd(G|0,C|0,F|0,E|0)|0;b=Dd(E|0,C|0,q|0,b|0)|0;b=Dd(b|0,C|0,D|0,e|0)|0;q=C;e=Hd(D|0,e|0,25)|0;e=Cd(h|0,A|0,e|0,C|0)|0;A=Dd(d|0,r|0,33554432,0)|0;A=Ed(A|0,C|0,26)|0;h=C;g=Dd(B|0,g|0,A|0,h|0)|0;h=Hd(A|0,h|0,26)|0;h=Cd(d|0,r|0,h|0,C|0)|0;r=Dd(b|0,q|0,33554432,0)|0;r=Ed(r|0,C|0,26)|0;d=C;w=Dd(z|0,y|0,x|0,w|0)|0;u=Dd(w|0,C|0,v|0,u|0)|0;s=Dd(u|0,C|0,t|0,s|0)|0;l=Dd(s|0,C|0,o|0,l|0)|0;l=Dd(l|0,C|0,r|0,d|0)|0;o=C;d=Hd(r|0,d|0,26)|0;d=Cd(b|0,q|0,d|0,C|0)|0;q=Dd(l|0,o|0,16777216,0)|0;q=Ed(q|0,C|0,25)|0;b=C;r=Od(q|0,b|0,19,0)|0;n=Dd(r|0,C|0,m|0,n|0)|0;m=C;b=Hd(q|0,b|0,25)|0;b=Cd(l|0,o|0,b|0,C|0)|0;o=Dd(n|0,m|0,33554432,0)|0;o=Ed(o|0,C|0,26)|0;l=C;k=Dd(p|0,k|0,o|0,l|0)|0;l=Hd(o|0,l|0,26)|0;l=Cd(n|0,m|0,l|0,C|0)|0;c[a>>2]=l;c[a+4>>2]=k;c[a+8>>2]=j;c[a+12>>2]=i;c[a+16>>2]=h;c[a+20>>2]=g;c[a+24>>2]=f;c[a+28>>2]=e;c[a+32>>2]=d;c[a+36>>2]=b;return}function Lc(b,d){b=b|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0;m=c[d>>2]|0;l=c[d+4>>2]|0;k=c[d+8>>2]|0;j=c[d+12>>2]|0;i=c[d+16>>2]|0;h=c[d+20>>2]|0;g=c[d+24>>2]|0;f=c[d+28>>2]|0;o=c[d+32>>2]|0;e=c[d+36>>2]|0;m=(((((((((((((e*19|0)+16777216>>25)+m>>26)+l>>25)+k>>26)+j>>25)+i>>26)+h>>25)+g>>26)+f>>25)+o>>26)+e>>25)*19|0)+m|0;n=m>>26;l=n+l|0;n=m-(n<<26)|0;m=l>>25;k=m+k|0;m=l-(m<<25)|0;l=k>>26;j=l+j|0;l=k-(l<<26)|0;k=j>>25;i=k+i|0;k=j-(k<<25)|0;j=i>>26;h=j+h|0;j=i-(j<<26)|0;i=h>>25;g=i+g|0;i=h-(i<<25)|0;h=g>>26;f=h+f|0;h=g-(h<<26)|0;g=f>>25;d=g+o|0;g=f-(g<<25)|0;f=d>>26;e=f+e|0;f=d-(f<<26)|0;d=e&33554431;a[b>>0]=n;a[b+1>>0]=n>>>8;a[b+2>>0]=n>>>16;a[b+3>>0]=m<<2|n>>>24;a[b+4>>0]=m>>>6;a[b+5>>0]=m>>>14;a[b+6>>0]=l<<3|m>>>22;a[b+7>>0]=l>>>5;a[b+8>>0]=l>>>13;a[b+9>>0]=k<<5|l>>>21;a[b+10>>0]=k>>>3;a[b+11>>0]=k>>>11;a[b+12>>0]=j<<6|k>>>19;a[b+13>>0]=j>>>2;a[b+14>>0]=j>>>10;a[b+15>>0]=j>>>18;a[b+16>>0]=i;a[b+17>>0]=i>>>8;a[b+18>>0]=i>>>16;a[b+19>>0]=h<<1|i>>>24;a[b+20>>0]=h>>>7;a[b+21>>0]=h>>>15;a[b+22>>0]=g<<3|h>>>23;a[b+23>>0]=g>>>5;a[b+24>>0]=g>>>13;a[b+25>>0]=f<<4|g>>>21;a[b+26>>0]=f>>>4;a[b+27>>0]=f>>>12;a[b+28>>0]=f>>>20|d<<6;a[b+29>>0]=e>>>2;a[b+30>>0]=e>>>10;a[b+31>>0]=d>>>18;return}function Mc(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0;V=b+40|0;j=b+44|0;m=b+48|0;p=b+52|0;s=b+56|0;v=b+60|0;y=b+64|0;B=b+68|0;E=b+72|0;C=b+76|0;S=b+4|0;P=b+8|0;e=b+12|0;l=b+16|0;n=b+20|0;u=b+24|0;w=b+28|0;D=b+32|0;O=b+36|0;ga=(c[S>>2]|0)+(c[j>>2]|0)|0;fa=(c[P>>2]|0)+(c[m>>2]|0)|0;ea=(c[e>>2]|0)+(c[p>>2]|0)|0;da=(c[l>>2]|0)+(c[s>>2]|0)|0;ca=(c[n>>2]|0)+(c[v>>2]|0)|0;ba=(c[u>>2]|0)+(c[y>>2]|0)|0;aa=(c[w>>2]|0)+(c[B>>2]|0)|0;$=(c[D>>2]|0)+(c[E>>2]|0)|0;Y=(c[O>>2]|0)+(c[C>>2]|0)|0;c[a>>2]=(c[b>>2]|0)+(c[V>>2]|0);ha=a+4|0;c[ha>>2]=ga;ga=a+8|0;c[ga>>2]=fa;fa=a+12|0;c[fa>>2]=ea;ea=a+16|0;c[ea>>2]=da;da=a+20|0;c[da>>2]=ca;ca=a+24|0;c[ca>>2]=ba;ba=a+28|0;c[ba>>2]=aa;aa=a+32|0;c[aa>>2]=$;$=a+36|0;c[$>>2]=Y;Y=a+40|0;S=(c[j>>2]|0)-(c[S>>2]|0)|0;P=(c[m>>2]|0)-(c[P>>2]|0)|0;e=(c[p>>2]|0)-(c[e>>2]|0)|0;l=(c[s>>2]|0)-(c[l>>2]|0)|0;n=(c[v>>2]|0)-(c[n>>2]|0)|0;u=(c[y>>2]|0)-(c[u>>2]|0)|0;w=(c[B>>2]|0)-(c[w>>2]|0)|0;D=(c[E>>2]|0)-(c[D>>2]|0)|0;O=(c[C>>2]|0)-(c[O>>2]|0)|0;c[Y>>2]=(c[V>>2]|0)-(c[b>>2]|0);V=a+44|0;c[V>>2]=S;S=a+48|0;c[S>>2]=P;P=a+52|0;c[P>>2]=e;e=a+56|0;c[e>>2]=l;l=a+60|0;c[l>>2]=n;n=a+64|0;c[n>>2]=u;u=a+68|0;c[u>>2]=w;w=a+72|0;c[w>>2]=D;D=a+76|0;c[D>>2]=O;O=a+80|0;Jc(O,a,d);Jc(Y,Y,d+40|0);C=a+120|0;Jc(C,d+120|0,b+120|0);Jc(a,b+80|0,d+80|0);E=c[a>>2]<<1;B=c[ha>>2]<<1;y=c[ga>>2]<<1;v=c[fa>>2]<<1;s=c[ea>>2]<<1;p=c[da>>2]<<1;m=c[ca>>2]<<1;j=c[ba>>2]<<1;g=c[aa>>2]<<1;b=c[$>>2]<<1;Z=c[O>>2]|0;N=a+84|0;W=c[N>>2]|0;M=a+88|0;T=c[M>>2]|0;L=a+92|0;Q=c[L>>2]|0;K=a+96|0;f=c[K>>2]|0;J=a+100|0;h=c[J>>2]|0;I=a+104|0;o=c[I>>2]|0;H=a+108|0;q=c[H>>2]|0;G=a+112|0;x=c[G>>2]|0;F=a+116|0;z=c[F>>2]|0;_=c[Y>>2]|0;X=c[V>>2]|0;U=c[S>>2]|0;R=c[P>>2]|0;d=c[e>>2]|0;i=c[l>>2]|0;k=c[n>>2]|0;r=c[u>>2]|0;t=c[w>>2]|0;A=c[D>>2]|0;c[a>>2]=Z-_;c[ha>>2]=W-X;c[ga>>2]=T-U;c[fa>>2]=Q-R;c[ea>>2]=f-d;c[da>>2]=h-i;c[ca>>2]=o-k;c[ba>>2]=q-r;c[aa>>2]=x-t;c[$>>2]=z-A;c[Y>>2]=_+Z;c[V>>2]=X+W;c[S>>2]=U+T;c[P>>2]=R+Q;c[e>>2]=d+f;c[l>>2]=i+h;c[n>>2]=k+o;c[u>>2]=r+q;c[w>>2]=t+x;c[D>>2]=A+z;D=c[C>>2]|0;z=a+124|0;A=c[z>>2]|0;w=a+128|0;x=c[w>>2]|0;t=a+132|0;u=c[t>>2]|0;q=a+136|0;r=c[q>>2]|0;n=a+140|0;o=c[n>>2]|0;k=a+144|0;l=c[k>>2]|0;h=a+148|0;i=c[h>>2]|0;e=a+152|0;f=c[e>>2]|0;a=a+156|0;d=c[a>>2]|0;c[O>>2]=D+E;c[N>>2]=A+B;c[M>>2]=x+y;c[L>>2]=u+v;c[K>>2]=r+s;c[J>>2]=o+p;c[I>>2]=l+m;c[H>>2]=i+j;c[G>>2]=f+g;c[F>>2]=d+b;c[C>>2]=E-D;c[z>>2]=B-A;c[w>>2]=y-x;c[t>>2]=v-u;c[q>>2]=s-r;c[n>>2]=p-o;c[k>>2]=m-l;c[h>>2]=j-i;c[e>>2]=g-f;c[a>>2]=b-d;return} function Ha(a){a=a|0;var b=0;b=i;i=i+a|0;i=i+15&-16;return b|0}function Ia(){return i|0}function Ja(a){a=a|0;i=a}function Ka(a,b){a=a|0;b=b|0;i=a;j=b}function La(a,b){a=a|0;b=b|0;if(!n){n=a;o=b}}function Ma(b){b=b|0;a[k>>0]=a[b>>0];a[k+1>>0]=a[b+1>>0];a[k+2>>0]=a[b+2>>0];a[k+3>>0]=a[b+3>>0]}function Na(b){b=b|0;a[k>>0]=a[b>>0];a[k+1>>0]=a[b+1>>0];a[k+2>>0]=a[b+2>>0];a[k+3>>0]=a[b+3>>0];a[k+4>>0]=a[b+4>>0];a[k+5>>0]=a[b+5>>0];a[k+6>>0]=a[b+6>>0];a[k+7>>0]=a[b+7>>0]}function Oa(a){a=a|0;C=a}function Pa(){return C|0}function Qa(){return 32}function Ra(){return 32}function Sa(a,b,c,d,e){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;Ua(a,b,c,d,e);return 0}function Ta(b,c,d,e,f){b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;var g=0,h=0;h=i;i=i+32|0;g=h;Ua(g,c,d,e,f);d=Yc(b,g)|0;e=(g|0)==(b|0);c=0;f=0;do{c=a[b+f>>0]^a[g+f>>0]|c;f=f+1|0}while((f|0)!=32);i=h;return (e?-1:d)|(((c&255)+511|0)>>>8&1)+-1|0}function Ua(b,d,e,f,g){b=b|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0;s=i;i=i+608|0;r=s+480|0;o=s+416|0;n=s;j=n+64|0;c[j>>2]=0;c[j+4>>2]=0;c[j+8>>2]=0;c[j+12>>2]=0;h=n;k=8;l=h+64|0;do{c[h>>2]=c[k>>2];h=h+4|0;k=k+4|0}while((h|0)<(l|0));h=r;l=h+128|0;do{a[h>>0]=54;h=h+1|0}while((h|0)<(l|0));a[r>>0]=a[g>>0]^54;h=1;do{q=r+h|0;a[q>>0]=a[q>>0]^a[g+h>>0];h=h+1|0}while((h|0)!=32);h=n+72|0;c[h>>2]=1024;c[h+4>>2]=0;c[j>>2]=0;c[j+4>>2]=0;j=n+80|0;h=j;k=r;l=h+128|0;do{a[h>>0]=a[k>>0]|0;h=h+1|0;k=k+1|0}while((h|0)<(l|0));Hb(n,j);j=a[g>>0]|0;q=n+208|0;m=n+272|0;c[m>>2]=0;c[m+4>>2]=0;c[m+8>>2]=0;c[m+12>>2]=0;h=q;k=8;l=h+64|0;do{c[h>>2]=c[k>>2];h=h+4|0;k=k+4|0}while((h|0)<(l|0));h=r;l=h+128|0;do{a[h>>0]=92;h=h+1|0}while((h|0)<(l|0));a[r>>0]=j^92;h=1;do{p=r+h|0;a[p>>0]=a[p>>0]^a[g+h>>0];h=h+1|0}while((h|0)!=32);j=n+280|0;p=j;c[p>>2]=1024;c[p+4>>2]=0;p=m;c[p>>2]=0;c[p+4>>2]=0;p=n+288|0;h=p;k=r;l=h+128|0;do{a[h>>0]=a[k>>0]|0;h=h+1|0;k=k+1|0}while((h|0)<(l|0));Hb(q,p);Fb(n,d,e,f);Gb(n,o);f=j;d=c[f>>2]|0;f=c[f+4>>2]|0;k=Gd(d|0,f|0,3)|0;k=k&127;h=Dd(d|0,f|0,512,0)|0;c[j>>2]=h;c[j+4>>2]=C;j=m;h=c[j>>2]|0;j=c[j+4>>2]|0;if(f>>>0>4294967295|(f|0)==-1&d>>>0>4294966783){h=Dd(h|0,j|0,1,0)|0;j=C;d=m;c[d>>2]=h;c[d+4>>2]=j}g=m;c[g>>2]=h;c[g+4>>2]=j;j=Cd(128,0,k|0,0)|0;g=C;h=n+288+k|0;if(g>>>0>0|(g|0)==0&j>>>0>64){k=o;l=h+64|0;do{a[h>>0]=a[k>>0]|0;h=h+1|0;k=k+1|0}while((h|0)<(l|0));Gb(q,r);h=b;k=r;l=h+32|0;do{a[h>>0]=a[k>>0]|0;h=h+1|0;k=k+1|0}while((h|0)<(l|0));i=s;return}Id(h|0,o|0,j|0)|0;Hb(q,p);h=o+j|0;j=Cd(64,0,j|0,g|0)|0;g=C;if(g>>>0>0|(g|0)==0&j>>>0>127)do{Hb(q,h);h=h+128|0;j=Dd(j|0,g|0,-128,-1)|0;g=C}while(g>>>0>0|(g|0)==0&j>>>0>127);Id(p|0,h|0,j|0)|0;Gb(q,r);h=b;k=r;l=h+32|0;do{a[h>>0]=a[k>>0]|0;h=h+1|0;k=k+1|0}while((h|0)<(l|0));i=s;return}function Va(){return 32}function Wa(){return 32}function Xa(){return 32}function Ya(){return 32}function Za(){return 24}function _a(){return 16}function $a(b,d,e){b=b|0;d=d|0;e=e|0;var f=0,g=0,h=0,j=0,k=0,l=0,m=0;k=i;i=i+272|0;h=k;g=k+208|0;f=h+64|0;j=h;l=8;m=j+64|0;do{c[j>>2]=c[l>>2];j=j+4|0;l=l+4|0}while((j|0)<(m|0));j=h+72|0;c[j>>2]=256;c[j+4>>2]=0;j=f;c[j>>2]=0;c[j+4>>2]=0;j=h+80|0;l=e;m=j+32|0;do{a[j>>0]=a[l>>0]|0;j=j+1|0;l=l+1|0}while((j|0)<(m|0));Gb(h,g);j=d;l=g;m=j+32|0;do{a[j>>0]=a[l>>0]|0;j=j+1|0;l=l+1|0}while((j|0)<(m|0));md(b,d,33785);i=k;return 0}function ab(b,c){b=b|0;c=c|0;var d=0;d=0;do{a[c+d>>0]=Ba(0)|0;d=d+1|0}while((d|0)!=32);md(b,c,33785);return 0}function bb(a,b,c){a=a|0;b=b|0;c=c|0;var d=0,e=0;d=i;i=i+32|0;e=d;md(e,c,b);nb(a,32576,e,32592);i=d;return 0}function cb(a,b,c,d,e,f,g){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;g=g|0;rc(a,b,c,d,e,f,g)|0;return 0}function db(a,b,c,d,e,f,g,h){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;g=g|0;h=h|0;var j=0,k=0,l=0;j=i;i=i+64|0;l=j+32|0;k=j;md(l,h,g);nb(k,32576,l,32592);rc(a,b,c,d,e,f,k)|0;i=j;return 0}function eb(a,b,c,d,e,f){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;if(d>>>0>0|(d|0)==0&c>>>0>4294967279){e=-1;return e|0}rc(a+16|0,a,b,c,d,e,f)|0;e=0;return e|0}function fb(a,b,c,d,e,f,g){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,j=0,k=0;k=i;i=i+64|0;j=k+32|0;h=k;if(d>>>0>0|(d|0)==0&c>>>0>4294967279){g=-1;i=k;return g|0}md(j,g,f);nb(h,32576,j,32592);rc(a+16|0,a,b,c,d,e,h)|0;g=0;i=k;return g|0}function gb(a,b,c,d,e,f,g){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;g=g|0;return tc(a,b,c,d,e,f,g)|0}function hb(a,b,c,d,e,f,g,h){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;g=g|0;h=h|0;var j=0,k=0,l=0;j=i;i=i+64|0;l=j+32|0;k=j;md(l,h,g);nb(k,32576,l,32592);h=tc(a,b,c,d,e,f,k)|0;i=j;return h|0}function ib(a,b,c,d,e,f){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;if(d>>>0<0|(d|0)==0&c>>>0<16){e=-1;return e|0}d=Dd(c|0,d|0,-16,-1)|0;e=tc(a,b+16|0,b,d,C,e,f)|0;return e|0}function jb(a,b,c,d,e,f,g){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,j=0,k=0;k=i;i=i+64|0;j=k+32|0;h=k;if(d>>>0<0|(d|0)==0&c>>>0<16){g=-1;i=k;return g|0}c=Dd(c|0,d|0,-16,-1)|0;d=C;md(j,g,f);nb(h,32576,j,32592);g=tc(a,b+16|0,b,c,d,e,h)|0;i=k;return g|0}function kb(b,d,e,f,g){b=b|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0;A=i;v=i=i+63&-64;i=i+480|0;y=v;w=v+448|0;x=v+424|0;j=v+392|0;v=v+360|0;h=0;do{a[v+h>>0]=Ba(0)|0;h=h+1|0}while((h|0)!=32);md(j,v,33785);h=b;o=j;p=h+32|0;do{a[h>>0]=a[o>>0]|0;h=h+1|0;o=o+1|0}while((h|0)<(p|0));Fd(y|0,0,357)|0;q=y;c[q>>2]=-222443248;c[q+4>>2]=1779033703;q=y+8|0;c[q>>2]=-2067093701;c[q+4>>2]=-1150833019;q=y+16|0;c[q>>2]=-23791573;c[q+4>>2]=1013904242;q=y+24|0;c[q>>2]=1595750129;c[q+4>>2]=-1521486534;q=y+32|0;c[q>>2]=-1377402159;c[q+4>>2]=1359893119;q=y+40|0;c[q>>2]=725511199;c[q+4>>2]=-1694144372;q=y+48|0;c[q>>2]=-79577749;c[q+4>>2]=528734635;q=y+56|0;c[q>>2]=327033209;c[q+4>>2]=1541459225;q=y+352|0;r=y+96|0;s=y+64|0;t=y+72|0;u=y+224|0;h=0;m=0;n=32;while(1){l=256-h|0;h=y+96+h|0;if(!(m>>>0>0|(m|0)==0&n>>>0>l>>>0)){z=5;break}Id(h|0,j|0,l|0)|0;c[q>>2]=(c[q>>2]|0)+l;p=s;h=c[p>>2]|0;p=c[p+4>>2]|0;k=Dd(h|0,p|0,128,0)|0;o=s;c[o>>2]=k;c[o+4>>2]=C;o=t;o=Dd((p>>>0>4294967295|(p|0)==-1&h>>>0>4294967167)&1|0,0,c[o>>2]|0,c[o+4>>2]|0)|0;h=t;c[h>>2]=o;c[h+4>>2]=C;Ab(y,r);h=r;o=u;p=h+128|0;do{c[h>>2]=c[o>>2];h=h+4|0;o=o+4|0}while((h|0)<(p|0));h=(c[q>>2]|0)+-128|0;c[q>>2]=h;k=Cd(n|0,m|0,l|0,0)|0;if((n|0)==(l|0)&(m|0)==0){n=g;l=0;m=32;break}else{j=j+l|0;m=C;n=k}}if((z|0)==5){Id(h|0,j|0,n|0)|0;h=Dd(c[q>>2]|0,0,n|0,m|0)|0;c[q>>2]=h;n=g;l=0;m=32}while(1){k=256-h|0;h=y+96+h|0;if(!(l>>>0>0|(l|0)==0&m>>>0>k>>>0)){z=8;break}Id(h|0,n|0,k|0)|0;c[q>>2]=(c[q>>2]|0)+k;p=s;h=c[p>>2]|0;p=c[p+4>>2]|0;j=Dd(h|0,p|0,128,0)|0;o=s;c[o>>2]=j;c[o+4>>2]=C;o=t;o=Dd((p>>>0>4294967295|(p|0)==-1&h>>>0>4294967167)&1|0,0,c[o>>2]|0,c[o+4>>2]|0)|0;h=t;c[h>>2]=o;c[h+4>>2]=C;Ab(y,r);h=r;o=u;p=h+128|0;do{c[h>>2]=c[o>>2];h=h+4|0;o=o+4|0}while((h|0)<(p|0));h=(c[q>>2]|0)+-128|0;c[q>>2]=h;j=Cd(m|0,l|0,k|0,0)|0;if((m|0)==(k|0)&(l|0)==0)break;else{n=n+k|0;l=C;m=j}}if((z|0)==8){Id(h|0,n|0,m|0)|0;z=Dd(c[q>>2]|0,0,m|0,l|0)|0;c[q>>2]=z}zb(y,x,24)|0;if(f>>>0>0|(f|0)==0&e>>>0>4294967279){z=-1;i=A;return z|0}md(y,v,g);nb(w,32576,y,32592);rc(b+48|0,b+32|0,d,e,f,x,w)|0;z=0;i=A;return z|0}function lb(a,b,d,e,f,g){a=a|0;b=b|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0;y=i;v=i=i+63&-64;i=i+416|0;w=v;u=v+384|0;v=v+360|0;if(e>>>0<0|(e|0)==0&d>>>0<48){x=-1;i=y;return x|0}Fd(w|0,0,357)|0;p=w;c[p>>2]=-222443248;c[p+4>>2]=1779033703;p=w+8|0;c[p>>2]=-2067093701;c[p+4>>2]=-1150833019;p=w+16|0;c[p>>2]=-23791573;c[p+4>>2]=1013904242;p=w+24|0;c[p>>2]=1595750129;c[p+4>>2]=-1521486534;p=w+32|0;c[p>>2]=-1377402159;c[p+4>>2]=1359893119;p=w+40|0;c[p>>2]=725511199;c[p+4>>2]=-1694144372;p=w+48|0;c[p>>2]=-79577749;c[p+4>>2]=528734635;p=w+56|0;c[p>>2]=327033209;c[p+4>>2]=1541459225;p=w+352|0;q=w+96|0;r=w+64|0;s=w+72|0;t=w+224|0;k=b;h=0;m=0;n=32;while(1){l=256-h|0;h=w+96+h|0;if(!(m>>>0>0|(m|0)==0&n>>>0>l>>>0)){x=4;break}Id(h|0,k|0,l|0)|0;c[p>>2]=(c[p>>2]|0)+l;o=r;h=c[o>>2]|0;o=c[o+4>>2]|0;z=Dd(h|0,o|0,128,0)|0;j=r;c[j>>2]=z;c[j+4>>2]=C;j=s;j=Dd((o>>>0>4294967295|(o|0)==-1&h>>>0>4294967167)&1|0,0,c[j>>2]|0,c[j+4>>2]|0)|0;h=s;c[h>>2]=j;c[h+4>>2]=C;Ab(w,q);h=q;j=t;o=h+128|0;do{c[h>>2]=c[j>>2];h=h+4|0;j=j+4|0}while((h|0)<(o|0));h=(c[p>>2]|0)+-128|0;c[p>>2]=h;j=Cd(n|0,m|0,l|0,0)|0;if((n|0)==(l|0)&(m|0)==0){l=0;m=32;break}else{k=k+l|0;m=C;n=j}}if((x|0)==4){Id(h|0,k|0,n|0)|0;h=Dd(c[p>>2]|0,0,n|0,m|0)|0;c[p>>2]=h;l=0;m=32}while(1){k=256-h|0;h=w+96+h|0;if(!(l>>>0>0|(l|0)==0&m>>>0>k>>>0)){x=7;break}Id(h|0,f|0,k|0)|0;c[p>>2]=(c[p>>2]|0)+k;o=r;h=c[o>>2]|0;o=c[o+4>>2]|0;z=Dd(h|0,o|0,128,0)|0;j=r;c[j>>2]=z;c[j+4>>2]=C;j=s;j=Dd((o>>>0>4294967295|(o|0)==-1&h>>>0>4294967167)&1|0,0,c[j>>2]|0,c[j+4>>2]|0)|0;h=s;c[h>>2]=j;c[h+4>>2]=C;Ab(w,q);h=q;j=t;o=h+128|0;do{c[h>>2]=c[j>>2];h=h+4|0;j=j+4|0}while((h|0)<(o|0));h=(c[p>>2]|0)+-128|0;c[p>>2]=h;j=Cd(m|0,l|0,k|0,0)|0;if((m|0)==(k|0)&(l|0)==0)break;else{f=f+k|0;l=C;m=j}}if((x|0)==7){Id(h|0,f|0,m|0)|0;z=Dd(c[p>>2]|0,0,m|0,l|0)|0;c[p>>2]=z}zb(w,v,24)|0;if((d&-16|0)==32&(e|0)==0){z=-1;i=y;return z|0}x=Dd(d|0,e|0,-48,-1)|0;z=C;md(w,g,b);nb(u,32576,w,32592);z=tc(a,b+48|0,b+32|0,x,z,v,u)|0;i=y;return z|0}function mb(){return 48}function nb(b,c,e,f){b=b|0;c=c|0;e=e|0;f=f|0;var g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0;k=20;l=(d[f+1>>0]|0)<<8|(d[f>>0]|0)|(d[f+2>>0]|0)<<16|(d[f+3>>0]|0)<<24;m=(d[e+1>>0]|0)<<8|(d[e>>0]|0)|(d[e+2>>0]|0)<<16|(d[e+3>>0]|0)<<24;n=(d[f+9>>0]|0)<<8|(d[f+8>>0]|0)|(d[f+10>>0]|0)<<16|(d[f+11>>0]|0)<<24;o=(d[e+17>>0]|0)<<8|(d[e+16>>0]|0)|(d[e+18>>0]|0)<<16|(d[e+19>>0]|0)<<24;p=(d[e+21>>0]|0)<<8|(d[e+20>>0]|0)|(d[e+22>>0]|0)<<16|(d[e+23>>0]|0)<<24;q=(d[e+25>>0]|0)<<8|(d[e+24>>0]|0)|(d[e+26>>0]|0)<<16|(d[e+27>>0]|0)<<24;r=(d[e+29>>0]|0)<<8|(d[e+28>>0]|0)|(d[e+30>>0]|0)<<16|(d[e+31>>0]|0)<<24;s=(d[f+13>>0]|0)<<8|(d[f+12>>0]|0)|(d[f+14>>0]|0)<<16|(d[f+15>>0]|0)<<24;t=(d[e+5>>0]|0)<<8|(d[e+4>>0]|0)|(d[e+6>>0]|0)<<16|(d[e+7>>0]|0)<<24;u=(d[e+9>>0]|0)<<8|(d[e+8>>0]|0)|(d[e+10>>0]|0)<<16|(d[e+11>>0]|0)<<24;j=(d[e+13>>0]|0)<<8|(d[e+12>>0]|0)|(d[e+14>>0]|0)<<16|(d[e+15>>0]|0)<<24;f=(d[f+5>>0]|0)<<8|(d[f+4>>0]|0)|(d[f+6>>0]|0)<<16|(d[f+7>>0]|0)<<24;g=(d[c+1>>0]|0)<<8|(d[c>>0]|0)|(d[c+2>>0]|0)<<16|(d[c+3>>0]|0)<<24;h=(d[c+5>>0]|0)<<8|(d[c+4>>0]|0)|(d[c+6>>0]|0)<<16|(d[c+7>>0]|0)<<24;i=(d[c+9>>0]|0)<<8|(d[c+8>>0]|0)|(d[c+10>>0]|0)<<16|(d[c+11>>0]|0)<<24;e=(d[c+13>>0]|0)<<8|(d[c+12>>0]|0)|(d[c+14>>0]|0)<<16|(d[c+15>>0]|0)<<24;while(1){D=p+l|0;D=(D>>>25|D<<7)^j;A=D+l|0;A=(A>>>23|A<<9)^i;x=A+D|0;x=(x>>>19|x<<13)^p;G=x+A|0;G=(G>>>14|G<<18)^l;z=f+m|0;z=e^(z>>>25|z<<7);w=z+f|0;w=q^(w>>>23|w<<9);J=w+z|0;J=(J>>>19|J<<13)^m;C=J+w|0;C=(C>>>14|C<<18)^f;v=n+g|0;v=r^(v>>>25|v<<7);I=v+n|0;I=(I>>>23|I<<9)^t;F=I+v|0;F=(F>>>19|F<<13)^g;y=F+I|0;y=(y>>>14|y<<18)^n;H=s+o|0;H=(H>>>25|H<<7)^u;E=H+s|0;E=(E>>>23|E<<9)^h;B=E+H|0;B=(B>>>19|B<<13)^o;c=B+E|0;c=(c>>>14|c<<18)^s;K=G+H|0;m=(K>>>25|K<<7)^J;J=m+G|0;t=(J>>>23|J<<9)^I;I=t+m|0;u=(I>>>19|I<<13)^H;H=u+t|0;l=(H>>>14|H<<18)^G;G=C+D|0;g=(G>>>25|G<<7)^F;F=g+C|0;h=(F>>>23|F<<9)^E;E=h+g|0;j=(E>>>19|E<<13)^D;D=j+h|0;f=(D>>>14|D<<18)^C;C=y+z|0;o=(C>>>25|C<<7)^B;B=o+y|0;i=(B>>>23|B<<9)^A;A=i+o|0;e=(A>>>19|A<<13)^z;z=e+i|0;n=(z>>>14|z<<18)^y;y=c+v|0;p=(y>>>25|y<<7)^x;x=p+c|0;q=(x>>>23|x<<9)^w;w=q+p|0;r=(w>>>19|w<<13)^v;v=r+q|0;s=(v>>>14|v<<18)^c;if((k|0)<=2)break;else k=k+-2|0}a[b>>0]=l;a[b+1>>0]=l>>>8;a[b+2>>0]=l>>>16;a[b+3>>0]=l>>>24;a[b+4>>0]=f;a[b+5>>0]=f>>>8;a[b+6>>0]=f>>>16;a[b+7>>0]=f>>>24;a[b+8>>0]=n;a[b+9>>0]=n>>>8;a[b+10>>0]=n>>>16;a[b+11>>0]=n>>>24;a[b+12>>0]=s;a[b+13>>0]=s>>>8;a[b+14>>0]=s>>>16;a[b+15>>0]=s>>>24;a[b+16>>0]=g;a[b+17>>0]=g>>>8;a[b+18>>0]=g>>>16;a[b+19>>0]=g>>>24;a[b+20>>0]=h;a[b+21>>0]=h>>>8;a[b+22>>0]=h>>>16;a[b+23>>0]=h>>>24;a[b+24>>0]=i;a[b+25>>0]=i>>>8;a[b+26>>0]=i>>>16;a[b+27>>0]=i>>>24;a[b+28>>0]=e;a[b+29>>0]=e>>>8;a[b+30>>0]=e>>>16;a[b+31>>0]=e>>>24;return}function ob(b,c,e,f){b=b|0;c=c|0;e=e|0;f=f|0;var g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0;F=(d[f+1>>0]|0)<<8|(d[f>>0]|0)|(d[f+2>>0]|0)<<16|(d[f+3>>0]|0)<<24;G=(d[e+1>>0]|0)<<8|(d[e>>0]|0)|(d[e+2>>0]|0)<<16|(d[e+3>>0]|0)<<24;H=(d[e+5>>0]|0)<<8|(d[e+4>>0]|0)|(d[e+6>>0]|0)<<16|(d[e+7>>0]|0)<<24;I=(d[e+9>>0]|0)<<8|(d[e+8>>0]|0)|(d[e+10>>0]|0)<<16|(d[e+11>>0]|0)<<24;J=(d[e+13>>0]|0)<<8|(d[e+12>>0]|0)|(d[e+14>>0]|0)<<16|(d[e+15>>0]|0)<<24;B=(d[f+5>>0]|0)<<8|(d[f+4>>0]|0)|(d[f+6>>0]|0)<<16|(d[f+7>>0]|0)<<24;C=(d[c+1>>0]|0)<<8|(d[c>>0]|0)|(d[c+2>>0]|0)<<16|(d[c+3>>0]|0)<<24;D=(d[c+5>>0]|0)<<8|(d[c+4>>0]|0)|(d[c+6>>0]|0)<<16|(d[c+7>>0]|0)<<24;E=(d[c+9>>0]|0)<<8|(d[c+8>>0]|0)|(d[c+10>>0]|0)<<16|(d[c+11>>0]|0)<<24;w=(d[c+13>>0]|0)<<8|(d[c+12>>0]|0)|(d[c+14>>0]|0)<<16|(d[c+15>>0]|0)<<24;x=(d[f+9>>0]|0)<<8|(d[f+8>>0]|0)|(d[f+10>>0]|0)<<16|(d[f+11>>0]|0)<<24;y=(d[e+17>>0]|0)<<8|(d[e+16>>0]|0)|(d[e+18>>0]|0)<<16|(d[e+19>>0]|0)<<24;z=(d[e+21>>0]|0)<<8|(d[e+20>>0]|0)|(d[e+22>>0]|0)<<16|(d[e+23>>0]|0)<<24;A=(d[e+25>>0]|0)<<8|(d[e+24>>0]|0)|(d[e+26>>0]|0)<<16|(d[e+27>>0]|0)<<24;v=(d[e+29>>0]|0)<<8|(d[e+28>>0]|0)|(d[e+30>>0]|0)<<16|(d[e+31>>0]|0)<<24;c=(d[f+13>>0]|0)<<8|(d[f+12>>0]|0)|(d[f+14>>0]|0)<<16|(d[f+15>>0]|0)<<24;e=20;f=F;g=G;h=x;i=y;j=z;k=A;l=v;m=c;n=H;o=I;p=J;q=B;r=C;s=D;t=E;u=w;while(1){T=f+j|0;T=(T>>>25|T<<7)^p;Q=T+f|0;Q=(Q>>>23|Q<<9)^t;N=Q+T|0;N=(N>>>19|N<<13)^j;W=N+Q|0;W=(W>>>14|W<<18)^f;P=g+q|0;P=(P>>>25|P<<7)^u;M=P+q|0;M=(M>>>23|M<<9)^k;Z=M+P|0;Z=(Z>>>19|Z<<13)^g;S=Z+M|0;S=(S>>>14|S<<18)^q;L=r+h|0;L=(L>>>25|L<<7)^l;Y=L+h|0;Y=(Y>>>23|Y<<9)^n;V=Y+L|0;V=(V>>>19|V<<13)^r;O=V+Y|0;O=(O>>>14|O<<18)^h;X=i+m|0;X=o^(X>>>25|X<<7);U=X+m|0;U=(U>>>23|U<<9)^s;R=U+X|0;R=(R>>>19|R<<13)^i;K=R+U|0;K=(K>>>14|K<<18)^m;_=W+X|0;g=(_>>>25|_<<7)^Z;Z=g+W|0;n=(Z>>>23|Z<<9)^Y;Y=n+g|0;o=(Y>>>19|Y<<13)^X;X=o+n|0;f=(X>>>14|X<<18)^W;W=S+T|0;r=(W>>>25|W<<7)^V;V=r+S|0;s=(V>>>23|V<<9)^U;U=s+r|0;p=(U>>>19|U<<13)^T;T=p+s|0;q=(T>>>14|T<<18)^S;S=O+P|0;i=(S>>>25|S<<7)^R;R=i+O|0;t=(R>>>23|R<<9)^Q;Q=t+i|0;u=(Q>>>19|Q<<13)^P;P=u+t|0;h=(P>>>14|P<<18)^O;O=K+L|0;j=(O>>>25|O<<7)^N;N=j+K|0;k=(N>>>23|N<<9)^M;M=k+j|0;l=(M>>>19|M<<13)^L;L=l+k|0;m=(L>>>14|L<<18)^K;if((e|0)<=2)break;else e=e+-2|0}L=f+F|0;M=g+G|0;N=n+H|0;O=o+I|0;P=p+J|0;Q=q+B|0;R=r+C|0;S=s+D|0;T=t+E|0;U=u+w|0;V=h+x|0;W=i+y|0;X=j+z|0;Y=k+A|0;Z=l+v|0;_=m+c|0;a[b>>0]=L;a[b+1>>0]=L>>>8;a[b+2>>0]=L>>>16;a[b+3>>0]=L>>>24;a[b+4>>0]=M;a[b+5>>0]=M>>>8;a[b+6>>0]=M>>>16;a[b+7>>0]=M>>>24;a[b+8>>0]=N;a[b+9>>0]=N>>>8;a[b+10>>0]=N>>>16;a[b+11>>0]=N>>>24;a[b+12>>0]=O;a[b+13>>0]=O>>>8;a[b+14>>0]=O>>>16;a[b+15>>0]=O>>>24;a[b+16>>0]=P;a[b+17>>0]=P>>>8;a[b+18>>0]=P>>>16;a[b+19>>0]=P>>>24;a[b+20>>0]=Q;a[b+21>>0]=Q>>>8;a[b+22>>0]=Q>>>16;a[b+23>>0]=Q>>>24;a[b+24>>0]=R;a[b+25>>0]=R>>>8;a[b+26>>0]=R>>>16;a[b+27>>0]=R>>>24;a[b+28>>0]=S;a[b+29>>0]=S>>>8;a[b+30>>0]=S>>>16;a[b+31>>0]=S>>>24;a[b+32>>0]=T;a[b+33>>0]=T>>>8;a[b+34>>0]=T>>>16;a[b+35>>0]=T>>>24;a[b+36>>0]=U;a[b+37>>0]=U>>>8;a[b+38>>0]=U>>>16;a[b+39>>0]=U>>>24;a[b+40>>0]=V;a[b+41>>0]=V>>>8;a[b+42>>0]=V>>>16;a[b+43>>0]=V>>>24;a[b+44>>0]=W;a[b+45>>0]=W>>>8;a[b+46>>0]=W>>>16;a[b+47>>0]=W>>>24;a[b+48>>0]=X;a[b+49>>0]=X>>>8;a[b+50>>0]=X>>>16;a[b+51>>0]=X>>>24;a[b+52>>0]=Y;a[b+53>>0]=Y>>>8;a[b+54>>0]=Y>>>16;a[b+55>>0]=Y>>>24;a[b+56>>0]=Z;a[b+57>>0]=Z>>>8;a[b+58>>0]=Z>>>16;a[b+59>>0]=Z>>>24;a[b+60>>0]=_;a[b+61>>0]=_>>>8;a[b+62>>0]=_>>>16;a[b+63>>0]=_>>>24;return}function pb(){return 16}function qb(){return 64}function rb(){return 32}function sb(){return 16}function tb(){return 64}function ub(){return 32}function vb(){return 384}function wb(b,e,f,g,h,j,k){b=b|0;e=e|0;f=f|0;g=g|0;h=h|0;j=j|0;k=k|0;var l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0;v=i;t=i=i+63&-64;i=i+496|0;n=t+360|0;if((e+-1|0)>>>0>63|k>>>0>64){u=-1;i=v;return u|0}if(e>>>0>=256)za(32608,32628,18,32680);if(k>>>0>=256)za(32707,32628,19,32680);m=k&255;do if(!((b|0)==0|(f|0)==0&((g|0)!=0|(h|0)!=0)|((e&255)+-1&255)>63)?(l=m<<24>>24==0,!((m&255)>64|((j|0)!=0|l)^1)):0){if(l){Fd(t|0,0,357)|0;m=t;c[m>>2]=e&255^-222443256;c[m+4>>2]=1779033703;m=t+8|0;c[m>>2]=-2067093701;c[m+4>>2]=-1150833019;m=t+16|0;c[m>>2]=-23791573;c[m+4>>2]=1013904242;m=t+24|0;c[m>>2]=1595750129;c[m+4>>2]=-1521486534;m=t+32|0;c[m>>2]=-1377402159;c[m+4>>2]=1359893119;m=t+40|0;c[m>>2]=725511199;c[m+4>>2]=-1694144372;m=t+48|0;c[m>>2]=-79577749;c[m+4>>2]=528734635;m=t+56|0;c[m>>2]=327033209;c[m+4>>2]=1541459225;m=0}else{if((j|0)==0|(m+-1&255)>63){l=-1;break}l=k&255;Fd(t|0,0,357)|0;s=Hd(l|0,0,8)|0;o=t;c[o>>2]=(s|e&255)^-222443256;c[o+4>>2]=C^1779033703;o=t+8|0;c[o>>2]=-2067093701;c[o+4>>2]=-1150833019;o=t+16|0;c[o>>2]=-23791573;c[o+4>>2]=1013904242;o=t+24|0;c[o>>2]=1595750129;c[o+4>>2]=-1521486534;o=t+32|0;c[o>>2]=-1377402159;c[o+4>>2]=1359893119;o=t+40|0;c[o>>2]=725511199;c[o+4>>2]=-1694144372;o=t+48|0;c[o>>2]=-79577749;c[o+4>>2]=528734635;o=t+56|0;c[o>>2]=327033209;c[o+4>>2]=1541459225;Fd(n+l|0,0,(m<<24>>24<0?0:128-l|0)|0)|0;Id(n|0,j|0,l|0)|0;l=t+352|0;o=t+96|0;m=o+128|0;do{a[o>>0]=a[n>>0]|0;o=o+1|0;n=n+1|0}while((o|0)<(m|0));c[l>>2]=128;m=128}k=t+352|0;if(!((g|0)==0&(h|0)==0)){q=t+96|0;j=t+64|0;r=t+72|0;s=t+224|0;p=f;while(1){f=256-m|0;l=t+96+m|0;if(!(h>>>0>0|(h|0)==0&g>>>0>f>>>0)){u=16;break}Id(l|0,p|0,f|0)|0;c[k>>2]=(c[k>>2]|0)+f;m=j;o=c[m>>2]|0;m=c[m+4>>2]|0;l=Dd(o|0,m|0,128,0)|0;n=j;c[n>>2]=l;c[n+4>>2]=C;n=r;n=Dd((m>>>0>4294967295|(m|0)==-1&o>>>0>4294967167)&1|0,0,c[n>>2]|0,c[n+4>>2]|0)|0;o=r;c[o>>2]=n;c[o+4>>2]=C;Ab(t,q);o=q;n=s;m=o+128|0;do{c[o>>2]=c[n>>2];o=o+4|0;n=n+4|0}while((o|0)<(m|0));m=(c[k>>2]|0)+-128|0;c[k>>2]=m;l=Cd(g|0,h|0,f|0,0)|0;if((g|0)==(f|0)&(h|0)==0)break;else{p=p+f|0;h=C;g=l}}if((u|0)==16){Id(l|0,p|0,g|0)|0;m=Dd(c[k>>2]|0,0,g|0,h|0)|0;c[k>>2]=m}l=e&255;if(m>>>0>128){s=j;e=c[s>>2]|0;s=c[s+4>>2]|0;m=Dd(e|0,s|0,128,0)|0;n=j;c[n>>2]=m;c[n+4>>2]=C;n=t+72|0;m=n;m=Dd((s>>>0>4294967295|(s|0)==-1&e>>>0>4294967167)&1|0,0,c[m>>2]|0,c[m+4>>2]|0)|0;e=n;c[e>>2]=m;c[e+4>>2]=C;e=t+96|0;Ab(t,e);m=(c[k>>2]|0)+-128|0;c[k>>2]=m;Jd(e|0,t+224|0,m|0)|0;m=c[k>>2]|0}else u=19}else{j=t+64|0;l=e&255;u=19}if((u|0)==19)n=t+72|0;u=j;u=Dd(c[u>>2]|0,c[u+4>>2]|0,m|0,0)|0;s=C;r=j;c[r>>2]=u;c[r+4>>2]=s;r=n;e=r;r=r+4|0;r=Dd((s>>>0<0|(s|0)==0&u>>>0>>0)&1|0,0,d[e>>0]|d[e+1>>0]<<8|d[e+2>>0]<<16|d[e+3>>0]<<24|0,d[r>>0]|d[r+1>>0]<<8|d[r+2>>0]<<16|d[r+3>>0]<<24|0)|0;e=C;u=n;s=u;a[s>>0]=r;a[s+1>>0]=r>>8;a[s+2>>0]=r>>16;a[s+3>>0]=r>>24;u=u+4|0;a[u>>0]=e;a[u+1>>0]=e>>8;a[u+2>>0]=e>>16;a[u+3>>0]=e>>24;if(a[t+356>>0]|0){u=t+88|0;c[u>>2]=-1;c[u+4>>2]=-1}u=t+80|0;c[u>>2]=-1;c[u+4>>2]=-1;Fd(t+96+m|0,0,256-m|0)|0;Ab(t,t+96|0);Id(b|0,t|0,l|0)|0;l=0}else l=-1;while(0);u=l;i=v;return u|0}function xb(b,c,d,e){b=b|0;c=c|0;d=d|0;e=e|0;var f=0,g=0,h=0,j=0,k=0,l=0;j=i;f=i=i+63&-64;i=i+128|0;if(d>>>0>64|(e+-1|0)>>>0>63){b=-1;i=j;return b|0}if(e>>>0>=256)za(32608,32628,53,32727);if(d>>>0>=256)za(32707,32628,54,32727);h=e&255;if((c|0)==0|(d|0)==0){if((h+-1&255)>63){b=-1;i=j;return b|0}Fd(b|0,0,357)|0;c=e&255^-222443256;e=b;d=e;a[d>>0]=c;a[d+1>>0]=c>>8;a[d+2>>0]=c>>16;a[d+3>>0]=c>>24;e=e+4|0;a[e>>0]=103;a[e+1>>0]=230;a[e+2>>0]=9;a[e+3>>0]=106;e=b+8|0;d=e;a[d>>0]=-2067093701;a[d+1>>0]=-2067093701>>8;a[d+2>>0]=-2067093701>>16;a[d+3>>0]=-2067093701>>24;e=e+4|0;a[e>>0]=-1150833019;a[e+1>>0]=-1150833019>>8;a[e+2>>0]=-1150833019>>16;a[e+3>>0]=-1150833019>>24;e=b+16|0;d=e;a[d>>0]=-23791573;a[d+1>>0]=-23791573>>8;a[d+2>>0]=-23791573>>16;a[d+3>>0]=-23791573>>24;e=e+4|0;a[e>>0]=114;a[e+1>>0]=243;a[e+2>>0]=110;a[e+3>>0]=60;e=b+24|0;d=e;a[d>>0]=241;a[d+1>>0]=54;a[d+2>>0]=29;a[d+3>>0]=95;e=e+4|0;a[e>>0]=-1521486534;a[e+1>>0]=-1521486534>>8;a[e+2>>0]=-1521486534>>16;a[e+3>>0]=-1521486534>>24;e=b+32|0;d=e;a[d>>0]=-1377402159;a[d+1>>0]=-1377402159>>8;a[d+2>>0]=-1377402159>>16;a[d+3>>0]=-1377402159>>24;e=e+4|0;a[e>>0]=127;a[e+1>>0]=82;a[e+2>>0]=14;a[e+3>>0]=81;e=b+40|0;d=e;a[d>>0]=31;a[d+1>>0]=108;a[d+2>>0]=62;a[d+3>>0]=43;e=e+4|0;a[e>>0]=-1694144372;a[e+1>>0]=-1694144372>>8;a[e+2>>0]=-1694144372>>16;a[e+3>>0]=-1694144372>>24;e=b+48|0;d=e;a[d>>0]=-79577749;a[d+1>>0]=-79577749>>8;a[d+2>>0]=-79577749>>16;a[d+3>>0]=-79577749>>24;e=e+4|0;a[e>>0]=171;a[e+1>>0]=217;a[e+2>>0]=131;a[e+3>>0]=31;b=b+56|0;e=b;a[e>>0]=121;a[e+1>>0]=33;a[e+2>>0]=126;a[e+3>>0]=19;b=b+4|0;a[b>>0]=25;a[b+1>>0]=205;a[b+2>>0]=224;a[b+3>>0]=91;b=0;i=j;return b|0}else{g=d&255;if((h+-1&255)>63|(g+-1&255)>63){b=-1;i=j;return b|0}h=d&255;Fd(b|0,0,357)|0;l=Hd(h|0,0,8)|0;l=(l|e&255)^-222443256;d=C^1779033703;e=b;k=e;a[k>>0]=l;a[k+1>>0]=l>>8;a[k+2>>0]=l>>16;a[k+3>>0]=l>>24;e=e+4|0;a[e>>0]=d;a[e+1>>0]=d>>8;a[e+2>>0]=d>>16;a[e+3>>0]=d>>24;e=b+8|0;d=e;a[d>>0]=-2067093701;a[d+1>>0]=-2067093701>>8;a[d+2>>0]=-2067093701>>16;a[d+3>>0]=-2067093701>>24;e=e+4|0;a[e>>0]=-1150833019;a[e+1>>0]=-1150833019>>8;a[e+2>>0]=-1150833019>>16;a[e+3>>0]=-1150833019>>24;e=b+16|0;d=e;a[d>>0]=-23791573;a[d+1>>0]=-23791573>>8;a[d+2>>0]=-23791573>>16;a[d+3>>0]=-23791573>>24;e=e+4|0;a[e>>0]=114;a[e+1>>0]=243;a[e+2>>0]=110;a[e+3>>0]=60;e=b+24|0;d=e;a[d>>0]=241;a[d+1>>0]=54;a[d+2>>0]=29;a[d+3>>0]=95;e=e+4|0;a[e>>0]=-1521486534;a[e+1>>0]=-1521486534>>8;a[e+2>>0]=-1521486534>>16;a[e+3>>0]=-1521486534>>24;e=b+32|0;d=e;a[d>>0]=-1377402159;a[d+1>>0]=-1377402159>>8;a[d+2>>0]=-1377402159>>16;a[d+3>>0]=-1377402159>>24;e=e+4|0;a[e>>0]=127;a[e+1>>0]=82;a[e+2>>0]=14;a[e+3>>0]=81;e=b+40|0;d=e;a[d>>0]=31;a[d+1>>0]=108;a[d+2>>0]=62;a[d+3>>0]=43;e=e+4|0;a[e>>0]=-1694144372;a[e+1>>0]=-1694144372>>8;a[e+2>>0]=-1694144372>>16;a[e+3>>0]=-1694144372>>24;e=b+48|0;d=e;a[d>>0]=-79577749;a[d+1>>0]=-79577749>>8;a[d+2>>0]=-79577749>>16;a[d+3>>0]=-79577749>>24;e=e+4|0;a[e>>0]=171;a[e+1>>0]=217;a[e+2>>0]=131;a[e+3>>0]=31;e=b+56|0;d=e;a[d>>0]=121;a[d+1>>0]=33;a[d+2>>0]=126;a[d+3>>0]=19;e=e+4|0;a[e>>0]=25;a[e+1>>0]=205;a[e+2>>0]=224;a[e+3>>0]=91;Fd(f+h|0,0,(g<<24>>24<0?0:128-h|0)|0)|0;Id(f|0,c|0,h|0)|0;c=b+352|0;h=b+96|0;g=h+128|0;do{a[h>>0]=a[f>>0]|0;h=h+1|0;f=f+1|0}while((h|0)<(g|0));a[c>>0]=128;a[c+1>>0]=0;a[c+2>>0]=0;a[c+3>>0]=0;l=0;i=j;return l|0}return 0}function yb(b,c,e,f){b=b|0;c=c|0;e=e|0;f=f|0;var g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0;if((e|0)==0&(f|0)==0)return 0;k=b+352|0;l=b+96|0;m=b+64|0;n=b+72|0;o=b+224|0;g=d[k>>0]|d[k+1>>0]<<8|d[k+2>>0]<<16|d[k+3>>0]<<24;j=e;while(1){i=256-g|0;e=b+96+g|0;if(!(f>>>0>0|(f|0)==0&j>>>0>i>>>0))break;Id(e|0,c|0,i|0)|0;h=(d[k>>0]|d[k+1>>0]<<8|d[k+2>>0]<<16|d[k+3>>0]<<24)+i|0;a[k>>0]=h;a[k+1>>0]=h>>8;a[k+2>>0]=h>>16;a[k+3>>0]=h>>24;h=m;e=h;e=d[e>>0]|d[e+1>>0]<<8|d[e+2>>0]<<16|d[e+3>>0]<<24;h=h+4|0;h=d[h>>0]|d[h+1>>0]<<8|d[h+2>>0]<<16|d[h+3>>0]<<24;s=Dd(e|0,h|0,128,0)|0;g=C;q=m;r=q;a[r>>0]=s;a[r+1>>0]=s>>8;a[r+2>>0]=s>>16;a[r+3>>0]=s>>24;q=q+4|0;a[q>>0]=g;a[q+1>>0]=g>>8;a[q+2>>0]=g>>16;a[q+3>>0]=g>>24;q=n;g=q;q=q+4|0;q=Dd((h>>>0>4294967295|(h|0)==-1&e>>>0>4294967167)&1|0,0,d[g>>0]|d[g+1>>0]<<8|d[g+2>>0]<<16|d[g+3>>0]<<24|0,d[q>>0]|d[q+1>>0]<<8|d[q+2>>0]<<16|d[q+3>>0]<<24|0)|0;g=C;e=n;h=e;a[h>>0]=q;a[h+1>>0]=q>>8;a[h+2>>0]=q>>16;a[h+3>>0]=q>>24;e=e+4|0;a[e>>0]=g;a[e+1>>0]=g>>8;a[e+2>>0]=g>>16;a[e+3>>0]=g>>24;Ab(b,l);e=l;g=o;h=e+128|0;do{a[e>>0]=a[g>>0]|0;e=e+1|0;g=g+1|0}while((e|0)<(h|0));g=(d[k>>0]|d[k+1>>0]<<8|d[k+2>>0]<<16|d[k+3>>0]<<24)+-128|0;a[k>>0]=g;a[k+1>>0]=g>>8;a[k+2>>0]=g>>16;a[k+3>>0]=g>>24;e=Cd(j|0,f|0,i|0,0)|0;if((j|0)==(i|0)&(f|0)==0){p=6;break}else{c=c+i|0;f=C;j=e}}if((p|0)==6)return 0;Id(e|0,c|0,j|0)|0;s=Dd(d[k>>0]|d[k+1>>0]<<8|d[k+2>>0]<<16|d[k+3>>0]<<24|0,0,j|0,f|0)|0;a[k>>0]=s;a[k+1>>0]=s>>8;a[k+2>>0]=s>>16;a[k+3>>0]=s>>24;return 0}function zb(b,c,e){b=b|0;c=c|0;e=e|0;var f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0;if(e>>>0>=256)za(32608,32628,106,32759);f=e&255;if(!(f<<24>>24)){b=-1;return b|0}if((f&255)>64){b=-1;return b|0}g=b+352|0;f=d[g>>0]|d[g+1>>0]<<8|d[g+2>>0]<<16|d[g+3>>0]<<24;i=b+64|0;if(f>>>0>128){k=i;j=k;j=d[j>>0]|d[j+1>>0]<<8|d[j+2>>0]<<16|d[j+3>>0]<<24;k=k+4|0;k=d[k>>0]|d[k+1>>0]<<8|d[k+2>>0]<<16|d[k+3>>0]<<24;m=Dd(j|0,k|0,128,0)|0;l=C;h=i;f=h;a[f>>0]=m;a[f+1>>0]=m>>8;a[f+2>>0]=m>>16;a[f+3>>0]=m>>24;h=h+4|0;a[h>>0]=l;a[h+1>>0]=l>>8;a[h+2>>0]=l>>16;a[h+3>>0]=l>>24;h=b+72|0;l=h;f=l;l=l+4|0;l=Dd((k>>>0>4294967295|(k|0)==-1&j>>>0>4294967167)&1|0,0,d[f>>0]|d[f+1>>0]<<8|d[f+2>>0]<<16|d[f+3>>0]<<24|0,d[l>>0]|d[l+1>>0]<<8|d[l+2>>0]<<16|d[l+3>>0]<<24|0)|0;f=C;j=h;k=j;a[k>>0]=l;a[k+1>>0]=l>>8;a[k+2>>0]=l>>16;a[k+3>>0]=l>>24;j=j+4|0;a[j>>0]=f;a[j+1>>0]=f>>8;a[j+2>>0]=f>>16;a[j+3>>0]=f>>24;j=b+96|0;Ab(b,j);f=(d[g>>0]|d[g+1>>0]<<8|d[g+2>>0]<<16|d[g+3>>0]<<24)+-128|0;a[g>>0]=f;a[g+1>>0]=f>>8;a[g+2>>0]=f>>16;a[g+3>>0]=f>>24;Jd(j|0,b+224|0,f|0)|0;f=d[g>>0]|d[g+1>>0]<<8|d[g+2>>0]<<16|d[g+3>>0]<<24}else h=b+72|0;m=i;k=m;m=m+4|0;m=Dd(d[k>>0]|d[k+1>>0]<<8|d[k+2>>0]<<16|d[k+3>>0]<<24|0,d[m>>0]|d[m+1>>0]<<8|d[m+2>>0]<<16|d[m+3>>0]<<24|0,f|0,0)|0;k=C;j=i;l=j;a[l>>0]=m;a[l+1>>0]=m>>8;a[l+2>>0]=m>>16;a[l+3>>0]=m>>24;j=j+4|0;a[j>>0]=k;a[j+1>>0]=k>>8;a[j+2>>0]=k>>16;a[j+3>>0]=k>>24;j=h;l=j;j=j+4|0;j=Dd((k>>>0<0|(k|0)==0&m>>>0>>0)&1|0,0,d[l>>0]|d[l+1>>0]<<8|d[l+2>>0]<<16|d[l+3>>0]<<24|0,d[j>>0]|d[j+1>>0]<<8|d[j+2>>0]<<16|d[j+3>>0]<<24|0)|0;l=C;m=h;k=m;a[k>>0]=j;a[k+1>>0]=j>>8;a[k+2>>0]=j>>16;a[k+3>>0]=j>>24;m=m+4|0;a[m>>0]=l;a[m+1>>0]=l>>8;a[m+2>>0]=l>>16;a[m+3>>0]=l>>24;if(a[b+356>>0]|0){m=b+88|0;l=m;a[l>>0]=-1;a[l+1>>0]=-1>>8;a[l+2>>0]=-1>>16;a[l+3>>0]=-1>>24;m=m+4|0;a[m>>0]=-1;a[m+1>>0]=-1>>8;a[m+2>>0]=-1>>16;a[m+3>>0]=-1>>24}m=b+80|0;l=m;a[l>>0]=-1;a[l+1>>0]=-1>>8;a[l+2>>0]=-1>>16;a[l+3>>0]=-1>>24;m=m+4|0;a[m>>0]=-1;a[m+1>>0]=-1>>8;a[m+2>>0]=-1>>16;a[m+3>>0]=-1>>24;Fd(b+96+f|0,0,256-f|0)|0;Ab(b,b+96|0);Id(c|0,b|0,e&255|0)|0;m=0;return m|0}function Ab(b,c){b=b|0;c=c|0;var e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0;P=c;R=P;R=d[R>>0]|d[R+1>>0]<<8|d[R+2>>0]<<16|d[R+3>>0]<<24;P=P+4|0;P=d[P>>0]|d[P+1>>0]<<8|d[P+2>>0]<<16|d[P+3>>0]<<24;U=c+8|0;W=U;W=d[W>>0]|d[W+1>>0]<<8|d[W+2>>0]<<16|d[W+3>>0]<<24;U=U+4|0;U=d[U>>0]|d[U+1>>0]<<8|d[U+2>>0]<<16|d[U+3>>0]<<24;x=c+16|0;t=x;t=d[t>>0]|d[t+1>>0]<<8|d[t+2>>0]<<16|d[t+3>>0]<<24;x=x+4|0;x=d[x>>0]|d[x+1>>0]<<8|d[x+2>>0]<<16|d[x+3>>0]<<24;l=c+24|0;h=l;h=d[h>>0]|d[h+1>>0]<<8|d[h+2>>0]<<16|d[h+3>>0]<<24;l=l+4|0;l=d[l>>0]|d[l+1>>0]<<8|d[l+2>>0]<<16|d[l+3>>0]<<24;$=c+32|0;p=$;p=d[p>>0]|d[p+1>>0]<<8|d[p+2>>0]<<16|d[p+3>>0]<<24;$=$+4|0;$=d[$>>0]|d[$+1>>0]<<8|d[$+2>>0]<<16|d[$+3>>0]<<24;F=c+40|0;H=F;H=d[H>>0]|d[H+1>>0]<<8|d[H+2>>0]<<16|d[H+3>>0]<<24;F=F+4|0;F=d[F>>0]|d[F+1>>0]<<8|d[F+2>>0]<<16|d[F+3>>0]<<24;u=c+48|0;s=u;s=d[s>>0]|d[s+1>>0]<<8|d[s+2>>0]<<16|d[s+3>>0]<<24;u=u+4|0;u=d[u>>0]|d[u+1>>0]<<8|d[u+2>>0]<<16|d[u+3>>0]<<24;r=c+56|0;n=r;n=d[n>>0]|d[n+1>>0]<<8|d[n+2>>0]<<16|d[n+3>>0]<<24;r=r+4|0;r=d[r>>0]|d[r+1>>0]<<8|d[r+2>>0]<<16|d[r+3>>0]<<24;i=c+64|0;g=i;g=d[g>>0]|d[g+1>>0]<<8|d[g+2>>0]<<16|d[g+3>>0]<<24;i=i+4|0;i=d[i>>0]|d[i+1>>0]<<8|d[i+2>>0]<<16|d[i+3>>0]<<24;Y=c+72|0;j=Y;j=d[j>>0]|d[j+1>>0]<<8|d[j+2>>0]<<16|d[j+3>>0]<<24;Y=Y+4|0;Y=d[Y>>0]|d[Y+1>>0]<<8|d[Y+2>>0]<<16|d[Y+3>>0]<<24;o=c+80|0;m=o;m=d[m>>0]|d[m+1>>0]<<8|d[m+2>>0]<<16|d[m+3>>0]<<24;o=o+4|0;o=d[o>>0]|d[o+1>>0]<<8|d[o+2>>0]<<16|d[o+3>>0]<<24;K=c+88|0;M=K;M=d[M>>0]|d[M+1>>0]<<8|d[M+2>>0]<<16|d[M+3>>0]<<24;K=K+4|0;K=d[K>>0]|d[K+1>>0]<<8|d[K+2>>0]<<16|d[K+3>>0]<<24;f=c+96|0;e=f;e=d[e>>0]|d[e+1>>0]<<8|d[e+2>>0]<<16|d[e+3>>0]<<24;f=f+4|0;f=d[f>>0]|d[f+1>>0]<<8|d[f+2>>0]<<16|d[f+3>>0]<<24;S=c+104|0;B=S;B=d[B>>0]|d[B+1>>0]<<8|d[B+2>>0]<<16|d[B+3>>0]<<24;S=S+4|0;S=d[S>>0]|d[S+1>>0]<<8|d[S+2>>0]<<16|d[S+3>>0]<<24;sa=c+112|0;ra=sa;ra=d[ra>>0]|d[ra+1>>0]<<8|d[ra+2>>0]<<16|d[ra+3>>0]<<24;sa=sa+4|0;sa=d[sa>>0]|d[sa+1>>0]<<8|d[sa+2>>0]<<16|d[sa+3>>0]<<24;A=c+120|0;y=A;y=d[y>>0]|d[y+1>>0]<<8|d[y+2>>0]<<16|d[y+3>>0]<<24;A=A+4|0;A=d[A>>0]|d[A+1>>0]<<8|d[A+2>>0]<<16|d[A+3>>0]<<24;ca=b;v=ca;ca=ca+4|0;N=b+8|0;oa=N;na=oa;na=d[na>>0]|d[na+1>>0]<<8|d[na+2>>0]<<16|d[na+3>>0]<<24;oa=oa+4|0;oa=d[oa>>0]|d[oa+1>>0]<<8|d[oa+2>>0]<<16|d[oa+3>>0]<<24;I=b+16|0;ka=I;ja=ka;ja=d[ja>>0]|d[ja+1>>0]<<8|d[ja+2>>0]<<16|d[ja+3>>0]<<24;ka=ka+4|0;ka=d[ka>>0]|d[ka+1>>0]<<8|d[ka+2>>0]<<16|d[ka+3>>0]<<24;D=b+24|0;ga=D;fa=ga;fa=d[fa>>0]|d[fa+1>>0]<<8|d[fa+2>>0]<<16|d[fa+3>>0]<<24;ga=ga+4|0;ga=d[ga>>0]|d[ga+1>>0]<<8|d[ga+2>>0]<<16|d[ga+3>>0]<<24;w=b+32|0;ma=w;la=ma;la=d[la>>0]|d[la+1>>0]<<8|d[la+2>>0]<<16|d[la+3>>0]<<24;ma=ma+4|0;ma=d[ma>>0]|d[ma+1>>0]<<8|d[ma+2>>0]<<16|d[ma+3>>0]<<24;q=b+40|0;ia=q;ha=ia;ha=d[ha>>0]|d[ha+1>>0]<<8|d[ha+2>>0]<<16|d[ha+3>>0]<<24;ia=ia+4|0;ia=d[ia>>0]|d[ia+1>>0]<<8|d[ia+2>>0]<<16|d[ia+3>>0]<<24;k=b+48|0;ua=k;ta=ua;ta=d[ta>>0]|d[ta+1>>0]<<8|d[ta+2>>0]<<16|d[ta+3>>0]<<24;ua=ua+4|0;ua=d[ua>>0]|d[ua+1>>0]<<8|d[ua+2>>0]<<16|d[ua+3>>0]<<24;c=b+56|0;qa=c;pa=qa;pa=d[pa>>0]|d[pa+1>>0]<<8|d[pa+2>>0]<<16|d[pa+3>>0]<<24;qa=qa+4|0;qa=d[qa>>0]|d[qa+1>>0]<<8|d[qa+2>>0]<<16|d[qa+3>>0]<<24;ba=b+64|0;aa=ba;ba=ba+4|0;aa=(d[aa>>0]|d[aa+1>>0]<<8|d[aa+2>>0]<<16|d[aa+3>>0]<<24)^-1377402159;ba=(d[ba>>0]|d[ba+1>>0]<<8|d[ba+2>>0]<<16|d[ba+3>>0]<<24)^1359893119;_=b+72|0;Z=_;_=_+4|0;Z=(d[Z>>0]|d[Z+1>>0]<<8|d[Z+2>>0]<<16|d[Z+3>>0]<<24)^725511199;_=(d[_>>0]|d[_+1>>0]<<8|d[_+2>>0]<<16|d[_+3>>0]<<24)^-1694144372;X=b+80|0;V=X;X=X+4|0;V=(d[V>>0]|d[V+1>>0]<<8|d[V+2>>0]<<16|d[V+3>>0]<<24)^-79577749;X=(d[X>>0]|d[X+1>>0]<<8|d[X+2>>0]<<16|d[X+3>>0]<<24)^528734635;ea=b+88|0;da=ea;ea=ea+4|0;da=(d[da>>0]|d[da+1>>0]<<8|d[da+2>>0]<<16|d[da+3>>0]<<24)^327033209;ea=(d[ea>>0]|d[ea+1>>0]<<8|d[ea+2>>0]<<16|d[ea+3>>0]<<24)^1541459225;ca=Dd(la|0,ma|0,d[v>>0]|d[v+1>>0]<<8|d[v+2>>0]<<16|d[v+3>>0]<<24|0,d[ca>>0]|d[ca+1>>0]<<8|d[ca+2>>0]<<16|d[ca+3>>0]<<24|0)|0;ca=Dd(ca|0,C|0,R|0,P|0)|0;v=C;aa=aa^ca;ba=ba^v;Q=Dd(ba|0,aa|0,-205731576,1779033703)|0;T=C;la=Q^la;ma=T^ma;O=Gd(la|0,ma|0,24)|0;L=C;ma=Hd(la|0,ma|0,40)|0;O=ma|O;L=C|L;v=Dd(W|0,U|0,ca|0,v|0)|0;v=Dd(v|0,C|0,O|0,L|0)|0;ca=C;ba=v^ba;aa=ca^aa;ma=Gd(ba|0,aa|0,16)|0;la=C;aa=Hd(ba|0,aa|0,48)|0;ma=aa|ma;la=C|la;T=Dd(ma|0,la|0,Q|0,T|0)|0;Q=C;O=T^O;L=Q^L;aa=Gd(O|0,L|0,63)|0;ba=C;L=Hd(O|0,L|0,1)|0;aa=L|aa;ba=C|ba;oa=Dd(ha|0,ia|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,t|0,x|0)|0;na=C;Z=Z^oa;_=_^na;L=Dd(_|0,Z|0,-2067093701,-1150833019)|0;O=C;ha=L^ha;ia=O^ia;J=Gd(ha|0,ia|0,24)|0;G=C;ia=Hd(ha|0,ia|0,40)|0;J=ia|J;G=C|G;na=Dd(h|0,l|0,oa|0,na|0)|0;na=Dd(na|0,C|0,J|0,G|0)|0;oa=C;_=na^_;Z=oa^Z;ia=Gd(_|0,Z|0,16)|0;ha=C;Z=Hd(_|0,Z|0,48)|0;ia=Z|ia;ha=C|ha;O=Dd(ia|0,ha|0,L|0,O|0)|0;L=C;J=O^J;G=L^G;Z=Gd(J|0,G|0,63)|0;_=C;G=Hd(J|0,G|0,1)|0;Z=G|Z;_=C|_;ka=Dd(ta|0,ua|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,p|0,$|0)|0;ja=C;V=V^ka;X=X^ja;G=Dd(X|0,V|0,-23791573,1013904242)|0;J=C;ta=G^ta;ua=J^ua;E=Gd(ta|0,ua|0,24)|0;z=C;ua=Hd(ta|0,ua|0,40)|0;E=ua|E;z=C|z;ja=Dd(H|0,F|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,E|0,z|0)|0;ka=C;X=ja^X;V=ka^V;ua=Gd(X|0,V|0,16)|0;ta=C;V=Hd(X|0,V|0,48)|0;ua=V|ua;ta=C|ta;J=Dd(ua|0,ta|0,G|0,J|0)|0;G=C;E=J^E;z=G^z;V=Gd(E|0,z|0,63)|0;X=C;z=Hd(E|0,z|0,1)|0;V=z|V;X=C|X;ga=Dd(pa|0,qa|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,s|0,u|0)|0;fa=C;da=da^ga;ea=ea^fa;z=Dd(ea|0,da|0,1595750129,-1521486534)|0;E=C;pa=z^pa;qa=E^qa;wa=Gd(pa|0,qa|0,24)|0;va=C;qa=Hd(pa|0,qa|0,40)|0;wa=qa|wa;va=C|va;fa=Dd(n|0,r|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ea=fa^ea;da=ga^da;qa=Gd(ea|0,da|0,16)|0;pa=C;da=Hd(ea|0,da|0,48)|0;qa=da|qa;pa=C|pa;E=Dd(qa|0,pa|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;da=Gd(wa|0,va|0,63)|0;ea=C;va=Hd(wa|0,va|0,1)|0;da=va|da;ea=C|ea;ca=Dd(Z|0,_|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,g|0,i|0)|0;v=C;qa=qa^ca;pa=pa^v;G=Dd(pa|0,qa|0,J|0,G|0)|0;J=C;Z=G^Z;_=J^_;va=Gd(Z|0,_|0,24)|0;wa=C;_=Hd(Z|0,_|0,40)|0;va=_|va;wa=C|wa;v=Dd(j|0,Y|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;pa=v^pa;qa=ca^qa;_=Gd(pa|0,qa|0,16)|0;Z=C;qa=Hd(pa|0,qa|0,48)|0;_=qa|_;Z=C|Z;J=Dd(_|0,Z|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;qa=Gd(va|0,wa|0,63)|0;pa=C;wa=Hd(va|0,wa|0,1)|0;qa=wa|qa;pa=C|pa;oa=Dd(V|0,X|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,m|0,o|0)|0;na=C;ma=ma^oa;la=la^na;z=Dd(la|0,ma|0,E|0,z|0)|0;E=C;V=z^V;X=E^X;wa=Gd(V|0,X|0,24)|0;va=C;X=Hd(V|0,X|0,40)|0;wa=X|wa;va=C|va;na=Dd(M|0,K|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;la=na^la;ma=oa^ma;X=Gd(la|0,ma|0,16)|0;V=C;ma=Hd(la|0,ma|0,48)|0;X=ma|X;V=C|V;E=Dd(X|0,V|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ma=Gd(wa|0,va|0,63)|0;la=C;va=Hd(wa|0,va|0,1)|0;ma=va|ma;la=C|la;ka=Dd(da|0,ea|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,e|0,f|0)|0;ja=C;ia=ia^ka;ha=ha^ja;Q=Dd(ha|0,ia|0,T|0,Q|0)|0;T=C;da=Q^da;ea=T^ea;va=Gd(da|0,ea|0,24)|0;wa=C;ea=Hd(da|0,ea|0,40)|0;va=ea|va;wa=C|wa;ja=Dd(B|0,S|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;ha=ja^ha;ia=ka^ia;ea=Gd(ha|0,ia|0,16)|0;da=C;ia=Hd(ha|0,ia|0,48)|0;ea=ia|ea;da=C|da;T=Dd(ea|0,da|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;ia=Gd(va|0,wa|0,63)|0;ha=C;wa=Hd(va|0,wa|0,1)|0;ia=wa|ia;ha=C|ha;ga=Dd(aa|0,ba|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,ra|0,sa|0)|0;fa=C;ua=ua^ga;ta=ta^fa;L=Dd(ta|0,ua|0,O|0,L|0)|0;O=C;aa=L^aa;ba=O^ba;wa=Gd(aa|0,ba|0,24)|0;va=C;ba=Hd(aa|0,ba|0,40)|0;wa=ba|wa;va=C|va;fa=Dd(y|0,A|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ta=fa^ta;ua=ga^ua;ba=Gd(ta|0,ua|0,16)|0;aa=C;ua=Hd(ta|0,ua|0,48)|0;ba=ua|ba;aa=C|aa;O=Dd(ba|0,aa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ua=Gd(wa|0,va|0,63)|0;ta=C;va=Hd(wa|0,va|0,1)|0;ua=va|ua;ta=C|ta;ca=Dd(ra|0,sa|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,ua|0,ta|0)|0;v=C;X=ca^X;V=v^V;Q=Dd(V|0,X|0,T|0,Q|0)|0;T=C;ua=Q^ua;ta=T^ta;va=Gd(ua|0,ta|0,24)|0;wa=C;ta=Hd(ua|0,ta|0,40)|0;va=ta|va;wa=C|wa;v=Dd(m|0,o|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;V=v^V;X=ca^X;ta=Gd(V|0,X|0,16)|0;ua=C;X=Hd(V|0,X|0,48)|0;ta=X|ta;ua=C|ua;T=Dd(ta|0,ua|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;X=Gd(va|0,wa|0,63)|0;V=C;wa=Hd(va|0,wa|0,1)|0;X=wa|X;V=C|V;oa=Dd(qa|0,pa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,p|0,$|0)|0;na=C;ea=ea^oa;da=da^na;L=Dd(da|0,ea|0,O|0,L|0)|0;O=C;qa=L^qa;pa=O^pa;wa=Gd(qa|0,pa|0,24)|0;va=C;pa=Hd(qa|0,pa|0,40)|0;wa=pa|wa;va=C|va;na=Dd(g|0,i|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;da=na^da;ea=oa^ea;pa=Gd(da|0,ea|0,16)|0;qa=C;ea=Hd(da|0,ea|0,48)|0;pa=ea|pa;qa=C|qa;O=Dd(pa|0,qa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ea=Gd(wa|0,va|0,63)|0;da=C;va=Hd(wa|0,va|0,1)|0;ea=va|ea;da=C|da;ka=Dd(ma|0,la|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,j|0,Y|0)|0;ja=C;ba=ba^ka;aa=aa^ja;G=Dd(aa|0,ba|0,J|0,G|0)|0;J=C;ma=G^ma;la=J^la;va=Gd(ma|0,la|0,24)|0;wa=C;la=Hd(ma|0,la|0,40)|0;va=la|va;wa=C|wa;ja=Dd(y|0,A|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;aa=ja^aa;ba=ka^ba;la=Gd(aa|0,ba|0,16)|0;ma=C;ba=Hd(aa|0,ba|0,48)|0;la=ba|la;ma=C|ma;J=Dd(la|0,ma|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ba=Gd(va|0,wa|0,63)|0;aa=C;wa=Hd(va|0,wa|0,1)|0;ba=wa|ba;aa=C|aa;ga=Dd(ia|0,ha|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,B|0,S|0)|0;fa=C;_=_^ga;Z=Z^fa;z=Dd(Z|0,_|0,E|0,z|0)|0;E=C;ia=z^ia;ha=E^ha;wa=Gd(ia|0,ha|0,24)|0;va=C;ha=Hd(ia|0,ha|0,40)|0;wa=ha|wa;va=C|va;fa=Dd(s|0,u|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;Z=fa^Z;_=ga^_;ha=Gd(Z|0,_|0,16)|0;ia=C;_=Hd(Z|0,_|0,48)|0;ha=_|ha;ia=C|ia;E=Dd(ha|0,ia|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;_=Gd(wa|0,va|0,63)|0;Z=C;va=Hd(wa|0,va|0,1)|0;_=va|_;Z=C|Z;ca=Dd(ea|0,da|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,W|0,U|0)|0;v=C;ha=ha^ca;ia=ia^v;G=Dd(ia|0,ha|0,J|0,G|0)|0;J=C;ea=G^ea;da=J^da;va=Gd(ea|0,da|0,24)|0;wa=C;da=Hd(ea|0,da|0,40)|0;va=da|va;wa=C|wa;v=Dd(e|0,f|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ia=v^ia;ha=ca^ha;da=Gd(ia|0,ha|0,16)|0;ea=C;ha=Hd(ia|0,ha|0,48)|0;da=ha|da;ea=C|ea;J=Dd(da|0,ea|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ha=Gd(va|0,wa|0,63)|0;ia=C;wa=Hd(va|0,wa|0,1)|0;ha=wa|ha;ia=C|ia;oa=Dd(ba|0,aa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,R|0,P|0)|0;na=C;ta=ta^oa;ua=ua^na;z=Dd(ua|0,ta|0,E|0,z|0)|0;E=C;ba=z^ba;aa=E^aa;wa=Gd(ba|0,aa|0,24)|0;va=C;aa=Hd(ba|0,aa|0,40)|0;wa=aa|wa;va=C|va;na=Dd(t|0,x|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;ua=na^ua;ta=oa^ta;aa=Gd(ua|0,ta|0,16)|0;ba=C;ta=Hd(ua|0,ta|0,48)|0;aa=ta|aa;ba=C|ba;E=Dd(aa|0,ba|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ta=Gd(wa|0,va|0,63)|0;ua=C;va=Hd(wa|0,va|0,1)|0;ta=va|ta;ua=C|ua;ka=Dd(_|0,Z|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,M|0,K|0)|0;ja=C;pa=pa^ka;qa=qa^ja;Q=Dd(qa|0,pa|0,T|0,Q|0)|0;T=C;_=Q^_;Z=T^Z;va=Gd(_|0,Z|0,24)|0;wa=C;Z=Hd(_|0,Z|0,40)|0;va=Z|va;wa=C|wa;ja=Dd(n|0,r|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;qa=ja^qa;pa=ka^pa;Z=Gd(qa|0,pa|0,16)|0;_=C;pa=Hd(qa|0,pa|0,48)|0;Z=pa|Z;_=C|_;T=Dd(Z|0,_|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;pa=Gd(va|0,wa|0,63)|0;qa=C;wa=Hd(va|0,wa|0,1)|0;pa=wa|pa;qa=C|qa;ga=Dd(X|0,V|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,H|0,F|0)|0;fa=C;la=la^ga;ma=ma^fa;L=Dd(ma|0,la|0,O|0,L|0)|0;O=C;X=L^X;V=O^V;wa=Gd(X|0,V|0,24)|0;va=C;V=Hd(X|0,V|0,40)|0;wa=V|wa;va=C|va;fa=Dd(h|0,l|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ma=fa^ma;la=ga^la;V=Gd(ma|0,la|0,16)|0;X=C;la=Hd(ma|0,la|0,48)|0;V=la|V;X=C|X;O=Dd(V|0,X|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;la=Gd(wa|0,va|0,63)|0;ma=C;va=Hd(wa|0,va|0,1)|0;la=va|la;ma=C|ma;ca=Dd(M|0,K|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,la|0,ma|0)|0;v=C;aa=ca^aa;ba=v^ba;Q=Dd(ba|0,aa|0,T|0,Q|0)|0;T=C;la=Q^la;ma=T^ma;va=Gd(la|0,ma|0,24)|0;wa=C;ma=Hd(la|0,ma|0,40)|0;va=ma|va;wa=C|wa;v=Dd(g|0,i|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ba=v^ba;aa=ca^aa;ma=Gd(ba|0,aa|0,16)|0;la=C;aa=Hd(ba|0,aa|0,48)|0;ma=aa|ma;la=C|la;T=Dd(ma|0,la|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;aa=Gd(va|0,wa|0,63)|0;ba=C;wa=Hd(va|0,wa|0,1)|0;aa=wa|aa;ba=C|ba;oa=Dd(ha|0,ia|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,e|0,f|0)|0;na=C;Z=Z^oa;_=_^na;L=Dd(_|0,Z|0,O|0,L|0)|0;O=C;ha=L^ha;ia=O^ia;wa=Gd(ha|0,ia|0,24)|0;va=C;ia=Hd(ha|0,ia|0,40)|0;wa=ia|wa;va=C|va;na=Dd(R|0,P|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;_=na^_;Z=oa^Z;ia=Gd(_|0,Z|0,16)|0;ha=C;Z=Hd(_|0,Z|0,48)|0;ia=Z|ia;ha=C|ha;O=Dd(ia|0,ha|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;Z=Gd(wa|0,va|0,63)|0;_=C;va=Hd(wa|0,va|0,1)|0;Z=va|Z;_=C|_;ka=Dd(ta|0,ua|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,H|0,F|0)|0;ja=C;V=V^ka;X=X^ja;G=Dd(X|0,V|0,J|0,G|0)|0;J=C;ta=G^ta;ua=J^ua;va=Gd(ta|0,ua|0,24)|0;wa=C;ua=Hd(ta|0,ua|0,40)|0;va=ua|va;wa=C|wa;ja=Dd(t|0,x|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;X=ja^X;V=ka^V;ua=Gd(X|0,V|0,16)|0;ta=C;V=Hd(X|0,V|0,48)|0;ua=V|ua;ta=C|ta;J=Dd(ua|0,ta|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;V=Gd(va|0,wa|0,63)|0;X=C;wa=Hd(va|0,wa|0,1)|0;V=wa|V;X=C|X;ga=Dd(pa|0,qa|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,y|0,A|0)|0;fa=C;da=da^ga;ea=ea^fa;z=Dd(ea|0,da|0,E|0,z|0)|0;E=C;pa=z^pa;qa=E^qa;wa=Gd(pa|0,qa|0,24)|0;va=C;qa=Hd(pa|0,qa|0,40)|0;wa=qa|wa;va=C|va;fa=Dd(B|0,S|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ea=fa^ea;da=ga^da;qa=Gd(ea|0,da|0,16)|0;pa=C;da=Hd(ea|0,da|0,48)|0;qa=da|qa;pa=C|pa;E=Dd(qa|0,pa|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;da=Gd(wa|0,va|0,63)|0;ea=C;va=Hd(wa|0,va|0,1)|0;da=va|da;ea=C|ea;ca=Dd(Z|0,_|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,m|0,o|0)|0;v=C;qa=qa^ca;pa=pa^v;G=Dd(pa|0,qa|0,J|0,G|0)|0;J=C;Z=G^Z;_=J^_;va=Gd(Z|0,_|0,24)|0;wa=C;_=Hd(Z|0,_|0,40)|0;va=_|va;wa=C|wa;v=Dd(ra|0,sa|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;pa=v^pa;qa=ca^qa;_=Gd(pa|0,qa|0,16)|0;Z=C;qa=Hd(pa|0,qa|0,48)|0;_=qa|_;Z=C|Z;J=Dd(_|0,Z|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;qa=Gd(va|0,wa|0,63)|0;pa=C;wa=Hd(va|0,wa|0,1)|0;qa=wa|qa;pa=C|pa;oa=Dd(V|0,X|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,h|0,l|0)|0;na=C;ma=ma^oa;la=la^na;z=Dd(la|0,ma|0,E|0,z|0)|0;E=C;V=z^V;X=E^X;wa=Gd(V|0,X|0,24)|0;va=C;X=Hd(V|0,X|0,40)|0;wa=X|wa;va=C|va;na=Dd(s|0,u|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;la=na^la;ma=oa^ma;X=Gd(la|0,ma|0,16)|0;V=C;ma=Hd(la|0,ma|0,48)|0;X=ma|X;V=C|V;E=Dd(X|0,V|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ma=Gd(wa|0,va|0,63)|0;la=C;va=Hd(wa|0,va|0,1)|0;ma=va|ma;la=C|la;ka=Dd(da|0,ea|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,n|0,r|0)|0;ja=C;ia=ia^ka;ha=ha^ja;Q=Dd(ha|0,ia|0,T|0,Q|0)|0;T=C;da=Q^da;ea=T^ea;va=Gd(da|0,ea|0,24)|0;wa=C;ea=Hd(da|0,ea|0,40)|0;va=ea|va;wa=C|wa;ja=Dd(W|0,U|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;ha=ja^ha;ia=ka^ia;ea=Gd(ha|0,ia|0,16)|0;da=C;ia=Hd(ha|0,ia|0,48)|0;ea=ia|ea;da=C|da;T=Dd(ea|0,da|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;ia=Gd(va|0,wa|0,63)|0;ha=C;wa=Hd(va|0,wa|0,1)|0;ia=wa|ia;ha=C|ha;ga=Dd(aa|0,ba|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,j|0,Y|0)|0;fa=C;ua=ua^ga;ta=ta^fa;L=Dd(ta|0,ua|0,O|0,L|0)|0;O=C;aa=L^aa;ba=O^ba;wa=Gd(aa|0,ba|0,24)|0;va=C;ba=Hd(aa|0,ba|0,40)|0;wa=ba|wa;va=C|va;fa=Dd(p|0,$|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ta=fa^ta;ua=ga^ua;ba=Gd(ta|0,ua|0,16)|0;aa=C;ua=Hd(ta|0,ua|0,48)|0;ba=ua|ba;aa=C|aa;O=Dd(ba|0,aa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ua=Gd(wa|0,va|0,63)|0;ta=C;va=Hd(wa|0,va|0,1)|0;ua=va|ua;ta=C|ta;ca=Dd(n|0,r|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,ua|0,ta|0)|0;v=C;X=ca^X;V=v^V;Q=Dd(V|0,X|0,T|0,Q|0)|0;T=C;ua=Q^ua;ta=T^ta;va=Gd(ua|0,ta|0,24)|0;wa=C;ta=Hd(ua|0,ta|0,40)|0;va=ta|va;wa=C|wa;v=Dd(j|0,Y|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;V=v^V;X=ca^X;ta=Gd(V|0,X|0,16)|0;ua=C;X=Hd(V|0,X|0,48)|0;ta=X|ta;ua=C|ua;T=Dd(ta|0,ua|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;X=Gd(va|0,wa|0,63)|0;V=C;wa=Hd(va|0,wa|0,1)|0;X=wa|X;V=C|V;oa=Dd(qa|0,pa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,h|0,l|0)|0;na=C;ea=ea^oa;da=da^na;L=Dd(da|0,ea|0,O|0,L|0)|0;O=C;qa=L^qa;pa=O^pa;wa=Gd(qa|0,pa|0,24)|0;va=C;pa=Hd(qa|0,pa|0,40)|0;wa=pa|wa;va=C|va;na=Dd(W|0,U|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;da=na^da;ea=oa^ea;pa=Gd(da|0,ea|0,16)|0;qa=C;ea=Hd(da|0,ea|0,48)|0;pa=ea|pa;qa=C|qa;O=Dd(pa|0,qa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ea=Gd(wa|0,va|0,63)|0;da=C;va=Hd(wa|0,va|0,1)|0;ea=va|ea;da=C|da;ka=Dd(ma|0,la|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,B|0,S|0)|0;ja=C;ba=ba^ka;aa=aa^ja;G=Dd(aa|0,ba|0,J|0,G|0)|0;J=C;ma=G^ma;la=J^la;va=Gd(ma|0,la|0,24)|0;wa=C;la=Hd(ma|0,la|0,40)|0;va=la|va;wa=C|wa;ja=Dd(e|0,f|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;aa=ja^aa;ba=ka^ba;la=Gd(aa|0,ba|0,16)|0;ma=C;ba=Hd(aa|0,ba|0,48)|0;la=ba|la;ma=C|ma;J=Dd(la|0,ma|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ba=Gd(va|0,wa|0,63)|0;aa=C;wa=Hd(va|0,wa|0,1)|0;ba=wa|ba;aa=C|aa;ga=Dd(ia|0,ha|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,M|0,K|0)|0;fa=C;_=_^ga;Z=Z^fa;z=Dd(Z|0,_|0,E|0,z|0)|0;E=C;ia=z^ia;ha=E^ha;wa=Gd(ia|0,ha|0,24)|0;va=C;ha=Hd(ia|0,ha|0,40)|0;wa=ha|wa;va=C|va;fa=Dd(ra|0,sa|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;Z=fa^Z;_=ga^_;ha=Gd(Z|0,_|0,16)|0;ia=C;_=Hd(Z|0,_|0,48)|0;ha=_|ha;ia=C|ia;E=Dd(ha|0,ia|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;_=Gd(wa|0,va|0,63)|0;Z=C;va=Hd(wa|0,va|0,1)|0;_=va|_;Z=C|Z;ca=Dd(ea|0,da|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,t|0,x|0)|0;v=C;ha=ha^ca;ia=ia^v;G=Dd(ia|0,ha|0,J|0,G|0)|0;J=C;ea=G^ea;da=J^da;va=Gd(ea|0,da|0,24)|0;wa=C;da=Hd(ea|0,da|0,40)|0;va=da|va;wa=C|wa;v=Dd(s|0,u|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ia=v^ia;ha=ca^ha;da=Gd(ia|0,ha|0,16)|0;ea=C;ha=Hd(ia|0,ha|0,48)|0;da=ha|da;ea=C|ea;J=Dd(da|0,ea|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ha=Gd(va|0,wa|0,63)|0;ia=C;wa=Hd(va|0,wa|0,1)|0;ha=wa|ha;ia=C|ia;oa=Dd(ba|0,aa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,H|0,F|0)|0;na=C;ta=ta^oa;ua=ua^na;z=Dd(ua|0,ta|0,E|0,z|0)|0;E=C;ba=z^ba;aa=E^aa;wa=Gd(ba|0,aa|0,24)|0;va=C;aa=Hd(ba|0,aa|0,40)|0;wa=aa|wa;va=C|va;na=Dd(m|0,o|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;ua=na^ua;ta=oa^ta;aa=Gd(ua|0,ta|0,16)|0;ba=C;ta=Hd(ua|0,ta|0,48)|0;aa=ta|aa;ba=C|ba;E=Dd(aa|0,ba|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ta=Gd(wa|0,va|0,63)|0;ua=C;va=Hd(wa|0,va|0,1)|0;ta=va|ta;ua=C|ua;ka=Dd(_|0,Z|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,p|0,$|0)|0;ja=C;pa=pa^ka;qa=qa^ja;Q=Dd(qa|0,pa|0,T|0,Q|0)|0;T=C;_=Q^_;Z=T^Z;va=Gd(_|0,Z|0,24)|0;wa=C;Z=Hd(_|0,Z|0,40)|0;va=Z|va;wa=C|wa;ja=Dd(R|0,P|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;qa=ja^qa;pa=ka^pa;Z=Gd(qa|0,pa|0,16)|0;_=C;pa=Hd(qa|0,pa|0,48)|0;Z=pa|Z;_=C|_;T=Dd(Z|0,_|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;pa=Gd(va|0,wa|0,63)|0;qa=C;wa=Hd(va|0,wa|0,1)|0;pa=wa|pa;qa=C|qa;ga=Dd(X|0,V|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,y|0,A|0)|0;fa=C;la=la^ga;ma=ma^fa;L=Dd(ma|0,la|0,O|0,L|0)|0;O=C;X=L^X;V=O^V;wa=Gd(X|0,V|0,24)|0;va=C;V=Hd(X|0,V|0,40)|0;wa=V|wa;va=C|va;fa=Dd(g|0,i|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ma=fa^ma;la=ga^la;V=Gd(ma|0,la|0,16)|0;X=C;la=Hd(ma|0,la|0,48)|0;V=la|V;X=C|X;O=Dd(V|0,X|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;la=Gd(wa|0,va|0,63)|0;ma=C;va=Hd(wa|0,va|0,1)|0;la=va|la;ma=C|ma;ca=Dd(j|0,Y|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,la|0,ma|0)|0;v=C;aa=ca^aa;ba=v^ba;Q=Dd(ba|0,aa|0,T|0,Q|0)|0;T=C;la=Q^la;ma=T^ma;va=Gd(la|0,ma|0,24)|0;wa=C;ma=Hd(la|0,ma|0,40)|0;va=ma|va;wa=C|wa;v=Dd(R|0,P|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ba=v^ba;aa=ca^aa;ma=Gd(ba|0,aa|0,16)|0;la=C;aa=Hd(ba|0,aa|0,48)|0;ma=aa|ma;la=C|la;T=Dd(ma|0,la|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;aa=Gd(va|0,wa|0,63)|0;ba=C;wa=Hd(va|0,wa|0,1)|0;aa=wa|aa;ba=C|ba;oa=Dd(ha|0,ia|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,H|0,F|0)|0;na=C;Z=Z^oa;_=_^na;L=Dd(_|0,Z|0,O|0,L|0)|0;O=C;ha=L^ha;ia=O^ia;wa=Gd(ha|0,ia|0,24)|0;va=C;ia=Hd(ha|0,ia|0,40)|0;wa=ia|wa;va=C|va;na=Dd(n|0,r|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;_=na^_;Z=oa^Z;ia=Gd(_|0,Z|0,16)|0;ha=C;Z=Hd(_|0,Z|0,48)|0;ia=Z|ia;ha=C|ha;O=Dd(ia|0,ha|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;Z=Gd(wa|0,va|0,63)|0;_=C;va=Hd(wa|0,va|0,1)|0;Z=va|Z;_=C|_;ka=Dd(ta|0,ua|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,t|0,x|0)|0;ja=C;V=V^ka;X=X^ja;G=Dd(X|0,V|0,J|0,G|0)|0;J=C;ta=G^ta;ua=J^ua;va=Gd(ta|0,ua|0,24)|0;wa=C;ua=Hd(ta|0,ua|0,40)|0;va=ua|va;wa=C|wa;ja=Dd(p|0,$|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;X=ja^X;V=ka^V;ua=Gd(X|0,V|0,16)|0;ta=C;V=Hd(X|0,V|0,48)|0;ua=V|ua;ta=C|ta;J=Dd(ua|0,ta|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;V=Gd(va|0,wa|0,63)|0;X=C;wa=Hd(va|0,wa|0,1)|0;V=wa|V;X=C|X;ga=Dd(pa|0,qa|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,m|0,o|0)|0;fa=C;da=da^ga;ea=ea^fa;z=Dd(ea|0,da|0,E|0,z|0)|0;E=C;pa=z^pa;qa=E^qa;wa=Gd(pa|0,qa|0,24)|0;va=C;qa=Hd(pa|0,qa|0,40)|0;wa=qa|wa;va=C|va;fa=Dd(y|0,A|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ea=fa^ea;da=ga^da;qa=Gd(ea|0,da|0,16)|0;pa=C;da=Hd(ea|0,da|0,48)|0;qa=da|qa;pa=C|pa;E=Dd(qa|0,pa|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;da=Gd(wa|0,va|0,63)|0;ea=C;va=Hd(wa|0,va|0,1)|0;da=va|da;ea=C|ea;ca=Dd(Z|0,_|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,ra|0,sa|0)|0;v=C;qa=qa^ca;pa=pa^v;G=Dd(pa|0,qa|0,J|0,G|0)|0;J=C;Z=G^Z;_=J^_;va=Gd(Z|0,_|0,24)|0;wa=C;_=Hd(Z|0,_|0,40)|0;va=_|va;wa=C|wa;v=Dd(W|0,U|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;pa=v^pa;qa=ca^qa;_=Gd(pa|0,qa|0,16)|0;Z=C;qa=Hd(pa|0,qa|0,48)|0;_=qa|_;Z=C|Z;J=Dd(_|0,Z|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;qa=Gd(va|0,wa|0,63)|0;pa=C;wa=Hd(va|0,wa|0,1)|0;qa=wa|qa;pa=C|pa;oa=Dd(V|0,X|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,M|0,K|0)|0;na=C;ma=ma^oa;la=la^na;z=Dd(la|0,ma|0,E|0,z|0)|0;E=C;V=z^V;X=E^X;wa=Gd(V|0,X|0,24)|0;va=C;X=Hd(V|0,X|0,40)|0;wa=X|wa;va=C|va;na=Dd(e|0,f|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;la=na^la;ma=oa^ma;X=Gd(la|0,ma|0,16)|0;V=C;ma=Hd(la|0,ma|0,48)|0;X=ma|X;V=C|V;E=Dd(X|0,V|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ma=Gd(wa|0,va|0,63)|0;la=C;va=Hd(wa|0,va|0,1)|0;ma=va|ma;la=C|la;ka=Dd(da|0,ea|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,s|0,u|0)|0;ja=C;ia=ia^ka;ha=ha^ja;Q=Dd(ha|0,ia|0,T|0,Q|0)|0;T=C;da=Q^da;ea=T^ea;va=Gd(da|0,ea|0,24)|0;wa=C;ea=Hd(da|0,ea|0,40)|0;va=ea|va;wa=C|wa;ja=Dd(g|0,i|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;ha=ja^ha;ia=ka^ia;ea=Gd(ha|0,ia|0,16)|0;da=C;ia=Hd(ha|0,ia|0,48)|0;ea=ia|ea;da=C|da;T=Dd(ea|0,da|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;ia=Gd(va|0,wa|0,63)|0;ha=C;wa=Hd(va|0,wa|0,1)|0;ia=wa|ia;ha=C|ha;ga=Dd(aa|0,ba|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,h|0,l|0)|0;fa=C;ua=ua^ga;ta=ta^fa;L=Dd(ta|0,ua|0,O|0,L|0)|0;O=C;aa=L^aa;ba=O^ba;wa=Gd(aa|0,ba|0,24)|0;va=C;ba=Hd(aa|0,ba|0,40)|0;wa=ba|wa;va=C|va;fa=Dd(B|0,S|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ta=fa^ta;ua=ga^ua;ba=Gd(ta|0,ua|0,16)|0;aa=C;ua=Hd(ta|0,ua|0,48)|0;ba=ua|ba;aa=C|aa;O=Dd(ba|0,aa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ua=Gd(wa|0,va|0,63)|0;ta=C;va=Hd(wa|0,va|0,1)|0;ua=va|ua;ta=C|ta;ca=Dd(t|0,x|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,ua|0,ta|0)|0;v=C;X=ca^X;V=v^V;Q=Dd(V|0,X|0,T|0,Q|0)|0;T=C;ua=Q^ua;ta=T^ta;va=Gd(ua|0,ta|0,24)|0;wa=C;ta=Hd(ua|0,ta|0,40)|0;va=ta|va;wa=C|wa;v=Dd(e|0,f|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;V=v^V;X=ca^X;ta=Gd(V|0,X|0,16)|0;ua=C;X=Hd(V|0,X|0,48)|0;ta=X|ta;ua=C|ua;T=Dd(ta|0,ua|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;X=Gd(va|0,wa|0,63)|0;V=C;wa=Hd(va|0,wa|0,1)|0;X=wa|X;V=C|V;oa=Dd(qa|0,pa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,s|0,u|0)|0;na=C;ea=ea^oa;da=da^na;L=Dd(da|0,ea|0,O|0,L|0)|0;O=C;qa=L^qa;pa=O^pa;wa=Gd(qa|0,pa|0,24)|0;va=C;pa=Hd(qa|0,pa|0,40)|0;wa=pa|wa;va=C|va;na=Dd(m|0,o|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;da=na^da;ea=oa^ea;pa=Gd(da|0,ea|0,16)|0;qa=C;ea=Hd(da|0,ea|0,48)|0;pa=ea|pa;qa=C|qa;O=Dd(pa|0,qa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ea=Gd(wa|0,va|0,63)|0;da=C;va=Hd(wa|0,va|0,1)|0;ea=va|ea;da=C|da;ka=Dd(ma|0,la|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,R|0,P|0)|0;ja=C;ba=ba^ka;aa=aa^ja;G=Dd(aa|0,ba|0,J|0,G|0)|0;J=C;ma=G^ma;la=J^la;va=Gd(ma|0,la|0,24)|0;wa=C;la=Hd(ma|0,la|0,40)|0;va=la|va;wa=C|wa;ja=Dd(M|0,K|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;aa=ja^aa;ba=ka^ba;la=Gd(aa|0,ba|0,16)|0;ma=C;ba=Hd(aa|0,ba|0,48)|0;la=ba|la;ma=C|ma;J=Dd(la|0,ma|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ba=Gd(va|0,wa|0,63)|0;aa=C;wa=Hd(va|0,wa|0,1)|0;ba=wa|ba;aa=C|aa;ga=Dd(ia|0,ha|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,g|0,i|0)|0;fa=C;_=_^ga;Z=Z^fa;z=Dd(Z|0,_|0,E|0,z|0)|0;E=C;ia=z^ia;ha=E^ha;wa=Gd(ia|0,ha|0,24)|0;va=C;ha=Hd(ia|0,ha|0,40)|0;wa=ha|wa;va=C|va;fa=Dd(h|0,l|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;Z=fa^Z;_=ga^_;ha=Gd(Z|0,_|0,16)|0;ia=C;_=Hd(Z|0,_|0,48)|0;ha=_|ha;ia=C|ia;E=Dd(ha|0,ia|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;_=Gd(wa|0,va|0,63)|0;Z=C;va=Hd(wa|0,va|0,1)|0;_=va|_;Z=C|Z;ca=Dd(ea|0,da|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,p|0,$|0)|0;v=C;ha=ha^ca;ia=ia^v;G=Dd(ia|0,ha|0,J|0,G|0)|0;J=C;ea=G^ea;da=J^da;va=Gd(ea|0,da|0,24)|0;wa=C;da=Hd(ea|0,da|0,40)|0;va=da|va;wa=C|wa;v=Dd(B|0,S|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ia=v^ia;ha=ca^ha;da=Gd(ia|0,ha|0,16)|0;ea=C;ha=Hd(ia|0,ha|0,48)|0;da=ha|da;ea=C|ea;J=Dd(da|0,ea|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ha=Gd(va|0,wa|0,63)|0;ia=C;wa=Hd(va|0,wa|0,1)|0;ha=wa|ha;ia=C|ia;oa=Dd(ba|0,aa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,n|0,r|0)|0;na=C;ta=ta^oa;ua=ua^na;z=Dd(ua|0,ta|0,E|0,z|0)|0;E=C;ba=z^ba;aa=E^aa;wa=Gd(ba|0,aa|0,24)|0;va=C;aa=Hd(ba|0,aa|0,40)|0;wa=aa|wa;va=C|va;na=Dd(H|0,F|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;ua=na^ua;ta=oa^ta;aa=Gd(ua|0,ta|0,16)|0;ba=C;ta=Hd(ua|0,ta|0,48)|0;aa=ta|aa;ba=C|ba;E=Dd(aa|0,ba|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ta=Gd(wa|0,va|0,63)|0;ua=C;va=Hd(wa|0,va|0,1)|0;ta=va|ta;ua=C|ua;ka=Dd(_|0,Z|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,y|0,A|0)|0;ja=C;pa=pa^ka;qa=qa^ja;Q=Dd(qa|0,pa|0,T|0,Q|0)|0;T=C;_=Q^_;Z=T^Z;va=Gd(_|0,Z|0,24)|0;wa=C;Z=Hd(_|0,Z|0,40)|0;va=Z|va;wa=C|wa;ja=Dd(ra|0,sa|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;qa=ja^qa;pa=ka^pa;Z=Gd(qa|0,pa|0,16)|0;_=C;pa=Hd(qa|0,pa|0,48)|0;Z=pa|Z;_=C|_;T=Dd(Z|0,_|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;pa=Gd(va|0,wa|0,63)|0;qa=C;wa=Hd(va|0,wa|0,1)|0;pa=wa|pa;qa=C|qa;ga=Dd(X|0,V|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,W|0,U|0)|0;fa=C;la=la^ga;ma=ma^fa;L=Dd(ma|0,la|0,O|0,L|0)|0;O=C;X=L^X;V=O^V;wa=Gd(X|0,V|0,24)|0;va=C;V=Hd(X|0,V|0,40)|0;wa=V|wa;va=C|va;fa=Dd(j|0,Y|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ma=fa^ma;la=ga^la;V=Gd(ma|0,la|0,16)|0;X=C;la=Hd(ma|0,la|0,48)|0;V=la|V;X=C|X;O=Dd(V|0,X|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;la=Gd(wa|0,va|0,63)|0;ma=C;va=Hd(wa|0,va|0,1)|0;la=va|la;ma=C|ma;ca=Dd(e|0,f|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,la|0,ma|0)|0;v=C;aa=ca^aa;ba=v^ba;Q=Dd(ba|0,aa|0,T|0,Q|0)|0;T=C;la=Q^la;ma=T^ma;va=Gd(la|0,ma|0,24)|0;wa=C;ma=Hd(la|0,ma|0,40)|0;va=ma|va;wa=C|wa;v=Dd(H|0,F|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ba=v^ba;aa=ca^aa;ma=Gd(ba|0,aa|0,16)|0;la=C;aa=Hd(ba|0,aa|0,48)|0;ma=aa|ma;la=C|la;T=Dd(ma|0,la|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;aa=Gd(va|0,wa|0,63)|0;ba=C;wa=Hd(va|0,wa|0,1)|0;aa=wa|aa;ba=C|ba;oa=Dd(ha|0,ia|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,W|0,U|0)|0;na=C;Z=Z^oa;_=_^na;L=Dd(_|0,Z|0,O|0,L|0)|0;O=C;ha=L^ha;ia=O^ia;wa=Gd(ha|0,ia|0,24)|0;va=C;ia=Hd(ha|0,ia|0,40)|0;wa=ia|wa;va=C|va;na=Dd(y|0,A|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;_=na^_;Z=oa^Z;ia=Gd(_|0,Z|0,16)|0;ha=C;Z=Hd(_|0,Z|0,48)|0;ia=Z|ia;ha=C|ha;O=Dd(ia|0,ha|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;Z=Gd(wa|0,va|0,63)|0;_=C;va=Hd(wa|0,va|0,1)|0;Z=va|Z;_=C|_;ka=Dd(ta|0,ua|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,ra|0,sa|0)|0;ja=C;V=V^ka;X=X^ja;G=Dd(X|0,V|0,J|0,G|0)|0;J=C;ta=G^ta;ua=J^ua;va=Gd(ta|0,ua|0,24)|0;wa=C;ua=Hd(ta|0,ua|0,40)|0;va=ua|va;wa=C|wa;ja=Dd(B|0,S|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;X=ja^X;V=ka^V;ua=Gd(X|0,V|0,16)|0;ta=C;V=Hd(X|0,V|0,48)|0;ua=V|ua;ta=C|ta;J=Dd(ua|0,ta|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;V=Gd(va|0,wa|0,63)|0;X=C;wa=Hd(va|0,wa|0,1)|0;V=wa|V;X=C|X;ga=Dd(pa|0,qa|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,p|0,$|0)|0;fa=C;da=da^ga;ea=ea^fa;z=Dd(ea|0,da|0,E|0,z|0)|0;E=C;pa=z^pa;qa=E^qa;wa=Gd(pa|0,qa|0,24)|0;va=C;qa=Hd(pa|0,qa|0,40)|0;wa=qa|wa;va=C|va;fa=Dd(m|0,o|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ea=fa^ea;da=ga^da;qa=Gd(ea|0,da|0,16)|0;pa=C;da=Hd(ea|0,da|0,48)|0;qa=da|qa;pa=C|pa;E=Dd(qa|0,pa|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;da=Gd(wa|0,va|0,63)|0;ea=C;va=Hd(wa|0,va|0,1)|0;da=va|da;ea=C|ea;ca=Dd(Z|0,_|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,R|0,P|0)|0;v=C;qa=qa^ca;pa=pa^v;G=Dd(pa|0,qa|0,J|0,G|0)|0;J=C;Z=G^Z;_=J^_;va=Gd(Z|0,_|0,24)|0;wa=C;_=Hd(Z|0,_|0,40)|0;va=_|va;wa=C|wa;v=Dd(n|0,r|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;pa=v^pa;qa=ca^qa;_=Gd(pa|0,qa|0,16)|0;Z=C;qa=Hd(pa|0,qa|0,48)|0;_=qa|_;Z=C|Z;J=Dd(_|0,Z|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;qa=Gd(va|0,wa|0,63)|0;pa=C;wa=Hd(va|0,wa|0,1)|0;qa=wa|qa;pa=C|pa;oa=Dd(V|0,X|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,s|0,u|0)|0;na=C;ma=ma^oa;la=la^na;z=Dd(la|0,ma|0,E|0,z|0)|0;E=C;V=z^V;X=E^X;wa=Gd(V|0,X|0,24)|0;va=C;X=Hd(V|0,X|0,40)|0;wa=X|wa;va=C|va;na=Dd(h|0,l|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;la=na^la;ma=oa^ma;X=Gd(la|0,ma|0,16)|0;V=C;ma=Hd(la|0,ma|0,48)|0;X=ma|X;V=C|V;E=Dd(X|0,V|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ma=Gd(wa|0,va|0,63)|0;la=C;va=Hd(wa|0,va|0,1)|0;ma=va|ma;la=C|la;ka=Dd(da|0,ea|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,j|0,Y|0)|0;ja=C;ia=ia^ka;ha=ha^ja;Q=Dd(ha|0,ia|0,T|0,Q|0)|0;T=C;da=Q^da;ea=T^ea;va=Gd(da|0,ea|0,24)|0;wa=C;ea=Hd(da|0,ea|0,40)|0;va=ea|va;wa=C|wa;ja=Dd(t|0,x|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;ha=ja^ha;ia=ka^ia;ea=Gd(ha|0,ia|0,16)|0;da=C;ia=Hd(ha|0,ia|0,48)|0;ea=ia|ea;da=C|da;T=Dd(ea|0,da|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;ia=Gd(va|0,wa|0,63)|0;ha=C;wa=Hd(va|0,wa|0,1)|0;ia=wa|ia;ha=C|ha;ga=Dd(aa|0,ba|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,g|0,i|0)|0;fa=C;ua=ua^ga;ta=ta^fa;L=Dd(ta|0,ua|0,O|0,L|0)|0;O=C;aa=L^aa;ba=O^ba;wa=Gd(aa|0,ba|0,24)|0;va=C;ba=Hd(aa|0,ba|0,40)|0;wa=ba|wa;va=C|va;fa=Dd(M|0,K|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ta=fa^ta;ua=ga^ua;ba=Gd(ta|0,ua|0,16)|0;aa=C;ua=Hd(ta|0,ua|0,48)|0;ba=ua|ba;aa=C|aa;O=Dd(ba|0,aa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ua=Gd(wa|0,va|0,63)|0;ta=C;va=Hd(wa|0,va|0,1)|0;ua=va|ua;ta=C|ta;ca=Dd(B|0,S|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,ua|0,ta|0)|0;v=C;X=ca^X;V=v^V;Q=Dd(V|0,X|0,T|0,Q|0)|0;T=C;ua=Q^ua;ta=T^ta;va=Gd(ua|0,ta|0,24)|0;wa=C;ta=Hd(ua|0,ta|0,40)|0;va=ta|va;wa=C|wa;v=Dd(M|0,K|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;V=v^V;X=ca^X;ta=Gd(V|0,X|0,16)|0;ua=C;X=Hd(V|0,X|0,48)|0;ta=X|ta;ua=C|ua;T=Dd(ta|0,ua|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;X=Gd(va|0,wa|0,63)|0;V=C;wa=Hd(va|0,wa|0,1)|0;X=wa|X;V=C|V;oa=Dd(qa|0,pa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,n|0,r|0)|0;na=C;ea=ea^oa;da=da^na;L=Dd(da|0,ea|0,O|0,L|0)|0;O=C;qa=L^qa;pa=O^pa;wa=Gd(qa|0,pa|0,24)|0;va=C;pa=Hd(qa|0,pa|0,40)|0;wa=pa|wa;va=C|va;na=Dd(ra|0,sa|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;da=na^da;ea=oa^ea;pa=Gd(da|0,ea|0,16)|0;qa=C;ea=Hd(da|0,ea|0,48)|0;pa=ea|pa;qa=C|qa;O=Dd(pa|0,qa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ea=Gd(wa|0,va|0,63)|0;da=C;va=Hd(wa|0,va|0,1)|0;ea=va|ea;da=C|da;ka=Dd(ma|0,la|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,e|0,f|0)|0;ja=C;ba=ba^ka;aa=aa^ja;G=Dd(aa|0,ba|0,J|0,G|0)|0;J=C;ma=G^ma;la=J^la;va=Gd(ma|0,la|0,24)|0;wa=C;la=Hd(ma|0,la|0,40)|0;va=la|va;wa=C|wa;ja=Dd(W|0,U|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;aa=ja^aa;ba=ka^ba;la=Gd(aa|0,ba|0,16)|0;ma=C;ba=Hd(aa|0,ba|0,48)|0;la=ba|la;ma=C|ma;J=Dd(la|0,ma|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ba=Gd(va|0,wa|0,63)|0;aa=C;wa=Hd(va|0,wa|0,1)|0;ba=wa|ba;aa=C|aa;ga=Dd(ia|0,ha|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,h|0,l|0)|0;fa=C;_=_^ga;Z=Z^fa;z=Dd(Z|0,_|0,E|0,z|0)|0;E=C;ia=z^ia;ha=E^ha;wa=Gd(ia|0,ha|0,24)|0;va=C;ha=Hd(ia|0,ha|0,40)|0;wa=ha|wa;va=C|va;fa=Dd(j|0,Y|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;Z=fa^Z;_=ga^_;ha=Gd(Z|0,_|0,16)|0;ia=C;_=Hd(Z|0,_|0,48)|0;ha=_|ha;ia=C|ia;E=Dd(ha|0,ia|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;_=Gd(wa|0,va|0,63)|0;Z=C;va=Hd(wa|0,va|0,1)|0;_=va|_;Z=C|Z;ca=Dd(ea|0,da|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,H|0,F|0)|0;v=C;ha=ha^ca;ia=ia^v;G=Dd(ia|0,ha|0,J|0,G|0)|0;J=C;ea=G^ea;da=J^da;va=Gd(ea|0,da|0,24)|0;wa=C;da=Hd(ea|0,da|0,40)|0;va=da|va;wa=C|wa;v=Dd(R|0,P|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ia=v^ia;ha=ca^ha;da=Gd(ia|0,ha|0,16)|0;ea=C;ha=Hd(ia|0,ha|0,48)|0;da=ha|da;ea=C|ea;J=Dd(da|0,ea|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ha=Gd(va|0,wa|0,63)|0;ia=C;wa=Hd(va|0,wa|0,1)|0;ha=wa|ha;ia=C|ia;oa=Dd(ba|0,aa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,y|0,A|0)|0;na=C;ta=ta^oa;ua=ua^na;z=Dd(ua|0,ta|0,E|0,z|0)|0;E=C;ba=z^ba;aa=E^aa;wa=Gd(ba|0,aa|0,24)|0;va=C;aa=Hd(ba|0,aa|0,40)|0;wa=aa|wa;va=C|va;na=Dd(p|0,$|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;ua=na^ua;ta=oa^ta;aa=Gd(ua|0,ta|0,16)|0;ba=C;ta=Hd(ua|0,ta|0,48)|0;aa=ta|aa;ba=C|ba;E=Dd(aa|0,ba|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ta=Gd(wa|0,va|0,63)|0;ua=C;va=Hd(wa|0,va|0,1)|0;ta=va|ta;ua=C|ua;ka=Dd(_|0,Z|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,g|0,i|0)|0;ja=C;pa=pa^ka;qa=qa^ja;Q=Dd(qa|0,pa|0,T|0,Q|0)|0;T=C;_=Q^_;Z=T^Z;va=Gd(_|0,Z|0,24)|0;wa=C;Z=Hd(_|0,Z|0,40)|0;va=Z|va;wa=C|wa;ja=Dd(s|0,u|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;qa=ja^qa;pa=ka^pa;Z=Gd(qa|0,pa|0,16)|0;_=C;pa=Hd(qa|0,pa|0,48)|0;Z=pa|Z;_=C|_;T=Dd(Z|0,_|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;pa=Gd(va|0,wa|0,63)|0;qa=C;wa=Hd(va|0,wa|0,1)|0;pa=wa|pa;qa=C|qa;ga=Dd(X|0,V|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,t|0,x|0)|0;fa=C;la=la^ga;ma=ma^fa;L=Dd(ma|0,la|0,O|0,L|0)|0;O=C;X=L^X;V=O^V;wa=Gd(X|0,V|0,24)|0;va=C;V=Hd(X|0,V|0,40)|0;wa=V|wa;va=C|va;fa=Dd(m|0,o|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ma=fa^ma;la=ga^la;V=Gd(ma|0,la|0,16)|0;X=C;la=Hd(ma|0,la|0,48)|0;V=la|V;X=C|X;O=Dd(V|0,X|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;la=Gd(wa|0,va|0,63)|0;ma=C;va=Hd(wa|0,va|0,1)|0;la=va|la;ma=C|ma;ca=Dd(s|0,u|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,la|0,ma|0)|0;v=C;aa=ca^aa;ba=v^ba;Q=Dd(ba|0,aa|0,T|0,Q|0)|0;T=C;la=Q^la;ma=T^ma;va=Gd(la|0,ma|0,24)|0;wa=C;ma=Hd(la|0,ma|0,40)|0;va=ma|va;wa=C|wa;v=Dd(y|0,A|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ba=v^ba;aa=ca^aa;ma=Gd(ba|0,aa|0,16)|0;la=C;aa=Hd(ba|0,aa|0,48)|0;ma=aa|ma;la=C|la;T=Dd(ma|0,la|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;aa=Gd(va|0,wa|0,63)|0;ba=C;wa=Hd(va|0,wa|0,1)|0;aa=wa|aa;ba=C|ba;oa=Dd(ha|0,ia|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,ra|0,sa|0)|0;na=C;Z=Z^oa;_=_^na;L=Dd(_|0,Z|0,O|0,L|0)|0;O=C;ha=L^ha;ia=O^ia;wa=Gd(ha|0,ia|0,24)|0;va=C;ia=Hd(ha|0,ia|0,40)|0;wa=ia|wa;va=C|va;na=Dd(j|0,Y|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;_=na^_;Z=oa^Z;ia=Gd(_|0,Z|0,16)|0;ha=C;Z=Hd(_|0,Z|0,48)|0;ia=Z|ia;ha=C|ha;O=Dd(ia|0,ha|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;Z=Gd(wa|0,va|0,63)|0;_=C;va=Hd(wa|0,va|0,1)|0;Z=va|Z;_=C|_;ka=Dd(ta|0,ua|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,M|0,K|0)|0;ja=C;V=V^ka;X=X^ja;G=Dd(X|0,V|0,J|0,G|0)|0;J=C;ta=G^ta;ua=J^ua;va=Gd(ta|0,ua|0,24)|0;wa=C;ua=Hd(ta|0,ua|0,40)|0;va=ua|va;wa=C|wa;ja=Dd(h|0,l|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;X=ja^X;V=ka^V;ua=Gd(X|0,V|0,16)|0;ta=C;V=Hd(X|0,V|0,48)|0;ua=V|ua;ta=C|ta;J=Dd(ua|0,ta|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;V=Gd(va|0,wa|0,63)|0;X=C;wa=Hd(va|0,wa|0,1)|0;V=wa|V;X=C|X;ga=Dd(pa|0,qa|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,R|0,P|0)|0;fa=C;da=da^ga;ea=ea^fa;z=Dd(ea|0,da|0,E|0,z|0)|0;E=C;pa=z^pa;qa=E^qa;wa=Gd(pa|0,qa|0,24)|0;va=C;qa=Hd(pa|0,qa|0,40)|0;wa=qa|wa;va=C|va;fa=Dd(g|0,i|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ea=fa^ea;da=ga^da;qa=Gd(ea|0,da|0,16)|0;pa=C;da=Hd(ea|0,da|0,48)|0;qa=da|qa;pa=C|pa;E=Dd(qa|0,pa|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;da=Gd(wa|0,va|0,63)|0;ea=C;va=Hd(wa|0,va|0,1)|0;da=va|da;ea=C|ea;ca=Dd(Z|0,_|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,e|0,f|0)|0;v=C;qa=qa^ca;pa=pa^v;G=Dd(pa|0,qa|0,J|0,G|0)|0;J=C;Z=G^Z;_=J^_;va=Gd(Z|0,_|0,24)|0;wa=C;_=Hd(Z|0,_|0,40)|0;va=_|va;wa=C|wa;v=Dd(t|0,x|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;pa=v^pa;qa=ca^qa;_=Gd(pa|0,qa|0,16)|0;Z=C;qa=Hd(pa|0,qa|0,48)|0;_=qa|_;Z=C|Z;J=Dd(_|0,Z|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;qa=Gd(va|0,wa|0,63)|0;pa=C;wa=Hd(va|0,wa|0,1)|0;qa=wa|qa;pa=C|pa;oa=Dd(V|0,X|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,B|0,S|0)|0;na=C;ma=ma^oa;la=la^na;z=Dd(la|0,ma|0,E|0,z|0)|0;E=C;V=z^V;X=E^X;wa=Gd(V|0,X|0,24)|0;va=C;X=Hd(V|0,X|0,40)|0;wa=X|wa;va=C|va;na=Dd(n|0,r|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;la=na^la;ma=oa^ma;X=Gd(la|0,ma|0,16)|0;V=C;ma=Hd(la|0,ma|0,48)|0;X=ma|X;V=C|V;E=Dd(X|0,V|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ma=Gd(wa|0,va|0,63)|0;la=C;va=Hd(wa|0,va|0,1)|0;ma=va|ma;la=C|la;ka=Dd(da|0,ea|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,W|0,U|0)|0;ja=C;ia=ia^ka;ha=ha^ja;Q=Dd(ha|0,ia|0,T|0,Q|0)|0;T=C;da=Q^da;ea=T^ea;va=Gd(da|0,ea|0,24)|0;wa=C;ea=Hd(da|0,ea|0,40)|0;va=ea|va;wa=C|wa;ja=Dd(p|0,$|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;ha=ja^ha;ia=ka^ia;ea=Gd(ha|0,ia|0,16)|0;da=C;ia=Hd(ha|0,ia|0,48)|0;ea=ia|ea;da=C|da;T=Dd(ea|0,da|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;ia=Gd(va|0,wa|0,63)|0;ha=C;wa=Hd(va|0,wa|0,1)|0;ia=wa|ia;ha=C|ha;ga=Dd(aa|0,ba|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,m|0,o|0)|0;fa=C;ua=ua^ga;ta=ta^fa;L=Dd(ta|0,ua|0,O|0,L|0)|0;O=C;aa=L^aa;ba=O^ba;wa=Gd(aa|0,ba|0,24)|0;va=C;ba=Hd(aa|0,ba|0,40)|0;wa=ba|wa;va=C|va;fa=Dd(H|0,F|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ta=fa^ta;ua=ga^ua;ba=Gd(ta|0,ua|0,16)|0;aa=C;ua=Hd(ta|0,ua|0,48)|0;ba=ua|ba;aa=C|aa;O=Dd(ba|0,aa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ua=Gd(wa|0,va|0,63)|0;ta=C;va=Hd(wa|0,va|0,1)|0;ua=va|ua;ta=C|ta;ca=Dd(m|0,o|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,ua|0,ta|0)|0;v=C;X=ca^X;V=v^V;Q=Dd(V|0,X|0,T|0,Q|0)|0;T=C;ua=Q^ua;ta=T^ta;va=Gd(ua|0,ta|0,24)|0;wa=C;ta=Hd(ua|0,ta|0,40)|0;va=ta|va;wa=C|wa;v=Dd(t|0,x|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;V=v^V;X=ca^X;ta=Gd(V|0,X|0,16)|0;ua=C;X=Hd(V|0,X|0,48)|0;ta=X|ta;ua=C|ua;T=Dd(ta|0,ua|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;X=Gd(va|0,wa|0,63)|0;V=C;wa=Hd(va|0,wa|0,1)|0;X=wa|X;V=C|V;oa=Dd(qa|0,pa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,g|0,i|0)|0;na=C;ea=ea^oa;da=da^na;L=Dd(da|0,ea|0,O|0,L|0)|0;O=C;qa=L^qa;pa=O^pa;wa=Gd(qa|0,pa|0,24)|0;va=C;pa=Hd(qa|0,pa|0,40)|0;wa=pa|wa;va=C|va;na=Dd(p|0,$|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;da=na^da;ea=oa^ea;pa=Gd(da|0,ea|0,16)|0;qa=C;ea=Hd(da|0,ea|0,48)|0;pa=ea|pa;qa=C|qa;O=Dd(pa|0,qa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ea=Gd(wa|0,va|0,63)|0;da=C;va=Hd(wa|0,va|0,1)|0;ea=va|ea;da=C|da;ka=Dd(ma|0,la|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,n|0,r|0)|0;ja=C;ba=ba^ka;aa=aa^ja;G=Dd(aa|0,ba|0,J|0,G|0)|0;J=C;ma=G^ma;la=J^la;va=Gd(ma|0,la|0,24)|0;wa=C;la=Hd(ma|0,la|0,40)|0;va=la|va;wa=C|wa;ja=Dd(s|0,u|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;aa=ja^aa;ba=ka^ba;la=Gd(aa|0,ba|0,16)|0;ma=C;ba=Hd(aa|0,ba|0,48)|0;la=ba|la;ma=C|ma;J=Dd(la|0,ma|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ba=Gd(va|0,wa|0,63)|0;aa=C;wa=Hd(va|0,wa|0,1)|0;ba=wa|ba;aa=C|aa;ga=Dd(ia|0,ha|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,W|0,U|0)|0;fa=C;_=_^ga;Z=Z^fa;z=Dd(Z|0,_|0,E|0,z|0)|0;E=C;ia=z^ia;ha=E^ha;wa=Gd(ia|0,ha|0,24)|0;va=C;ha=Hd(ia|0,ha|0,40)|0;wa=ha|wa;va=C|va;fa=Dd(H|0,F|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;Z=fa^Z;_=ga^_;ha=Gd(Z|0,_|0,16)|0;ia=C;_=Hd(Z|0,_|0,48)|0;ha=_|ha;ia=C|ia;E=Dd(ha|0,ia|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;_=Gd(wa|0,va|0,63)|0;Z=C;va=Hd(wa|0,va|0,1)|0;_=va|_;Z=C|Z;ca=Dd(ea|0,da|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,y|0,A|0)|0;v=C;ha=ha^ca;ia=ia^v;G=Dd(ia|0,ha|0,J|0,G|0)|0;J=C;ea=G^ea;da=J^da;va=Gd(ea|0,da|0,24)|0;wa=C;da=Hd(ea|0,da|0,40)|0;va=da|va;wa=C|wa;v=Dd(M|0,K|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ia=v^ia;ha=ca^ha;da=Gd(ia|0,ha|0,16)|0;ea=C;ha=Hd(ia|0,ha|0,48)|0;da=ha|da;ea=C|ea;J=Dd(da|0,ea|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ha=Gd(va|0,wa|0,63)|0;ia=C;wa=Hd(va|0,wa|0,1)|0;ha=wa|ha;ia=C|ia;oa=Dd(ba|0,aa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,j|0,Y|0)|0;na=C;ta=ta^oa;ua=ua^na;z=Dd(ua|0,ta|0,E|0,z|0)|0;E=C;ba=z^ba;aa=E^aa;wa=Gd(ba|0,aa|0,24)|0;va=C;aa=Hd(ba|0,aa|0,40)|0;wa=aa|wa;va=C|va;na=Dd(ra|0,sa|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;ua=na^ua;ta=oa^ta;aa=Gd(ua|0,ta|0,16)|0;ba=C;ta=Hd(ua|0,ta|0,48)|0;aa=ta|aa;ba=C|ba;E=Dd(aa|0,ba|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ta=Gd(wa|0,va|0,63)|0;ua=C;va=Hd(wa|0,va|0,1)|0;ta=va|ta;ua=C|ua;ka=Dd(_|0,Z|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,h|0,l|0)|0;ja=C;pa=pa^ka;qa=qa^ja;Q=Dd(qa|0,pa|0,T|0,Q|0)|0;T=C;_=Q^_;Z=T^Z;va=Gd(_|0,Z|0,24)|0;wa=C;Z=Hd(_|0,Z|0,40)|0;va=Z|va;wa=C|wa;ja=Dd(e|0,f|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;qa=ja^qa;pa=ka^pa;Z=Gd(qa|0,pa|0,16)|0;_=C;pa=Hd(qa|0,pa|0,48)|0;Z=pa|Z;_=C|_;T=Dd(Z|0,_|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;pa=Gd(va|0,wa|0,63)|0;qa=C;wa=Hd(va|0,wa|0,1)|0;pa=wa|pa;qa=C|qa;ga=Dd(X|0,V|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,B|0,S|0)|0;fa=C;la=la^ga;ma=ma^fa;L=Dd(ma|0,la|0,O|0,L|0)|0;O=C;X=L^X;V=O^V;wa=Gd(X|0,V|0,24)|0;va=C;V=Hd(X|0,V|0,40)|0;wa=V|wa;va=C|va;fa=Dd(R|0,P|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ma=fa^ma;la=ga^la;V=Gd(ma|0,la|0,16)|0;X=C;la=Hd(ma|0,la|0,48)|0;V=la|V;X=C|X;O=Dd(V|0,X|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;la=Gd(wa|0,va|0,63)|0;ma=C;va=Hd(wa|0,va|0,1)|0;la=va|la;ma=C|ma;ca=Dd(R|0,P|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,la|0,ma|0)|0;v=C;aa=ca^aa;ba=v^ba;Q=Dd(ba|0,aa|0,T|0,Q|0)|0;T=C;la=Q^la;ma=T^ma;va=Gd(la|0,ma|0,24)|0;wa=C;ma=Hd(la|0,ma|0,40)|0;va=ma|va;wa=C|wa;v=Dd(W|0,U|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ba=v^ba;aa=ca^aa;ma=Gd(ba|0,aa|0,16)|0;la=C;aa=Hd(ba|0,aa|0,48)|0;ma=aa|ma;la=C|la;T=Dd(ma|0,la|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;aa=Gd(va|0,wa|0,63)|0;ba=C;wa=Hd(va|0,wa|0,1)|0;aa=wa|aa;ba=C|ba;oa=Dd(ha|0,ia|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,t|0,x|0)|0;na=C;Z=Z^oa;_=_^na;L=Dd(_|0,Z|0,O|0,L|0)|0;O=C;ha=L^ha;ia=O^ia;wa=Gd(ha|0,ia|0,24)|0;va=C;ia=Hd(ha|0,ia|0,40)|0;wa=ia|wa;va=C|va;na=Dd(h|0,l|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;_=na^_;Z=oa^Z;ia=Gd(_|0,Z|0,16)|0;ha=C;Z=Hd(_|0,Z|0,48)|0;ia=Z|ia;ha=C|ha;O=Dd(ia|0,ha|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;Z=Gd(wa|0,va|0,63)|0;_=C;va=Hd(wa|0,va|0,1)|0;Z=va|Z;_=C|_;ka=Dd(ta|0,ua|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,p|0,$|0)|0;ja=C;V=V^ka;X=X^ja;G=Dd(X|0,V|0,J|0,G|0)|0;J=C;ta=G^ta;ua=J^ua;va=Gd(ta|0,ua|0,24)|0;wa=C;ua=Hd(ta|0,ua|0,40)|0;va=ua|va;wa=C|wa;ja=Dd(H|0,F|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;X=ja^X;V=ka^V;ua=Gd(X|0,V|0,16)|0;ta=C;V=Hd(X|0,V|0,48)|0;ua=V|ua;ta=C|ta;J=Dd(ua|0,ta|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;V=Gd(va|0,wa|0,63)|0;X=C;wa=Hd(va|0,wa|0,1)|0;V=wa|V;X=C|X;ga=Dd(pa|0,qa|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,s|0,u|0)|0;fa=C;da=da^ga;ea=ea^fa;z=Dd(ea|0,da|0,E|0,z|0)|0;E=C;pa=z^pa;qa=E^qa;wa=Gd(pa|0,qa|0,24)|0;va=C;qa=Hd(pa|0,qa|0,40)|0;wa=qa|wa;va=C|va;fa=Dd(n|0,r|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ea=fa^ea;da=ga^da;qa=Gd(ea|0,da|0,16)|0;pa=C;da=Hd(ea|0,da|0,48)|0;qa=da|qa;pa=C|pa;E=Dd(qa|0,pa|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;da=Gd(wa|0,va|0,63)|0;ea=C;va=Hd(wa|0,va|0,1)|0;da=va|da;ea=C|ea;ca=Dd(Z|0,_|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,g|0,i|0)|0;v=C;qa=qa^ca;pa=pa^v;G=Dd(pa|0,qa|0,J|0,G|0)|0;J=C;Z=G^Z;_=J^_;va=Gd(Z|0,_|0,24)|0;wa=C;_=Hd(Z|0,_|0,40)|0;va=_|va;wa=C|wa;v=Dd(j|0,Y|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;pa=v^pa;qa=ca^qa;_=Gd(pa|0,qa|0,16)|0;Z=C;qa=Hd(pa|0,qa|0,48)|0;_=qa|_;Z=C|Z;J=Dd(_|0,Z|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;qa=Gd(va|0,wa|0,63)|0;pa=C;wa=Hd(va|0,wa|0,1)|0;qa=wa|qa;pa=C|pa;oa=Dd(V|0,X|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,m|0,o|0)|0;na=C;ma=ma^oa;la=la^na;z=Dd(la|0,ma|0,E|0,z|0)|0;E=C;V=z^V;X=E^X;wa=Gd(V|0,X|0,24)|0;va=C;X=Hd(V|0,X|0,40)|0;wa=X|wa;va=C|va;na=Dd(M|0,K|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;la=na^la;ma=oa^ma;X=Gd(la|0,ma|0,16)|0;V=C;ma=Hd(la|0,ma|0,48)|0;X=ma|X;V=C|V;E=Dd(X|0,V|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ma=Gd(wa|0,va|0,63)|0;la=C;va=Hd(wa|0,va|0,1)|0;ma=va|ma;la=C|la;ka=Dd(da|0,ea|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,e|0,f|0)|0;ja=C;ia=ia^ka;ha=ha^ja;Q=Dd(ha|0,ia|0,T|0,Q|0)|0;T=C;da=Q^da;ea=T^ea;va=Gd(da|0,ea|0,24)|0;wa=C;ea=Hd(da|0,ea|0,40)|0;va=ea|va;wa=C|wa;ja=Dd(B|0,S|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;ha=ja^ha;ia=ka^ia;ea=Gd(ha|0,ia|0,16)|0;da=C;ia=Hd(ha|0,ia|0,48)|0;ea=ia|ea;da=C|da;T=Dd(ea|0,da|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;ia=Gd(va|0,wa|0,63)|0;ha=C;wa=Hd(va|0,wa|0,1)|0;ia=wa|ia;ha=C|ha;ga=Dd(aa|0,ba|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,ra|0,sa|0)|0;fa=C;ua=ua^ga;ta=ta^fa;L=Dd(ta|0,ua|0,O|0,L|0)|0;O=C;aa=L^aa;ba=O^ba;wa=Gd(aa|0,ba|0,24)|0;va=C;ba=Hd(aa|0,ba|0,40)|0;wa=ba|wa;va=C|va;fa=Dd(y|0,A|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ta=fa^ta;ua=ga^ua;ba=Gd(ta|0,ua|0,16)|0;aa=C;ua=Hd(ta|0,ua|0,48)|0;ba=ua|ba;aa=C|aa;O=Dd(ba|0,aa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ua=Gd(wa|0,va|0,63)|0;ta=C;va=Hd(wa|0,va|0,1)|0;ua=va|ua;ta=C|ta;ca=Dd(ra|0,sa|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,ua|0,ta|0)|0;v=C;X=ca^X;V=v^V;Q=Dd(V|0,X|0,T|0,Q|0)|0;T=C;ua=Q^ua;ta=T^ta;sa=Gd(ua|0,ta|0,24)|0;ra=C;ta=Hd(ua|0,ta|0,40)|0;sa=ta|sa;ra=C|ra;v=Dd(m|0,o|0,ca|0,v|0)|0;v=Dd(v|0,C|0,sa|0,ra|0)|0;ca=C;V=v^V;X=ca^X;o=Gd(V|0,X|0,16)|0;m=C;X=Hd(V|0,X|0,48)|0;o=X|o;m=C|m;T=Dd(o|0,m|0,Q|0,T|0)|0;Q=C;sa=T^sa;ra=Q^ra;X=Gd(sa|0,ra|0,63)|0;V=C;ra=Hd(sa|0,ra|0,1)|0;X=ra|X;V=C|V;oa=Dd(qa|0,pa|0,na|0,oa|0)|0;$=Dd(oa|0,C|0,p|0,$|0)|0;p=C;ea=ea^$;da=da^p;L=Dd(da|0,ea|0,O|0,L|0)|0;O=C;qa=L^qa;pa=O^pa;oa=Gd(qa|0,pa|0,24)|0;na=C;pa=Hd(qa|0,pa|0,40)|0;oa=pa|oa;na=C|na;p=Dd(g|0,i|0,$|0,p|0)|0;p=Dd(p|0,C|0,oa|0,na|0)|0;$=C;da=p^da;ea=$^ea;i=Gd(da|0,ea|0,16)|0;g=C;ea=Hd(da|0,ea|0,48)|0;i=ea|i;g=C|g;O=Dd(i|0,g|0,L|0,O|0)|0;L=C;oa=O^oa;na=L^na;ea=Gd(oa|0,na|0,63)|0;da=C;na=Hd(oa|0,na|0,1)|0;ea=na|ea;da=C|da;ka=Dd(ma|0,la|0,ja|0,ka|0)|0;Y=Dd(ka|0,C|0,j|0,Y|0)|0;j=C;ba=ba^Y;aa=aa^j;G=Dd(aa|0,ba|0,J|0,G|0)|0;J=C;ma=G^ma;la=J^la;ka=Gd(ma|0,la|0,24)|0;ja=C;la=Hd(ma|0,la|0,40)|0;ka=la|ka;ja=C|ja;j=Dd(y|0,A|0,Y|0,j|0)|0;j=Dd(j|0,C|0,ka|0,ja|0)|0;Y=C;aa=j^aa;ba=Y^ba;A=Gd(aa|0,ba|0,16)|0;y=C;ba=Hd(aa|0,ba|0,48)|0;A=ba|A;y=C|y;J=Dd(A|0,y|0,G|0,J|0)|0;G=C;ka=J^ka;ja=G^ja;ba=Gd(ka|0,ja|0,63)|0;aa=C;ja=Hd(ka|0,ja|0,1)|0;ba=ja|ba;aa=C|aa;ga=Dd(ia|0,ha|0,fa|0,ga|0)|0;S=Dd(ga|0,C|0,B|0,S|0)|0;B=C;_=_^S;Z=Z^B;z=Dd(Z|0,_|0,E|0,z|0)|0;E=C;ia=z^ia;ha=E^ha;ga=Gd(ia|0,ha|0,24)|0;fa=C;ha=Hd(ia|0,ha|0,40)|0;ga=ha|ga;fa=C|fa;B=Dd(s|0,u|0,S|0,B|0)|0;B=Dd(B|0,C|0,ga|0,fa|0)|0;S=C;Z=B^Z;_=S^_;u=Gd(Z|0,_|0,16)|0;s=C;_=Hd(Z|0,_|0,48)|0;u=_|u;s=C|s;E=Dd(u|0,s|0,z|0,E|0)|0;z=C;ga=E^ga;fa=z^fa;_=Gd(ga|0,fa|0,63)|0;Z=C;fa=Hd(ga|0,fa|0,1)|0;_=fa|_;Z=C|Z;ca=Dd(ea|0,da|0,v|0,ca|0)|0;U=Dd(ca|0,C|0,W|0,U|0)|0;W=C;u=u^U;s=s^W;G=Dd(s|0,u|0,J|0,G|0)|0;J=C;ea=G^ea;da=J^da;ca=Gd(ea|0,da|0,24)|0;v=C;da=Hd(ea|0,da|0,40)|0;ca=da|ca;v=C|v;W=Dd(e|0,f|0,U|0,W|0)|0;W=Dd(W|0,C|0,ca|0,v|0)|0;U=C;s=W^s;u=U^u;f=Gd(s|0,u|0,16)|0;e=C;u=Hd(s|0,u|0,48)|0;f=u|f;e=C|e;J=Dd(f|0,e|0,G|0,J|0)|0;G=C;ca=J^ca;v=G^v;u=Gd(ca|0,v|0,63)|0;s=C;v=Hd(ca|0,v|0,1)|0;s=C|s;$=Dd(ba|0,aa|0,p|0,$|0)|0;P=Dd($|0,C|0,R|0,P|0)|0;R=C;o=o^P;m=m^R;z=Dd(m|0,o|0,E|0,z|0)|0;E=C;ba=z^ba;aa=E^aa;$=Gd(ba|0,aa|0,24)|0;p=C;aa=Hd(ba|0,aa|0,40)|0;$=aa|$;p=C|p;R=Dd(t|0,x|0,P|0,R|0)|0;R=Dd(R|0,C|0,$|0,p|0)|0;P=C;m=R^m;o=P^o;x=Gd(m|0,o|0,16)|0;t=C;o=Hd(m|0,o|0,48)|0;x=o|x;t=C|t;E=Dd(x|0,t|0,z|0,E|0)|0;z=C;$=E^$;p=z^p;o=Gd($|0,p|0,63)|0;m=C;p=Hd($|0,p|0,1)|0;m=C|m;Y=Dd(_|0,Z|0,j|0,Y|0)|0;K=Dd(Y|0,C|0,M|0,K|0)|0;M=C;i=i^K;g=g^M;Q=Dd(g|0,i|0,T|0,Q|0)|0;T=C;_=Q^_;Z=T^Z;Y=Gd(_|0,Z|0,24)|0;j=C;Z=Hd(_|0,Z|0,40)|0;Y=Z|Y;j=C|j;M=Dd(n|0,r|0,K|0,M|0)|0;M=Dd(M|0,C|0,Y|0,j|0)|0;K=C;g=M^g;i=K^i;r=Gd(g|0,i|0,16)|0;n=C;i=Hd(g|0,i|0,48)|0;r=i|r;n=C|n;T=Dd(r|0,n|0,Q|0,T|0)|0;Q=C;Y=T^Y;j=Q^j;i=Gd(Y|0,j|0,63)|0;g=C;j=Hd(Y|0,j|0,1)|0;g=C|g;S=Dd(X|0,V|0,B|0,S|0)|0;F=Dd(S|0,C|0,H|0,F|0)|0;H=C;A=A^F;y=y^H;L=Dd(y|0,A|0,O|0,L|0)|0;O=C;X=L^X;V=O^V;S=Gd(X|0,V|0,24)|0;B=C;V=Hd(X|0,V|0,40)|0;S=V|S;B=C|B;H=Dd(h|0,l|0,F|0,H|0)|0;H=Dd(H|0,C|0,S|0,B|0)|0;F=C;y=H^y;A=F^A;l=Gd(y|0,A|0,16)|0;h=C;A=Hd(y|0,A|0,48)|0;l=A|l;h=C|h;O=Dd(l|0,h|0,L|0,O|0)|0;L=C;S=O^S;B=L^B;A=Gd(S|0,B|0,63)|0;y=C;B=Hd(S|0,B|0,1)|0;S=b;V=S;S=S+4|0;T=W^(d[V>>0]|d[V+1>>0]<<8|d[V+2>>0]<<16|d[V+3>>0]<<24)^T;Q=U^(d[S>>0]|d[S+1>>0]<<8|d[S+2>>0]<<16|d[S+3>>0]<<24)^Q;S=b;a[S>>0]=T;a[S+1>>0]=T>>8;a[S+2>>0]=T>>16;a[S+3>>0]=T>>24;b=b+4|0;a[b>>0]=Q;a[b+1>>0]=Q>>8;a[b+2>>0]=Q>>16;a[b+3>>0]=Q>>24;b=N;Q=b;b=b+4|0;O=R^(d[Q>>0]|d[Q+1>>0]<<8|d[Q+2>>0]<<16|d[Q+3>>0]<<24)^O;L=P^(d[b>>0]|d[b+1>>0]<<8|d[b+2>>0]<<16|d[b+3>>0]<<24)^L;b=N;N=b;a[N>>0]=O;a[N+1>>0]=O>>8;a[N+2>>0]=O>>16;a[N+3>>0]=O>>24;b=b+4|0;a[b>>0]=L;a[b+1>>0]=L>>8;a[b+2>>0]=L>>16;a[b+3>>0]=L>>24;b=I;L=b;b=b+4|0;J=M^(d[L>>0]|d[L+1>>0]<<8|d[L+2>>0]<<16|d[L+3>>0]<<24)^J;G=K^(d[b>>0]|d[b+1>>0]<<8|d[b+2>>0]<<16|d[b+3>>0]<<24)^G;b=I;I=b;a[I>>0]=J;a[I+1>>0]=J>>8;a[I+2>>0]=J>>16;a[I+3>>0]=J>>24;b=b+4|0;a[b>>0]=G;a[b+1>>0]=G>>8;a[b+2>>0]=G>>16;a[b+3>>0]=G>>24;b=D;G=b;b=b+4|0;E=H^(d[G>>0]|d[G+1>>0]<<8|d[G+2>>0]<<16|d[G+3>>0]<<24)^E;z=F^(d[b>>0]|d[b+1>>0]<<8|d[b+2>>0]<<16|d[b+3>>0]<<24)^z;b=D;D=b;a[D>>0]=E;a[D+1>>0]=E>>8;a[D+2>>0]=E>>16;a[D+3>>0]=E>>24;b=b+4|0;a[b>>0]=z;a[b+1>>0]=z>>8;a[b+2>>0]=z>>16;a[b+3>>0]=z>>24;b=w;z=b;b=b+4|0;x=(B|A)^(d[z>>0]|d[z+1>>0]<<8|d[z+2>>0]<<16|d[z+3>>0]<<24)^x;t=(C|y)^(d[b>>0]|d[b+1>>0]<<8|d[b+2>>0]<<16|d[b+3>>0]<<24)^t;b=w;w=b;a[w>>0]=x;a[w+1>>0]=x>>8;a[w+2>>0]=x>>16;a[w+3>>0]=x>>24;b=b+4|0;a[b>>0]=t;a[b+1>>0]=t>>8;a[b+2>>0]=t>>16;a[b+3>>0]=t>>24;b=q;t=b;b=b+4|0;r=(v|u)^(d[t>>0]|d[t+1>>0]<<8|d[t+2>>0]<<16|d[t+3>>0]<<24)^r;n=s^(d[b>>0]|d[b+1>>0]<<8|d[b+2>>0]<<16|d[b+3>>0]<<24)^n;b=q;q=b;a[q>>0]=r;a[q+1>>0]=r>>8;a[q+2>>0]=r>>16;a[q+3>>0]=r>>24;b=b+4|0;a[b>>0]=n;a[b+1>>0]=n>>8;a[b+2>>0]=n>>16;a[b+3>>0]=n>>24;b=k;n=b;b=b+4|0;l=(p|o)^(d[n>>0]|d[n+1>>0]<<8|d[n+2>>0]<<16|d[n+3>>0]<<24)^l;h=m^(d[b>>0]|d[b+1>>0]<<8|d[b+2>>0]<<16|d[b+3>>0]<<24)^h;b=k;k=b;a[k>>0]=l;a[k+1>>0]=l>>8;a[k+2>>0]=l>>16;a[k+3>>0]=l>>24;b=b+4|0;a[b>>0]=h;a[b+1>>0]=h>>8;a[b+2>>0]=h>>16;a[b+3>>0]=h>>24;b=c;h=b;b=b+4|0;f=(j|i)^(d[h>>0]|d[h+1>>0]<<8|d[h+2>>0]<<16|d[h+3>>0]<<24)^f;b=g^(d[b>>0]|d[b+1>>0]<<8|d[b+2>>0]<<16|d[b+3>>0]<<24)^e;e=c;a[e>>0]=f;a[e+1>>0]=f>>8;a[e+2>>0]=f>>16;a[e+3>>0]=f>>24;c=c+4|0;a[c>>0]=b;a[c+1>>0]=b>>8;a[c+2>>0]=b>>16;a[c+3>>0]=b>>24;return}function Bb(){return 64}function Cb(b,d,e,f){b=b|0;d=d|0;e=e|0;f=f|0;var g=0,h=0,j=0,k=0,l=0,m=0,n=0;n=i;m=i=i+63&-64;i=i+208|0;g=m+64|0;h=m;j=8;k=h+64|0;do{c[h>>2]=c[j>>2];h=h+4|0;j=j+4|0}while((h|0)<(k|0));h=Hd(e|0,f|0,3)|0;j=C;k=Gd(e|0,f|0,61)|0;l=m+72|0;c[l>>2]=h;c[l+4>>2]=j;l=g;c[l>>2]=k;c[l+4>>2]=C;l=m+80|0;if(f>>>0<0|(f|0)==0&e>>>0<128){Id(l|0,d|0,e|0)|0;Gb(m,b);i=n;return 0}h=l;j=d;k=h+128|0;do{a[h>>0]=a[j>>0]|0;h=h+1|0;j=j+1|0}while((h|0)<(k|0));Hb(m,l);g=d+128|0;d=Dd(e|0,f|0,-128,-1)|0;h=C;if(h>>>0>0|(h|0)==0&d>>>0>127)do{Hb(m,g);g=g+128|0;d=Dd(d|0,h|0,-128,-1)|0;h=C}while(h>>>0>0|(h|0)==0&d>>>0>127);Id(l|0,g|0,d|0)|0;Gb(m,b);i=n;return 0}function Db(b,d){b=b|0;d=d|0;var e=0,f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0;n=i;m=i=i+63&-64;i=i+16|0;l=b+32|0;e=l;f=c[e>>2]|0;e=c[e+4>>2]|0;a[m+7>>0]=f;g=Gd(f|0,e|0,8)|0;a[m+6>>0]=g;g=Gd(f|0,e|0,16)|0;a[m+5>>0]=g;g=Gd(f|0,e|0,24)|0;a[m+4>>0]=g;a[m+3>>0]=e;g=Gd(f|0,e|0,40)|0;a[m+2>>0]=g;g=Gd(f|0,e|0,48)|0;a[m+1>>0]=g;g=Gd(f|0,e|0,56)|0;a[m>>0]=g;g=Gd(f|0,e|0,3)|0;g=g&63;k=g>>>0<56?56:120;j=k-g|0;do if((k|0)!=(g|0)){h=Hd(j|0,0,3)|0;f=Dd(h|0,C|0,f|0,e|0)|0;e=C;h=l;c[h>>2]=f;c[h+4>>2]=e;h=64-g|0;g=b+40+g|0;if(j>>>0>>0){Id(g|0,32792,j|0)|0;break}Id(g|0,32792,h|0)|0;k=b+40|0;Eb(b,k);e=32792+h|0;g=Cd(j|0,0,h|0,0)|0;f=C;if(f>>>0>0|(f|0)==0&g>>>0>63){do{Eb(b,e);e=e+64|0;g=Dd(g|0,f|0,-64,-1)|0;f=C}while(f>>>0>0|(f|0)==0&g>>>0>63);f=g}else f=g;Id(k|0,e|0,f|0)|0;e=l;f=c[e>>2]|0;e=c[e+4>>2]|0}while(0);k=Gd(f|0,e|0,3)|0;k=k&63;e=Dd(f|0,e|0,64,0)|0;f=l;c[f>>2]=e;c[f+4>>2]=C;f=64-k|0;e=b+40+k|0;if(f>>>0>8){k=c[m>>2]|0;m=c[m+4>>2]|0;l=e;a[l>>0]=k;a[l+1>>0]=k>>8;a[l+2>>0]=k>>16;a[l+3>>0]=k>>24;e=e+4|0;a[e>>0]=m;a[e+1>>0]=m>>8;a[e+2>>0]=m>>16;a[e+3>>0]=m>>24;e=b}else{Id(e|0,m|0,f|0)|0;h=b+40|0;Eb(b,h);e=m+f|0;g=Cd(8,0,f|0,0)|0;f=C;if(f>>>0>0|(f|0)==0&g>>>0>63){do{Eb(b,e);e=e+64|0;g=Dd(g|0,f|0,-64,-1)|0;f=C}while(f>>>0>0|(f|0)==0&g>>>0>63);f=g}else f=g;Id(h|0,e|0,f|0)|0;e=b}e=c[e>>2]|0;a[d+3>>0]=e;a[d+2>>0]=e>>>8;a[d+1>>0]=e>>>16;a[d>>0]=e>>>24;e=c[b+4>>2]|0;a[d+7>>0]=e;a[d+6>>0]=e>>>8;a[d+5>>0]=e>>>16;a[d+4>>0]=e>>>24;e=c[b+8>>2]|0;a[d+11>>0]=e;a[d+10>>0]=e>>>8;a[d+9>>0]=e>>>16;a[d+8>>0]=e>>>24;e=c[b+12>>2]|0;a[d+15>>0]=e;a[d+14>>0]=e>>>8;a[d+13>>0]=e>>>16;a[d+12>>0]=e>>>24;e=c[b+16>>2]|0;a[d+19>>0]=e;a[d+18>>0]=e>>>8;a[d+17>>0]=e>>>16;a[d+16>>0]=e>>>24;e=c[b+20>>2]|0;a[d+23>>0]=e;a[d+22>>0]=e>>>8;a[d+21>>0]=e>>>16;a[d+20>>0]=e>>>24;e=c[b+24>>2]|0;a[d+27>>0]=e;a[d+26>>0]=e>>>8;a[d+25>>0]=e>>>16;a[d+24>>0]=e>>>24;e=c[b+28>>2]|0;a[d+31>>0]=e;a[d+30>>0]=e>>>8;a[d+29>>0]=e>>>16;a[d+28>>0]=e>>>24;e=b+104|0;do{a[b>>0]=0;b=b+1|0}while((b|0)<(e|0));i=n;return}function Eb(a,b){a=a|0;b=b|0;var e=0,f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0;g=i;f=i=i+63&-64;i=i+256|0;e=0;do{h=b+(e<<2)|0;c[f+(e<<2)>>2]=(d[h+2>>0]|0)<<8|(d[h+3>>0]|0)|(d[h+1>>0]|0)<<16|(d[h>>0]|0)<<24;e=e+1|0}while((e|0)!=16);b=c[f>>2]|0;e=16;do{h=c[f+(e+-2<<2)>>2]|0;j=b;b=c[f+(e+-15<<2)>>2]|0;c[f+(e<<2)>>2]=j+(c[f+(e+-7<<2)>>2]|0)+((h>>>19|h<<13)^h>>>10^(h>>>17|h<<15))+((b>>>18|b<<14)^b>>>3^(b>>>7|b<<25));e=e+1|0}while((e|0)!=64);u=c[a>>2]|0;s=a+4|0;t=c[s>>2]|0;q=a+8|0;r=c[q>>2]|0;o=a+12|0;m=a+16|0;n=c[m>>2]|0;k=a+20|0;l=c[k>>2]|0;e=a+24|0;b=c[e>>2]|0;j=a+28|0;h=(c[j>>2]|0)+1116352408+(c[f>>2]|0)+((n>>>6|n<<26)^(n>>>11|n<<21)^(n>>>25|n<<7))+((b^l)&n^b)|0;p=(c[o>>2]|0)+h|0;h=((r|t)&u|r&t)+((u>>>2|u<<30)^(u>>>13|u<<19)^(u>>>22|u<<10))+h|0;b=b+1899447441+(c[f+4>>2]|0)+((p>>>6|p<<26)^(p>>>11|p<<21)^(p>>>25|p<<7))+((l^n)&p^l)|0;r=r+b|0;b=((t|u)&h|t&u)+((h>>>2|h<<30)^(h>>>13|h<<19)^(h>>>22|h<<10))+b|0;l=l+-1245643825+(c[f+8>>2]|0)+((r>>>6|r<<26)^(r>>>11|r<<21)^(r>>>25|r<<7))+((n^p)&r^n)|0;t=t+l|0;l=((u|h)&b|u&h)+((b>>>2|b<<30)^(b>>>13|b<<19)^(b>>>22|b<<10))+l|0;n=n+-373957723+(c[f+12>>2]|0)+((t>>>6|t<<26)^(t>>>11|t<<21)^(t>>>25|t<<7))+((p^r)&t^p)|0;u=u+n|0;n=((h|b)&l|h&b)+((l>>>2|l<<30)^(l>>>13|l<<19)^(l>>>22|l<<10))+n|0;p=p+961987163+(c[f+16>>2]|0)+((u>>>6|u<<26)^(u>>>11|u<<21)^(u>>>25|u<<7))+((r^t)&u^r)|0;h=h+p|0;p=((b|l)&n|b&l)+((n>>>2|n<<30)^(n>>>13|n<<19)^(n>>>22|n<<10))+p|0;r=r+1508970993+(c[f+20>>2]|0)+((h>>>6|h<<26)^(h>>>11|h<<21)^(h>>>25|h<<7))+((t^u)&h^t)|0;b=b+r|0;r=((l|n)&p|l&n)+((p>>>2|p<<30)^(p>>>13|p<<19)^(p>>>22|p<<10))+r|0;t=t+-1841331548+(c[f+24>>2]|0)+((b>>>6|b<<26)^(b>>>11|b<<21)^(b>>>25|b<<7))+((u^h)&b^u)|0;l=l+t|0;t=((n|p)&r|n&p)+((r>>>2|r<<30)^(r>>>13|r<<19)^(r>>>22|r<<10))+t|0;u=u+-1424204075+(c[f+28>>2]|0)+((l>>>6|l<<26)^(l>>>11|l<<21)^(l>>>25|l<<7))+((h^b)&l^h)|0;n=n+u|0;u=((p|r)&t|p&r)+((t>>>2|t<<30)^(t>>>13|t<<19)^(t>>>22|t<<10))+u|0;h=h+-670586216+(c[f+32>>2]|0)+((n>>>6|n<<26)^(n>>>11|n<<21)^(n>>>25|n<<7))+((b^l)&n^b)|0;p=p+h|0;h=((r|t)&u|r&t)+((u>>>2|u<<30)^(u>>>13|u<<19)^(u>>>22|u<<10))+h|0;b=b+310598401+(c[f+36>>2]|0)+((p>>>6|p<<26)^(p>>>11|p<<21)^(p>>>25|p<<7))+((l^n)&p^l)|0;r=r+b|0;b=((t|u)&h|t&u)+((h>>>2|h<<30)^(h>>>13|h<<19)^(h>>>22|h<<10))+b|0;l=l+607225278+(c[f+40>>2]|0)+((r>>>6|r<<26)^(r>>>11|r<<21)^(r>>>25|r<<7))+((n^p)&r^n)|0;t=t+l|0;l=((u|h)&b|u&h)+((b>>>2|b<<30)^(b>>>13|b<<19)^(b>>>22|b<<10))+l|0;n=n+1426881987+(c[f+44>>2]|0)+((t>>>6|t<<26)^(t>>>11|t<<21)^(t>>>25|t<<7))+((p^r)&t^p)|0;u=u+n|0;n=((h|b)&l|h&b)+((l>>>2|l<<30)^(l>>>13|l<<19)^(l>>>22|l<<10))+n|0;p=p+1925078388+(c[f+48>>2]|0)+((u>>>6|u<<26)^(u>>>11|u<<21)^(u>>>25|u<<7))+((r^t)&u^r)|0;h=h+p|0;p=((b|l)&n|b&l)+((n>>>2|n<<30)^(n>>>13|n<<19)^(n>>>22|n<<10))+p|0;r=r+-2132889090+(c[f+52>>2]|0)+((h>>>6|h<<26)^(h>>>11|h<<21)^(h>>>25|h<<7))+((t^u)&h^t)|0;b=b+r|0;r=((l|n)&p|l&n)+((p>>>2|p<<30)^(p>>>13|p<<19)^(p>>>22|p<<10))+r|0;t=t+-1680079193+(c[f+56>>2]|0)+((b>>>6|b<<26)^(b>>>11|b<<21)^(b>>>25|b<<7))+((u^h)&b^u)|0;l=l+t|0;t=((n|p)&r|n&p)+((r>>>2|r<<30)^(r>>>13|r<<19)^(r>>>22|r<<10))+t|0;u=u+-1046744716+(c[f+60>>2]|0)+((l>>>6|l<<26)^(l>>>11|l<<21)^(l>>>25|l<<7))+((h^b)&l^h)|0;n=n+u|0;u=((p|r)&t|p&r)+((t>>>2|t<<30)^(t>>>13|t<<19)^(t>>>22|t<<10))+u|0;h=h+-459576895+(c[f+64>>2]|0)+((n>>>6|n<<26)^(n>>>11|n<<21)^(n>>>25|n<<7))+((b^l)&n^b)|0;p=p+h|0;h=((r|t)&u|r&t)+((u>>>2|u<<30)^(u>>>13|u<<19)^(u>>>22|u<<10))+h|0;b=b+-272742522+(c[f+68>>2]|0)+((p>>>6|p<<26)^(p>>>11|p<<21)^(p>>>25|p<<7))+((l^n)&p^l)|0;r=r+b|0;b=((t|u)&h|t&u)+((h>>>2|h<<30)^(h>>>13|h<<19)^(h>>>22|h<<10))+b|0;l=l+264347078+(c[f+72>>2]|0)+((r>>>6|r<<26)^(r>>>11|r<<21)^(r>>>25|r<<7))+((n^p)&r^n)|0;t=t+l|0;l=((u|h)&b|u&h)+((b>>>2|b<<30)^(b>>>13|b<<19)^(b>>>22|b<<10))+l|0;n=n+604807628+(c[f+76>>2]|0)+((t>>>6|t<<26)^(t>>>11|t<<21)^(t>>>25|t<<7))+((p^r)&t^p)|0;u=u+n|0;n=((h|b)&l|h&b)+((l>>>2|l<<30)^(l>>>13|l<<19)^(l>>>22|l<<10))+n|0;p=p+770255983+(c[f+80>>2]|0)+((u>>>6|u<<26)^(u>>>11|u<<21)^(u>>>25|u<<7))+((r^t)&u^r)|0;h=h+p|0;p=((b|l)&n|b&l)+((n>>>2|n<<30)^(n>>>13|n<<19)^(n>>>22|n<<10))+p|0;r=r+1249150122+(c[f+84>>2]|0)+((h>>>6|h<<26)^(h>>>11|h<<21)^(h>>>25|h<<7))+((t^u)&h^t)|0;b=b+r|0;r=((l|n)&p|l&n)+((p>>>2|p<<30)^(p>>>13|p<<19)^(p>>>22|p<<10))+r|0;t=t+1555081692+(c[f+88>>2]|0)+((b>>>6|b<<26)^(b>>>11|b<<21)^(b>>>25|b<<7))+((u^h)&b^u)|0;l=l+t|0;t=((n|p)&r|n&p)+((r>>>2|r<<30)^(r>>>13|r<<19)^(r>>>22|r<<10))+t|0;u=u+1996064986+(c[f+92>>2]|0)+((l>>>6|l<<26)^(l>>>11|l<<21)^(l>>>25|l<<7))+((h^b)&l^h)|0;n=n+u|0;u=((p|r)&t|p&r)+((t>>>2|t<<30)^(t>>>13|t<<19)^(t>>>22|t<<10))+u|0;h=h+-1740746414+(c[f+96>>2]|0)+((n>>>6|n<<26)^(n>>>11|n<<21)^(n>>>25|n<<7))+((b^l)&n^b)|0;p=p+h|0;h=((r|t)&u|r&t)+((u>>>2|u<<30)^(u>>>13|u<<19)^(u>>>22|u<<10))+h|0;b=b+-1473132947+(c[f+100>>2]|0)+((p>>>6|p<<26)^(p>>>11|p<<21)^(p>>>25|p<<7))+((l^n)&p^l)|0;r=r+b|0;b=((t|u)&h|t&u)+((h>>>2|h<<30)^(h>>>13|h<<19)^(h>>>22|h<<10))+b|0;l=l+-1341970488+(c[f+104>>2]|0)+((r>>>6|r<<26)^(r>>>11|r<<21)^(r>>>25|r<<7))+((n^p)&r^n)|0;t=t+l|0;l=((u|h)&b|u&h)+((b>>>2|b<<30)^(b>>>13|b<<19)^(b>>>22|b<<10))+l|0;n=n+-1084653625+(c[f+108>>2]|0)+((t>>>6|t<<26)^(t>>>11|t<<21)^(t>>>25|t<<7))+((p^r)&t^p)|0;u=u+n|0;n=((h|b)&l|h&b)+((l>>>2|l<<30)^(l>>>13|l<<19)^(l>>>22|l<<10))+n|0;p=p+-958395405+(c[f+112>>2]|0)+((u>>>6|u<<26)^(u>>>11|u<<21)^(u>>>25|u<<7))+((r^t)&u^r)|0;h=h+p|0;p=((b|l)&n|b&l)+((n>>>2|n<<30)^(n>>>13|n<<19)^(n>>>22|n<<10))+p|0;r=r+-710438585+(c[f+116>>2]|0)+((h>>>6|h<<26)^(h>>>11|h<<21)^(h>>>25|h<<7))+((t^u)&h^t)|0;b=b+r|0;r=((l|n)&p|l&n)+((p>>>2|p<<30)^(p>>>13|p<<19)^(p>>>22|p<<10))+r|0;t=t+113926993+(c[f+120>>2]|0)+((b>>>6|b<<26)^(b>>>11|b<<21)^(b>>>25|b<<7))+((u^h)&b^u)|0;l=l+t|0;t=((n|p)&r|n&p)+((r>>>2|r<<30)^(r>>>13|r<<19)^(r>>>22|r<<10))+t|0;u=u+338241895+(c[f+124>>2]|0)+((l>>>6|l<<26)^(l>>>11|l<<21)^(l>>>25|l<<7))+((h^b)&l^h)|0;n=n+u|0;u=((p|r)&t|p&r)+((t>>>2|t<<30)^(t>>>13|t<<19)^(t>>>22|t<<10))+u|0;h=h+666307205+(c[f+128>>2]|0)+((n>>>6|n<<26)^(n>>>11|n<<21)^(n>>>25|n<<7))+((b^l)&n^b)|0;p=p+h|0;h=((r|t)&u|r&t)+((u>>>2|u<<30)^(u>>>13|u<<19)^(u>>>22|u<<10))+h|0;b=b+773529912+(c[f+132>>2]|0)+((p>>>6|p<<26)^(p>>>11|p<<21)^(p>>>25|p<<7))+((l^n)&p^l)|0;r=r+b|0;b=((t|u)&h|t&u)+((h>>>2|h<<30)^(h>>>13|h<<19)^(h>>>22|h<<10))+b|0;l=l+1294757372+(c[f+136>>2]|0)+((r>>>6|r<<26)^(r>>>11|r<<21)^(r>>>25|r<<7))+((n^p)&r^n)|0;t=t+l|0;l=((u|h)&b|u&h)+((b>>>2|b<<30)^(b>>>13|b<<19)^(b>>>22|b<<10))+l|0;n=n+1396182291+(c[f+140>>2]|0)+((t>>>6|t<<26)^(t>>>11|t<<21)^(t>>>25|t<<7))+((p^r)&t^p)|0;u=u+n|0;n=((h|b)&l|h&b)+((l>>>2|l<<30)^(l>>>13|l<<19)^(l>>>22|l<<10))+n|0;p=p+1695183700+(c[f+144>>2]|0)+((u>>>6|u<<26)^(u>>>11|u<<21)^(u>>>25|u<<7))+((r^t)&u^r)|0;h=h+p|0;p=((b|l)&n|b&l)+((n>>>2|n<<30)^(n>>>13|n<<19)^(n>>>22|n<<10))+p|0;r=r+1986661051+(c[f+148>>2]|0)+((h>>>6|h<<26)^(h>>>11|h<<21)^(h>>>25|h<<7))+((t^u)&h^t)|0;b=b+r|0;r=((l|n)&p|l&n)+((p>>>2|p<<30)^(p>>>13|p<<19)^(p>>>22|p<<10))+r|0;t=t+-2117940946+(c[f+152>>2]|0)+((b>>>6|b<<26)^(b>>>11|b<<21)^(b>>>25|b<<7))+((u^h)&b^u)|0;l=l+t|0;t=((n|p)&r|n&p)+((r>>>2|r<<30)^(r>>>13|r<<19)^(r>>>22|r<<10))+t|0;u=u+-1838011259+(c[f+156>>2]|0)+((l>>>6|l<<26)^(l>>>11|l<<21)^(l>>>25|l<<7))+((h^b)&l^h)|0;n=n+u|0;u=((p|r)&t|p&r)+((t>>>2|t<<30)^(t>>>13|t<<19)^(t>>>22|t<<10))+u|0;h=h+-1564481375+(c[f+160>>2]|0)+((n>>>6|n<<26)^(n>>>11|n<<21)^(n>>>25|n<<7))+((b^l)&n^b)|0;p=p+h|0;h=((r|t)&u|r&t)+((u>>>2|u<<30)^(u>>>13|u<<19)^(u>>>22|u<<10))+h|0;b=b+-1474664885+(c[f+164>>2]|0)+((p>>>6|p<<26)^(p>>>11|p<<21)^(p>>>25|p<<7))+((l^n)&p^l)|0;r=r+b|0;b=((t|u)&h|t&u)+((h>>>2|h<<30)^(h>>>13|h<<19)^(h>>>22|h<<10))+b|0;l=l+-1035236496+(c[f+168>>2]|0)+((r>>>6|r<<26)^(r>>>11|r<<21)^(r>>>25|r<<7))+((n^p)&r^n)|0;t=t+l|0;l=((u|h)&b|u&h)+((b>>>2|b<<30)^(b>>>13|b<<19)^(b>>>22|b<<10))+l|0;n=n+-949202525+(c[f+172>>2]|0)+((t>>>6|t<<26)^(t>>>11|t<<21)^(t>>>25|t<<7))+((p^r)&t^p)|0;u=u+n|0;n=((h|b)&l|h&b)+((l>>>2|l<<30)^(l>>>13|l<<19)^(l>>>22|l<<10))+n|0;p=p+-778901479+(c[f+176>>2]|0)+((u>>>6|u<<26)^(u>>>11|u<<21)^(u>>>25|u<<7))+((r^t)&u^r)|0;h=h+p|0;p=((b|l)&n|b&l)+((n>>>2|n<<30)^(n>>>13|n<<19)^(n>>>22|n<<10))+p|0;r=r+-694614492+(c[f+180>>2]|0)+((h>>>6|h<<26)^(h>>>11|h<<21)^(h>>>25|h<<7))+((t^u)&h^t)|0;b=b+r|0;r=((l|n)&p|l&n)+((p>>>2|p<<30)^(p>>>13|p<<19)^(p>>>22|p<<10))+r|0;t=t+-200395387+(c[f+184>>2]|0)+((b>>>6|b<<26)^(b>>>11|b<<21)^(b>>>25|b<<7))+((u^h)&b^u)|0;l=l+t|0;t=((n|p)&r|n&p)+((r>>>2|r<<30)^(r>>>13|r<<19)^(r>>>22|r<<10))+t|0;u=u+275423344+(c[f+188>>2]|0)+((l>>>6|l<<26)^(l>>>11|l<<21)^(l>>>25|l<<7))+((h^b)&l^h)|0;n=n+u|0;u=((p|r)&t|p&r)+((t>>>2|t<<30)^(t>>>13|t<<19)^(t>>>22|t<<10))+u|0;h=h+430227734+(c[f+192>>2]|0)+((n>>>6|n<<26)^(n>>>11|n<<21)^(n>>>25|n<<7))+((b^l)&n^b)|0;p=p+h|0;h=((r|t)&u|r&t)+((u>>>2|u<<30)^(u>>>13|u<<19)^(u>>>22|u<<10))+h|0;b=b+506948616+(c[f+196>>2]|0)+((p>>>6|p<<26)^(p>>>11|p<<21)^(p>>>25|p<<7))+((l^n)&p^l)|0;r=r+b|0;b=((t|u)&h|t&u)+((h>>>2|h<<30)^(h>>>13|h<<19)^(h>>>22|h<<10))+b|0;l=l+659060556+(c[f+200>>2]|0)+((r>>>6|r<<26)^(r>>>11|r<<21)^(r>>>25|r<<7))+((n^p)&r^n)|0;t=t+l|0;l=((u|h)&b|u&h)+((b>>>2|b<<30)^(b>>>13|b<<19)^(b>>>22|b<<10))+l|0;n=n+883997877+(c[f+204>>2]|0)+((t>>>6|t<<26)^(t>>>11|t<<21)^(t>>>25|t<<7))+((p^r)&t^p)|0;u=u+n|0;n=((h|b)&l|h&b)+((l>>>2|l<<30)^(l>>>13|l<<19)^(l>>>22|l<<10))+n|0;p=p+958139571+(c[f+208>>2]|0)+((u>>>6|u<<26)^(u>>>11|u<<21)^(u>>>25|u<<7))+((r^t)&u^r)|0;h=h+p|0;p=((b|l)&n|b&l)+((n>>>2|n<<30)^(n>>>13|n<<19)^(n>>>22|n<<10))+p|0;r=r+1322822218+(c[f+212>>2]|0)+((h>>>6|h<<26)^(h>>>11|h<<21)^(h>>>25|h<<7))+((t^u)&h^t)|0;b=b+r|0;r=((l|n)&p|l&n)+((p>>>2|p<<30)^(p>>>13|p<<19)^(p>>>22|p<<10))+r|0;t=t+1537002063+(c[f+216>>2]|0)+((b>>>6|b<<26)^(b>>>11|b<<21)^(b>>>25|b<<7))+((u^h)&b^u)|0;l=l+t|0;t=((n|p)&r|n&p)+((r>>>2|r<<30)^(r>>>13|r<<19)^(r>>>22|r<<10))+t|0;u=u+1747873779+(c[f+220>>2]|0)+((l>>>6|l<<26)^(l>>>11|l<<21)^(l>>>25|l<<7))+((h^b)&l^h)|0;n=n+u|0;u=((p|r)&t|p&r)+((t>>>2|t<<30)^(t>>>13|t<<19)^(t>>>22|t<<10))+u|0;h=h+1955562222+(c[f+224>>2]|0)+((n>>>6|n<<26)^(n>>>11|n<<21)^(n>>>25|n<<7))+((b^l)&n^b)|0;p=p+h|0;h=((r|t)&u|r&t)+((u>>>2|u<<30)^(u>>>13|u<<19)^(u>>>22|u<<10))+h|0;b=b+2024104815+(c[f+228>>2]|0)+((p>>>6|p<<26)^(p>>>11|p<<21)^(p>>>25|p<<7))+((l^n)&p^l)|0;r=r+b|0;b=((t|u)&h|t&u)+((h>>>2|h<<30)^(h>>>13|h<<19)^(h>>>22|h<<10))+b|0;l=l+-2067236844+(c[f+232>>2]|0)+((r>>>6|r<<26)^(r>>>11|r<<21)^(r>>>25|r<<7))+((n^p)&r^n)|0;t=t+l|0;l=((u|h)&b|u&h)+((b>>>2|b<<30)^(b>>>13|b<<19)^(b>>>22|b<<10))+l|0;n=n+-1933114872+(c[f+236>>2]|0)+((t>>>6|t<<26)^(t>>>11|t<<21)^(t>>>25|t<<7))+((p^r)&t^p)|0;u=u+n|0;n=((h|b)&l|h&b)+((l>>>2|l<<30)^(l>>>13|l<<19)^(l>>>22|l<<10))+n|0;p=p+-1866530822+(c[f+240>>2]|0)+((u>>>6|u<<26)^(u>>>11|u<<21)^(u>>>25|u<<7))+((r^t)&u^r)|0;h=h+p|0;p=((b|l)&n|b&l)+((n>>>2|n<<30)^(n>>>13|n<<19)^(n>>>22|n<<10))+p|0;r=r+-1538233109+(c[f+244>>2]|0)+((h>>>6|h<<26)^(h>>>11|h<<21)^(h>>>25|h<<7))+((t^u)&h^t)|0;b=b+r|0;r=((l|n)&p|l&n)+((p>>>2|p<<30)^(p>>>13|p<<19)^(p>>>22|p<<10))+r|0;t=t+-1090935817+(c[f+248>>2]|0)+((b>>>6|b<<26)^(b>>>11|b<<21)^(b>>>25|b<<7))+((u^h)&b^u)|0;l=l+t|0;t=((n|p)&r|n&p)+((r>>>2|r<<30)^(r>>>13|r<<19)^(r>>>22|r<<10))+t|0;f=u+-965641998+(c[f+252>>2]|0)+((l>>>6|l<<26)^(l>>>11|l<<21)^(l>>>25|l<<7))+((h^b)&l^h)|0;c[a>>2]=(c[a>>2]|0)+(((p|r)&t|p&r)+((t>>>2|t<<30)^(t>>>13|t<<19)^(t>>>22|t<<10))+f);c[s>>2]=(c[s>>2]|0)+t;c[q>>2]=(c[q>>2]|0)+r;c[o>>2]=(c[o>>2]|0)+p;c[m>>2]=(c[m>>2]|0)+(n+f);c[k>>2]=(c[k>>2]|0)+l;c[e>>2]=(c[e>>2]|0)+b;c[j>>2]=(c[j>>2]|0)+h;i=g;return}function Fb(a,b,d,e){a=a|0;b=b|0;d=d|0;e=e|0;var f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0;j=a+72|0;m=j;o=c[m>>2]|0;m=c[m+4>>2]|0;k=Gd(o|0,m|0,3)|0;k=k&127;l=Hd(d|0,e|0,3)|0;n=C;h=Gd(d|0,e|0,61)|0;i=C;m=Dd(o|0,m|0,l|0,n|0)|0;o=C;c[j>>2]=m;c[j+4>>2]=o;j=a+64|0;g=j;f=c[g>>2]|0;g=c[g+4>>2]|0;if(o>>>0>>0|(o|0)==(n|0)&m>>>0>>0){f=Dd(f|0,g|0,1,0)|0;g=C;o=j;c[o>>2]=f;c[o+4>>2]=g}h=Dd(f|0,g|0,h|0,i|0)|0;g=j;c[g>>2]=h;c[g+4>>2]=C;g=Cd(128,0,k|0,0)|0;h=C;f=a+80+k|0;if(h>>>0>e>>>0|(h|0)==(e|0)&g>>>0>d>>>0){Id(f|0,b|0,d|0)|0;return}Id(f|0,b|0,g|0)|0;i=a+80|0;Hb(a,i);f=b+g|0;g=Cd(d|0,e|0,g|0,h|0)|0;h=C;if(h>>>0>0|(h|0)==0&g>>>0>127)do{Hb(a,f);f=f+128|0;g=Dd(g|0,h|0,-128,-1)|0;h=C}while(h>>>0>0|(h|0)==0&g>>>0>127);Id(i|0,f|0,g|0)|0;return}function Gb(b,d){b=b|0;d=d|0;var e=0,f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0;s=i;e=i=i+63&-64;i=i+16|0;r=b+64|0;f=r;g=c[f>>2]|0;f=c[f+4>>2]|0;a[e+7>>0]=g;q=Gd(g|0,f|0,8)|0;a[e+6>>0]=q;q=Gd(g|0,f|0,16)|0;a[e+5>>0]=q;q=Gd(g|0,f|0,24)|0;a[e+4>>0]=q;a[e+3>>0]=f;q=Gd(g|0,f|0,40)|0;a[e+2>>0]=q;q=Gd(g|0,f|0,48)|0;a[e+1>>0]=q;q=Gd(g|0,f|0,56)|0;a[e>>0]=q;q=b+72|0;j=q;h=c[j>>2]|0;j=c[j+4>>2]|0;a[e+15>>0]=h;n=Gd(h|0,j|0,8)|0;a[e+14>>0]=n;n=Gd(h|0,j|0,16)|0;a[e+13>>0]=n;n=Gd(h|0,j|0,24)|0;a[e+12>>0]=n;a[e+11>>0]=j;n=Gd(h|0,j|0,40)|0;a[e+10>>0]=n;n=Gd(h|0,j|0,48)|0;a[e+9>>0]=n;n=Gd(h|0,j|0,56)|0;a[e+8>>0]=n;n=Gd(h|0,j|0,3)|0;n=n&127;o=0<0|0==0&n>>>0<112;o=Cd((o?112:240)|0,(o?0:0)|0,n|0,0)|0;p=C;m=Hd(o|0,p|0,3)|0;t=C;k=Gd(o|0,p|0,61)|0;l=C;j=Dd(m|0,t|0,h|0,j|0)|0;h=C;u=q;c[u>>2]=j;c[u+4>>2]=h;if(h>>>0>>0|(h|0)==(t|0)&j>>>0>>0){g=Dd(g|0,f|0,1,0)|0;f=C;u=r;c[u>>2]=g;c[u+4>>2]=f}g=Dd(g|0,f|0,k|0,l|0)|0;f=C;l=r;c[l>>2]=g;c[l+4>>2]=f;l=Cd(128,0,n|0,0)|0;m=C;k=b+80+n|0;if(p>>>0>>0|(p|0)==(m|0)&o>>>0>>0)Id(k|0,32856,o|0)|0;else{Id(k|0,32856,l|0)|0;j=b+80|0;Hb(b,j);f=32856+l|0;g=Cd(o|0,p|0,l|0,m|0)|0;h=C;if(h>>>0>0|(h|0)==0&g>>>0>127)do{Hb(b,f);f=f+128|0;g=Dd(g|0,h|0,-128,-1)|0;h=C}while(h>>>0>0|(h|0)==0&g>>>0>127);Id(j|0,f|0,g|0)|0;h=q;f=r;j=c[h>>2]|0;h=c[h+4>>2]|0;g=c[f>>2]|0;f=c[f+4>>2]|0}k=Gd(j|0,h|0,3)|0;k=k&127;t=Dd(j|0,h|0,128,0)|0;u=q;c[u>>2]=t;c[u+4>>2]=C;if(h>>>0>4294967295|(h|0)==-1&j>>>0>4294967167){g=Dd(g|0,f|0,1,0)|0;f=C;u=r;c[u>>2]=g;c[u+4>>2]=f}h=r;c[h>>2]=g;c[h+4>>2]=f;g=Cd(128,0,k|0,0)|0;h=C;f=b+80+k|0;if(h>>>0>0|(h|0)==0&g>>>0>16){g=f;f=g+16|0;do{a[g>>0]=a[e>>0]|0;g=g+1|0;e=e+1|0}while((g|0)<(f|0))}else{Id(f|0,e|0,g|0)|0;j=b+80|0;Hb(b,j);e=e+g|0;f=Cd(16,0,g|0,h|0)|0;g=C;if(g>>>0>0|(g|0)==0&f>>>0>127)do{Hb(b,e);e=e+128|0;f=Dd(f|0,g|0,-128,-1)|0;g=C}while(g>>>0>0|(g|0)==0&f>>>0>127);Id(j|0,e|0,f|0)|0}e=0;do{u=d+(e<<3)|0;t=b+(e<<3)|0;r=c[t>>2]|0;t=c[t+4>>2]|0;a[u+7>>0]=r;q=Gd(r|0,t|0,8)|0;a[u+6>>0]=q;q=Gd(r|0,t|0,16)|0;a[u+5>>0]=q;q=Gd(r|0,t|0,24)|0;a[u+4>>0]=q;a[u+3>>0]=t;q=Gd(r|0,t|0,40)|0;a[u+2>>0]=q;q=Gd(r|0,t|0,48)|0;a[u+1>>0]=q;t=Gd(r|0,t|0,56)|0;a[u>>0]=t;e=e+1|0}while((e|0)!=8);Fd(b|0,0,208)|0;i=s;return} function yd(a){a=a|0;var b=0,d=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0;do if(a>>>0<245){o=a>>>0<11?16:a+11&-8;a=o>>>3;j=c[8020]|0;b=j>>>a;if(b&3){b=(b&1^1)+a|0;d=32120+(b<<1<<2)|0;e=d+8|0;f=c[e>>2]|0;g=f+8|0;h=c[g>>2]|0;do if((d|0)!=(h|0)){if(h>>>0<(c[8024]|0)>>>0)ra();a=h+12|0;if((c[a>>2]|0)==(f|0)){c[a>>2]=d;c[e>>2]=h;break}else ra()}else c[8020]=j&~(1<>2]=G|3;G=f+G+4|0;c[G>>2]=c[G>>2]|1;G=g;return G|0}h=c[8022]|0;if(o>>>0>h>>>0){if(b){d=2<>>12&16;d=d>>>i;f=d>>>5&8;d=d>>>f;g=d>>>2&4;d=d>>>g;e=d>>>1&2;d=d>>>e;b=d>>>1&1;b=(f|i|g|e|b)+(d>>>b)|0;d=32120+(b<<1<<2)|0;e=d+8|0;g=c[e>>2]|0;i=g+8|0;f=c[i>>2]|0;do if((d|0)!=(f|0)){if(f>>>0<(c[8024]|0)>>>0)ra();a=f+12|0;if((c[a>>2]|0)==(g|0)){c[a>>2]=d;c[e>>2]=f;k=c[8022]|0;break}else ra()}else{c[8020]=j&~(1<>2]=o|3;e=g+o|0;c[e+4>>2]=h|1;c[e+h>>2]=h;if(k){f=c[8025]|0;b=k>>>3;d=32120+(b<<1<<2)|0;a=c[8020]|0;b=1<>2]|0;if(b>>>0<(c[8024]|0)>>>0)ra();else{l=a;m=b}}else{c[8020]=a|b;l=d+8|0;m=d}c[l>>2]=f;c[m+12>>2]=f;c[f+8>>2]=m;c[f+12>>2]=d}c[8022]=h;c[8025]=e;G=i;return G|0}a=c[8021]|0;if(a){i=(a&0-a)+-1|0;F=i>>>12&16;i=i>>>F;E=i>>>5&8;i=i>>>E;G=i>>>2&4;i=i>>>G;b=i>>>1&2;i=i>>>b;j=i>>>1&1;j=c[32384+((E|F|G|b|j)+(i>>>j)<<2)>>2]|0;i=(c[j+4>>2]&-8)-o|0;b=j;while(1){a=c[b+16>>2]|0;if(!a){a=c[b+20>>2]|0;if(!a)break}b=(c[a+4>>2]&-8)-o|0;G=b>>>0>>0;i=G?b:i;b=a;j=G?a:j}f=c[8024]|0;if(j>>>0>>0)ra();h=j+o|0;if(j>>>0>=h>>>0)ra();g=c[j+24>>2]|0;d=c[j+12>>2]|0;do if((d|0)==(j|0)){b=j+20|0;a=c[b>>2]|0;if(!a){b=j+16|0;a=c[b>>2]|0;if(!a){n=0;break}}while(1){d=a+20|0;e=c[d>>2]|0;if(e){a=e;b=d;continue}d=a+16|0;e=c[d>>2]|0;if(!e)break;else{a=e;b=d}}if(b>>>0>>0)ra();else{c[b>>2]=0;n=a;break}}else{e=c[j+8>>2]|0;if(e>>>0>>0)ra();a=e+12|0;if((c[a>>2]|0)!=(j|0))ra();b=d+8|0;if((c[b>>2]|0)==(j|0)){c[a>>2]=d;c[b>>2]=e;n=d;break}else ra()}while(0);do if(g){a=c[j+28>>2]|0;b=32384+(a<<2)|0;if((j|0)==(c[b>>2]|0)){c[b>>2]=n;if(!n){c[8021]=c[8021]&~(1<>>0<(c[8024]|0)>>>0)ra();a=g+16|0;if((c[a>>2]|0)==(j|0))c[a>>2]=n;else c[g+20>>2]=n;if(!n)break}b=c[8024]|0;if(n>>>0>>0)ra();c[n+24>>2]=g;a=c[j+16>>2]|0;do if(a)if(a>>>0>>0)ra();else{c[n+16>>2]=a;c[a+24>>2]=n;break}while(0);a=c[j+20>>2]|0;if(a)if(a>>>0<(c[8024]|0)>>>0)ra();else{c[n+20>>2]=a;c[a+24>>2]=n;break}}while(0);if(i>>>0<16){G=i+o|0;c[j+4>>2]=G|3;G=j+G+4|0;c[G>>2]=c[G>>2]|1}else{c[j+4>>2]=o|3;c[h+4>>2]=i|1;c[h+i>>2]=i;a=c[8022]|0;if(a){e=c[8025]|0;b=a>>>3;d=32120+(b<<1<<2)|0;a=c[8020]|0;b=1<>2]|0;if(b>>>0<(c[8024]|0)>>>0)ra();else{p=a;q=b}}else{c[8020]=a|b;p=d+8|0;q=d}c[p>>2]=e;c[q+12>>2]=e;c[e+8>>2]=q;c[e+12>>2]=d}c[8022]=i;c[8025]=h}G=j+8|0;return G|0}}}else if(a>>>0<=4294967231){a=a+11|0;o=a&-8;k=c[8021]|0;if(k){d=0-o|0;a=a>>>8;if(a)if(o>>>0>16777215)j=31;else{q=(a+1048320|0)>>>16&8;z=a<>>16&4;z=z<>>16&2;j=14-(p|q|j)+(z<>>15)|0;j=o>>>(j+7|0)&1|j<<1}else j=0;b=c[32384+(j<<2)>>2]|0;a:do if(!b){a=0;b=0;z=86}else{f=d;a=0;h=o<<((j|0)==31?0:25-(j>>>1)|0);i=b;b=0;while(1){e=c[i+4>>2]&-8;d=e-o|0;if(d>>>0>>0)if((e|0)==(o|0)){a=i;b=i;z=90;break a}else b=i;else d=f;e=c[i+20>>2]|0;i=c[i+16+(h>>>31<<2)>>2]|0;a=(e|0)==0|(e|0)==(i|0)?a:e;e=(i|0)==0;if(e){z=86;break}else{f=d;h=h<<(e&1^1)}}}while(0);if((z|0)==86){if((a|0)==0&(b|0)==0){a=2<>>12&16;q=q>>>m;l=q>>>5&8;q=q>>>l;n=q>>>2&4;q=q>>>n;p=q>>>1&2;q=q>>>p;a=q>>>1&1;a=c[32384+((l|m|n|p|a)+(q>>>a)<<2)>>2]|0}if(!a){i=d;j=b}else z=90}if((z|0)==90)while(1){z=0;q=(c[a+4>>2]&-8)-o|0;e=q>>>0>>0;d=e?q:d;b=e?a:b;e=c[a+16>>2]|0;if(e){a=e;z=90;continue}a=c[a+20>>2]|0;if(!a){i=d;j=b;break}else z=90}if((j|0)!=0?i>>>0<((c[8022]|0)-o|0)>>>0:0){f=c[8024]|0;if(j>>>0>>0)ra();h=j+o|0;if(j>>>0>=h>>>0)ra();g=c[j+24>>2]|0;d=c[j+12>>2]|0;do if((d|0)==(j|0)){b=j+20|0;a=c[b>>2]|0;if(!a){b=j+16|0;a=c[b>>2]|0;if(!a){s=0;break}}while(1){d=a+20|0;e=c[d>>2]|0;if(e){a=e;b=d;continue}d=a+16|0;e=c[d>>2]|0;if(!e)break;else{a=e;b=d}}if(b>>>0>>0)ra();else{c[b>>2]=0;s=a;break}}else{e=c[j+8>>2]|0;if(e>>>0>>0)ra();a=e+12|0;if((c[a>>2]|0)!=(j|0))ra();b=d+8|0;if((c[b>>2]|0)==(j|0)){c[a>>2]=d;c[b>>2]=e;s=d;break}else ra()}while(0);do if(g){a=c[j+28>>2]|0;b=32384+(a<<2)|0;if((j|0)==(c[b>>2]|0)){c[b>>2]=s;if(!s){c[8021]=c[8021]&~(1<>>0<(c[8024]|0)>>>0)ra();a=g+16|0;if((c[a>>2]|0)==(j|0))c[a>>2]=s;else c[g+20>>2]=s;if(!s)break}b=c[8024]|0;if(s>>>0>>0)ra();c[s+24>>2]=g;a=c[j+16>>2]|0;do if(a)if(a>>>0>>0)ra();else{c[s+16>>2]=a;c[a+24>>2]=s;break}while(0);a=c[j+20>>2]|0;if(a)if(a>>>0<(c[8024]|0)>>>0)ra();else{c[s+20>>2]=a;c[a+24>>2]=s;break}}while(0);do if(i>>>0>=16){c[j+4>>2]=o|3;c[h+4>>2]=i|1;c[h+i>>2]=i;a=i>>>3;if(i>>>0<256){d=32120+(a<<1<<2)|0;b=c[8020]|0;a=1<>2]|0;if(b>>>0<(c[8024]|0)>>>0)ra();else{t=a;v=b}}else{c[8020]=b|a;t=d+8|0;v=d}c[t>>2]=h;c[v+12>>2]=h;c[h+8>>2]=v;c[h+12>>2]=d;break}a=i>>>8;if(a)if(i>>>0>16777215)d=31;else{F=(a+1048320|0)>>>16&8;G=a<>>16&4;G=G<>>16&2;d=14-(E|F|d)+(G<>>15)|0;d=i>>>(d+7|0)&1|d<<1}else d=0;e=32384+(d<<2)|0;c[h+28>>2]=d;a=h+16|0;c[a+4>>2]=0;c[a>>2]=0;a=c[8021]|0;b=1<>2]=h;c[h+24>>2]=e;c[h+12>>2]=h;c[h+8>>2]=h;break}d=i<<((d|0)==31?0:25-(d>>>1)|0);e=c[e>>2]|0;while(1){if((c[e+4>>2]&-8|0)==(i|0)){z=148;break}b=e+16+(d>>>31<<2)|0;a=c[b>>2]|0;if(!a){z=145;break}else{d=d<<1;e=a}}if((z|0)==145)if(b>>>0<(c[8024]|0)>>>0)ra();else{c[b>>2]=h;c[h+24>>2]=e;c[h+12>>2]=h;c[h+8>>2]=h;break}else if((z|0)==148){a=e+8|0;b=c[a>>2]|0;G=c[8024]|0;if(b>>>0>=G>>>0&e>>>0>=G>>>0){c[b+12>>2]=h;c[a>>2]=h;c[h+8>>2]=b;c[h+12>>2]=e;c[h+24>>2]=0;break}else ra()}}else{G=i+o|0;c[j+4>>2]=G|3;G=j+G+4|0;c[G>>2]=c[G>>2]|1}while(0);G=j+8|0;return G|0}}}else o=-1;while(0);d=c[8022]|0;if(d>>>0>=o>>>0){a=d-o|0;b=c[8025]|0;if(a>>>0>15){G=b+o|0;c[8025]=G;c[8022]=a;c[G+4>>2]=a|1;c[G+a>>2]=a;c[b+4>>2]=o|3}else{c[8022]=0;c[8025]=0;c[b+4>>2]=d|3;G=b+d+4|0;c[G>>2]=c[G>>2]|1}G=b+8|0;return G|0}a=c[8023]|0;if(a>>>0>o>>>0){E=a-o|0;c[8023]=E;G=c[8026]|0;F=G+o|0;c[8026]=F;c[F+4>>2]=E|1;c[G+4>>2]=o|3;G=G+8|0;return G|0}do if(!(c[8138]|0)){a=na(30)|0;if(!(a+-1&a)){c[8140]=a;c[8139]=a;c[8141]=-1;c[8142]=-1;c[8143]=0;c[8131]=0;c[8138]=(ta(0)|0)&-16^1431655768;break}else ra()}while(0);h=o+48|0;e=c[8140]|0;i=o+47|0;d=e+i|0;e=0-e|0;j=d&e;if(j>>>0<=o>>>0){G=0;return G|0}a=c[8130]|0;if((a|0)!=0?(t=c[8128]|0,v=t+j|0,v>>>0<=t>>>0|v>>>0>a>>>0):0){G=0;return G|0}b:do if(!(c[8131]&4)){b=c[8026]|0;c:do if(b){f=32528;while(1){a=c[f>>2]|0;if(a>>>0<=b>>>0?(r=f+4|0,(a+(c[r>>2]|0)|0)>>>0>b>>>0):0)break;a=c[f+8>>2]|0;if(!a){z=173;break c}else f=a}a=d-(c[8023]|0)&e;if(a>>>0<2147483647){b=sa(a|0)|0;if((b|0)==((c[f>>2]|0)+(c[r>>2]|0)|0)){if((b|0)!=(-1|0)){h=b;g=a;z=193;break b}}else z=183}}else z=173;while(0);do if((z|0)==173?(u=sa(0)|0,(u|0)!=(-1|0)):0){a=u;b=c[8139]|0;d=b+-1|0;if(!(d&a))a=j;else a=j-a+(d+a&0-b)|0;b=c[8128]|0;d=b+a|0;if(a>>>0>o>>>0&a>>>0<2147483647){v=c[8130]|0;if((v|0)!=0?d>>>0<=b>>>0|d>>>0>v>>>0:0)break;b=sa(a|0)|0;if((b|0)==(u|0)){h=u;g=a;z=193;break b}else z=183}}while(0);d:do if((z|0)==183){d=0-a|0;do if(h>>>0>a>>>0&(a>>>0<2147483647&(b|0)!=(-1|0))?(w=c[8140]|0,w=i-a+w&0-w,w>>>0<2147483647):0)if((sa(w|0)|0)==(-1|0)){sa(d|0)|0;break d}else{a=w+a|0;break}while(0);if((b|0)!=(-1|0)){h=b;g=a;z=193;break b}}while(0);c[8131]=c[8131]|4;z=190}else z=190;while(0);if((((z|0)==190?j>>>0<2147483647:0)?(x=sa(j|0)|0,y=sa(0)|0,x>>>0>>0&((x|0)!=(-1|0)&(y|0)!=(-1|0))):0)?(g=y-x|0,g>>>0>(o+40|0)>>>0):0){h=x;z=193}if((z|0)==193){a=(c[8128]|0)+g|0;c[8128]=a;if(a>>>0>(c[8129]|0)>>>0)c[8129]=a;k=c[8026]|0;do if(k){f=32528;while(1){a=c[f>>2]|0;b=f+4|0;d=c[b>>2]|0;if((h|0)==(a+d|0)){z=203;break}e=c[f+8>>2]|0;if(!e)break;else f=e}if(((z|0)==203?(c[f+12>>2]&8|0)==0:0)?k>>>0>>0&k>>>0>=a>>>0:0){c[b>>2]=d+g;G=k+8|0;G=(G&7|0)==0?0:0-G&7;F=k+G|0;G=g-G+(c[8023]|0)|0;c[8026]=F;c[8023]=G;c[F+4>>2]=G|1;c[F+G+4>>2]=40;c[8027]=c[8142];break}a=c[8024]|0;if(h>>>0
>>0){c[8024]=h;i=h}else i=a;b=h+g|0;a=32528;while(1){if((c[a>>2]|0)==(b|0)){z=211;break}a=c[a+8>>2]|0;if(!a){b=32528;break}}if((z|0)==211)if(!(c[a+12>>2]&8)){c[a>>2]=h;m=a+4|0;c[m>>2]=(c[m>>2]|0)+g;m=h+8|0;m=h+((m&7|0)==0?0:0-m&7)|0;a=b+8|0;a=b+((a&7|0)==0?0:0-a&7)|0;l=m+o|0;j=a-m-o|0;c[m+4>>2]=o|3;do if((a|0)!=(k|0)){if((a|0)==(c[8025]|0)){G=(c[8022]|0)+j|0;c[8022]=G;c[8025]=l;c[l+4>>2]=G|1;c[l+G>>2]=G;break}b=c[a+4>>2]|0;if((b&3|0)==1){h=b&-8;f=b>>>3;e:do if(b>>>0>=256){g=c[a+24>>2]|0;e=c[a+12>>2]|0;do if((e|0)==(a|0)){e=a+16|0;d=e+4|0;b=c[d>>2]|0;if(!b){b=c[e>>2]|0;if(!b){E=0;break}else d=e}while(1){e=b+20|0;f=c[e>>2]|0;if(f){b=f;d=e;continue}e=b+16|0;f=c[e>>2]|0;if(!f)break;else{b=f;d=e}}if(d>>>0>>0)ra();else{c[d>>2]=0;E=b;break}}else{f=c[a+8>>2]|0;if(f>>>0>>0)ra();b=f+12|0;if((c[b>>2]|0)!=(a|0))ra();d=e+8|0;if((c[d>>2]|0)==(a|0)){c[b>>2]=e;c[d>>2]=f;E=e;break}else ra()}while(0);if(!g)break;b=c[a+28>>2]|0;d=32384+(b<<2)|0;do if((a|0)!=(c[d>>2]|0)){if(g>>>0<(c[8024]|0)>>>0)ra();b=g+16|0;if((c[b>>2]|0)==(a|0))c[b>>2]=E;else c[g+20>>2]=E;if(!E)break e}else{c[d>>2]=E;if(E)break;c[8021]=c[8021]&~(1<>>0>>0)ra();c[E+24>>2]=g;b=a+16|0;d=c[b>>2]|0;do if(d)if(d>>>0>>0)ra();else{c[E+16>>2]=d;c[d+24>>2]=E;break}while(0);b=c[b+4>>2]|0;if(!b)break;if(b>>>0<(c[8024]|0)>>>0)ra();else{c[E+20>>2]=b;c[b+24>>2]=E;break}}else{d=c[a+8>>2]|0;e=c[a+12>>2]|0;b=32120+(f<<1<<2)|0;do if((d|0)!=(b|0)){if(d>>>0>>0)ra();if((c[d+12>>2]|0)==(a|0))break;ra()}while(0);if((e|0)==(d|0)){c[8020]=c[8020]&~(1<>>0>>0)ra();b=e+8|0;if((c[b>>2]|0)==(a|0)){B=b;break}ra()}while(0);c[d+12>>2]=e;c[B>>2]=d}while(0);a=a+h|0;f=h+j|0}else f=j;a=a+4|0;c[a>>2]=c[a>>2]&-2;c[l+4>>2]=f|1;c[l+f>>2]=f;a=f>>>3;if(f>>>0<256){d=32120+(a<<1<<2)|0;b=c[8020]|0;a=1<>2]|0;if(b>>>0>=(c[8024]|0)>>>0){F=a;G=b;break}ra()}while(0);c[F>>2]=l;c[G+12>>2]=l;c[l+8>>2]=G;c[l+12>>2]=d;break}a=f>>>8;do if(!a)d=0;else{if(f>>>0>16777215){d=31;break}F=(a+1048320|0)>>>16&8;G=a<>>16&4;G=G<>>16&2;d=14-(E|F|d)+(G<>>15)|0;d=f>>>(d+7|0)&1|d<<1}while(0);e=32384+(d<<2)|0;c[l+28>>2]=d;a=l+16|0;c[a+4>>2]=0;c[a>>2]=0;a=c[8021]|0;b=1<>2]=l;c[l+24>>2]=e;c[l+12>>2]=l;c[l+8>>2]=l;break}d=f<<((d|0)==31?0:25-(d>>>1)|0);e=c[e>>2]|0;while(1){if((c[e+4>>2]&-8|0)==(f|0)){z=281;break}b=e+16+(d>>>31<<2)|0;a=c[b>>2]|0;if(!a){z=278;break}else{d=d<<1;e=a}}if((z|0)==278)if(b>>>0<(c[8024]|0)>>>0)ra();else{c[b>>2]=l;c[l+24>>2]=e;c[l+12>>2]=l;c[l+8>>2]=l;break}else if((z|0)==281){a=e+8|0;b=c[a>>2]|0;G=c[8024]|0;if(b>>>0>=G>>>0&e>>>0>=G>>>0){c[b+12>>2]=l;c[a>>2]=l;c[l+8>>2]=b;c[l+12>>2]=e;c[l+24>>2]=0;break}else ra()}}else{G=(c[8023]|0)+j|0;c[8023]=G;c[8026]=l;c[l+4>>2]=G|1}while(0);G=m+8|0;return G|0}else b=32528;while(1){a=c[b>>2]|0;if(a>>>0<=k>>>0?(A=a+(c[b+4>>2]|0)|0,A>>>0>k>>>0):0)break;b=c[b+8>>2]|0}f=A+-47|0;b=f+8|0;b=f+((b&7|0)==0?0:0-b&7)|0;f=k+16|0;b=b>>>0>>0?k:b;a=b+8|0;d=h+8|0;d=(d&7|0)==0?0:0-d&7;G=h+d|0;d=g+-40-d|0;c[8026]=G;c[8023]=d;c[G+4>>2]=d|1;c[G+d+4>>2]=40;c[8027]=c[8142];d=b+4|0;c[d>>2]=27;c[a>>2]=c[8132];c[a+4>>2]=c[8133];c[a+8>>2]=c[8134];c[a+12>>2]=c[8135];c[8132]=h;c[8133]=g;c[8135]=0;c[8134]=a;a=b+24|0;do{a=a+4|0;c[a>>2]=7}while((a+4|0)>>>0>>0);if((b|0)!=(k|0)){g=b-k|0;c[d>>2]=c[d>>2]&-2;c[k+4>>2]=g|1;c[b>>2]=g;a=g>>>3;if(g>>>0<256){d=32120+(a<<1<<2)|0;b=c[8020]|0;a=1<>2]|0;if(b>>>0<(c[8024]|0)>>>0)ra();else{C=a;D=b}}else{c[8020]=b|a;C=d+8|0;D=d}c[C>>2]=k;c[D+12>>2]=k;c[k+8>>2]=D;c[k+12>>2]=d;break}a=g>>>8;if(a)if(g>>>0>16777215)d=31;else{F=(a+1048320|0)>>>16&8;G=a<>>16&4;G=G<>>16&2;d=14-(E|F|d)+(G<>>15)|0;d=g>>>(d+7|0)&1|d<<1}else d=0;e=32384+(d<<2)|0;c[k+28>>2]=d;c[k+20>>2]=0;c[f>>2]=0;a=c[8021]|0;b=1<>2]=k;c[k+24>>2]=e;c[k+12>>2]=k;c[k+8>>2]=k;break}d=g<<((d|0)==31?0:25-(d>>>1)|0);e=c[e>>2]|0;while(1){if((c[e+4>>2]&-8|0)==(g|0)){z=307;break}b=e+16+(d>>>31<<2)|0;a=c[b>>2]|0;if(!a){z=304;break}else{d=d<<1;e=a}}if((z|0)==304)if(b>>>0<(c[8024]|0)>>>0)ra();else{c[b>>2]=k;c[k+24>>2]=e;c[k+12>>2]=k;c[k+8>>2]=k;break}else if((z|0)==307){a=e+8|0;b=c[a>>2]|0;G=c[8024]|0;if(b>>>0>=G>>>0&e>>>0>=G>>>0){c[b+12>>2]=k;c[a>>2]=k;c[k+8>>2]=b;c[k+12>>2]=e;c[k+24>>2]=0;break}else ra()}}}else{G=c[8024]|0;if((G|0)==0|h>>>0>>0)c[8024]=h;c[8132]=h;c[8133]=g;c[8135]=0;c[8029]=c[8138];c[8028]=-1;a=0;do{G=32120+(a<<1<<2)|0;c[G+12>>2]=G;c[G+8>>2]=G;a=a+1|0}while((a|0)!=32);G=h+8|0;G=(G&7|0)==0?0:0-G&7;F=h+G|0;G=g+-40-G|0;c[8026]=F;c[8023]=G;c[F+4>>2]=G|1;c[F+G+4>>2]=40;c[8027]=c[8142]}while(0);a=c[8023]|0;if(a>>>0>o>>>0){E=a-o|0;c[8023]=E;G=c[8026]|0;F=G+o|0;c[8026]=F;c[F+4>>2]=E|1;c[G+4>>2]=o|3;G=G+8|0;return G|0}}if(!(c[7979]|0))a=31964;else a=c[(oa()|0)+60>>2]|0;c[a>>2]=12;G=0;return G|0}function zd(a){a=a|0;var b=0,d=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0;if(!a)return;d=a+-8|0;h=c[8024]|0;if(d>>>0>>0)ra();a=c[a+-4>>2]|0;b=a&3;if((b|0)==1)ra();e=a&-8;m=d+e|0;do if(!(a&1)){a=c[d>>2]|0;if(!b)return;k=d+(0-a)|0;j=a+e|0;if(k>>>0>>0)ra();if((k|0)==(c[8025]|0)){a=m+4|0;b=c[a>>2]|0;if((b&3|0)!=3){q=k;f=j;break}c[8022]=j;c[a>>2]=b&-2;c[k+4>>2]=j|1;c[k+j>>2]=j;return}e=a>>>3;if(a>>>0<256){b=c[k+8>>2]|0;d=c[k+12>>2]|0;a=32120+(e<<1<<2)|0;if((b|0)!=(a|0)){if(b>>>0>>0)ra();if((c[b+12>>2]|0)!=(k|0))ra()}if((d|0)==(b|0)){c[8020]=c[8020]&~(1<>>0>>0)ra();a=d+8|0;if((c[a>>2]|0)==(k|0))g=a;else ra()}else g=d+8|0;c[b+12>>2]=d;c[g>>2]=b;q=k;f=j;break}g=c[k+24>>2]|0;d=c[k+12>>2]|0;do if((d|0)==(k|0)){d=k+16|0;b=d+4|0;a=c[b>>2]|0;if(!a){a=c[d>>2]|0;if(!a){i=0;break}else b=d}while(1){d=a+20|0;e=c[d>>2]|0;if(e){a=e;b=d;continue}d=a+16|0;e=c[d>>2]|0;if(!e)break;else{a=e;b=d}}if(b>>>0>>0)ra();else{c[b>>2]=0;i=a;break}}else{e=c[k+8>>2]|0;if(e>>>0>>0)ra();a=e+12|0;if((c[a>>2]|0)!=(k|0))ra();b=d+8|0;if((c[b>>2]|0)==(k|0)){c[a>>2]=d;c[b>>2]=e;i=d;break}else ra()}while(0);if(g){a=c[k+28>>2]|0;b=32384+(a<<2)|0;if((k|0)==(c[b>>2]|0)){c[b>>2]=i;if(!i){c[8021]=c[8021]&~(1<>>0<(c[8024]|0)>>>0)ra();a=g+16|0;if((c[a>>2]|0)==(k|0))c[a>>2]=i;else c[g+20>>2]=i;if(!i){q=k;f=j;break}}d=c[8024]|0;if(i>>>0>>0)ra();c[i+24>>2]=g;a=k+16|0;b=c[a>>2]|0;do if(b)if(b>>>0>>0)ra();else{c[i+16>>2]=b;c[b+24>>2]=i;break}while(0);a=c[a+4>>2]|0;if(a)if(a>>>0<(c[8024]|0)>>>0)ra();else{c[i+20>>2]=a;c[a+24>>2]=i;q=k;f=j;break}else{q=k;f=j}}else{q=k;f=j}}else{q=d;f=e}while(0);if(q>>>0>=m>>>0)ra();a=m+4|0;b=c[a>>2]|0;if(!(b&1))ra();if(!(b&2)){if((m|0)==(c[8026]|0)){p=(c[8023]|0)+f|0;c[8023]=p;c[8026]=q;c[q+4>>2]=p|1;if((q|0)!=(c[8025]|0))return;c[8025]=0;c[8022]=0;return}if((m|0)==(c[8025]|0)){p=(c[8022]|0)+f|0;c[8022]=p;c[8025]=q;c[q+4>>2]=p|1;c[q+p>>2]=p;return}f=(b&-8)+f|0;e=b>>>3;do if(b>>>0>=256){g=c[m+24>>2]|0;a=c[m+12>>2]|0;do if((a|0)==(m|0)){d=m+16|0;b=d+4|0;a=c[b>>2]|0;if(!a){a=c[d>>2]|0;if(!a){n=0;break}else b=d}while(1){d=a+20|0;e=c[d>>2]|0;if(e){a=e;b=d;continue}d=a+16|0;e=c[d>>2]|0;if(!e)break;else{a=e;b=d}}if(b>>>0<(c[8024]|0)>>>0)ra();else{c[b>>2]=0;n=a;break}}else{b=c[m+8>>2]|0;if(b>>>0<(c[8024]|0)>>>0)ra();d=b+12|0;if((c[d>>2]|0)!=(m|0))ra();e=a+8|0;if((c[e>>2]|0)==(m|0)){c[d>>2]=a;c[e>>2]=b;n=a;break}else ra()}while(0);if(g){a=c[m+28>>2]|0;b=32384+(a<<2)|0;if((m|0)==(c[b>>2]|0)){c[b>>2]=n;if(!n){c[8021]=c[8021]&~(1<>>0<(c[8024]|0)>>>0)ra();a=g+16|0;if((c[a>>2]|0)==(m|0))c[a>>2]=n;else c[g+20>>2]=n;if(!n)break}d=c[8024]|0;if(n>>>0>>0)ra();c[n+24>>2]=g;a=m+16|0;b=c[a>>2]|0;do if(b)if(b>>>0>>0)ra();else{c[n+16>>2]=b;c[b+24>>2]=n;break}while(0);a=c[a+4>>2]|0;if(a)if(a>>>0<(c[8024]|0)>>>0)ra();else{c[n+20>>2]=a;c[a+24>>2]=n;break}}}else{b=c[m+8>>2]|0;d=c[m+12>>2]|0;a=32120+(e<<1<<2)|0;if((b|0)!=(a|0)){if(b>>>0<(c[8024]|0)>>>0)ra();if((c[b+12>>2]|0)!=(m|0))ra()}if((d|0)==(b|0)){c[8020]=c[8020]&~(1<>>0<(c[8024]|0)>>>0)ra();a=d+8|0;if((c[a>>2]|0)==(m|0))l=a;else ra()}else l=d+8|0;c[b+12>>2]=d;c[l>>2]=b}while(0);c[q+4>>2]=f|1;c[q+f>>2]=f;if((q|0)==(c[8025]|0)){c[8022]=f;return}}else{c[a>>2]=b&-2;c[q+4>>2]=f|1;c[q+f>>2]=f}a=f>>>3;if(f>>>0<256){d=32120+(a<<1<<2)|0;b=c[8020]|0;a=1<>2]|0;if(b>>>0<(c[8024]|0)>>>0)ra();else{o=a;p=b}}else{c[8020]=b|a;o=d+8|0;p=d}c[o>>2]=q;c[p+12>>2]=q;c[q+8>>2]=p;c[q+12>>2]=d;return}a=f>>>8;if(a)if(f>>>0>16777215)d=31;else{o=(a+1048320|0)>>>16&8;p=a<>>16&4;p=p<>>16&2;d=14-(n|o|d)+(p<>>15)|0;d=f>>>(d+7|0)&1|d<<1}else d=0;e=32384+(d<<2)|0;c[q+28>>2]=d;c[q+20>>2]=0;c[q+16>>2]=0;a=c[8021]|0;b=1<>>1)|0);e=c[e>>2]|0;while(1){if((c[e+4>>2]&-8|0)==(f|0)){a=130;break}b=e+16+(d>>>31<<2)|0;a=c[b>>2]|0;if(!a){a=127;break}else{d=d<<1;e=a}}if((a|0)==127)if(b>>>0<(c[8024]|0)>>>0)ra();else{c[b>>2]=q;c[q+24>>2]=e;c[q+12>>2]=q;c[q+8>>2]=q;break}else if((a|0)==130){a=e+8|0;b=c[a>>2]|0;p=c[8024]|0;if(b>>>0>=p>>>0&e>>>0>=p>>>0){c[b+12>>2]=q;c[a>>2]=q;c[q+8>>2]=b;c[q+12>>2]=e;c[q+24>>2]=0;break}else ra()}}else{c[8021]=a|b;c[e>>2]=q;c[q+24>>2]=e;c[q+12>>2]=q;c[q+8>>2]=q}while(0);q=(c[8028]|0)+-1|0;c[8028]=q;if(!q)a=32536;else return;while(1){a=c[a>>2]|0;if(!a)break;else a=a+8|0}c[8028]=-1;return}function Ad(a,b){a=a|0;b=b|0;var d=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0;o=a+b|0;d=c[a+4>>2]|0;do if(!(d&1)){g=c[a>>2]|0;if(!(d&3))return;l=a+(0-g)|0;k=g+b|0;i=c[8024]|0;if(l>>>0>>0)ra();if((l|0)==(c[8025]|0)){a=o+4|0;d=c[a>>2]|0;if((d&3|0)!=3){r=l;f=k;break}c[8022]=k;c[a>>2]=d&-2;c[l+4>>2]=k|1;c[l+k>>2]=k;return}e=g>>>3;if(g>>>0<256){a=c[l+8>>2]|0;b=c[l+12>>2]|0;d=32120+(e<<1<<2)|0;if((a|0)!=(d|0)){if(a>>>0>>0)ra();if((c[a+12>>2]|0)!=(l|0))ra()}if((b|0)==(a|0)){c[8020]=c[8020]&~(1<>>0>>0)ra();d=b+8|0;if((c[d>>2]|0)==(l|0))h=d;else ra()}else h=b+8|0;c[a+12>>2]=b;c[h>>2]=a;r=l;f=k;break}g=c[l+24>>2]|0;b=c[l+12>>2]|0;do if((b|0)==(l|0)){b=l+16|0;a=b+4|0;d=c[a>>2]|0;if(!d){d=c[b>>2]|0;if(!d){j=0;break}else a=b}while(1){b=d+20|0;e=c[b>>2]|0;if(e){d=e;a=b;continue}b=d+16|0;e=c[b>>2]|0;if(!e)break;else{d=e;a=b}}if(a>>>0>>0)ra();else{c[a>>2]=0;j=d;break}}else{e=c[l+8>>2]|0;if(e>>>0>>0)ra();d=e+12|0;if((c[d>>2]|0)!=(l|0))ra();a=b+8|0;if((c[a>>2]|0)==(l|0)){c[d>>2]=b;c[a>>2]=e;j=b;break}else ra()}while(0);if(g){d=c[l+28>>2]|0;a=32384+(d<<2)|0;if((l|0)==(c[a>>2]|0)){c[a>>2]=j;if(!j){c[8021]=c[8021]&~(1<>>0<(c[8024]|0)>>>0)ra();d=g+16|0;if((c[d>>2]|0)==(l|0))c[d>>2]=j;else c[g+20>>2]=j;if(!j){r=l;f=k;break}}b=c[8024]|0;if(j>>>0>>0)ra();c[j+24>>2]=g;d=l+16|0;a=c[d>>2]|0;do if(a)if(a>>>0>>0)ra();else{c[j+16>>2]=a;c[a+24>>2]=j;break}while(0);d=c[d+4>>2]|0;if(d)if(d>>>0<(c[8024]|0)>>>0)ra();else{c[j+20>>2]=d;c[d+24>>2]=j;r=l;f=k;break}else{r=l;f=k}}else{r=l;f=k}}else{r=a;f=b}while(0);h=c[8024]|0;if(o>>>0>>0)ra();d=o+4|0;a=c[d>>2]|0;if(!(a&2)){if((o|0)==(c[8026]|0)){q=(c[8023]|0)+f|0;c[8023]=q;c[8026]=r;c[r+4>>2]=q|1;if((r|0)!=(c[8025]|0))return;c[8025]=0;c[8022]=0;return}if((o|0)==(c[8025]|0)){q=(c[8022]|0)+f|0;c[8022]=q;c[8025]=r;c[r+4>>2]=q|1;c[r+q>>2]=q;return}f=(a&-8)+f|0;e=a>>>3;do if(a>>>0>=256){g=c[o+24>>2]|0;b=c[o+12>>2]|0;do if((b|0)==(o|0)){b=o+16|0;a=b+4|0;d=c[a>>2]|0;if(!d){d=c[b>>2]|0;if(!d){n=0;break}else a=b}while(1){b=d+20|0;e=c[b>>2]|0;if(e){d=e;a=b;continue}b=d+16|0;e=c[b>>2]|0;if(!e)break;else{d=e;a=b}}if(a>>>0>>0)ra();else{c[a>>2]=0;n=d;break}}else{e=c[o+8>>2]|0;if(e>>>0>>0)ra();d=e+12|0;if((c[d>>2]|0)!=(o|0))ra();a=b+8|0;if((c[a>>2]|0)==(o|0)){c[d>>2]=b;c[a>>2]=e;n=b;break}else ra()}while(0);if(g){d=c[o+28>>2]|0;a=32384+(d<<2)|0;if((o|0)==(c[a>>2]|0)){c[a>>2]=n;if(!n){c[8021]=c[8021]&~(1<>>0<(c[8024]|0)>>>0)ra();d=g+16|0;if((c[d>>2]|0)==(o|0))c[d>>2]=n;else c[g+20>>2]=n;if(!n)break}b=c[8024]|0;if(n>>>0>>0)ra();c[n+24>>2]=g;d=o+16|0;a=c[d>>2]|0;do if(a)if(a>>>0>>0)ra();else{c[n+16>>2]=a;c[a+24>>2]=n;break}while(0);d=c[d+4>>2]|0;if(d)if(d>>>0<(c[8024]|0)>>>0)ra();else{c[n+20>>2]=d;c[d+24>>2]=n;break}}}else{a=c[o+8>>2]|0;b=c[o+12>>2]|0;d=32120+(e<<1<<2)|0;if((a|0)!=(d|0)){if(a>>>0>>0)ra();if((c[a+12>>2]|0)!=(o|0))ra()}if((b|0)==(a|0)){c[8020]=c[8020]&~(1<>>0>>0)ra();d=b+8|0;if((c[d>>2]|0)==(o|0))m=d;else ra()}else m=b+8|0;c[a+12>>2]=b;c[m>>2]=a}while(0);c[r+4>>2]=f|1;c[r+f>>2]=f;if((r|0)==(c[8025]|0)){c[8022]=f;return}}else{c[d>>2]=a&-2;c[r+4>>2]=f|1;c[r+f>>2]=f}d=f>>>3;if(f>>>0<256){b=32120+(d<<1<<2)|0;a=c[8020]|0;d=1<>2]|0;if(a>>>0<(c[8024]|0)>>>0)ra();else{p=d;q=a}}else{c[8020]=a|d;p=b+8|0;q=b}c[p>>2]=r;c[q+12>>2]=r;c[r+8>>2]=q;c[r+12>>2]=b;return}d=f>>>8;if(d)if(f>>>0>16777215)b=31;else{p=(d+1048320|0)>>>16&8;q=d<>>16&4;q=q<>>16&2;b=14-(o|p|b)+(q<>>15)|0;b=f>>>(b+7|0)&1|b<<1}else b=0;e=32384+(b<<2)|0;c[r+28>>2]=b;c[r+20>>2]=0;c[r+16>>2]=0;d=c[8021]|0;a=1<>2]=r;c[r+24>>2]=e;c[r+12>>2]=r;c[r+8>>2]=r;return}b=f<<((b|0)==31?0:25-(b>>>1)|0);e=c[e>>2]|0;while(1){if((c[e+4>>2]&-8|0)==(f|0)){d=127;break}a=e+16+(b>>>31<<2)|0;d=c[a>>2]|0;if(!d){d=124;break}else{b=b<<1;e=d}}if((d|0)==124){if(a>>>0<(c[8024]|0)>>>0)ra();c[a>>2]=r;c[r+24>>2]=e;c[r+12>>2]=r;c[r+8>>2]=r;return}else if((d|0)==127){d=e+8|0;a=c[d>>2]|0;q=c[8024]|0;if(!(a>>>0>=q>>>0&e>>>0>=q>>>0))ra();c[a+12>>2]=r;c[d>>2]=r;c[r+8>>2]=a;c[r+12>>2]=e;c[r+24>>2]=0;return}}function Bd(){}function Cd(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;d=b-d-(c>>>0>a>>>0|0)>>>0;return (C=d,a-c>>>0|0)|0}function Dd(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;c=a+c>>>0;return (C=b+d+(c>>>0>>0|0)>>>0,c|0)|0}function Ed(a,b,c){a=a|0;b=b|0;c=c|0;if((c|0)<32){C=b>>c;return a>>>c|(b&(1<>c-32|0}function Fd(b,d,e){b=b|0;d=d|0;e=e|0;var f=0,g=0,h=0,i=0;f=b+e|0;if((e|0)>=20){d=d&255;h=b&3;i=d|d<<8|d<<16|d<<24;g=f&~3;if(h){h=b+4-h|0;while((b|0)<(h|0)){a[b>>0]=d;b=b+1|0}}while((b|0)<(g|0)){c[b>>2]=i;b=b+4|0}}while((b|0)<(f|0)){a[b>>0]=d;b=b+1|0}return b-e|0}function Gd(a,b,c){a=a|0;b=b|0;c=c|0;if((c|0)<32){C=b>>>c;return a>>>c|(b&(1<>>c-32|0}function Hd(a,b,c){a=a|0;b=b|0;c=c|0;if((c|0)<32){C=b<>>32-c;return a<=4096)return va(b|0,d|0,e|0)|0;f=b|0;if((b&3)==(d&3)){while(b&3){if(!e)return f|0;a[b>>0]=a[d>>0]|0;b=b+1|0;d=d+1|0;e=e-1|0}while((e|0)>=4){c[b>>2]=c[d>>2];b=b+4|0;d=d+4|0;e=e-4|0}}while((e|0)>0){a[b>>0]=a[d>>0]|0;b=b+1|0;d=d+1|0;e=e-1|0}return f|0}function Jd(b,c,d){b=b|0;c=c|0;d=d|0;var e=0;if((c|0)<(b|0)&(b|0)<(c+d|0)){e=b;c=c+d|0;b=b+d|0;while((d|0)>0){b=b-1|0;c=c-1|0;d=d-1|0;a[b>>0]=a[c>>0]|0}b=e}else Id(b,c,d)|0;return b|0}function Kd(b){b=b|0;var c=0;c=a[m+(b&255)>>0]|0;if((c|0)<8)return c|0;c=a[m+(b>>8&255)>>0]|0;if((c|0)<8)return c+8|0;c=a[m+(b>>16&255)>>0]|0;if((c|0)<8)return c+16|0;return (a[m+(b>>>24)>>0]|0)+24|0}function Ld(a,b){a=a|0;b=b|0;var c=0,d=0,e=0,f=0;f=a&65535;e=b&65535;c=_(e,f)|0;d=a>>>16;a=(c>>>16)+(_(e,d)|0)|0;e=b>>>16;b=_(e,f)|0;return (C=(a>>>16)+(_(e,d)|0)+(((a&65535)+b|0)>>>16)|0,a+b<<16|c&65535|0)|0}function Md(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0;j=b>>31|((b|0)<0?-1:0)<<1;i=((b|0)<0?-1:0)>>31|((b|0)<0?-1:0)<<1;f=d>>31|((d|0)<0?-1:0)<<1;e=((d|0)<0?-1:0)>>31|((d|0)<0?-1:0)<<1;h=Cd(j^a,i^b,j,i)|0;g=C;a=f^j;b=e^i;return Cd((Rd(h,g,Cd(f^c,e^d,f,e)|0,C,0)|0)^a,C^b,a,b)|0}function Nd(a,b,d,e){a=a|0;b=b|0;d=d|0;e=e|0;var f=0,g=0,h=0,j=0,k=0,l=0;f=i;i=i+16|0;j=f|0;h=b>>31|((b|0)<0?-1:0)<<1;g=((b|0)<0?-1:0)>>31|((b|0)<0?-1:0)<<1;l=e>>31|((e|0)<0?-1:0)<<1;k=((e|0)<0?-1:0)>>31|((e|0)<0?-1:0)<<1;a=Cd(h^a,g^b,h,g)|0;b=C;Rd(a,b,Cd(l^d,k^e,l,k)|0,C,j)|0;e=Cd(c[j>>2]^h,c[j+4>>2]^g,h,g)|0;d=C;i=f;return (C=d,e)|0}function Od(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;var e=0,f=0;e=a;f=c;c=Ld(e,f)|0;a=C;return (C=(_(b,f)|0)+(_(d,e)|0)+a|a&0,c|0|0)|0}function Pd(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;return Rd(a,b,c,d,0)|0}function Qd(a,b,d,e){a=a|0;b=b|0;d=d|0;e=e|0;var f=0,g=0;g=i;i=i+16|0;f=g|0;Rd(a,b,d,e,f)|0;i=g;return (C=c[f+4>>2]|0,c[f>>2]|0)|0}function Rd(a,b,d,e,f){a=a|0;b=b|0;d=d|0;e=e|0;f=f|0;var g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0;l=a;j=b;k=j;h=d;n=e;i=n;if(!k){g=(f|0)!=0;if(!i){if(g){c[f>>2]=(l>>>0)%(h>>>0);c[f+4>>2]=0}n=0;f=(l>>>0)/(h>>>0)>>>0;return (C=n,f)|0}else{if(!g){n=0;f=0;return (C=n,f)|0}c[f>>2]=a|0;c[f+4>>2]=b&0;n=0;f=0;return (C=n,f)|0}}g=(i|0)==0;do if(h){if(!g){g=(aa(i|0)|0)-(aa(k|0)|0)|0;if(g>>>0<=31){m=g+1|0;i=31-g|0;b=g-31>>31;h=m;a=l>>>(m>>>0)&b|k<>>(m>>>0)&b;g=0;i=l<>2]=a|0;c[f+4>>2]=j|b&0;n=0;f=0;return (C=n,f)|0}g=h-1|0;if(g&h){i=(aa(h|0)|0)+33-(aa(k|0)|0)|0;p=64-i|0;m=32-i|0;j=m>>31;o=i-32|0;b=o>>31;h=i;a=m-1>>31&k>>>(o>>>0)|(k<>>(i>>>0))&b;b=b&k>>>(i>>>0);g=l<>>(o>>>0))&j|l<>31;break}if(f){c[f>>2]=g&l;c[f+4>>2]=0}if((h|0)==1){o=j|b&0;p=a|0|0;return (C=o,p)|0}else{p=Kd(h|0)|0;o=k>>>(p>>>0)|0;p=k<<32-p|l>>>(p>>>0)|0;return (C=o,p)|0}}else{if(g){if(f){c[f>>2]=(k>>>0)%(h>>>0);c[f+4>>2]=0}o=0;p=(k>>>0)/(h>>>0)>>>0;return (C=o,p)|0}if(!l){if(f){c[f>>2]=0;c[f+4>>2]=(k>>>0)%(i>>>0)}o=0;p=(k>>>0)/(i>>>0)>>>0;return (C=o,p)|0}g=i-1|0;if(!(g&i)){if(f){c[f>>2]=a|0;c[f+4>>2]=g&k|b&0}o=0;p=k>>>((Kd(i|0)|0)>>>0);return (C=o,p)|0}g=(aa(i|0)|0)-(aa(k|0)|0)|0;if(g>>>0<=30){b=g+1|0;i=31-g|0;h=b;a=k<>>(b>>>0);b=k>>>(b>>>0);g=0;i=l<>2]=a|0;c[f+4>>2]=j|b&0;o=0;p=0;return (C=o,p)|0}while(0);if(!h){k=i;j=0;i=0}else{m=d|0|0;l=n|e&0;k=Dd(m|0,l|0,-1,-1)|0;d=C;j=i;i=0;do{e=j;j=g>>>31|j<<1;g=i|g<<1;e=a<<1|e>>>31|0;n=a>>>31|b<<1|0;Cd(k,d,e,n)|0;p=C;o=p>>31|((p|0)<0?-1:0)<<1;i=o&1;a=Cd(e,n,o&m,(((p|0)<0?-1:0)>>31|((p|0)<0?-1:0)<<1)&l)|0;b=C;h=h-1|0}while((h|0)!=0);k=j;j=0}h=0;if(f){c[f>>2]=a;c[f+4>>2]=b}o=(g|0)>>>31|(k|h)<<1|(h<<1|g>>>31)&0|j;p=(g<<1|0>>>31)&-2|i;return (C=o,p)|0}function Sd(a){a=a|0;return Da[a&31]()|0}function Td(){return ea(0)|0}function Ud(){return ea(1)|0}function Vd(){return ea(2)|0}function Wd(){return ea(3)|0}function Xd(){return ea(4)|0}function Yd(){return ea(5)|0}function Zd(){return ea(6)|0}function _d(){return ea(7)|0}function $d(a,b){a=a|0;b=b|0;return Ea[a&31](b|0)|0}function ae(a){a=a|0;return ga(0,a|0)|0}function be(a){a=a|0;return ga(1,a|0)|0}function ce(a){a=a|0;return ga(2,a|0)|0}function de(a){a=a|0;return ga(3,a|0)|0}function ee(a){a=a|0;return ga(4,a|0)|0}function fe(a){a=a|0;return ga(5,a|0)|0}function ge(a){a=a|0;return ga(6,a|0)|0}function he(a){a=a|0;return ga(7,a|0)|0}function ie(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;return Fa[a&31](b|0,c|0,d|0)|0}function je(a,b,c){a=a|0;b=b|0;c=c|0;return ia(0,a|0,b|0,c|0)|0}function ke(a,b,c){a=a|0;b=b|0;c=c|0;return ia(1,a|0,b|0,c|0)|0}function le(a,b,c){a=a|0;b=b|0;c=c|0;return ia(2,a|0,b|0,c|0)|0}function me(a,b,c){a=a|0;b=b|0;c=c|0;return ia(3,a|0,b|0,c|0)|0}function ne(a,b,c){a=a|0;b=b|0;c=c|0;return ia(4,a|0,b|0,c|0)|0}function oe(a,b,c){a=a|0;b=b|0;c=c|0;return ia(5,a|0,b|0,c|0)|0}function pe(a,b,c){a=a|0;b=b|0;c=c|0;return ia(6,a|0,b|0,c|0)|0}function qe(a,b,c){a=a|0;b=b|0;c=c|0;return ia(7,a|0,b|0,c|0)|0}function re(a,b){a=a|0;b=b|0;Ga[a&31](b|0)}function se(a){a=a|0;ka(0,a|0)}function te(a){a=a|0;ka(1,a|0)}function ue(a){a=a|0;ka(2,a|0)}function ve(a){a=a|0;ka(3,a|0)}function we(a){a=a|0;ka(4,a|0)}function xe(a){a=a|0;ka(5,a|0)}function ye(a){a=a|0;ka(6,a|0)}function ze(a){a=a|0;ka(7,a|0)}function Ae(){ba(0);return 0}function Be(a){a=a|0;ba(1);return 0}function Ce(a,b,c){a=a|0;b=b|0;c=c|0;ba(2);return 0}function De(a){a=a|0;ba(3)} // EMSCRIPTEN_END_FUNCS var Da=[Ae,Ae,Td,Ae,Ud,Ae,Vd,Ae,Wd,Ae,Xd,Ae,Yd,Ae,Zd,Ae,_d,Ae,Ae,Ae,Ae,Ae,Ae,Ae,Ae,Ae,Ae,Ae,Ae,Ae,Ae,Ae];var Ea=[Be,Be,ae,Be,be,Be,ce,Be,de,Be,ee,Be,fe,Be,ge,Be,he,Be,pd,Be,Be,Be,Be,Be,Be,Be,Be,Be,Be,Be,Be,Be];var Fa=[Ce,Ce,je,Ce,ke,Ce,le,Ce,me,Ce,ne,Ce,oe,Ce,pe,Ce,qe,Ce,sd,qd,rd,Ce,Ce,Ce,Ce,Ce,Ce,Ce,Ce,Ce,Ce,Ce];var Ga=[De,De,se,De,te,De,ue,De,ve,De,we,De,xe,De,ye,De,ze,De,wd,De,De,De,De,De,De,De,De,De,De,De,De,De];return{_sodium_library_version_minor:jd,_crypto_onetimeauth_bytes:Jb,_sodium_version_string:hd,_sodium_hex2bin:gd,_crypto_pwhash_scryptsalsa208sha256_memlimit_sensitive:dc,_bitshift64Lshr:Gd,_crypto_pwhash_scryptsalsa208sha256:ec,_crypto_box_noncebytes:Za,_crypto_box_beforenm:bb,_crypto_scalarmult_base:mc,_crypto_auth_bytes:Qa,_crypto_sign_open:Fc,_memcpy:Id,_crypto_box_seed_keypair:$a,_crypto_pwhash_scryptsalsa208sha256_memlimit_interactive:bc,_crypto_box_open_easy_afternm:ib,_crypto_sign_ed25519_sk_to_curve25519:Uc,_sodium_memzero:ed,_crypto_box_seal:kb,_free:zd,_crypto_shorthash:xc,_crypto_auth_keybytes:Ra,_crypto_pwhash_scryptsalsa208sha256_saltbytes:Zb,_crypto_sign_seedbytes:zc,_crypto_box_detached_afternm:cb,_crypto_auth:Sa,_randombytes_random:_c,_crypto_sign_keypair:Dc,_crypto_shorthash_keybytes:wc,_crypto_generichash_statebytes:vb,_crypto_pwhash_scryptsalsa208sha256_str_verify:gc,_crypto_generichash_init:xb,_crypto_generichash_keybytes_max:tb,_crypto_sign_ed25519_pk_to_curve25519:Tc,_crypto_box_beforenmbytes:Ya,_crypto_generichash:wb,_sodium_library_version_major:id,_randombytes_stir:$c,_randombytes_close:cd,_crypto_onetimeauth_keybytes:Kb,_crypto_onetimeauth:Lb,_crypto_shorthash_bytes:vc,_crypto_box_secretkeybytes:Xa,_crypto_onetimeauth_update:Ob,_crypto_pwhash_scryptsalsa208sha256_ll:Wb,_crypto_box_detached:db,_randombytes_buf:bd,_crypto_pwhash_scryptsalsa208sha256_str:fc,_bitshift64Ashr:Ed,_crypto_box_open_detached:hb,_crypto_scalarmult_bytes:kc,_crypto_auth_verify:Ta,_crypto_box_seal_open:lb,_crypto_secretbox_detached:rc,_crypto_secretbox_easy:sc,_crypto_pwhash_scryptsalsa208sha256_strbytes:_b,_memset:Fd,_crypto_box_open_detached_afternm:gb,_crypto_box_sealbytes:mb,_i64Subtract:Cd,_crypto_pwhash_scryptsalsa208sha256_strprefix:$b,_crypto_box_seedbytes:Va,_crypto_hash:Cb,_crypto_box_easy_afternm:eb,_crypto_box_macbytes:_a,_crypto_box_publickeybytes:Wa,_sodium_bin2hex:fd,_crypto_sign_secretkeybytes:Bc,_crypto_scalarmult_scalarbytes:lc,_crypto_onetimeauth_statebytes:Ib,_crypto_generichash_keybytes_min:sb,_malloc:yd,_memmove:Jd,_crypto_sign:Ec,_crypto_secretbox_noncebytes:pc,_randombytes_set_implementation:Zc,_crypto_box_keypair:ab,_crypto_generichash_keybytes:ub,_crypto_generichash_bytes_min:pb,_sodium_init:dd,_crypto_secretbox_macbytes:qc,_crypto_secretbox_keybytes:oc,_bitshift64Shl:Hd,_crypto_hash_bytes:Bb,_fflush:td,_crypto_generichash_bytes:rb,_crypto_generichash_bytes_max:qb,_crypto_secretbox_open_detached:tc,_crypto_sign_verify_detached:Hc,_crypto_onetimeauth_verify:Mb,_crypto_box_open_easy:jb,_crypto_pwhash_scryptsalsa208sha256_opslimit_sensitive:cc,_crypto_sign_publickeybytes:Ac,_i64Add:Dd,_crypto_sign_bytes:yc,_crypto_generichash_update:yb,_crypto_scalarmult:nc,_crypto_sign_detached:Gc,_crypto_box_easy:fb,___errno_location:od,_crypto_onetimeauth_final:Pb,_crypto_secretbox_open_easy:uc,_crypto_generichash_final:zb,_randombytes_uniform:ad,_crypto_sign_seed_keypair:Cc,_crypto_pwhash_scryptsalsa208sha256_opslimit_interactive:ac,_crypto_onetimeauth_init:Nb,runPostSets:Bd,stackAlloc:Ha,stackSave:Ia,stackRestore:Ja,establishStackSpace:Ka,setThrew:La,setTempRet0:Oa,getTempRet0:Pa,dynCall_i:Sd,dynCall_ii:$d,dynCall_iiii:ie,dynCall_vi:re}}) // EMSCRIPTEN_END_ASM (Module.asmGlobalArg,Module.asmLibraryArg,buffer);var _sodium_library_version_minor=Module["_sodium_library_version_minor"]=asm["_sodium_library_version_minor"];var _crypto_onetimeauth_bytes=Module["_crypto_onetimeauth_bytes"]=asm["_crypto_onetimeauth_bytes"];var _crypto_pwhash_scryptsalsa208sha256_memlimit_sensitive=Module["_crypto_pwhash_scryptsalsa208sha256_memlimit_sensitive"]=asm["_crypto_pwhash_scryptsalsa208sha256_memlimit_sensitive"];var _bitshift64Lshr=Module["_bitshift64Lshr"]=asm["_bitshift64Lshr"];var _crypto_pwhash_scryptsalsa208sha256=Module["_crypto_pwhash_scryptsalsa208sha256"]=asm["_crypto_pwhash_scryptsalsa208sha256"];var _crypto_box_noncebytes=Module["_crypto_box_noncebytes"]=asm["_crypto_box_noncebytes"];var _crypto_box_beforenm=Module["_crypto_box_beforenm"]=asm["_crypto_box_beforenm"];var _crypto_scalarmult_base=Module["_crypto_scalarmult_base"]=asm["_crypto_scalarmult_base"];var _crypto_auth_bytes=Module["_crypto_auth_bytes"]=asm["_crypto_auth_bytes"];var _crypto_sign_open=Module["_crypto_sign_open"]=asm["_crypto_sign_open"];var _memcpy=Module["_memcpy"]=asm["_memcpy"];var _crypto_box_seed_keypair=Module["_crypto_box_seed_keypair"]=asm["_crypto_box_seed_keypair"];var _crypto_pwhash_scryptsalsa208sha256_memlimit_interactive=Module["_crypto_pwhash_scryptsalsa208sha256_memlimit_interactive"]=asm["_crypto_pwhash_scryptsalsa208sha256_memlimit_interactive"];var _crypto_box_open_easy_afternm=Module["_crypto_box_open_easy_afternm"]=asm["_crypto_box_open_easy_afternm"];var _crypto_sign_ed25519_sk_to_curve25519=Module["_crypto_sign_ed25519_sk_to_curve25519"]=asm["_crypto_sign_ed25519_sk_to_curve25519"];var _sodium_memzero=Module["_sodium_memzero"]=asm["_sodium_memzero"];var _crypto_box_seal=Module["_crypto_box_seal"]=asm["_crypto_box_seal"];var _free=Module["_free"]=asm["_free"];var runPostSets=Module["runPostSets"]=asm["runPostSets"];var _crypto_shorthash=Module["_crypto_shorthash"]=asm["_crypto_shorthash"];var _crypto_auth_keybytes=Module["_crypto_auth_keybytes"]=asm["_crypto_auth_keybytes"];var _crypto_pwhash_scryptsalsa208sha256_saltbytes=Module["_crypto_pwhash_scryptsalsa208sha256_saltbytes"]=asm["_crypto_pwhash_scryptsalsa208sha256_saltbytes"];var _crypto_sign_seedbytes=Module["_crypto_sign_seedbytes"]=asm["_crypto_sign_seedbytes"];var _crypto_box_detached_afternm=Module["_crypto_box_detached_afternm"]=asm["_crypto_box_detached_afternm"];var _crypto_auth=Module["_crypto_auth"]=asm["_crypto_auth"];var _randombytes_random=Module["_randombytes_random"]=asm["_randombytes_random"];var _crypto_sign_keypair=Module["_crypto_sign_keypair"]=asm["_crypto_sign_keypair"];var _crypto_generichash_keybytes_min=Module["_crypto_generichash_keybytes_min"]=asm["_crypto_generichash_keybytes_min"];var _crypto_generichash_statebytes=Module["_crypto_generichash_statebytes"]=asm["_crypto_generichash_statebytes"];var _crypto_pwhash_scryptsalsa208sha256_str_verify=Module["_crypto_pwhash_scryptsalsa208sha256_str_verify"]=asm["_crypto_pwhash_scryptsalsa208sha256_str_verify"];var _sodium_version_string=Module["_sodium_version_string"]=asm["_sodium_version_string"];var _crypto_generichash_keybytes_max=Module["_crypto_generichash_keybytes_max"]=asm["_crypto_generichash_keybytes_max"];var _crypto_sign_ed25519_pk_to_curve25519=Module["_crypto_sign_ed25519_pk_to_curve25519"]=asm["_crypto_sign_ed25519_pk_to_curve25519"];var _crypto_sign_publickeybytes=Module["_crypto_sign_publickeybytes"]=asm["_crypto_sign_publickeybytes"];var _crypto_box_beforenmbytes=Module["_crypto_box_beforenmbytes"]=asm["_crypto_box_beforenmbytes"];var _crypto_generichash=Module["_crypto_generichash"]=asm["_crypto_generichash"];var _sodium_library_version_major=Module["_sodium_library_version_major"]=asm["_sodium_library_version_major"];var _randombytes_stir=Module["_randombytes_stir"]=asm["_randombytes_stir"];var _crypto_shorthash_keybytes=Module["_crypto_shorthash_keybytes"]=asm["_crypto_shorthash_keybytes"];var _randombytes_close=Module["_randombytes_close"]=asm["_randombytes_close"];var _crypto_onetimeauth_keybytes=Module["_crypto_onetimeauth_keybytes"]=asm["_crypto_onetimeauth_keybytes"];var _crypto_onetimeauth=Module["_crypto_onetimeauth"]=asm["_crypto_onetimeauth"];var _crypto_shorthash_bytes=Module["_crypto_shorthash_bytes"]=asm["_crypto_shorthash_bytes"];var _crypto_box_secretkeybytes=Module["_crypto_box_secretkeybytes"]=asm["_crypto_box_secretkeybytes"];var _crypto_onetimeauth_update=Module["_crypto_onetimeauth_update"]=asm["_crypto_onetimeauth_update"];var _crypto_pwhash_scryptsalsa208sha256_ll=Module["_crypto_pwhash_scryptsalsa208sha256_ll"]=asm["_crypto_pwhash_scryptsalsa208sha256_ll"];var _crypto_box_detached=Module["_crypto_box_detached"]=asm["_crypto_box_detached"];var _randombytes_buf=Module["_randombytes_buf"]=asm["_randombytes_buf"];var _crypto_pwhash_scryptsalsa208sha256_strbytes=Module["_crypto_pwhash_scryptsalsa208sha256_strbytes"]=asm["_crypto_pwhash_scryptsalsa208sha256_strbytes"];var _bitshift64Ashr=Module["_bitshift64Ashr"]=asm["_bitshift64Ashr"];var _crypto_box_open_detached=Module["_crypto_box_open_detached"]=asm["_crypto_box_open_detached"];var _crypto_scalarmult_bytes=Module["_crypto_scalarmult_bytes"]=asm["_crypto_scalarmult_bytes"];var _crypto_auth_verify=Module["_crypto_auth_verify"]=asm["_crypto_auth_verify"];var _crypto_sign_detached=Module["_crypto_sign_detached"]=asm["_crypto_sign_detached"];var _crypto_secretbox_detached=Module["_crypto_secretbox_detached"]=asm["_crypto_secretbox_detached"];var _crypto_secretbox_easy=Module["_crypto_secretbox_easy"]=asm["_crypto_secretbox_easy"];var _crypto_pwhash_scryptsalsa208sha256_str=Module["_crypto_pwhash_scryptsalsa208sha256_str"]=asm["_crypto_pwhash_scryptsalsa208sha256_str"];var _memset=Module["_memset"]=asm["_memset"];var _crypto_box_open_detached_afternm=Module["_crypto_box_open_detached_afternm"]=asm["_crypto_box_open_detached_afternm"];var _crypto_box_sealbytes=Module["_crypto_box_sealbytes"]=asm["_crypto_box_sealbytes"];var _i64Subtract=Module["_i64Subtract"]=asm["_i64Subtract"];var _crypto_pwhash_scryptsalsa208sha256_strprefix=Module["_crypto_pwhash_scryptsalsa208sha256_strprefix"]=asm["_crypto_pwhash_scryptsalsa208sha256_strprefix"];var _crypto_box_seedbytes=Module["_crypto_box_seedbytes"]=asm["_crypto_box_seedbytes"];var _crypto_hash=Module["_crypto_hash"]=asm["_crypto_hash"];var _crypto_box_easy_afternm=Module["_crypto_box_easy_afternm"]=asm["_crypto_box_easy_afternm"];var _crypto_box_macbytes=Module["_crypto_box_macbytes"]=asm["_crypto_box_macbytes"];var _crypto_box_publickeybytes=Module["_crypto_box_publickeybytes"]=asm["_crypto_box_publickeybytes"];var _sodium_bin2hex=Module["_sodium_bin2hex"]=asm["_sodium_bin2hex"];var _crypto_sign_secretkeybytes=Module["_crypto_sign_secretkeybytes"]=asm["_crypto_sign_secretkeybytes"];var _crypto_scalarmult_scalarbytes=Module["_crypto_scalarmult_scalarbytes"]=asm["_crypto_scalarmult_scalarbytes"];var _crypto_onetimeauth_statebytes=Module["_crypto_onetimeauth_statebytes"]=asm["_crypto_onetimeauth_statebytes"];var _crypto_generichash_bytes_min=Module["_crypto_generichash_bytes_min"]=asm["_crypto_generichash_bytes_min"];var _malloc=Module["_malloc"]=asm["_malloc"];var _crypto_secretbox_open_easy=Module["_crypto_secretbox_open_easy"]=asm["_crypto_secretbox_open_easy"];var _crypto_sign=Module["_crypto_sign"]=asm["_crypto_sign"];var _crypto_secretbox_noncebytes=Module["_crypto_secretbox_noncebytes"]=asm["_crypto_secretbox_noncebytes"];var _randombytes_set_implementation=Module["_randombytes_set_implementation"]=asm["_randombytes_set_implementation"];var _crypto_box_keypair=Module["_crypto_box_keypair"]=asm["_crypto_box_keypair"];var _crypto_generichash_keybytes=Module["_crypto_generichash_keybytes"]=asm["_crypto_generichash_keybytes"];var _sodium_hex2bin=Module["_sodium_hex2bin"]=asm["_sodium_hex2bin"];var _sodium_init=Module["_sodium_init"]=asm["_sodium_init"];var _crypto_secretbox_macbytes=Module["_crypto_secretbox_macbytes"]=asm["_crypto_secretbox_macbytes"];var _crypto_secretbox_keybytes=Module["_crypto_secretbox_keybytes"]=asm["_crypto_secretbox_keybytes"];var _bitshift64Shl=Module["_bitshift64Shl"]=asm["_bitshift64Shl"];var _crypto_hash_bytes=Module["_crypto_hash_bytes"]=asm["_crypto_hash_bytes"];var _fflush=Module["_fflush"]=asm["_fflush"];var _crypto_generichash_bytes=Module["_crypto_generichash_bytes"]=asm["_crypto_generichash_bytes"];var _crypto_generichash_bytes_max=Module["_crypto_generichash_bytes_max"]=asm["_crypto_generichash_bytes_max"];var _crypto_secretbox_open_detached=Module["_crypto_secretbox_open_detached"]=asm["_crypto_secretbox_open_detached"];var _crypto_sign_verify_detached=Module["_crypto_sign_verify_detached"]=asm["_crypto_sign_verify_detached"];var _crypto_onetimeauth_verify=Module["_crypto_onetimeauth_verify"]=asm["_crypto_onetimeauth_verify"];var _crypto_box_open_easy=Module["_crypto_box_open_easy"]=asm["_crypto_box_open_easy"];var _crypto_pwhash_scryptsalsa208sha256_opslimit_sensitive=Module["_crypto_pwhash_scryptsalsa208sha256_opslimit_sensitive"]=asm["_crypto_pwhash_scryptsalsa208sha256_opslimit_sensitive"];var _crypto_generichash_init=Module["_crypto_generichash_init"]=asm["_crypto_generichash_init"];var _i64Add=Module["_i64Add"]=asm["_i64Add"];var _crypto_sign_bytes=Module["_crypto_sign_bytes"]=asm["_crypto_sign_bytes"];var _crypto_generichash_update=Module["_crypto_generichash_update"]=asm["_crypto_generichash_update"];var _crypto_scalarmult=Module["_crypto_scalarmult"]=asm["_crypto_scalarmult"];var _crypto_box_seal_open=Module["_crypto_box_seal_open"]=asm["_crypto_box_seal_open"];var _crypto_box_easy=Module["_crypto_box_easy"]=asm["_crypto_box_easy"];var ___errno_location=Module["___errno_location"]=asm["___errno_location"];var _crypto_onetimeauth_final=Module["_crypto_onetimeauth_final"]=asm["_crypto_onetimeauth_final"];var _memmove=Module["_memmove"]=asm["_memmove"];var _crypto_generichash_final=Module["_crypto_generichash_final"]=asm["_crypto_generichash_final"];var _randombytes_uniform=Module["_randombytes_uniform"]=asm["_randombytes_uniform"];var _crypto_sign_seed_keypair=Module["_crypto_sign_seed_keypair"]=asm["_crypto_sign_seed_keypair"];var _crypto_pwhash_scryptsalsa208sha256_opslimit_interactive=Module["_crypto_pwhash_scryptsalsa208sha256_opslimit_interactive"]=asm["_crypto_pwhash_scryptsalsa208sha256_opslimit_interactive"];var _crypto_onetimeauth_init=Module["_crypto_onetimeauth_init"]=asm["_crypto_onetimeauth_init"];var dynCall_i=Module["dynCall_i"]=asm["dynCall_i"];var dynCall_ii=Module["dynCall_ii"]=asm["dynCall_ii"];var dynCall_iiii=Module["dynCall_iiii"]=asm["dynCall_iiii"];var dynCall_vi=Module["dynCall_vi"]=asm["dynCall_vi"];Runtime.stackAlloc=asm["stackAlloc"];Runtime.stackSave=asm["stackSave"];Runtime.stackRestore=asm["stackRestore"];Runtime.establishStackSpace=asm["establishStackSpace"];Runtime.setTempRet0=asm["setTempRet0"];Runtime.getTempRet0=asm["getTempRet0"];function ExitStatus(status){this.name="ExitStatus";this.message="Program terminated with exit("+status+")";this.status=status}ExitStatus.prototype=new Error;ExitStatus.prototype.constructor=ExitStatus;var initialStackTop;var preloadStartTime=null;var calledMain=false;dependenciesFulfilled=function runCaller(){if(!Module["calledRun"])run();if(!Module["calledRun"])dependenciesFulfilled=runCaller};Module["callMain"]=Module.callMain=function callMain(args){assert(runDependencies==0,"cannot call main when async dependencies remain! (listen on __ATMAIN__)");assert(__ATPRERUN__.length==0,"cannot call main when preRun functions remain to be called");args=args||[];ensureInitRuntime();var argc=args.length+1;function pad(){for(var i=0;i<4-1;i++){argv.push(0)}}var argv=[allocate(intArrayFromString(Module["thisProgram"]),"i8",ALLOC_NORMAL)];pad();for(var i=0;i0){return}preRun();if(runDependencies>0)return;if(Module["calledRun"])return;function doRun(){if(Module["calledRun"])return;Module["calledRun"]=true;if(ABORT)return;ensureInitRuntime();preMain();if(Module["onRuntimeInitialized"])Module["onRuntimeInitialized"]();if(Module["_main"]&&shouldRunNow)Module["callMain"](args);postRun()}if(Module["setStatus"]){Module["setStatus"]("Running...");setTimeout((function(){setTimeout((function(){Module["setStatus"]("")}),1);doRun()}),1)}else{doRun()}}Module["run"]=Module.run=run;function exit(status,implicit){if(implicit&&Module["noExitRuntime"]){return}if(Module["noExitRuntime"]){}else{ABORT=true;EXITSTATUS=status;STACKTOP=initialStackTop;exitRuntime();if(Module["onExit"])Module["onExit"](status)}if(ENVIRONMENT_IS_NODE){process["stdout"]["once"]("drain",(function(){process["exit"](status)}));console.log(" ");setTimeout((function(){process["exit"](status)}),500)}else if(ENVIRONMENT_IS_SHELL&&typeof quit==="function"){quit(status)}throw new ExitStatus(status)}Module["exit"]=Module.exit=exit;var abortDecorators=[];function abort(what){if(what!==undefined){Module.print(what);Module.printErr(what);what=JSON.stringify(what)}else{what=""}ABORT=true;EXITSTATUS=1;var extra="\nIf this abort() is unexpected, build with -s ASSERTIONS=1 which can give more information.";var output="abort("+what+") at "+stackTrace()+extra;if(abortDecorators){abortDecorators.forEach((function(decorator){output=decorator(output,what)}))}throw output}Module["abort"]=Module.abort=abort;if(Module["preInit"]){if(typeof Module["preInit"]=="function")Module["preInit"]=[Module["preInit"]];while(Module["preInit"].length>0){Module["preInit"].pop()()}}var shouldRunNow=true;if(Module["noInitialRun"]){shouldRunNow=false}run() return Module; }); }).call(this,require('_process'),require("buffer").Buffer,"/node_modules/libsodium/dist/modules") },{"_process":295,"buffer":61,"crypto":110,"fs":58,"path":290}],224:[function(require,module,exports){ 'use strict'; /** * Get the count of the longest repeating streak of * `character` in `value`. * * @example * longestStreak('` foo `` bar `', '`') // 2 * * @param {string} value - Content, coerced to string. * @param {string} character - Single character to look * for. * @return {number} - Number of characters at the place * where `character` occurs in its longest streak in * `value`. * @throws {Error} - when `character` is not a single * character. */ function longestStreak(value, character) { var count = 0; var maximum = 0; var index = -1; var length; value = String(value); length = value.length; if (typeof character !== 'string' || character.length !== 1) { throw new Error('Expected character'); } while (++index < length) { if (value.charAt(index) === character) { count++; if (count > maximum) { maximum = count; } } else { count = 0; } } return maximum; } /* * Expose. */ module.exports = longestStreak; },{}],225:[function(require,module,exports){ var looper = module.exports = function (fun) { return function next (a, b, c) { var loop = true, returned = false, sync = false do { sync = true; loop = false fun.call(function (x, y, z) { if(sync) { a = x; b = y; c = z loop = true } else next(x, y, z) }, a, b, c) sync = false } while(loop) } } },{}],226:[function(require,module,exports){ (function (Buffer){ exports.compare = function (a, b) { if(Buffer.isBuffer(a)) { var l = Math.min(a.length, b.length) for(var i = 0; i < l; i++) { var cmp = a[i] - b[i] if(cmp) return cmp } return a.length - b.length } return a < b ? -1 : a > b ? 1 : 0 } function has(obj, key) { return Object.hasOwnProperty.call(obj, key) } // to be compatible with the current abstract-leveldown tests // nullish or empty strings. // I could use !!val but I want to permit numbers and booleans, // if possible. function isDef (val) { return val !== undefined && val !== '' } function has (range, name) { return Object.hasOwnProperty.call(range, name) } function hasKey(range, name) { return Object.hasOwnProperty.call(range, name) && name } var lowerBoundKey = exports.lowerBoundKey = function (range) { return ( hasKey(range, 'gt') || hasKey(range, 'gte') || hasKey(range, 'min') || (range.reverse ? hasKey(range, 'end') : hasKey(range, 'start')) || undefined ) } var lowerBound = exports.lowerBound = function (range) { var k = lowerBoundKey(range) return k && range[k] return ( has(range, 'gt') ? range.gt : has(range, 'gte') ? range.gte : has(range, 'min') ? range.min : has(range, 'start') && !range.reverse ? range.start : has(range, 'end') && range.reverse ? range.end : undefined ) } exports.lowerBoundInclusive = function (range) { return has(range, 'gt') ? false : true } exports.upperBoundInclusive = function (range) { return has(range, 'lt') || !range.minEx ? false : true } var lowerBoundExclusive = exports.lowerBoundExclusive = function (range) { return has(range, 'gt') || range.minEx ? true : false } var upperBoundExclusive = exports.upperBoundExclusive = function (range) { return has(range, 'lt') ? true : false } var upperBoundKey = exports.upperBoundKey = function (range) { return ( hasKey(range, 'lt') || hasKey(range, 'lte') || hasKey(range, 'max') || (range.reverse ? hasKey(range, 'start') : hasKey(range, 'end')) || undefined ) } var upperBound = exports.upperBound = function (range) { var k = upperBoundKey(range) return k && range[k] } function id (e) { return e } exports.toLtgt = function (range, _range, map, lower, upper) { _range = _range || {} map = map || id var defaults = arguments.length > 3 var lb = exports.lowerBoundKey(range) var ub = exports.upperBoundKey(range) if(lb) { if(lb === 'gt') _range.gt = map(range.gt) else _range.gte = map(range[lb]) } else if(defaults) _range.gte = map(lower) if(ub) { if(ub === 'lt') _range.lt = map(range.lt) else _range.lte = map(range[ub]) } else if(defaults) _range.lte = map(upper) if(range.reverse != null) _range.reverse = !!range.reverse return _range } exports.contains = function (range, key, compare) { compare = compare || exports.compare var lb = lowerBound(range) if(isDef(lb)) { var cmp = compare(key, lb) if(cmp < 0 || (cmp === 0 && lowerBoundExclusive(range))) return false } var ub = upperBound(range) if(isDef(ub)) { var cmp = compare(key, ub) if(cmp > 0 || (cmp === 0) && upperBoundExclusive(range)) return false } return true } exports.filter = function (range, compare) { return function (key) { return exports.contains(range, key, compare) } } }).call(this,{"isBuffer":require("../is-buffer/index.js")}) },{"../is-buffer/index.js":170}],227:[function(require,module,exports){ module.exports = { $count: function (a, b) { if(b === undefined) return (a||0) return (a||0)+1 }, $sum: function (a, b) { if(b === undefined) return (a||0) return (a||0)+(b||0) }, $max: function (a, b) { if(b === undefined) a if(a === undefined) return b return Math.max(a, b) }, $min: function (a, b) { if(b === undefined) a if(a === undefined) return b return Math.min(a, b) }, $collect: function (a, b) { if(!a) a = a || [] if(!Array.isArray(a)) a = [a] if(b == undefined) return a a.push(b) return a } } },{}],228:[function(require,module,exports){ var u = require('./util') var isBasic = u.isBasic var isRange = u.isRange var isString = u.isString var isLtgt = u.isLtgt var isObject = u.isObject var isArray = u.isArray var has = u.has var map = u.map function exact(q) { return function (v) { return q === v } } function prefix(p) { if(isString(p)) return function (v) { return isString(v) && v.substring(0, p.length) === p } if(isArray(p)) { if(!p.every(isBasic)) throw new Error('{$prefix: array} must have exact elements in the array') return function (v) { if(!isArray(v) || v.length < p.length) return false for(var i = 0; i < p.length; i++) if(v[i] !== p[i]) return false return true } } } function lt (q) { return function (v) { return v < q } } function gt (q) { return function (v) { return v > q } } function lte (q) { return function (v) { return v <= q } } function gte (q) { return function (v) { return v >= q } } function combine(f, g) { if(!g) return f return function (v) { return f(v) && g(v) } } function ltgt (q) { var filter = null if(has(q, '$lt')) filter = lt(q.$lt) if(has(q, '$lte')) filter = combine(lte(q.$lte), filter) if(has(q, '$gt')) filter = combine(gt(q.$gt), filter) if(has(q, '$gte')) filter = combine(gte(q.$gte), filter) return filter } function all (q) { return function (v) { if(v == null) return false for(var k in q) if(!q[k](v[k])) return false return true } } function absent (v) { return v == null } function never () { return false } function make (q) { return ( isBasic(q) ? exact(q) : has(q, '$prefix') ? prefix(q.$prefix) : isLtgt(q) ? ltgt(q) : u.isObject(q) || u.isArray(q) ? all(map(q, make)) : isNullish(q) ? absent : never ) } module.exports = make },{"./util":238}],229:[function(require,module,exports){ var pull = require('pull-stream') var filter = require('./filter') var map = require('./map') var reduce = require('./reduce') var SinkThrough = require('pull-sink-through') function first (q) { for(var k in q) return k } function get (q) { var k = first(q) var s = k.substring(1) if(k[0] == '$' && exports[s]) return exports[s](q[k]) throw new Error('unknown function:'+ k) } function last (l) { return l[l.length - 1] } exports = module.exports = function (q, cb) { q = q.filter(Boolean) if(last(q).$reduce && cb) { return pull.apply(null, q.slice(0, q.length - 1).map(get) .concat(exports.reduce(last(q).$reduce, cb)) ) } else if(Array.isArray(q)) return pull.apply(null, q.map(get)) else return get(q) } exports.filter = function (q) { return pull.filter(filter(q)) } exports.map = function (q) { return pull(pull.map(map(q)),pull.filter()) } exports.reduce = function (q, cb) { if(cb) return pull.reduce(reduce(q), null, cb) return SinkThrough(function (cb) { return pull.reduce(reduce(q), null, cb) }) } },{"./filter":228,"./map":231,"./reduce":237,"pull-sink-through":379,"pull-stream":232}],230:[function(require,module,exports){ var u = require('./util') var isArray = u.isArray var isString = u.isString var extractors = { $filter: function (query) { var o = {} for(var k in query) o[k] = true return o }, $reduce: function (query) { var o = {} if(isArray(query.$group)) query.$group.forEach(function (path) { o[isArray(path) ? path[0]: path] = true }) //TODO: check what paths the other reduces touch. return o }, $map: function (query) { var o = {} for(var k in query) if(isArray(query[k])) o[query[k][0]] = true else if(isString(query[k])) o[query[k]] = true return o } } function merge (a, b) { var o = {} for(var k in a) o[k] = true for(var k in b) o[k] = true return o } function first(q) { for(var k in q) return k } function keys (query) { var keys = {} for(var i = query.length - 1; i >= 0; i--) { var k = first(query[i]) keys = merge(extractors[k](query[i][k]), keys) } return keys } module.exports = keys },{"./util":238}],231:[function(require,module,exports){ var u = require('./util') var map = u.map function id (v, k) { return k ? v[k] : v } function isNull (n) { return n == null } function key(q) { return function (v) { if(isNull(v)) return undefined return v[q] } } function path (q) { return q.reduce(function (map1, map2) { return function (v) { return map2(map1(v)) } }) } function notEmpty (o) { for(var k in o) return o return undefined } function obj (q) { return function (v) { if(isNull(v)) return undefined return notEmpty(map(q, function (fn, k, o) { return fn(v, k) })) } } function make(q) { if(true === q) return id if(isNull(q)) return isNull if(u.isString(q) || u.isNumber(q)) return key(q) if(u.isArray(q)) return path(q.map(make)) if(u.isObject(q)) return obj(map(q, make)) throw new Error('no match - should never mappen') } module.exports = make },{"./util":238}],232:[function(require,module,exports){ var sources = require('./sources') var sinks = require('./sinks') var throughs = require('./throughs') exports = module.exports = require('./pull') for(var k in sources) exports[k] = sources[k] for(var k in throughs) exports[k] = throughs[k] for(var k in sinks) exports[k] = sinks[k] },{"./pull":233,"./sinks":234,"./sources":235,"./throughs":236}],233:[function(require,module,exports){ module.exports = function pull (a) { var length = arguments.length if (typeof a === 'function' && a.length === 1) { var args = new Array(length) for(var i = 0; i < length; i++) args[i] = arguments[i] return function (read) { args.unshift(read) return pull.apply(null, args) } } var read = a if (read && typeof read.source === 'function') { read = read.source } for (var i = 1; i < length; i++) { var s = arguments[i] if (typeof s === 'function') { read = s(read) } else if (s && typeof s === 'object') { s.sink(read) read = s.source } } return read } },{}],234:[function(require,module,exports){ 'use strict' function id (item) { return item } function prop (key) { return ( 'string' == typeof key ? function (data) { return data[key] } : key && 'object' === typeof key && 'function' === typeof key.exec //regexp ? function (data) { var v = map.exec(data); return v && v[0] } : key || id ) } var drain = exports.drain = function (op, done) { var read, abort function sink (_read) { read = _read if(abort) return sink.abort() //this function is much simpler to write if you //just use recursion, but by using a while loop //we do not blow the stack if the stream happens to be sync. ;(function next() { var loop = true, cbed = false while(loop) { cbed = false read(null, function (end, data) { cbed = true if(end = end || abort) { loop = false if(done) done(end === true ? null : end) else if(end && end !== true) throw end } else if(op && false === op(data) || abort) { loop = false read(abort || true, done || function () {}) } else if(!loop){ next() } }) if(!cbed) { loop = false return } } })() } sink.abort = function (err, cb) { if('function' == typeof err) cb = err, err = true abort = err || true if(read) return read(abort, cb || function () {}) } return sink } var onEnd = exports.onEnd = function (done) { return drain(null, done) } var log = exports.log = function (done) { return drain(function (data) { console.log(data) }, done) } var find = exports.find = function (test, cb) { var ended = false if(!cb) cb = test, test = id else test = prop(test) || id return drain(function (data) { if(test(data)) { ended = true cb(null, data) return false } }, function (err) { if(ended) return //already called back cb(err === true ? null : err, null) }) } var reduce = exports.reduce = function (reduce, acc, cb) { return drain(function (data) { acc = reduce(acc, data) }, function (err) { cb(err, acc) }) } var collect = exports.collect = function (cb) { return reduce(function (arr, item) { arr.push(item) return arr }, [], cb) } var concat = exports.concat = function (cb) { return reduce(function (a, b) { return a + b }, '', cb) } },{}],235:[function(require,module,exports){ var keys = exports.keys = function (object) { return values(Object.keys(object)) } function abortCb(cb, abort, onAbort) { cb(abort) onAbort && onAbort(abort === true ? null: abort) return } var once = exports.once = function (value, onAbort) { return function (abort, cb) { if(abort) return abortCb(cb, abort, onAbort) if(value != null) { var _value = value; value = null cb(null, _value) } else cb(true) } } var values = exports.values = exports.readArray = function (array, onAbort) { if(!array) return function (abort, cb) { if(abort) return abortCb(cb, abort, onAbort) return cb(true) } if(!Array.isArray(array)) array = Object.keys(array).map(function (k) { return array[k] }) var i = 0 return function (abort, cb) { if(abort) return abortCb(cb, abort, onAbort) cb(i >= array.length || null, array[i++]) } } var count = exports.count = function (max) { var i = 0; max = max || Infinity return function (end, cb) { if(end) return cb && cb(end) if(i > max) return cb(true) cb(null, i++) } } var infinite = exports.infinite = function (generate) { generate = generate || Math.random return function (end, cb) { if(end) return cb && cb(end) return cb(null, generate()) } } //a stream that ends immediately. var empty = exports.empty = function () { return function (abort, cb) { cb(true) } } //a stream that errors immediately. var error = exports.error = function (err) { return function (abort, cb) { cb(err) } } },{}],236:[function(require,module,exports){ 'use strict'; function id (item) { return item } function prop (key) { return ( 'string' == typeof key ? function (data) { return data[key] } : 'object' === typeof key && 'function' === typeof key.exec //regexp ? function (data) { var v = map.exec(data); return v && v[0] } : key ) } function tester (test) { return ( 'object' === typeof test && 'function' === typeof test.test //regexp ? function (data) { return test.test(data) } : prop (test) || id ) } var sources = require('./sources') var sinks = require('./sinks') var map = exports.map = function (map) { if(!map) return id map = prop(map) return function (read) { return function (abort, cb) { read(abort, function (end, data) { try { data = !end ? map(data) : null } catch (err) { return read(err, function () { return cb(err) }) } cb(end, data) }) } } } var asyncMap = exports.asyncMap = function async (map) { if(!map) return id map = prop(map) var busy = false, abortCb, aborted return function (read) { return function next (abort, cb) { if(aborted) return cb(aborted) if(abort) { aborted = abort if(!busy) read(abort, cb) else read(abort, function () { //if we are still busy, wait for the mapper to complete. if(busy) abortCb = cb else cb(abort) }) } else read(null, function (end, data) { if(end) { cb(end) if(abortCb) cb(end, data) } else { busy = true map(data, function (err, data) { busy = false if(aborted) { cb(aborted) abortCb(aborted) } else if(err) next (err, cb) else cb(null, data) }) } }) } } } function asyncMap (map) { if(!map) return id //when read is passed, pass it on. return function (read) { return function (end, cb) { if(end) return read(end, cb) //abort read(null, function (end, data) { if(end) return cb(end, data) map(data, cb) }) } } } var filter = exports.filter = function (test) { //regexp test = tester(test) return function (read) { return function next (end, cb) { var sync, loop = true while(loop) { loop = false sync = true read(end, function (end, data) { if(!end && !test(data)) return sync ? loop = true : next(end, cb) cb(end, data) }) sync = false } } } } var filterNot = exports.filterNot = function (test) { test = tester(test) return filter(function (data) { return !test(data) }) } //a pass through stream that doesn't change the value. var through = exports.through = function (op, onEnd) { var a = false function once (abort) { if(a || !onEnd) return a = true onEnd(abort === true ? null : abort) } return function (read) { return function (end, cb) { if(end) once(end) return read(end, function (end, data) { if(!end) op && op(data) else once(end) cb(end, data) }) } } } //read a number of items and then stop. var take = exports.take = function (test, opts) { opts = opts || {} var last = opts.last || false // whether the first item for which !test(item) should still pass var ended = false if('number' === typeof test) { last = true var n = test; test = function () { return --n } } return function (read) { function terminate (cb) { read(true, function (err) { last = false; cb(err || true) }) } return function (end, cb) { if(ended) last ? terminate(cb) : cb(ended) else if(ended = end) read(ended, cb) else read(null, function (end, data) { if(ended = ended || end) { //last ? terminate(cb) : cb(ended) } else if(!test(data)) { ended = true last ? cb(null, data) : terminate(cb) } else cb(null, data) }) } } } //drop items you have already seen. var unique = exports.unique = function (field, invert) { field = prop(field) || id var seen = {} return filter(function (data) { var key = field(data) if(seen[key]) return !!invert //false, by default else seen[key] = true return !invert //true by default }) } //passes an item through when you see it for the second time. var nonUnique = exports.nonUnique = function (field) { return unique(field, true) } //convert a stream of arrays or streams into just a stream. var flatten = exports.flatten = function () { return function (read) { var _read return function (abort, cb) { if (abort) { //abort the current stream, and then stream of streams. _read ? _read(abort, function(err) { read(err || abort, cb) }) : read(abort, cb) } else if(_read) nextChunk() else nextStream() function nextChunk () { _read(null, function (err, data) { if (err === true) nextStream() else if (err) { read(true, function(abortErr) { // TODO: what do we do with the abortErr? cb(err) }) } else cb(null, data) }) } function nextStream () { _read = null read(null, function (end, stream) { if(end) return cb(end) if(Array.isArray(stream) || stream && 'object' === typeof stream) stream = sources.values(stream) else if('function' != typeof stream) stream = sources.once(stream) _read = stream nextChunk() }) } } } } },{"./sinks":234,"./sources":235}],237:[function(require,module,exports){ var u = require('./util') var map = u.map var simple = require('./basic') function isFunction (f) { return 'function' === typeof f } function isSimple(query) { for(var k in simple) if(u.has(query, k)) return k } function lookup(reduce, path) { if(path === true) return reduce return function (a, b) { return reduce(a, u.get(b, path)) } } function multi(obj) { return function (a, b) { return map(obj, function (reduce, k) { return reduce(a[k], b) }, a = a || {}) } } function each(list, iter) { if(u.isString(list)) return iter(list) for(var i = 0; i < list.length; i++) iter(list[i], (list.length - i - 1)) } //instead of taking the query, //this should take a path, and a reduce function. function group (g, reduce) { return function (a, b) { var A = a = a || {} each(g, function (k, notLast) { var v = u.get(b, k) A[v] = !notLast ? reduce(A[v], b) : A[v] || {} A = A[v] }) return a } } function make (query) { var k = isSimple(query) if(k) return lookup(simple[k], query[k]) else if(u.isObject(query)) return multi(map(query, function (q, k) { if(k == '$group') return undefined return gmake(query[k]) })) } function gmake (query) { return query.$group ? group(query.$group, make(query)) : make(query) } module.exports = gmake },{"./basic":227,"./util":238}],238:[function(require,module,exports){ 'use strict' function isString(s) { return 'string' === typeof s } function isNumber(n) { return !isNaN(+n) } function isBoolean (b) { return 'boolean' === typeof b } function isBasic (p) { return isString(p) || isNumber(p) || isBoolean(p) } var isArray = Array.isArray function isObject (o) { return o && 'object' === typeof o } function has(o, k) { return Object.hasOwnProperty.call(o, k) } function isExact (v) { if(isBasic(v)) return true if(isArray(v)) return v.every(isExact) return isObject(v) && has(v, '$eq') } function isLtgt (v) { return has(v, '$lt') || has(v, '$gt') || has(v, '$lte') || has(v, '$gte') } function isRange (v) { if(!isObject(v)) return false if(isString(v.$prefix)) return true if(isArray(v)) return find(v, isRange) return isLtgt(v) } function find (ary, test) { for(var i = 0; i < ary.length; i++) if(test(ary[i], i, ary)) return true return false } function lower (v) { if(isBasic(v)) return v if(isObject(v)) { if(isArray(v.$prefix)) return v.$prefix.concat(exports.HI) if(isString(v.$prefix)) return v.$prefix if(has(v, '$lt')) return v.$lt if(has(v, '$lte')) return v.$lte } if(isArray(v)) return v.map(lower) } function upper (v) { if(isBasic(v)) return v if(isObject(v)) { if(isArray(v.$prefix)) return v.$prefix.concat(exports.LO) if(isString(v.$prefix)) return v.$prefix+'\uffff' if(has(v, '$gt')) return v.$gt if(has(v, '$gte')) return v.$gte } if(isArray(v)) return v.map(upper) } function get(obj, path) { if(isString(path)) return obj[path] if(isArray(path)) { for(var i = 0; i < path.length; i++) { if(obj == null) return undefined obj = obj[path[i]] } return obj } if(path === true) return obj return undefined } function map(obj, iter, o) { if(Array.isArray(obj)) return obj.map(iter) o = o || {} for(var k in obj) { var v = iter(obj[k], k, obj) if(v !== undefined) o[k] = v } return o } exports.isString = isString exports.isNumber = isNumber exports.isBasic = isBasic exports.isArray = isArray exports.isObject = isObject exports.isRange = isRange exports.isExact = isExact exports.isLtgt = isLtgt exports.has = has exports.get = get exports.map = map exports.upper = upper exports.lower = lower exports.HI = undefined exports.LO = null },{}],239:[function(require,module,exports){ function isObject(o) { return o && 'object' === typeof o } var isArray = Array.isArray function isUndefined (u) { return 'undefined' === typeof u } var find = exports.find = function find(ary, test) { for(var i in ary) if(test(ary[i], i, ary)) return ary[i] } exports = module.exports = merge exports.merge = exports var clone = exports.clone = function clone (obj, mapper) { function map(v, k) { return isObject(v) ? clone(v, mapper) : mapper(v, k) } if(isArray(obj)) return obj.map(map) else if(isObject(obj)) { var o = {} for(var k in obj) o[k] = map(obj[k], k) return o } else return map(obj) } var mergeKeys = exports.mergeKeys = function (a, b, iter) { var o = {} for(var k in a) { if(!isUndefined(a[k])) o[k] = iter(a[k], b[k], k) } for(var k in b) { if(isUndefined(a[k])) o[k] = iter(undefined, b[k], k) } return o } var mergeArrays = exports.mergeArrays = function (a, b, iter) { var o = [] a.forEach(function (v, i) { var j = b.indexOf(v) o.push(iter(v, b[j], o.length)) }) b.forEach(function (v, i) { var j = a.indexOf(v) if(!~j) o.push(iter(undefined, b[i], o.length)) }) return o } function merge (a, b, merge) { //merge a and b objects merge = merge || function (x, y) { return y == null ? x : y } function merger(a, b, k) { if(isArray(a) && isArray(b)) return mergeArrays(a, b, merger) else if(isObject(a) && isObject(b)) { return mergeKeys(a, b, merger) } else return merge(a, b, k) } return merger(a, b, undefined) } },{}],240:[function(require,module,exports){ 'use strict'; /* * Useful expressions. */ var EXPRESSION_DOT = /\./; var EXPRESSION_LAST_DOT = /\.[^.]*$/; /* * Allowed alignment values. */ var LEFT = 'l'; var RIGHT = 'r'; var CENTER = 'c'; var DOT = '.'; var NULL = ''; var ALLIGNMENT = [LEFT, RIGHT, CENTER, DOT, NULL]; /* * Characters. */ var COLON = ':'; var DASH = '-'; var PIPE = '|'; var SPACE = ' '; var NEW_LINE = '\n'; /** * Get the length of `value`. * * @param {string} value * @return {number} */ function lengthNoop(value) { return String(value).length; } /** * Get a string consisting of `length` `character`s. * * @param {number} length * @param {string} [character=' '] * @return {string} */ function pad(length, character) { return Array(length + 1).join(character || SPACE); } /** * Get the position of the last dot in `value`. * * @param {string} value * @return {number} */ function dotindex(value) { var match = EXPRESSION_LAST_DOT.exec(value); return match ? match.index + 1 : value.length; } /** * Create a table from a matrix of strings. * * @param {Array.>} table * @param {Object?} options * @param {boolean?} [options.rule=true] * @param {string?} [options.delimiter=" | "] * @param {string?} [options.start="| "] * @param {string?} [options.end=" |"] * @param {Array.?} options.align * @param {function(string)?} options.stringLength * @return {string} Pretty table */ function markdownTable(table, options) { var settings = options || {}; var delimiter = settings.delimiter; var start = settings.start; var end = settings.end; var alignment = settings.align; var calculateStringLength = settings.stringLength || lengthNoop; var cellCount = 0; var rowIndex = -1; var rowLength = table.length; var sizes = []; var align; var rule; var rows; var row; var cells; var index; var position; var size; var value; var spacing; var before; var after; alignment = alignment ? alignment.concat() : []; if (delimiter === null || delimiter === undefined) { delimiter = SPACE + PIPE + SPACE; } if (start === null || start === undefined) { start = PIPE + SPACE; } if (end === null || end === undefined) { end = SPACE + PIPE; } while (++rowIndex < rowLength) { row = table[rowIndex]; index = -1; if (row.length > cellCount) { cellCount = row.length; } while (++index < cellCount) { position = row[index] ? dotindex(row[index]) : null; if (!sizes[index]) { sizes[index] = 3; } if (position > sizes[index]) { sizes[index] = position; } } } if (typeof alignment === 'string') { alignment = pad(cellCount, alignment).split(''); } /* * Make sure only valid alignments are used. */ index = -1; while (++index < cellCount) { align = alignment[index]; if (typeof align === 'string') { align = align.charAt(0).toLowerCase(); } if (ALLIGNMENT.indexOf(align) === -1) { align = NULL; } alignment[index] = align; } rowIndex = -1; rows = []; while (++rowIndex < rowLength) { row = table[rowIndex]; index = -1; cells = []; while (++index < cellCount) { value = row[index]; if (value === null || value === undefined) { value = ''; } else { value = String(value); } if (alignment[index] !== DOT) { cells[index] = value; } else { position = dotindex(value); size = sizes[index] + (EXPRESSION_DOT.test(value) ? 0 : 1) - (calculateStringLength(value) - position); cells[index] = value + pad(size - 1); } } rows[rowIndex] = cells; } sizes = []; rowIndex = -1; while (++rowIndex < rowLength) { cells = rows[rowIndex]; index = -1; while (++index < cellCount) { value = cells[index]; if (!sizes[index]) { sizes[index] = 3; } size = calculateStringLength(value); if (size > sizes[index]) { sizes[index] = size; } } } rowIndex = -1; while (++rowIndex < rowLength) { cells = rows[rowIndex]; index = -1; while (++index < cellCount) { value = cells[index]; position = sizes[index] - (calculateStringLength(value) || 0); spacing = pad(position); if (alignment[index] === RIGHT || alignment[index] === DOT) { value = spacing + value; } else if (alignment[index] !== CENTER) { value = value + spacing; } else { position = position / 2; if (position % 1 === 0) { before = position; after = position; } else { before = position + 0.5; after = position - 0.5; } value = pad(before) + value + pad(after); } cells[index] = value; } rows[rowIndex] = cells.join(delimiter); } if (settings.rule !== false) { index = -1; rule = []; while (++index < cellCount) { align = alignment[index]; /* * When `align` is left, don't add colons. */ value = align === RIGHT || align === NULL ? DASH : COLON; value += pad(sizes[index] - 2, DASH); value += align !== LEFT && align !== NULL ? COLON : DASH; rule[index] = value; } rows.splice(1, 0, rule.join(delimiter)); } return start + rows.join(end + NEW_LINE + start) + end; } /* * Expose `markdownTable`. */ module.exports = markdownTable; },{}],241:[function(require,module,exports){ var assert = require('assert') var remark = require('remark') var html = require('remark-html') // - obj: object // - path: array, a list of keys // - value: any // will create any subobject needed // eg var x = {}; set(x, ['foo', 'bar'], 5); x.foo.bar == 5 function set (obj, path, value) { while (path.length > 1) { var k = path.shift() if (!obj[k]) obj[k] = {} obj = obj[k] } obj[path[0]] = value } function fill (str, n) { if (n > str.length) return str + ' '.repeat(n - str.length) return str } function methodTable (methods, nameWidth) { // figure out how long the names column needs to be if (!nameWidth) { nameWidth = 1 methods.forEach(function (m) { if (m.name.length > nameWidth) nameWidth = m.name.length }) } return methods.map(function (m) { return ' ' + fill(m.name, nameWidth) + ' ' + m.desc }).join('').trim() } function parseMethodHeading (token, prefix) { var textToken = token.children[0] assert.equal(textToken.type, 'text', 'Headings should not have any markup') var parts = textToken.value.split(': ') assert.equal(parts.length, 2, 'Heading "'+textToken.value+'" should be of form `method: type`') var name = parts[0], type = parts[1] assert(nameRegex.test(name), 'Function name "'+name+'" does nots match '+nameRegex) assert(nameRegex.test(type), 'Function type "'+type+'" does not match '+typeRegex) if (prefix) parts[0] = prefix + '.' + parts[0] return parts } var nameRegex = /^[a-z][a-z0-9\.\-_]*$/i var typeRegex = /^[a-z]+$/i module.exports.manifest = function (text) { assert.equal(typeof text, 'string', 'Input should be a markdown string') var manifest = {} remark().parse(text).children.forEach(function (token, i) { if (token.type === 'heading' && token.depth === 2) { var parts = parseMethodHeading(token) set(manifest, parts[0].split('.'), parts[1]) } }) return manifest } module.exports.usage = function (text, cmd, opts) { assert.equal(typeof text, 'string', 'Input should be a markdown string') opts = opts || {} var lexer = remark() var tokens = lexer.parse(text).children if (!cmd) { // toplevel usage var inSummary = true // in the api summary? var toplevelParas = [] var methods = [] var currentMethod tokens.forEach(function (token) { if (token.type == 'paragraph' && inSummary) { // a para in the api's toplevel summary toplevelParas.push(lexer.stringify({ type: 'root', children: token.children })) } else if (token.type == 'heading' && token.depth == 2) { // a method heading inSummary = false // no longer in the api summary var parts = parseMethodHeading(token, opts.prefix) currentMethod = parts[0] } else if (token.type == 'paragraph' && currentMethod) { // the first para in a method methods.push({ name: currentMethod, desc: lexer.stringify({ type: 'root', children: token.children })}) currentMethod = null } }) if (currentMethod) methods.push({ name: currentMethod }) return toplevelParas.join('\n') + '\nCommands:\n ' + methodTable(methods, opts.nameWidth) } // method usage var inMethod = false // in the method? var elems = [] for (var i=0; i < tokens.length; i++) { var token = tokens[i] if (token.type == 'heading') { // a heading if (inMethod) break // done pulling from the method's summary if (token.depth == 2 && parseMethodHeading(token)[0] == cmd) inMethod = true // we're in the target method's summary } else if (inMethod) { if (token.type == 'code') { // only include code examples for the CLI if (token.lang == 'bash' || token.lang == 'sh' || token.lang == 'shell' || !token.lang) { token.type = 'text' elems.push(token) } } else elems.push(token) } } return lexer .stringify({ type: 'root', children: elems }) .trim() .replace(/\\\[/g, '[') // dont escape '[' } module.exports.html = function (text) { assert.equal(typeof text, 'string', 'Input should be a markdown string') return remark().use(html).process(text) } },{"assert":15,"remark":415,"remark-html":411}],242:[function(require,module,exports){ var bn = require('bn.js'); var brorand = require('brorand'); function MillerRabin(rand) { this.rand = rand || new brorand.Rand(); } module.exports = MillerRabin; MillerRabin.create = function create(rand) { return new MillerRabin(rand); }; MillerRabin.prototype._rand = function _rand(n) { var len = n.bitLength(); var buf = this.rand.generate(Math.ceil(len / 8)); // Set low bits buf[0] |= 3; // Mask high bits var mask = len & 0x7; if (mask !== 0) buf[buf.length - 1] >>= 7 - mask; return new bn(buf); } MillerRabin.prototype.test = function test(n, k, cb) { var len = n.bitLength(); var red = bn.mont(n); var rone = new bn(1).toRed(red); if (!k) k = Math.max(1, (len / 48) | 0); // Find d and s, (n - 1) = (2 ^ s) * d; var n1 = n.subn(1); var n2 = n1.subn(1); for (var s = 0; !n1.testn(s); s++) {} var d = n.shrn(s); var rn1 = n1.toRed(red); var prime = true; for (; k > 0; k--) { var a = this._rand(n2); if (cb) cb(a); var x = a.toRed(red).redPow(d); if (x.cmp(rone) === 0 || x.cmp(rn1) === 0) continue; for (var i = 1; i < s; i++) { x = x.redSqr(); if (x.cmp(rone) === 0) return false; if (x.cmp(rn1) === 0) break; } if (i === s) return false; } return prime; }; MillerRabin.prototype.getDivisor = function getDivisor(n, k) { var len = n.bitLength(); var red = bn.mont(n); var rone = new bn(1).toRed(red); if (!k) k = Math.max(1, (len / 48) | 0); // Find d and s, (n - 1) = (2 ^ s) * d; var n1 = n.subn(1); var n2 = n1.subn(1); for (var s = 0; !n1.testn(s); s++) {} var d = n.shrn(s); var rn1 = n1.toRed(red); for (; k > 0; k--) { var a = this._rand(n2); var g = n.gcd(a); if (g.cmpn(1) !== 0) return g; var x = a.toRed(red).redPow(d); if (x.cmp(rone) === 0 || x.cmp(rn1) === 0) continue; for (var i = 1; i < s; i++) { x = x.redSqr(); if (x.cmp(rone) === 0) return x.fromRed().subn(1).gcd(n); if (x.cmp(rn1) === 0) break; } if (i === s) { x = x.redSqr(); return x.fromRed().subn(1).gcd(n); } } return false; }; },{"bn.js":29,"brorand":32}],243:[function(require,module,exports){ module.exports={ "application/1d-interleaved-parityfec": { "source": "iana" }, "application/3gpdash-qoe-report+xml": { "source": "iana" }, "application/3gpp-ims+xml": { "source": "iana" }, "application/a2l": { "source": "iana" }, "application/activemessage": { "source": "iana" }, "application/alto-costmap+json": { "source": "iana", "compressible": true }, "application/alto-costmapfilter+json": { "source": "iana", "compressible": true }, "application/alto-directory+json": { "source": "iana", "compressible": true }, "application/alto-endpointcost+json": { "source": "iana", "compressible": true }, "application/alto-endpointcostparams+json": { "source": "iana", "compressible": true }, "application/alto-endpointprop+json": { "source": "iana", "compressible": true }, "application/alto-endpointpropparams+json": { "source": "iana", "compressible": true }, "application/alto-error+json": { "source": "iana", "compressible": true }, "application/alto-networkmap+json": { "source": "iana", "compressible": true }, "application/alto-networkmapfilter+json": { "source": "iana", "compressible": true }, "application/aml": { "source": "iana" }, "application/andrew-inset": { "source": "iana", "extensions": ["ez"] }, "application/applefile": { "source": "iana" }, "application/applixware": { "source": "apache", "extensions": ["aw"] }, "application/atf": { "source": "iana" }, "application/atfx": { "source": "iana" }, "application/atom+xml": { "source": "iana", "compressible": true, "extensions": ["atom"] }, "application/atomcat+xml": { "source": "iana", "extensions": ["atomcat"] }, "application/atomdeleted+xml": { "source": "iana" }, "application/atomicmail": { "source": "iana" }, "application/atomsvc+xml": { "source": "iana", "extensions": ["atomsvc"] }, "application/atxml": { "source": "iana" }, "application/auth-policy+xml": { "source": "iana" }, "application/bacnet-xdd+zip": { "source": "iana" }, "application/batch-smtp": { "source": "iana" }, "application/bdoc": { "compressible": false, "extensions": ["bdoc"] }, "application/beep+xml": { "source": "iana" }, "application/calendar+json": { "source": "iana", "compressible": true }, "application/calendar+xml": { "source": "iana" }, "application/call-completion": { "source": "iana" }, "application/cals-1840": { "source": "iana" }, "application/cbor": { "source": "iana" }, "application/ccmp+xml": { "source": "iana" }, "application/ccxml+xml": { "source": "iana", "extensions": ["ccxml"] }, "application/cdfx+xml": { "source": "iana" }, "application/cdmi-capability": { "source": "iana", "extensions": ["cdmia"] }, "application/cdmi-container": { "source": "iana", "extensions": ["cdmic"] }, "application/cdmi-domain": { "source": "iana", "extensions": ["cdmid"] }, "application/cdmi-object": { "source": "iana", "extensions": ["cdmio"] }, "application/cdmi-queue": { "source": "iana", "extensions": ["cdmiq"] }, "application/cdni": { "source": "iana" }, "application/cea": { "source": "iana" }, "application/cea-2018+xml": { "source": "iana" }, "application/cellml+xml": { "source": "iana" }, "application/cfw": { "source": "iana" }, "application/cms": { "source": "iana" }, "application/cnrp+xml": { "source": "iana" }, "application/coap-group+json": { "source": "iana", "compressible": true }, "application/commonground": { "source": "iana" }, "application/conference-info+xml": { "source": "iana" }, "application/cpl+xml": { "source": "iana" }, "application/csrattrs": { "source": "iana" }, "application/csta+xml": { "source": "iana" }, "application/cstadata+xml": { "source": "iana" }, "application/csvm+json": { "source": "iana", "compressible": true }, "application/cu-seeme": { "source": "apache", "extensions": ["cu"] }, "application/cybercash": { "source": "iana" }, "application/dart": { "compressible": true }, "application/dash+xml": { "source": "iana", "extensions": ["mpd"] }, "application/dashdelta": { "source": "iana" }, "application/davmount+xml": { "source": "iana", "extensions": ["davmount"] }, "application/dca-rft": { "source": "iana" }, "application/dcd": { "source": "iana" }, "application/dec-dx": { "source": "iana" }, "application/dialog-info+xml": { "source": "iana" }, "application/dicom": { "source": "iana" }, "application/dii": { "source": "iana" }, "application/dit": { "source": "iana" }, "application/dns": { "source": "iana" }, "application/docbook+xml": { "source": "apache", "extensions": ["dbk"] }, "application/dskpp+xml": { "source": "iana" }, "application/dssc+der": { "source": "iana", "extensions": ["dssc"] }, "application/dssc+xml": { "source": "iana", "extensions": ["xdssc"] }, "application/dvcs": { "source": "iana" }, "application/ecmascript": { "source": "iana", "compressible": true, "extensions": ["ecma"] }, "application/edi-consent": { "source": "iana" }, "application/edi-x12": { "source": "iana", "compressible": false }, "application/edifact": { "source": "iana", "compressible": false }, "application/emergencycalldata.comment+xml": { "source": "iana" }, "application/emergencycalldata.deviceinfo+xml": { "source": "iana" }, "application/emergencycalldata.providerinfo+xml": { "source": "iana" }, "application/emergencycalldata.serviceinfo+xml": { "source": "iana" }, "application/emergencycalldata.subscriberinfo+xml": { "source": "iana" }, "application/emma+xml": { "source": "iana", "extensions": ["emma"] }, "application/emotionml+xml": { "source": "iana" }, "application/encaprtp": { "source": "iana" }, "application/epp+xml": { "source": "iana" }, "application/epub+zip": { "source": "iana", "extensions": ["epub"] }, "application/eshop": { "source": "iana" }, "application/exi": { "source": "iana", "extensions": ["exi"] }, "application/fastinfoset": { "source": "iana" }, "application/fastsoap": { "source": "iana" }, "application/fdt+xml": { "source": "iana" }, "application/fits": { "source": "iana" }, "application/font-sfnt": { "source": "iana" }, "application/font-tdpfr": { "source": "iana", "extensions": ["pfr"] }, "application/font-woff": { "source": "iana", "compressible": false, "extensions": ["woff"] }, "application/font-woff2": { "compressible": false, "extensions": ["woff2"] }, "application/framework-attributes+xml": { "source": "iana" }, "application/gml+xml": { "source": "apache", "extensions": ["gml"] }, "application/gpx+xml": { "source": "apache", "extensions": ["gpx"] }, "application/gxf": { "source": "apache", "extensions": ["gxf"] }, "application/gzip": { "source": "iana", "compressible": false }, "application/h224": { "source": "iana" }, "application/held+xml": { "source": "iana" }, "application/http": { "source": "iana" }, "application/hyperstudio": { "source": "iana", "extensions": ["stk"] }, "application/ibe-key-request+xml": { "source": "iana" }, "application/ibe-pkg-reply+xml": { "source": "iana" }, "application/ibe-pp-data": { "source": "iana" }, "application/iges": { "source": "iana" }, "application/im-iscomposing+xml": { "source": "iana" }, "application/index": { "source": "iana" }, "application/index.cmd": { "source": "iana" }, "application/index.obj": { "source": "iana" }, "application/index.response": { "source": "iana" }, "application/index.vnd": { "source": "iana" }, "application/inkml+xml": { "source": "iana", "extensions": ["ink","inkml"] }, "application/iotp": { "source": "iana" }, "application/ipfix": { "source": "iana", "extensions": ["ipfix"] }, "application/ipp": { "source": "iana" }, "application/isup": { "source": "iana" }, "application/its+xml": { "source": "iana" }, "application/java-archive": { "source": "apache", "compressible": false, "extensions": ["jar","war","ear"] }, "application/java-serialized-object": { "source": "apache", "compressible": false, "extensions": ["ser"] }, "application/java-vm": { "source": "apache", "compressible": false, "extensions": ["class"] }, "application/javascript": { "source": "iana", "charset": "UTF-8", "compressible": true, "extensions": ["js"] }, "application/jose": { "source": "iana" }, "application/jose+json": { "source": "iana", "compressible": true }, "application/jrd+json": { "source": "iana", "compressible": true }, "application/json": { "source": "iana", "charset": "UTF-8", "compressible": true, "extensions": ["json","map"] }, "application/json-patch+json": { "source": "iana", "compressible": true }, "application/json-seq": { "source": "iana" }, "application/json5": { "extensions": ["json5"] }, "application/jsonml+json": { "source": "apache", "compressible": true, "extensions": ["jsonml"] }, "application/jwk+json": { "source": "iana", "compressible": true }, "application/jwk-set+json": { "source": "iana", "compressible": true }, "application/jwt": { "source": "iana" }, "application/kpml-request+xml": { "source": "iana" }, "application/kpml-response+xml": { "source": "iana" }, "application/ld+json": { "source": "iana", "compressible": true, "extensions": ["jsonld"] }, "application/link-format": { "source": "iana" }, "application/load-control+xml": { "source": "iana" }, "application/lost+xml": { "source": "iana", "extensions": ["lostxml"] }, "application/lostsync+xml": { "source": "iana" }, "application/lxf": { "source": "iana" }, "application/mac-binhex40": { "source": "iana", "extensions": ["hqx"] }, "application/mac-compactpro": { "source": "apache", "extensions": ["cpt"] }, "application/macwriteii": { "source": "iana" }, "application/mads+xml": { "source": "iana", "extensions": ["mads"] }, "application/manifest+json": { "charset": "UTF-8", "compressible": true, "extensions": ["webmanifest"] }, "application/marc": { "source": "iana", "extensions": ["mrc"] }, "application/marcxml+xml": { "source": "iana", "extensions": ["mrcx"] }, "application/mathematica": { "source": "iana", "extensions": ["ma","nb","mb"] }, "application/mathml+xml": { "source": "iana", "extensions": ["mathml"] }, "application/mathml-content+xml": { "source": "iana" }, "application/mathml-presentation+xml": { "source": "iana" }, "application/mbms-associated-procedure-description+xml": { "source": "iana" }, "application/mbms-deregister+xml": { "source": "iana" }, "application/mbms-envelope+xml": { "source": "iana" }, "application/mbms-msk+xml": { "source": "iana" }, "application/mbms-msk-response+xml": { "source": "iana" }, "application/mbms-protection-description+xml": { "source": "iana" }, "application/mbms-reception-report+xml": { "source": "iana" }, "application/mbms-register+xml": { "source": "iana" }, "application/mbms-register-response+xml": { "source": "iana" }, "application/mbms-schedule+xml": { "source": "iana" }, "application/mbms-user-service-description+xml": { "source": "iana" }, "application/mbox": { "source": "iana", "extensions": ["mbox"] }, "application/media-policy-dataset+xml": { "source": "iana" }, "application/media_control+xml": { "source": "iana" }, "application/mediaservercontrol+xml": { "source": "iana", "extensions": ["mscml"] }, "application/merge-patch+json": { "source": "iana", "compressible": true }, "application/metalink+xml": { "source": "apache", "extensions": ["metalink"] }, "application/metalink4+xml": { "source": "iana", "extensions": ["meta4"] }, "application/mets+xml": { "source": "iana", "extensions": ["mets"] }, "application/mf4": { "source": "iana" }, "application/mikey": { "source": "iana" }, "application/mods+xml": { "source": "iana", "extensions": ["mods"] }, "application/moss-keys": { "source": "iana" }, "application/moss-signature": { "source": "iana" }, "application/mosskey-data": { "source": "iana" }, "application/mosskey-request": { "source": "iana" }, "application/mp21": { "source": "iana", "extensions": ["m21","mp21"] }, "application/mp4": { "source": "iana", "extensions": ["mp4s","m4p"] }, "application/mpeg4-generic": { "source": "iana" }, "application/mpeg4-iod": { "source": "iana" }, "application/mpeg4-iod-xmt": { "source": "iana" }, "application/mrb-consumer+xml": { "source": "iana" }, "application/mrb-publish+xml": { "source": "iana" }, "application/msc-ivr+xml": { "source": "iana" }, "application/msc-mixer+xml": { "source": "iana" }, "application/msword": { "source": "iana", "compressible": false, "extensions": ["doc","dot"] }, "application/mxf": { "source": "iana", "extensions": ["mxf"] }, "application/nasdata": { "source": "iana" }, "application/news-checkgroups": { "source": "iana" }, "application/news-groupinfo": { "source": "iana" }, "application/news-transmission": { "source": "iana" }, "application/nlsml+xml": { "source": "iana" }, "application/nss": { "source": "iana" }, "application/ocsp-request": { "source": "iana" }, "application/ocsp-response": { "source": "iana" }, "application/octet-stream": { "source": "iana", "compressible": false, "extensions": ["bin","dms","lrf","mar","so","dist","distz","pkg","bpk","dump","elc","deploy","exe","dll","deb","dmg","iso","img","msi","msp","msm","buffer"] }, "application/oda": { "source": "iana", "extensions": ["oda"] }, "application/odx": { "source": "iana" }, "application/oebps-package+xml": { "source": "iana", "extensions": ["opf"] }, "application/ogg": { "source": "iana", "compressible": false, "extensions": ["ogx"] }, "application/omdoc+xml": { "source": "apache", "extensions": ["omdoc"] }, "application/onenote": { "source": "apache", "extensions": ["onetoc","onetoc2","onetmp","onepkg"] }, "application/oxps": { "source": "iana", "extensions": ["oxps"] }, "application/p2p-overlay+xml": { "source": "iana" }, "application/parityfec": { "source": "iana" }, "application/patch-ops-error+xml": { "source": "iana", "extensions": ["xer"] }, "application/pdf": { "source": "iana", "compressible": false, "extensions": ["pdf"] }, "application/pdx": { "source": "iana" }, "application/pgp-encrypted": { "source": "iana", "compressible": false, "extensions": ["pgp"] }, "application/pgp-keys": { "source": "iana" }, "application/pgp-signature": { "source": "iana", "extensions": ["asc","sig"] }, "application/pics-rules": { "source": "apache", "extensions": ["prf"] }, "application/pidf+xml": { "source": "iana" }, "application/pidf-diff+xml": { "source": "iana" }, "application/pkcs10": { "source": "iana", "extensions": ["p10"] }, "application/pkcs12": { "source": "iana" }, "application/pkcs7-mime": { "source": "iana", "extensions": ["p7m","p7c"] }, "application/pkcs7-signature": { "source": "iana", "extensions": ["p7s"] }, "application/pkcs8": { "source": "iana", "extensions": ["p8"] }, "application/pkix-attr-cert": { "source": "iana", "extensions": ["ac"] }, "application/pkix-cert": { "source": "iana", "extensions": ["cer"] }, "application/pkix-crl": { "source": "iana", "extensions": ["crl"] }, "application/pkix-pkipath": { "source": "iana", "extensions": ["pkipath"] }, "application/pkixcmp": { "source": "iana", "extensions": ["pki"] }, "application/pls+xml": { "source": "iana", "extensions": ["pls"] }, "application/poc-settings+xml": { "source": "iana" }, "application/postscript": { "source": "iana", "compressible": true, "extensions": ["ai","eps","ps"] }, "application/ppsp-tracker+json": { "source": "iana", "compressible": true }, "application/problem+json": { "source": "iana", "compressible": true }, "application/problem+xml": { "source": "iana" }, "application/provenance+xml": { "source": "iana" }, "application/prs.alvestrand.titrax-sheet": { "source": "iana" }, "application/prs.cww": { "source": "iana", "extensions": ["cww"] }, "application/prs.hpub+zip": { "source": "iana" }, "application/prs.nprend": { "source": "iana" }, "application/prs.plucker": { "source": "iana" }, "application/prs.rdf-xml-crypt": { "source": "iana" }, "application/prs.xsf+xml": { "source": "iana" }, "application/pskc+xml": { "source": "iana", "extensions": ["pskcxml"] }, "application/qsig": { "source": "iana" }, "application/raptorfec": { "source": "iana" }, "application/rdap+json": { "source": "iana", "compressible": true }, "application/rdf+xml": { "source": "iana", "compressible": true, "extensions": ["rdf"] }, "application/reginfo+xml": { "source": "iana", "extensions": ["rif"] }, "application/relax-ng-compact-syntax": { "source": "iana", "extensions": ["rnc"] }, "application/remote-printing": { "source": "iana" }, "application/reputon+json": { "source": "iana", "compressible": true }, "application/resource-lists+xml": { "source": "iana", "extensions": ["rl"] }, "application/resource-lists-diff+xml": { "source": "iana", "extensions": ["rld"] }, "application/rfc+xml": { "source": "iana" }, "application/riscos": { "source": "iana" }, "application/rlmi+xml": { "source": "iana" }, "application/rls-services+xml": { "source": "iana", "extensions": ["rs"] }, "application/rpki-ghostbusters": { "source": "iana", "extensions": ["gbr"] }, "application/rpki-manifest": { "source": "iana", "extensions": ["mft"] }, "application/rpki-roa": { "source": "iana", "extensions": ["roa"] }, "application/rpki-updown": { "source": "iana" }, "application/rsd+xml": { "source": "apache", "extensions": ["rsd"] }, "application/rss+xml": { "source": "apache", "compressible": true, "extensions": ["rss"] }, "application/rtf": { "source": "iana", "compressible": true, "extensions": ["rtf"] }, "application/rtploopback": { "source": "iana" }, "application/rtx": { "source": "iana" }, "application/samlassertion+xml": { "source": "iana" }, "application/samlmetadata+xml": { "source": "iana" }, "application/sbml+xml": { "source": "iana", "extensions": ["sbml"] }, "application/scaip+xml": { "source": "iana" }, "application/scim+json": { "source": "iana", "compressible": true }, "application/scvp-cv-request": { "source": "iana", "extensions": ["scq"] }, "application/scvp-cv-response": { "source": "iana", "extensions": ["scs"] }, "application/scvp-vp-request": { "source": "iana", "extensions": ["spq"] }, "application/scvp-vp-response": { "source": "iana", "extensions": ["spp"] }, "application/sdp": { "source": "iana", "extensions": ["sdp"] }, "application/sep+xml": { "source": "iana" }, "application/sep-exi": { "source": "iana" }, "application/session-info": { "source": "iana" }, "application/set-payment": { "source": "iana" }, "application/set-payment-initiation": { "source": "iana", "extensions": ["setpay"] }, "application/set-registration": { "source": "iana" }, "application/set-registration-initiation": { "source": "iana", "extensions": ["setreg"] }, "application/sgml": { "source": "iana" }, "application/sgml-open-catalog": { "source": "iana" }, "application/shf+xml": { "source": "iana", "extensions": ["shf"] }, "application/sieve": { "source": "iana" }, "application/simple-filter+xml": { "source": "iana" }, "application/simple-message-summary": { "source": "iana" }, "application/simplesymbolcontainer": { "source": "iana" }, "application/slate": { "source": "iana" }, "application/smil": { "source": "iana" }, "application/smil+xml": { "source": "iana", "extensions": ["smi","smil"] }, "application/smpte336m": { "source": "iana" }, "application/soap+fastinfoset": { "source": "iana" }, "application/soap+xml": { "source": "iana", "compressible": true }, "application/sparql-query": { "source": "iana", "extensions": ["rq"] }, "application/sparql-results+xml": { "source": "iana", "extensions": ["srx"] }, "application/spirits-event+xml": { "source": "iana" }, "application/sql": { "source": "iana" }, "application/srgs": { "source": "iana", "extensions": ["gram"] }, "application/srgs+xml": { "source": "iana", "extensions": ["grxml"] }, "application/sru+xml": { "source": "iana", "extensions": ["sru"] }, "application/ssdl+xml": { "source": "apache", "extensions": ["ssdl"] }, "application/ssml+xml": { "source": "iana", "extensions": ["ssml"] }, "application/tamp-apex-update": { "source": "iana" }, "application/tamp-apex-update-confirm": { "source": "iana" }, "application/tamp-community-update": { "source": "iana" }, "application/tamp-community-update-confirm": { "source": "iana" }, "application/tamp-error": { "source": "iana" }, "application/tamp-sequence-adjust": { "source": "iana" }, "application/tamp-sequence-adjust-confirm": { "source": "iana" }, "application/tamp-status-query": { "source": "iana" }, "application/tamp-status-response": { "source": "iana" }, "application/tamp-update": { "source": "iana" }, "application/tamp-update-confirm": { "source": "iana" }, "application/tar": { "compressible": true }, "application/tei+xml": { "source": "iana", "extensions": ["tei","teicorpus"] }, "application/thraud+xml": { "source": "iana", "extensions": ["tfi"] }, "application/timestamp-query": { "source": "iana" }, "application/timestamp-reply": { "source": "iana" }, "application/timestamped-data": { "source": "iana", "extensions": ["tsd"] }, "application/ttml+xml": { "source": "iana" }, "application/tve-trigger": { "source": "iana" }, "application/ulpfec": { "source": "iana" }, "application/urc-grpsheet+xml": { "source": "iana" }, "application/urc-ressheet+xml": { "source": "iana" }, "application/urc-targetdesc+xml": { "source": "iana" }, "application/urc-uisocketdesc+xml": { "source": "iana" }, "application/vcard+json": { "source": "iana", "compressible": true }, "application/vcard+xml": { "source": "iana" }, "application/vemmi": { "source": "iana" }, "application/vividence.scriptfile": { "source": "apache" }, "application/vnd.3gpp-prose+xml": { "source": "iana" }, "application/vnd.3gpp-prose-pc3ch+xml": { "source": "iana" }, "application/vnd.3gpp.access-transfer-events+xml": { "source": "iana" }, "application/vnd.3gpp.bsf+xml": { "source": "iana" }, "application/vnd.3gpp.mid-call+xml": { "source": "iana" }, "application/vnd.3gpp.pic-bw-large": { "source": "iana", "extensions": ["plb"] }, "application/vnd.3gpp.pic-bw-small": { "source": "iana", "extensions": ["psb"] }, "application/vnd.3gpp.pic-bw-var": { "source": "iana", "extensions": ["pvb"] }, "application/vnd.3gpp.sms": { "source": "iana" }, "application/vnd.3gpp.srvcc-ext+xml": { "source": "iana" }, "application/vnd.3gpp.srvcc-info+xml": { "source": "iana" }, "application/vnd.3gpp.state-and-event-info+xml": { "source": "iana" }, "application/vnd.3gpp.ussd+xml": { "source": "iana" }, "application/vnd.3gpp2.bcmcsinfo+xml": { "source": "iana" }, "application/vnd.3gpp2.sms": { "source": "iana" }, "application/vnd.3gpp2.tcap": { "source": "iana", "extensions": ["tcap"] }, "application/vnd.3m.post-it-notes": { "source": "iana", "extensions": ["pwn"] }, "application/vnd.accpac.simply.aso": { "source": "iana", "extensions": ["aso"] }, "application/vnd.accpac.simply.imp": { "source": "iana", "extensions": ["imp"] }, "application/vnd.acucobol": { "source": "iana", "extensions": ["acu"] }, "application/vnd.acucorp": { "source": "iana", "extensions": ["atc","acutc"] }, "application/vnd.adobe.air-application-installer-package+zip": { "source": "apache", "extensions": ["air"] }, "application/vnd.adobe.flash.movie": { "source": "iana" }, "application/vnd.adobe.formscentral.fcdt": { "source": "iana", "extensions": ["fcdt"] }, "application/vnd.adobe.fxp": { "source": "iana", "extensions": ["fxp","fxpl"] }, "application/vnd.adobe.partial-upload": { "source": "iana" }, "application/vnd.adobe.xdp+xml": { "source": "iana", "extensions": ["xdp"] }, "application/vnd.adobe.xfdf": { "source": "iana", "extensions": ["xfdf"] }, "application/vnd.aether.imp": { "source": "iana" }, "application/vnd.ah-barcode": { "source": "iana" }, "application/vnd.ahead.space": { "source": "iana", "extensions": ["ahead"] }, "application/vnd.airzip.filesecure.azf": { "source": "iana", "extensions": ["azf"] }, "application/vnd.airzip.filesecure.azs": { "source": "iana", "extensions": ["azs"] }, "application/vnd.amazon.ebook": { "source": "apache", "extensions": ["azw"] }, "application/vnd.americandynamics.acc": { "source": "iana", "extensions": ["acc"] }, "application/vnd.amiga.ami": { "source": "iana", "extensions": ["ami"] }, "application/vnd.amundsen.maze+xml": { "source": "iana" }, "application/vnd.android.package-archive": { "source": "apache", "compressible": false, "extensions": ["apk"] }, "application/vnd.anki": { "source": "iana" }, "application/vnd.anser-web-certificate-issue-initiation": { "source": "iana", "extensions": ["cii"] }, "application/vnd.anser-web-funds-transfer-initiation": { "source": "apache", "extensions": ["fti"] }, "application/vnd.antix.game-component": { "source": "iana", "extensions": ["atx"] }, "application/vnd.apache.thrift.binary": { "source": "iana" }, "application/vnd.apache.thrift.compact": { "source": "iana" }, "application/vnd.apache.thrift.json": { "source": "iana" }, "application/vnd.api+json": { "source": "iana", "compressible": true }, "application/vnd.apple.installer+xml": { "source": "iana", "extensions": ["mpkg"] }, "application/vnd.apple.mpegurl": { "source": "iana", "extensions": ["m3u8"] }, "application/vnd.apple.pkpass": { "compressible": false, "extensions": ["pkpass"] }, "application/vnd.arastra.swi": { "source": "iana" }, "application/vnd.aristanetworks.swi": { "source": "iana", "extensions": ["swi"] }, "application/vnd.artsquare": { "source": "iana" }, "application/vnd.astraea-software.iota": { "source": "iana", "extensions": ["iota"] }, "application/vnd.audiograph": { "source": "iana", "extensions": ["aep"] }, "application/vnd.autopackage": { "source": "iana" }, "application/vnd.avistar+xml": { "source": "iana" }, "application/vnd.balsamiq.bmml+xml": { "source": "iana" }, "application/vnd.balsamiq.bmpr": { "source": "iana" }, "application/vnd.bekitzur-stech+json": { "source": "iana", "compressible": true }, "application/vnd.biopax.rdf+xml": { "source": "iana" }, "application/vnd.blueice.multipass": { "source": "iana", "extensions": ["mpm"] }, "application/vnd.bluetooth.ep.oob": { "source": "iana" }, "application/vnd.bluetooth.le.oob": { "source": "iana" }, "application/vnd.bmi": { "source": "iana", "extensions": ["bmi"] }, "application/vnd.businessobjects": { "source": "iana", "extensions": ["rep"] }, "application/vnd.cab-jscript": { "source": "iana" }, "application/vnd.canon-cpdl": { "source": "iana" }, "application/vnd.canon-lips": { "source": "iana" }, "application/vnd.cendio.thinlinc.clientconf": { "source": "iana" }, "application/vnd.century-systems.tcp_stream": { "source": "iana" }, "application/vnd.chemdraw+xml": { "source": "iana", "extensions": ["cdxml"] }, "application/vnd.chipnuts.karaoke-mmd": { "source": "iana", "extensions": ["mmd"] }, "application/vnd.cinderella": { "source": "iana", "extensions": ["cdy"] }, "application/vnd.cirpack.isdn-ext": { "source": "iana" }, "application/vnd.citationstyles.style+xml": { "source": "iana" }, "application/vnd.claymore": { "source": "iana", "extensions": ["cla"] }, "application/vnd.cloanto.rp9": { "source": "iana", "extensions": ["rp9"] }, "application/vnd.clonk.c4group": { "source": "iana", "extensions": ["c4g","c4d","c4f","c4p","c4u"] }, "application/vnd.cluetrust.cartomobile-config": { "source": "iana", "extensions": ["c11amc"] }, "application/vnd.cluetrust.cartomobile-config-pkg": { "source": "iana", "extensions": ["c11amz"] }, "application/vnd.coffeescript": { "source": "iana" }, "application/vnd.collection+json": { "source": "iana", "compressible": true }, "application/vnd.collection.doc+json": { "source": "iana", "compressible": true }, "application/vnd.collection.next+json": { "source": "iana", "compressible": true }, "application/vnd.commerce-battelle": { "source": "iana" }, "application/vnd.commonspace": { "source": "iana", "extensions": ["csp"] }, "application/vnd.contact.cmsg": { "source": "iana", "extensions": ["cdbcmsg"] }, "application/vnd.cosmocaller": { "source": "iana", "extensions": ["cmc"] }, "application/vnd.crick.clicker": { "source": "iana", "extensions": ["clkx"] }, "application/vnd.crick.clicker.keyboard": { "source": "iana", "extensions": ["clkk"] }, "application/vnd.crick.clicker.palette": { "source": "iana", "extensions": ["clkp"] }, "application/vnd.crick.clicker.template": { "source": "iana", "extensions": ["clkt"] }, "application/vnd.crick.clicker.wordbank": { "source": "iana", "extensions": ["clkw"] }, "application/vnd.criticaltools.wbs+xml": { "source": "iana", "extensions": ["wbs"] }, "application/vnd.ctc-posml": { "source": "iana", "extensions": ["pml"] }, "application/vnd.ctct.ws+xml": { "source": "iana" }, "application/vnd.cups-pdf": { "source": "iana" }, "application/vnd.cups-postscript": { "source": "iana" }, "application/vnd.cups-ppd": { "source": "iana", "extensions": ["ppd"] }, "application/vnd.cups-raster": { "source": "iana" }, "application/vnd.cups-raw": { "source": "iana" }, "application/vnd.curl": { "source": "iana" }, "application/vnd.curl.car": { "source": "apache", "extensions": ["car"] }, "application/vnd.curl.pcurl": { "source": "apache", "extensions": ["pcurl"] }, "application/vnd.cyan.dean.root+xml": { "source": "iana" }, "application/vnd.cybank": { "source": "iana" }, "application/vnd.dart": { "source": "iana", "compressible": true, "extensions": ["dart"] }, "application/vnd.data-vision.rdz": { "source": "iana", "extensions": ["rdz"] }, "application/vnd.debian.binary-package": { "source": "iana" }, "application/vnd.dece.data": { "source": "iana", "extensions": ["uvf","uvvf","uvd","uvvd"] }, "application/vnd.dece.ttml+xml": { "source": "iana", "extensions": ["uvt","uvvt"] }, "application/vnd.dece.unspecified": { "source": "iana", "extensions": ["uvx","uvvx"] }, "application/vnd.dece.zip": { "source": "iana", "extensions": ["uvz","uvvz"] }, "application/vnd.denovo.fcselayout-link": { "source": "iana", "extensions": ["fe_launch"] }, "application/vnd.desmume-movie": { "source": "iana" }, "application/vnd.dir-bi.plate-dl-nosuffix": { "source": "iana" }, "application/vnd.dm.delegation+xml": { "source": "iana" }, "application/vnd.dna": { "source": "iana", "extensions": ["dna"] }, "application/vnd.document+json": { "source": "iana", "compressible": true }, "application/vnd.dolby.mlp": { "source": "apache", "extensions": ["mlp"] }, "application/vnd.dolby.mobile.1": { "source": "iana" }, "application/vnd.dolby.mobile.2": { "source": "iana" }, "application/vnd.doremir.scorecloud-binary-document": { "source": "iana" }, "application/vnd.dpgraph": { "source": "iana", "extensions": ["dpg"] }, "application/vnd.dreamfactory": { "source": "iana", "extensions": ["dfac"] }, "application/vnd.drive+json": { "source": "iana", "compressible": true }, "application/vnd.ds-keypoint": { "source": "apache", "extensions": ["kpxx"] }, "application/vnd.dtg.local": { "source": "iana" }, "application/vnd.dtg.local.flash": { "source": "iana" }, "application/vnd.dtg.local.html": { "source": "iana" }, "application/vnd.dvb.ait": { "source": "iana", "extensions": ["ait"] }, "application/vnd.dvb.dvbj": { "source": "iana" }, "application/vnd.dvb.esgcontainer": { "source": "iana" }, "application/vnd.dvb.ipdcdftnotifaccess": { "source": "iana" }, "application/vnd.dvb.ipdcesgaccess": { "source": "iana" }, "application/vnd.dvb.ipdcesgaccess2": { "source": "iana" }, "application/vnd.dvb.ipdcesgpdd": { "source": "iana" }, "application/vnd.dvb.ipdcroaming": { "source": "iana" }, "application/vnd.dvb.iptv.alfec-base": { "source": "iana" }, "application/vnd.dvb.iptv.alfec-enhancement": { "source": "iana" }, "application/vnd.dvb.notif-aggregate-root+xml": { "source": "iana" }, "application/vnd.dvb.notif-container+xml": { "source": "iana" }, "application/vnd.dvb.notif-generic+xml": { "source": "iana" }, "application/vnd.dvb.notif-ia-msglist+xml": { "source": "iana" }, "application/vnd.dvb.notif-ia-registration-request+xml": { "source": "iana" }, "application/vnd.dvb.notif-ia-registration-response+xml": { "source": "iana" }, "application/vnd.dvb.notif-init+xml": { "source": "iana" }, "application/vnd.dvb.pfr": { "source": "iana" }, "application/vnd.dvb.service": { "source": "iana", "extensions": ["svc"] }, "application/vnd.dxr": { "source": "iana" }, "application/vnd.dynageo": { "source": "iana", "extensions": ["geo"] }, "application/vnd.dzr": { "source": "iana" }, "application/vnd.easykaraoke.cdgdownload": { "source": "iana" }, "application/vnd.ecdis-update": { "source": "iana" }, "application/vnd.ecowin.chart": { "source": "iana", "extensions": ["mag"] }, "application/vnd.ecowin.filerequest": { "source": "iana" }, "application/vnd.ecowin.fileupdate": { "source": "iana" }, "application/vnd.ecowin.series": { "source": "iana" }, "application/vnd.ecowin.seriesrequest": { "source": "iana" }, "application/vnd.ecowin.seriesupdate": { "source": "iana" }, "application/vnd.emclient.accessrequest+xml": { "source": "iana" }, "application/vnd.enliven": { "source": "iana", "extensions": ["nml"] }, "application/vnd.enphase.envoy": { "source": "iana" }, "application/vnd.eprints.data+xml": { "source": "iana" }, "application/vnd.epson.esf": { "source": "iana", "extensions": ["esf"] }, "application/vnd.epson.msf": { "source": "iana", "extensions": ["msf"] }, "application/vnd.epson.quickanime": { "source": "iana", "extensions": ["qam"] }, "application/vnd.epson.salt": { "source": "iana", "extensions": ["slt"] }, "application/vnd.epson.ssf": { "source": "iana", "extensions": ["ssf"] }, "application/vnd.ericsson.quickcall": { "source": "iana" }, "application/vnd.eszigno3+xml": { "source": "iana", "extensions": ["es3","et3"] }, "application/vnd.etsi.aoc+xml": { "source": "iana" }, "application/vnd.etsi.asic-e+zip": { "source": "iana" }, "application/vnd.etsi.asic-s+zip": { "source": "iana" }, "application/vnd.etsi.cug+xml": { "source": "iana" }, "application/vnd.etsi.iptvcommand+xml": { "source": "iana" }, "application/vnd.etsi.iptvdiscovery+xml": { "source": "iana" }, "application/vnd.etsi.iptvprofile+xml": { "source": "iana" }, "application/vnd.etsi.iptvsad-bc+xml": { "source": "iana" }, "application/vnd.etsi.iptvsad-cod+xml": { "source": "iana" }, "application/vnd.etsi.iptvsad-npvr+xml": { "source": "iana" }, "application/vnd.etsi.iptvservice+xml": { "source": "iana" }, "application/vnd.etsi.iptvsync+xml": { "source": "iana" }, "application/vnd.etsi.iptvueprofile+xml": { "source": "iana" }, "application/vnd.etsi.mcid+xml": { "source": "iana" }, "application/vnd.etsi.mheg5": { "source": "iana" }, "application/vnd.etsi.overload-control-policy-dataset+xml": { "source": "iana" }, "application/vnd.etsi.pstn+xml": { "source": "iana" }, "application/vnd.etsi.sci+xml": { "source": "iana" }, "application/vnd.etsi.simservs+xml": { "source": "iana" }, "application/vnd.etsi.timestamp-token": { "source": "iana" }, "application/vnd.etsi.tsl+xml": { "source": "iana" }, "application/vnd.etsi.tsl.der": { "source": "iana" }, "application/vnd.eudora.data": { "source": "iana" }, "application/vnd.ezpix-album": { "source": "iana", "extensions": ["ez2"] }, "application/vnd.ezpix-package": { "source": "iana", "extensions": ["ez3"] }, "application/vnd.f-secure.mobile": { "source": "iana" }, "application/vnd.fastcopy-disk-image": { "source": "iana" }, "application/vnd.fdf": { "source": "iana", "extensions": ["fdf"] }, "application/vnd.fdsn.mseed": { "source": "iana", "extensions": ["mseed"] }, "application/vnd.fdsn.seed": { "source": "iana", "extensions": ["seed","dataless"] }, "application/vnd.ffsns": { "source": "iana" }, "application/vnd.filmit.zfc": { "source": "iana" }, "application/vnd.fints": { "source": "iana" }, "application/vnd.firemonkeys.cloudcell": { "source": "iana" }, "application/vnd.flographit": { "source": "iana", "extensions": ["gph"] }, "application/vnd.fluxtime.clip": { "source": "iana", "extensions": ["ftc"] }, "application/vnd.font-fontforge-sfd": { "source": "iana" }, "application/vnd.framemaker": { "source": "iana", "extensions": ["fm","frame","maker","book"] }, "application/vnd.frogans.fnc": { "source": "iana", "extensions": ["fnc"] }, "application/vnd.frogans.ltf": { "source": "iana", "extensions": ["ltf"] }, "application/vnd.fsc.weblaunch": { "source": "iana", "extensions": ["fsc"] }, "application/vnd.fujitsu.oasys": { "source": "iana", "extensions": ["oas"] }, "application/vnd.fujitsu.oasys2": { "source": "iana", "extensions": ["oa2"] }, "application/vnd.fujitsu.oasys3": { "source": "iana", "extensions": ["oa3"] }, "application/vnd.fujitsu.oasysgp": { "source": "iana", "extensions": ["fg5"] }, "application/vnd.fujitsu.oasysprs": { "source": "iana", "extensions": ["bh2"] }, "application/vnd.fujixerox.art-ex": { "source": "iana" }, "application/vnd.fujixerox.art4": { "source": "iana" }, "application/vnd.fujixerox.ddd": { "source": "iana", "extensions": ["ddd"] }, "application/vnd.fujixerox.docuworks": { "source": "iana", "extensions": ["xdw"] }, "application/vnd.fujixerox.docuworks.binder": { "source": "iana", "extensions": ["xbd"] }, "application/vnd.fujixerox.docuworks.container": { "source": "iana" }, "application/vnd.fujixerox.hbpl": { "source": "iana" }, "application/vnd.fut-misnet": { "source": "iana" }, "application/vnd.fuzzysheet": { "source": "iana", "extensions": ["fzs"] }, "application/vnd.genomatix.tuxedo": { "source": "iana", "extensions": ["txd"] }, "application/vnd.geo+json": { "source": "iana", "compressible": true }, "application/vnd.geocube+xml": { "source": "iana" }, "application/vnd.geogebra.file": { "source": "iana", "extensions": ["ggb"] }, "application/vnd.geogebra.tool": { "source": "iana", "extensions": ["ggt"] }, "application/vnd.geometry-explorer": { "source": "iana", "extensions": ["gex","gre"] }, "application/vnd.geonext": { "source": "iana", "extensions": ["gxt"] }, "application/vnd.geoplan": { "source": "iana", "extensions": ["g2w"] }, "application/vnd.geospace": { "source": "iana", "extensions": ["g3w"] }, "application/vnd.gerber": { "source": "iana" }, "application/vnd.globalplatform.card-content-mgt": { "source": "iana" }, "application/vnd.globalplatform.card-content-mgt-response": { "source": "iana" }, "application/vnd.gmx": { "source": "iana", "extensions": ["gmx"] }, "application/vnd.google-apps.document": { "compressible": false, "extensions": ["gdoc"] }, "application/vnd.google-apps.presentation": { "compressible": false, "extensions": ["gslides"] }, "application/vnd.google-apps.spreadsheet": { "compressible": false, "extensions": ["gsheet"] }, "application/vnd.google-earth.kml+xml": { "source": "iana", "compressible": true, "extensions": ["kml"] }, "application/vnd.google-earth.kmz": { "source": "iana", "compressible": false, "extensions": ["kmz"] }, "application/vnd.gov.sk.e-form+xml": { "source": "iana" }, "application/vnd.gov.sk.e-form+zip": { "source": "iana" }, "application/vnd.gov.sk.xmldatacontainer+xml": { "source": "iana" }, "application/vnd.grafeq": { "source": "iana", "extensions": ["gqf","gqs"] }, "application/vnd.gridmp": { "source": "iana" }, "application/vnd.groove-account": { "source": "iana", "extensions": ["gac"] }, "application/vnd.groove-help": { "source": "iana", "extensions": ["ghf"] }, "application/vnd.groove-identity-message": { "source": "iana", "extensions": ["gim"] }, "application/vnd.groove-injector": { "source": "iana", "extensions": ["grv"] }, "application/vnd.groove-tool-message": { "source": "iana", "extensions": ["gtm"] }, "application/vnd.groove-tool-template": { "source": "iana", "extensions": ["tpl"] }, "application/vnd.groove-vcard": { "source": "iana", "extensions": ["vcg"] }, "application/vnd.hal+json": { "source": "iana", "compressible": true }, "application/vnd.hal+xml": { "source": "iana", "extensions": ["hal"] }, "application/vnd.handheld-entertainment+xml": { "source": "iana", "extensions": ["zmm"] }, "application/vnd.hbci": { "source": "iana", "extensions": ["hbci"] }, "application/vnd.hcl-bireports": { "source": "iana" }, "application/vnd.hdt": { "source": "iana" }, "application/vnd.heroku+json": { "source": "iana", "compressible": true }, "application/vnd.hhe.lesson-player": { "source": "iana", "extensions": ["les"] }, "application/vnd.hp-hpgl": { "source": "iana", "extensions": ["hpgl"] }, "application/vnd.hp-hpid": { "source": "iana", "extensions": ["hpid"] }, "application/vnd.hp-hps": { "source": "iana", "extensions": ["hps"] }, "application/vnd.hp-jlyt": { "source": "iana", "extensions": ["jlt"] }, "application/vnd.hp-pcl": { "source": "iana", "extensions": ["pcl"] }, "application/vnd.hp-pclxl": { "source": "iana", "extensions": ["pclxl"] }, "application/vnd.httphone": { "source": "iana" }, "application/vnd.hydrostatix.sof-data": { "source": "iana", "extensions": ["sfd-hdstx"] }, "application/vnd.hyperdrive+json": { "source": "iana", "compressible": true }, "application/vnd.hzn-3d-crossword": { "source": "iana" }, "application/vnd.ibm.afplinedata": { "source": "iana" }, "application/vnd.ibm.electronic-media": { "source": "iana" }, "application/vnd.ibm.minipay": { "source": "iana", "extensions": ["mpy"] }, "application/vnd.ibm.modcap": { "source": "iana", "extensions": ["afp","listafp","list3820"] }, "application/vnd.ibm.rights-management": { "source": "iana", "extensions": ["irm"] }, "application/vnd.ibm.secure-container": { "source": "iana", "extensions": ["sc"] }, "application/vnd.iccprofile": { "source": "iana", "extensions": ["icc","icm"] }, "application/vnd.ieee.1905": { "source": "iana" }, "application/vnd.igloader": { "source": "iana", "extensions": ["igl"] }, "application/vnd.immervision-ivp": { "source": "iana", "extensions": ["ivp"] }, "application/vnd.immervision-ivu": { "source": "iana", "extensions": ["ivu"] }, "application/vnd.ims.imsccv1p1": { "source": "iana" }, "application/vnd.ims.imsccv1p2": { "source": "iana" }, "application/vnd.ims.imsccv1p3": { "source": "iana" }, "application/vnd.ims.lis.v2.result+json": { "source": "iana", "compressible": true }, "application/vnd.ims.lti.v2.toolconsumerprofile+json": { "source": "iana", "compressible": true }, "application/vnd.ims.lti.v2.toolproxy+json": { "source": "iana", "compressible": true }, "application/vnd.ims.lti.v2.toolproxy.id+json": { "source": "iana", "compressible": true }, "application/vnd.ims.lti.v2.toolsettings+json": { "source": "iana", "compressible": true }, "application/vnd.ims.lti.v2.toolsettings.simple+json": { "source": "iana", "compressible": true }, "application/vnd.informedcontrol.rms+xml": { "source": "iana" }, "application/vnd.informix-visionary": { "source": "iana" }, "application/vnd.infotech.project": { "source": "iana" }, "application/vnd.infotech.project+xml": { "source": "iana" }, "application/vnd.innopath.wamp.notification": { "source": "iana" }, "application/vnd.insors.igm": { "source": "iana", "extensions": ["igm"] }, "application/vnd.intercon.formnet": { "source": "iana", "extensions": ["xpw","xpx"] }, "application/vnd.intergeo": { "source": "iana", "extensions": ["i2g"] }, "application/vnd.intertrust.digibox": { "source": "iana" }, "application/vnd.intertrust.nncp": { "source": "iana" }, "application/vnd.intu.qbo": { "source": "iana", "extensions": ["qbo"] }, "application/vnd.intu.qfx": { "source": "iana", "extensions": ["qfx"] }, "application/vnd.iptc.g2.catalogitem+xml": { "source": "iana" }, "application/vnd.iptc.g2.conceptitem+xml": { "source": "iana" }, "application/vnd.iptc.g2.knowledgeitem+xml": { "source": "iana" }, "application/vnd.iptc.g2.newsitem+xml": { "source": "iana" }, "application/vnd.iptc.g2.newsmessage+xml": { "source": "iana" }, "application/vnd.iptc.g2.packageitem+xml": { "source": "iana" }, "application/vnd.iptc.g2.planningitem+xml": { "source": "iana" }, "application/vnd.ipunplugged.rcprofile": { "source": "iana", "extensions": ["rcprofile"] }, "application/vnd.irepository.package+xml": { "source": "iana", "extensions": ["irp"] }, "application/vnd.is-xpr": { "source": "iana", "extensions": ["xpr"] }, "application/vnd.isac.fcs": { "source": "iana", "extensions": ["fcs"] }, "application/vnd.jam": { "source": "iana", "extensions": ["jam"] }, "application/vnd.japannet-directory-service": { "source": "iana" }, "application/vnd.japannet-jpnstore-wakeup": { "source": "iana" }, "application/vnd.japannet-payment-wakeup": { "source": "iana" }, "application/vnd.japannet-registration": { "source": "iana" }, "application/vnd.japannet-registration-wakeup": { "source": "iana" }, "application/vnd.japannet-setstore-wakeup": { "source": "iana" }, "application/vnd.japannet-verification": { "source": "iana" }, "application/vnd.japannet-verification-wakeup": { "source": "iana" }, "application/vnd.jcp.javame.midlet-rms": { "source": "iana", "extensions": ["rms"] }, "application/vnd.jisp": { "source": "iana", "extensions": ["jisp"] }, "application/vnd.joost.joda-archive": { "source": "iana", "extensions": ["joda"] }, "application/vnd.jsk.isdn-ngn": { "source": "iana" }, "application/vnd.kahootz": { "source": "iana", "extensions": ["ktz","ktr"] }, "application/vnd.kde.karbon": { "source": "iana", "extensions": ["karbon"] }, "application/vnd.kde.kchart": { "source": "iana", "extensions": ["chrt"] }, "application/vnd.kde.kformula": { "source": "iana", "extensions": ["kfo"] }, "application/vnd.kde.kivio": { "source": "iana", "extensions": ["flw"] }, "application/vnd.kde.kontour": { "source": "iana", "extensions": ["kon"] }, "application/vnd.kde.kpresenter": { "source": "iana", "extensions": ["kpr","kpt"] }, "application/vnd.kde.kspread": { "source": "iana", "extensions": ["ksp"] }, "application/vnd.kde.kword": { "source": "iana", "extensions": ["kwd","kwt"] }, "application/vnd.kenameaapp": { "source": "iana", "extensions": ["htke"] }, "application/vnd.kidspiration": { "source": "iana", "extensions": ["kia"] }, "application/vnd.kinar": { "source": "iana", "extensions": ["kne","knp"] }, "application/vnd.koan": { "source": "iana", "extensions": ["skp","skd","skt","skm"] }, "application/vnd.kodak-descriptor": { "source": "iana", "extensions": ["sse"] }, "application/vnd.las.las+xml": { "source": "iana", "extensions": ["lasxml"] }, "application/vnd.liberty-request+xml": { "source": "iana" }, "application/vnd.llamagraphics.life-balance.desktop": { "source": "iana", "extensions": ["lbd"] }, "application/vnd.llamagraphics.life-balance.exchange+xml": { "source": "iana", "extensions": ["lbe"] }, "application/vnd.lotus-1-2-3": { "source": "iana", "extensions": ["123"] }, "application/vnd.lotus-approach": { "source": "iana", "extensions": ["apr"] }, "application/vnd.lotus-freelance": { "source": "iana", "extensions": ["pre"] }, "application/vnd.lotus-notes": { "source": "iana", "extensions": ["nsf"] }, "application/vnd.lotus-organizer": { "source": "iana", "extensions": ["org"] }, "application/vnd.lotus-screencam": { "source": "iana", "extensions": ["scm"] }, "application/vnd.lotus-wordpro": { "source": "iana", "extensions": ["lwp"] }, "application/vnd.macports.portpkg": { "source": "iana", "extensions": ["portpkg"] }, "application/vnd.mapbox-vector-tile": { "source": "iana" }, "application/vnd.marlin.drm.actiontoken+xml": { "source": "iana" }, "application/vnd.marlin.drm.conftoken+xml": { "source": "iana" }, "application/vnd.marlin.drm.license+xml": { "source": "iana" }, "application/vnd.marlin.drm.mdcf": { "source": "iana" }, "application/vnd.mason+json": { "source": "iana", "compressible": true }, "application/vnd.maxmind.maxmind-db": { "source": "iana" }, "application/vnd.mcd": { "source": "iana", "extensions": ["mcd"] }, "application/vnd.medcalcdata": { "source": "iana", "extensions": ["mc1"] }, "application/vnd.mediastation.cdkey": { "source": "iana", "extensions": ["cdkey"] }, "application/vnd.meridian-slingshot": { "source": "iana" }, "application/vnd.mfer": { "source": "iana", "extensions": ["mwf"] }, "application/vnd.mfmp": { "source": "iana", "extensions": ["mfm"] }, "application/vnd.micro+json": { "source": "iana", "compressible": true }, "application/vnd.micrografx.flo": { "source": "iana", "extensions": ["flo"] }, "application/vnd.micrografx.igx": { "source": "iana", "extensions": ["igx"] }, "application/vnd.microsoft.portable-executable": { "source": "iana" }, "application/vnd.miele+json": { "source": "iana", "compressible": true }, "application/vnd.mif": { "source": "iana", "extensions": ["mif"] }, "application/vnd.minisoft-hp3000-save": { "source": "iana" }, "application/vnd.mitsubishi.misty-guard.trustweb": { "source": "iana" }, "application/vnd.mobius.daf": { "source": "iana", "extensions": ["daf"] }, "application/vnd.mobius.dis": { "source": "iana", "extensions": ["dis"] }, "application/vnd.mobius.mbk": { "source": "iana", "extensions": ["mbk"] }, "application/vnd.mobius.mqy": { "source": "iana", "extensions": ["mqy"] }, "application/vnd.mobius.msl": { "source": "iana", "extensions": ["msl"] }, "application/vnd.mobius.plc": { "source": "iana", "extensions": ["plc"] }, "application/vnd.mobius.txf": { "source": "iana", "extensions": ["txf"] }, "application/vnd.mophun.application": { "source": "iana", "extensions": ["mpn"] }, "application/vnd.mophun.certificate": { "source": "iana", "extensions": ["mpc"] }, "application/vnd.motorola.flexsuite": { "source": "iana" }, "application/vnd.motorola.flexsuite.adsi": { "source": "iana" }, "application/vnd.motorola.flexsuite.fis": { "source": "iana" }, "application/vnd.motorola.flexsuite.gotap": { "source": "iana" }, "application/vnd.motorola.flexsuite.kmr": { "source": "iana" }, "application/vnd.motorola.flexsuite.ttc": { "source": "iana" }, "application/vnd.motorola.flexsuite.wem": { "source": "iana" }, "application/vnd.motorola.iprm": { "source": "iana" }, "application/vnd.mozilla.xul+xml": { "source": "iana", "compressible": true, "extensions": ["xul"] }, "application/vnd.ms-3mfdocument": { "source": "iana" }, "application/vnd.ms-artgalry": { "source": "iana", "extensions": ["cil"] }, "application/vnd.ms-asf": { "source": "iana" }, "application/vnd.ms-cab-compressed": { "source": "iana", "extensions": ["cab"] }, "application/vnd.ms-color.iccprofile": { "source": "apache" }, "application/vnd.ms-excel": { "source": "iana", "compressible": false, "extensions": ["xls","xlm","xla","xlc","xlt","xlw"] }, "application/vnd.ms-excel.addin.macroenabled.12": { "source": "iana", "extensions": ["xlam"] }, "application/vnd.ms-excel.sheet.binary.macroenabled.12": { "source": "iana", "extensions": ["xlsb"] }, "application/vnd.ms-excel.sheet.macroenabled.12": { "source": "iana", "extensions": ["xlsm"] }, "application/vnd.ms-excel.template.macroenabled.12": { "source": "iana", "extensions": ["xltm"] }, "application/vnd.ms-fontobject": { "source": "iana", "compressible": true, "extensions": ["eot"] }, "application/vnd.ms-htmlhelp": { "source": "iana", "extensions": ["chm"] }, "application/vnd.ms-ims": { "source": "iana", "extensions": ["ims"] }, "application/vnd.ms-lrm": { "source": "iana", "extensions": ["lrm"] }, "application/vnd.ms-office.activex+xml": { "source": "iana" }, "application/vnd.ms-officetheme": { "source": "iana", "extensions": ["thmx"] }, "application/vnd.ms-opentype": { "source": "apache", "compressible": true }, "application/vnd.ms-package.obfuscated-opentype": { "source": "apache" }, "application/vnd.ms-pki.seccat": { "source": "apache", "extensions": ["cat"] }, "application/vnd.ms-pki.stl": { "source": "apache", "extensions": ["stl"] }, "application/vnd.ms-playready.initiator+xml": { "source": "iana" }, "application/vnd.ms-powerpoint": { "source": "iana", "compressible": false, "extensions": ["ppt","pps","pot"] }, "application/vnd.ms-powerpoint.addin.macroenabled.12": { "source": "iana", "extensions": ["ppam"] }, "application/vnd.ms-powerpoint.presentation.macroenabled.12": { "source": "iana", "extensions": ["pptm"] }, "application/vnd.ms-powerpoint.slide.macroenabled.12": { "source": "iana", "extensions": ["sldm"] }, "application/vnd.ms-powerpoint.slideshow.macroenabled.12": { "source": "iana", "extensions": ["ppsm"] }, "application/vnd.ms-powerpoint.template.macroenabled.12": { "source": "iana", "extensions": ["potm"] }, "application/vnd.ms-printdevicecapabilities+xml": { "source": "iana" }, "application/vnd.ms-printing.printticket+xml": { "source": "apache" }, "application/vnd.ms-printschematicket+xml": { "source": "iana" }, "application/vnd.ms-project": { "source": "iana", "extensions": ["mpp","mpt"] }, "application/vnd.ms-tnef": { "source": "iana" }, "application/vnd.ms-windows.devicepairing": { "source": "iana" }, "application/vnd.ms-windows.nwprinting.oob": { "source": "iana" }, "application/vnd.ms-windows.printerpairing": { "source": "iana" }, "application/vnd.ms-windows.wsd.oob": { "source": "iana" }, "application/vnd.ms-wmdrm.lic-chlg-req": { "source": "iana" }, "application/vnd.ms-wmdrm.lic-resp": { "source": "iana" }, "application/vnd.ms-wmdrm.meter-chlg-req": { "source": "iana" }, "application/vnd.ms-wmdrm.meter-resp": { "source": "iana" }, "application/vnd.ms-word.document.macroenabled.12": { "source": "iana", "extensions": ["docm"] }, "application/vnd.ms-word.template.macroenabled.12": { "source": "iana", "extensions": ["dotm"] }, "application/vnd.ms-works": { "source": "iana", "extensions": ["wps","wks","wcm","wdb"] }, "application/vnd.ms-wpl": { "source": "iana", "extensions": ["wpl"] }, "application/vnd.ms-xpsdocument": { "source": "iana", "compressible": false, "extensions": ["xps"] }, "application/vnd.msa-disk-image": { "source": "iana" }, "application/vnd.mseq": { "source": "iana", "extensions": ["mseq"] }, "application/vnd.msign": { "source": "iana" }, "application/vnd.multiad.creator": { "source": "iana" }, "application/vnd.multiad.creator.cif": { "source": "iana" }, "application/vnd.music-niff": { "source": "iana" }, "application/vnd.musician": { "source": "iana", "extensions": ["mus"] }, "application/vnd.muvee.style": { "source": "iana", "extensions": ["msty"] }, "application/vnd.mynfc": { "source": "iana", "extensions": ["taglet"] }, "application/vnd.ncd.control": { "source": "iana" }, "application/vnd.ncd.reference": { "source": "iana" }, "application/vnd.nervana": { "source": "iana" }, "application/vnd.netfpx": { "source": "iana" }, "application/vnd.neurolanguage.nlu": { "source": "iana", "extensions": ["nlu"] }, "application/vnd.nintendo.nitro.rom": { "source": "iana" }, "application/vnd.nintendo.snes.rom": { "source": "iana" }, "application/vnd.nitf": { "source": "iana", "extensions": ["ntf","nitf"] }, "application/vnd.noblenet-directory": { "source": "iana", "extensions": ["nnd"] }, "application/vnd.noblenet-sealer": { "source": "iana", "extensions": ["nns"] }, "application/vnd.noblenet-web": { "source": "iana", "extensions": ["nnw"] }, "application/vnd.nokia.catalogs": { "source": "iana" }, "application/vnd.nokia.conml+wbxml": { "source": "iana" }, "application/vnd.nokia.conml+xml": { "source": "iana" }, "application/vnd.nokia.iptv.config+xml": { "source": "iana" }, "application/vnd.nokia.isds-radio-presets": { "source": "iana" }, "application/vnd.nokia.landmark+wbxml": { "source": "iana" }, "application/vnd.nokia.landmark+xml": { "source": "iana" }, "application/vnd.nokia.landmarkcollection+xml": { "source": "iana" }, "application/vnd.nokia.n-gage.ac+xml": { "source": "iana" }, "application/vnd.nokia.n-gage.data": { "source": "iana", "extensions": ["ngdat"] }, "application/vnd.nokia.n-gage.symbian.install": { "source": "iana", "extensions": ["n-gage"] }, "application/vnd.nokia.ncd": { "source": "iana" }, "application/vnd.nokia.pcd+wbxml": { "source": "iana" }, "application/vnd.nokia.pcd+xml": { "source": "iana" }, "application/vnd.nokia.radio-preset": { "source": "iana", "extensions": ["rpst"] }, "application/vnd.nokia.radio-presets": { "source": "iana", "extensions": ["rpss"] }, "application/vnd.novadigm.edm": { "source": "iana", "extensions": ["edm"] }, "application/vnd.novadigm.edx": { "source": "iana", "extensions": ["edx"] }, "application/vnd.novadigm.ext": { "source": "iana", "extensions": ["ext"] }, "application/vnd.ntt-local.content-share": { "source": "iana" }, "application/vnd.ntt-local.file-transfer": { "source": "iana" }, "application/vnd.ntt-local.ogw_remote-access": { "source": "iana" }, "application/vnd.ntt-local.sip-ta_remote": { "source": "iana" }, "application/vnd.ntt-local.sip-ta_tcp_stream": { "source": "iana" }, "application/vnd.oasis.opendocument.chart": { "source": "iana", "extensions": ["odc"] }, "application/vnd.oasis.opendocument.chart-template": { "source": "iana", "extensions": ["otc"] }, "application/vnd.oasis.opendocument.database": { "source": "iana", "extensions": ["odb"] }, "application/vnd.oasis.opendocument.formula": { "source": "iana", "extensions": ["odf"] }, "application/vnd.oasis.opendocument.formula-template": { "source": "iana", "extensions": ["odft"] }, "application/vnd.oasis.opendocument.graphics": { "source": "iana", "compressible": false, "extensions": ["odg"] }, "application/vnd.oasis.opendocument.graphics-template": { "source": "iana", "extensions": ["otg"] }, "application/vnd.oasis.opendocument.image": { "source": "iana", "extensions": ["odi"] }, "application/vnd.oasis.opendocument.image-template": { "source": "iana", "extensions": ["oti"] }, "application/vnd.oasis.opendocument.presentation": { "source": "iana", "compressible": false, "extensions": ["odp"] }, "application/vnd.oasis.opendocument.presentation-template": { "source": "iana", "extensions": ["otp"] }, "application/vnd.oasis.opendocument.spreadsheet": { "source": "iana", "compressible": false, "extensions": ["ods"] }, "application/vnd.oasis.opendocument.spreadsheet-template": { "source": "iana", "extensions": ["ots"] }, "application/vnd.oasis.opendocument.text": { "source": "iana", "compressible": false, "extensions": ["odt"] }, "application/vnd.oasis.opendocument.text-master": { "source": "iana", "extensions": ["odm"] }, "application/vnd.oasis.opendocument.text-template": { "source": "iana", "extensions": ["ott"] }, "application/vnd.oasis.opendocument.text-web": { "source": "iana", "extensions": ["oth"] }, "application/vnd.obn": { "source": "iana" }, "application/vnd.oftn.l10n+json": { "source": "iana", "compressible": true }, "application/vnd.oipf.contentaccessdownload+xml": { "source": "iana" }, "application/vnd.oipf.contentaccessstreaming+xml": { "source": "iana" }, "application/vnd.oipf.cspg-hexbinary": { "source": "iana" }, "application/vnd.oipf.dae.svg+xml": { "source": "iana" }, "application/vnd.oipf.dae.xhtml+xml": { "source": "iana" }, "application/vnd.oipf.mippvcontrolmessage+xml": { "source": "iana" }, "application/vnd.oipf.pae.gem": { "source": "iana" }, "application/vnd.oipf.spdiscovery+xml": { "source": "iana" }, "application/vnd.oipf.spdlist+xml": { "source": "iana" }, "application/vnd.oipf.ueprofile+xml": { "source": "iana" }, "application/vnd.oipf.userprofile+xml": { "source": "iana" }, "application/vnd.olpc-sugar": { "source": "iana", "extensions": ["xo"] }, "application/vnd.oma-scws-config": { "source": "iana" }, "application/vnd.oma-scws-http-request": { "source": "iana" }, "application/vnd.oma-scws-http-response": { "source": "iana" }, "application/vnd.oma.bcast.associated-procedure-parameter+xml": { "source": "iana" }, "application/vnd.oma.bcast.drm-trigger+xml": { "source": "iana" }, "application/vnd.oma.bcast.imd+xml": { "source": "iana" }, "application/vnd.oma.bcast.ltkm": { "source": "iana" }, "application/vnd.oma.bcast.notification+xml": { "source": "iana" }, "application/vnd.oma.bcast.provisioningtrigger": { "source": "iana" }, "application/vnd.oma.bcast.sgboot": { "source": "iana" }, "application/vnd.oma.bcast.sgdd+xml": { "source": "iana" }, "application/vnd.oma.bcast.sgdu": { "source": "iana" }, "application/vnd.oma.bcast.simple-symbol-container": { "source": "iana" }, "application/vnd.oma.bcast.smartcard-trigger+xml": { "source": "iana" }, "application/vnd.oma.bcast.sprov+xml": { "source": "iana" }, "application/vnd.oma.bcast.stkm": { "source": "iana" }, "application/vnd.oma.cab-address-book+xml": { "source": "iana" }, "application/vnd.oma.cab-feature-handler+xml": { "source": "iana" }, "application/vnd.oma.cab-pcc+xml": { "source": "iana" }, "application/vnd.oma.cab-subs-invite+xml": { "source": "iana" }, "application/vnd.oma.cab-user-prefs+xml": { "source": "iana" }, "application/vnd.oma.dcd": { "source": "iana" }, "application/vnd.oma.dcdc": { "source": "iana" }, "application/vnd.oma.dd2+xml": { "source": "iana", "extensions": ["dd2"] }, "application/vnd.oma.drm.risd+xml": { "source": "iana" }, "application/vnd.oma.group-usage-list+xml": { "source": "iana" }, "application/vnd.oma.pal+xml": { "source": "iana" }, "application/vnd.oma.poc.detailed-progress-report+xml": { "source": "iana" }, "application/vnd.oma.poc.final-report+xml": { "source": "iana" }, "application/vnd.oma.poc.groups+xml": { "source": "iana" }, "application/vnd.oma.poc.invocation-descriptor+xml": { "source": "iana" }, "application/vnd.oma.poc.optimized-progress-report+xml": { "source": "iana" }, "application/vnd.oma.push": { "source": "iana" }, "application/vnd.oma.scidm.messages+xml": { "source": "iana" }, "application/vnd.oma.xcap-directory+xml": { "source": "iana" }, "application/vnd.omads-email+xml": { "source": "iana" }, "application/vnd.omads-file+xml": { "source": "iana" }, "application/vnd.omads-folder+xml": { "source": "iana" }, "application/vnd.omaloc-supl-init": { "source": "iana" }, "application/vnd.openblox.game+xml": { "source": "iana" }, "application/vnd.openblox.game-binary": { "source": "iana" }, "application/vnd.openeye.oeb": { "source": "iana" }, "application/vnd.openofficeorg.extension": { "source": "apache", "extensions": ["oxt"] }, "application/vnd.openxmlformats-officedocument.custom-properties+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.customxmlproperties+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.drawing+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.drawingml.chart+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.drawingml.chartshapes+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.drawingml.diagramcolors+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.drawingml.diagramdata+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.drawingml.diagramlayout+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.drawingml.diagramstyle+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.extended-properties+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.presentationml-template": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.presentationml.commentauthors+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.presentationml.comments+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.presentationml.handoutmaster+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.presentationml.notesmaster+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.presentationml.notesslide+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.presentationml.presentation": { "source": "iana", "compressible": false, "extensions": ["pptx"] }, "application/vnd.openxmlformats-officedocument.presentationml.presentation.main+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.presentationml.presprops+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.presentationml.slide": { "source": "iana", "extensions": ["sldx"] }, "application/vnd.openxmlformats-officedocument.presentationml.slide+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.presentationml.slidelayout+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.presentationml.slidemaster+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.presentationml.slideshow": { "source": "iana", "extensions": ["ppsx"] }, "application/vnd.openxmlformats-officedocument.presentationml.slideshow.main+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.presentationml.slideupdateinfo+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.presentationml.tablestyles+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.presentationml.tags+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.presentationml.template": { "source": "apache", "extensions": ["potx"] }, "application/vnd.openxmlformats-officedocument.presentationml.template.main+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.presentationml.viewprops+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml-template": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.calcchain+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.chartsheet+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.comments+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.connections+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.dialogsheet+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.externallink+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.pivotcachedefinition+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.pivotcacherecords+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.pivottable+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.querytable+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.revisionheaders+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.revisionlog+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.sharedstrings+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet": { "source": "iana", "compressible": false, "extensions": ["xlsx"] }, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheetmetadata+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.table+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.tablesinglecells+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.template": { "source": "apache", "extensions": ["xltx"] }, "application/vnd.openxmlformats-officedocument.spreadsheetml.template.main+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.usernames+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.volatiledependencies+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.theme+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.themeoverride+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.vmldrawing": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.wordprocessingml-template": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.wordprocessingml.comments+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.wordprocessingml.document": { "source": "iana", "compressible": false, "extensions": ["docx"] }, "application/vnd.openxmlformats-officedocument.wordprocessingml.document.glossary+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.wordprocessingml.document.main+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.wordprocessingml.endnotes+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.wordprocessingml.fonttable+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.wordprocessingml.footer+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.wordprocessingml.footnotes+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.wordprocessingml.numbering+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.wordprocessingml.settings+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.wordprocessingml.styles+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.wordprocessingml.template": { "source": "apache", "extensions": ["dotx"] }, "application/vnd.openxmlformats-officedocument.wordprocessingml.template.main+xml": { "source": "iana" }, "application/vnd.openxmlformats-officedocument.wordprocessingml.websettings+xml": { "source": "iana" }, "application/vnd.openxmlformats-package.core-properties+xml": { "source": "iana" }, "application/vnd.openxmlformats-package.digital-signature-xmlsignature+xml": { "source": "iana" }, "application/vnd.openxmlformats-package.relationships+xml": { "source": "iana" }, "application/vnd.oracle.resource+json": { "source": "iana", "compressible": true }, "application/vnd.orange.indata": { "source": "iana" }, "application/vnd.osa.netdeploy": { "source": "iana" }, "application/vnd.osgeo.mapguide.package": { "source": "iana", "extensions": ["mgp"] }, "application/vnd.osgi.bundle": { "source": "iana" }, "application/vnd.osgi.dp": { "source": "iana", "extensions": ["dp"] }, "application/vnd.osgi.subsystem": { "source": "iana", "extensions": ["esa"] }, "application/vnd.otps.ct-kip+xml": { "source": "iana" }, "application/vnd.oxli.countgraph": { "source": "iana" }, "application/vnd.pagerduty+json": { "source": "iana", "compressible": true }, "application/vnd.palm": { "source": "iana", "extensions": ["pdb","pqa","oprc"] }, "application/vnd.panoply": { "source": "iana" }, "application/vnd.paos+xml": { "source": "iana" }, "application/vnd.paos.xml": { "source": "apache" }, "application/vnd.pawaafile": { "source": "iana", "extensions": ["paw"] }, "application/vnd.pcos": { "source": "iana" }, "application/vnd.pg.format": { "source": "iana", "extensions": ["str"] }, "application/vnd.pg.osasli": { "source": "iana", "extensions": ["ei6"] }, "application/vnd.piaccess.application-licence": { "source": "iana" }, "application/vnd.picsel": { "source": "iana", "extensions": ["efif"] }, "application/vnd.pmi.widget": { "source": "iana", "extensions": ["wg"] }, "application/vnd.poc.group-advertisement+xml": { "source": "iana" }, "application/vnd.pocketlearn": { "source": "iana", "extensions": ["plf"] }, "application/vnd.powerbuilder6": { "source": "iana", "extensions": ["pbd"] }, "application/vnd.powerbuilder6-s": { "source": "iana" }, "application/vnd.powerbuilder7": { "source": "iana" }, "application/vnd.powerbuilder7-s": { "source": "iana" }, "application/vnd.powerbuilder75": { "source": "iana" }, "application/vnd.powerbuilder75-s": { "source": "iana" }, "application/vnd.preminet": { "source": "iana" }, "application/vnd.previewsystems.box": { "source": "iana", "extensions": ["box"] }, "application/vnd.proteus.magazine": { "source": "iana", "extensions": ["mgz"] }, "application/vnd.publishare-delta-tree": { "source": "iana", "extensions": ["qps"] }, "application/vnd.pvi.ptid1": { "source": "iana", "extensions": ["ptid"] }, "application/vnd.pwg-multiplexed": { "source": "iana" }, "application/vnd.pwg-xhtml-print+xml": { "source": "iana" }, "application/vnd.qualcomm.brew-app-res": { "source": "iana" }, "application/vnd.quark.quarkxpress": { "source": "iana", "extensions": ["qxd","qxt","qwd","qwt","qxl","qxb"] }, "application/vnd.quobject-quoxdocument": { "source": "iana" }, "application/vnd.radisys.moml+xml": { "source": "iana" }, "application/vnd.radisys.msml+xml": { "source": "iana" }, "application/vnd.radisys.msml-audit+xml": { "source": "iana" }, "application/vnd.radisys.msml-audit-conf+xml": { "source": "iana" }, "application/vnd.radisys.msml-audit-conn+xml": { "source": "iana" }, "application/vnd.radisys.msml-audit-dialog+xml": { "source": "iana" }, "application/vnd.radisys.msml-audit-stream+xml": { "source": "iana" }, "application/vnd.radisys.msml-conf+xml": { "source": "iana" }, "application/vnd.radisys.msml-dialog+xml": { "source": "iana" }, "application/vnd.radisys.msml-dialog-base+xml": { "source": "iana" }, "application/vnd.radisys.msml-dialog-fax-detect+xml": { "source": "iana" }, "application/vnd.radisys.msml-dialog-fax-sendrecv+xml": { "source": "iana" }, "application/vnd.radisys.msml-dialog-group+xml": { "source": "iana" }, "application/vnd.radisys.msml-dialog-speech+xml": { "source": "iana" }, "application/vnd.radisys.msml-dialog-transform+xml": { "source": "iana" }, "application/vnd.rainstor.data": { "source": "iana" }, "application/vnd.rapid": { "source": "iana" }, "application/vnd.realvnc.bed": { "source": "iana", "extensions": ["bed"] }, "application/vnd.recordare.musicxml": { "source": "iana", "extensions": ["mxl"] }, "application/vnd.recordare.musicxml+xml": { "source": "iana", "extensions": ["musicxml"] }, "application/vnd.renlearn.rlprint": { "source": "iana" }, "application/vnd.rig.cryptonote": { "source": "iana", "extensions": ["cryptonote"] }, "application/vnd.rim.cod": { "source": "apache", "extensions": ["cod"] }, "application/vnd.rn-realmedia": { "source": "apache", "extensions": ["rm"] }, "application/vnd.rn-realmedia-vbr": { "source": "apache", "extensions": ["rmvb"] }, "application/vnd.route66.link66+xml": { "source": "iana", "extensions": ["link66"] }, "application/vnd.rs-274x": { "source": "iana" }, "application/vnd.ruckus.download": { "source": "iana" }, "application/vnd.s3sms": { "source": "iana" }, "application/vnd.sailingtracker.track": { "source": "iana", "extensions": ["st"] }, "application/vnd.sbm.cid": { "source": "iana" }, "application/vnd.sbm.mid2": { "source": "iana" }, "application/vnd.scribus": { "source": "iana" }, "application/vnd.sealed.3df": { "source": "iana" }, "application/vnd.sealed.csf": { "source": "iana" }, "application/vnd.sealed.doc": { "source": "iana" }, "application/vnd.sealed.eml": { "source": "iana" }, "application/vnd.sealed.mht": { "source": "iana" }, "application/vnd.sealed.net": { "source": "iana" }, "application/vnd.sealed.ppt": { "source": "iana" }, "application/vnd.sealed.tiff": { "source": "iana" }, "application/vnd.sealed.xls": { "source": "iana" }, "application/vnd.sealedmedia.softseal.html": { "source": "iana" }, "application/vnd.sealedmedia.softseal.pdf": { "source": "iana" }, "application/vnd.seemail": { "source": "iana", "extensions": ["see"] }, "application/vnd.sema": { "source": "iana", "extensions": ["sema"] }, "application/vnd.semd": { "source": "iana", "extensions": ["semd"] }, "application/vnd.semf": { "source": "iana", "extensions": ["semf"] }, "application/vnd.shana.informed.formdata": { "source": "iana", "extensions": ["ifm"] }, "application/vnd.shana.informed.formtemplate": { "source": "iana", "extensions": ["itp"] }, "application/vnd.shana.informed.interchange": { "source": "iana", "extensions": ["iif"] }, "application/vnd.shana.informed.package": { "source": "iana", "extensions": ["ipk"] }, "application/vnd.simtech-mindmapper": { "source": "iana", "extensions": ["twd","twds"] }, "application/vnd.siren+json": { "source": "iana", "compressible": true }, "application/vnd.smaf": { "source": "iana", "extensions": ["mmf"] }, "application/vnd.smart.notebook": { "source": "iana" }, "application/vnd.smart.teacher": { "source": "iana", "extensions": ["teacher"] }, "application/vnd.software602.filler.form+xml": { "source": "iana" }, "application/vnd.software602.filler.form-xml-zip": { "source": "iana" }, "application/vnd.solent.sdkm+xml": { "source": "iana", "extensions": ["sdkm","sdkd"] }, "application/vnd.spotfire.dxp": { "source": "iana", "extensions": ["dxp"] }, "application/vnd.spotfire.sfs": { "source": "iana", "extensions": ["sfs"] }, "application/vnd.sss-cod": { "source": "iana" }, "application/vnd.sss-dtf": { "source": "iana" }, "application/vnd.sss-ntf": { "source": "iana" }, "application/vnd.stardivision.calc": { "source": "apache", "extensions": ["sdc"] }, "application/vnd.stardivision.draw": { "source": "apache", "extensions": ["sda"] }, "application/vnd.stardivision.impress": { "source": "apache", "extensions": ["sdd"] }, "application/vnd.stardivision.math": { "source": "apache", "extensions": ["smf"] }, "application/vnd.stardivision.writer": { "source": "apache", "extensions": ["sdw","vor"] }, "application/vnd.stardivision.writer-global": { "source": "apache", "extensions": ["sgl"] }, "application/vnd.stepmania.package": { "source": "iana", "extensions": ["smzip"] }, "application/vnd.stepmania.stepchart": { "source": "iana", "extensions": ["sm"] }, "application/vnd.street-stream": { "source": "iana" }, "application/vnd.sun.wadl+xml": { "source": "iana" }, "application/vnd.sun.xml.calc": { "source": "apache", "extensions": ["sxc"] }, "application/vnd.sun.xml.calc.template": { "source": "apache", "extensions": ["stc"] }, "application/vnd.sun.xml.draw": { "source": "apache", "extensions": ["sxd"] }, "application/vnd.sun.xml.draw.template": { "source": "apache", "extensions": ["std"] }, "application/vnd.sun.xml.impress": { "source": "apache", "extensions": ["sxi"] }, "application/vnd.sun.xml.impress.template": { "source": "apache", "extensions": ["sti"] }, "application/vnd.sun.xml.math": { "source": "apache", "extensions": ["sxm"] }, "application/vnd.sun.xml.writer": { "source": "apache", "extensions": ["sxw"] }, "application/vnd.sun.xml.writer.global": { "source": "apache", "extensions": ["sxg"] }, "application/vnd.sun.xml.writer.template": { "source": "apache", "extensions": ["stw"] }, "application/vnd.sus-calendar": { "source": "iana", "extensions": ["sus","susp"] }, "application/vnd.svd": { "source": "iana", "extensions": ["svd"] }, "application/vnd.swiftview-ics": { "source": "iana" }, "application/vnd.symbian.install": { "source": "apache", "extensions": ["sis","sisx"] }, "application/vnd.syncml+xml": { "source": "iana", "extensions": ["xsm"] }, "application/vnd.syncml.dm+wbxml": { "source": "iana", "extensions": ["bdm"] }, "application/vnd.syncml.dm+xml": { "source": "iana", "extensions": ["xdm"] }, "application/vnd.syncml.dm.notification": { "source": "iana" }, "application/vnd.syncml.dmddf+wbxml": { "source": "iana" }, "application/vnd.syncml.dmddf+xml": { "source": "iana" }, "application/vnd.syncml.dmtnds+wbxml": { "source": "iana" }, "application/vnd.syncml.dmtnds+xml": { "source": "iana" }, "application/vnd.syncml.ds.notification": { "source": "iana" }, "application/vnd.tao.intent-module-archive": { "source": "iana", "extensions": ["tao"] }, "application/vnd.tcpdump.pcap": { "source": "iana", "extensions": ["pcap","cap","dmp"] }, "application/vnd.tmd.mediaflex.api+xml": { "source": "iana" }, "application/vnd.tml": { "source": "iana" }, "application/vnd.tmobile-livetv": { "source": "iana", "extensions": ["tmo"] }, "application/vnd.trid.tpt": { "source": "iana", "extensions": ["tpt"] }, "application/vnd.triscape.mxs": { "source": "iana", "extensions": ["mxs"] }, "application/vnd.trueapp": { "source": "iana", "extensions": ["tra"] }, "application/vnd.truedoc": { "source": "iana" }, "application/vnd.ubisoft.webplayer": { "source": "iana" }, "application/vnd.ufdl": { "source": "iana", "extensions": ["ufd","ufdl"] }, "application/vnd.uiq.theme": { "source": "iana", "extensions": ["utz"] }, "application/vnd.umajin": { "source": "iana", "extensions": ["umj"] }, "application/vnd.unity": { "source": "iana", "extensions": ["unityweb"] }, "application/vnd.uoml+xml": { "source": "iana", "extensions": ["uoml"] }, "application/vnd.uplanet.alert": { "source": "iana" }, "application/vnd.uplanet.alert-wbxml": { "source": "iana" }, "application/vnd.uplanet.bearer-choice": { "source": "iana" }, "application/vnd.uplanet.bearer-choice-wbxml": { "source": "iana" }, "application/vnd.uplanet.cacheop": { "source": "iana" }, "application/vnd.uplanet.cacheop-wbxml": { "source": "iana" }, "application/vnd.uplanet.channel": { "source": "iana" }, "application/vnd.uplanet.channel-wbxml": { "source": "iana" }, "application/vnd.uplanet.list": { "source": "iana" }, "application/vnd.uplanet.list-wbxml": { "source": "iana" }, "application/vnd.uplanet.listcmd": { "source": "iana" }, "application/vnd.uplanet.listcmd-wbxml": { "source": "iana" }, "application/vnd.uplanet.signal": { "source": "iana" }, "application/vnd.uri-map": { "source": "iana" }, "application/vnd.valve.source.material": { "source": "iana" }, "application/vnd.vcx": { "source": "iana", "extensions": ["vcx"] }, "application/vnd.vd-study": { "source": "iana" }, "application/vnd.vectorworks": { "source": "iana" }, "application/vnd.verimatrix.vcas": { "source": "iana" }, "application/vnd.vidsoft.vidconference": { "source": "iana" }, "application/vnd.visio": { "source": "iana", "extensions": ["vsd","vst","vss","vsw"] }, "application/vnd.visionary": { "source": "iana", "extensions": ["vis"] }, "application/vnd.vividence.scriptfile": { "source": "iana" }, "application/vnd.vsf": { "source": "iana", "extensions": ["vsf"] }, "application/vnd.wap.sic": { "source": "iana" }, "application/vnd.wap.slc": { "source": "iana" }, "application/vnd.wap.wbxml": { "source": "iana", "extensions": ["wbxml"] }, "application/vnd.wap.wmlc": { "source": "iana", "extensions": ["wmlc"] }, "application/vnd.wap.wmlscriptc": { "source": "iana", "extensions": ["wmlsc"] }, "application/vnd.webturbo": { "source": "iana", "extensions": ["wtb"] }, "application/vnd.wfa.p2p": { "source": "iana" }, "application/vnd.wfa.wsc": { "source": "iana" }, "application/vnd.windows.devicepairing": { "source": "iana" }, "application/vnd.wmc": { "source": "iana" }, "application/vnd.wmf.bootstrap": { "source": "iana" }, "application/vnd.wolfram.mathematica": { "source": "iana" }, "application/vnd.wolfram.mathematica.package": { "source": "iana" }, "application/vnd.wolfram.player": { "source": "iana", "extensions": ["nbp"] }, "application/vnd.wordperfect": { "source": "iana", "extensions": ["wpd"] }, "application/vnd.wqd": { "source": "iana", "extensions": ["wqd"] }, "application/vnd.wrq-hp3000-labelled": { "source": "iana" }, "application/vnd.wt.stf": { "source": "iana", "extensions": ["stf"] }, "application/vnd.wv.csp+wbxml": { "source": "iana" }, "application/vnd.wv.csp+xml": { "source": "iana" }, "application/vnd.wv.ssp+xml": { "source": "iana" }, "application/vnd.xacml+json": { "source": "iana", "compressible": true }, "application/vnd.xara": { "source": "iana", "extensions": ["xar"] }, "application/vnd.xfdl": { "source": "iana", "extensions": ["xfdl"] }, "application/vnd.xfdl.webform": { "source": "iana" }, "application/vnd.xmi+xml": { "source": "iana" }, "application/vnd.xmpie.cpkg": { "source": "iana" }, "application/vnd.xmpie.dpkg": { "source": "iana" }, "application/vnd.xmpie.plan": { "source": "iana" }, "application/vnd.xmpie.ppkg": { "source": "iana" }, "application/vnd.xmpie.xlim": { "source": "iana" }, "application/vnd.yamaha.hv-dic": { "source": "iana", "extensions": ["hvd"] }, "application/vnd.yamaha.hv-script": { "source": "iana", "extensions": ["hvs"] }, "application/vnd.yamaha.hv-voice": { "source": "iana", "extensions": ["hvp"] }, "application/vnd.yamaha.openscoreformat": { "source": "iana", "extensions": ["osf"] }, "application/vnd.yamaha.openscoreformat.osfpvg+xml": { "source": "iana", "extensions": ["osfpvg"] }, "application/vnd.yamaha.remote-setup": { "source": "iana" }, "application/vnd.yamaha.smaf-audio": { "source": "iana", "extensions": ["saf"] }, "application/vnd.yamaha.smaf-phrase": { "source": "iana", "extensions": ["spf"] }, "application/vnd.yamaha.through-ngn": { "source": "iana" }, "application/vnd.yamaha.tunnel-udpencap": { "source": "iana" }, "application/vnd.yaoweme": { "source": "iana" }, "application/vnd.yellowriver-custom-menu": { "source": "iana", "extensions": ["cmp"] }, "application/vnd.zul": { "source": "iana", "extensions": ["zir","zirz"] }, "application/vnd.zzazz.deck+xml": { "source": "iana", "extensions": ["zaz"] }, "application/voicexml+xml": { "source": "iana", "extensions": ["vxml"] }, "application/vq-rtcpxr": { "source": "iana" }, "application/watcherinfo+xml": { "source": "iana" }, "application/whoispp-query": { "source": "iana" }, "application/whoispp-response": { "source": "iana" }, "application/widget": { "source": "iana", "extensions": ["wgt"] }, "application/winhlp": { "source": "apache", "extensions": ["hlp"] }, "application/wita": { "source": "iana" }, "application/wordperfect5.1": { "source": "iana" }, "application/wsdl+xml": { "source": "iana", "extensions": ["wsdl"] }, "application/wspolicy+xml": { "source": "iana", "extensions": ["wspolicy"] }, "application/x-7z-compressed": { "source": "apache", "compressible": false, "extensions": ["7z"] }, "application/x-abiword": { "source": "apache", "extensions": ["abw"] }, "application/x-ace-compressed": { "source": "apache", "extensions": ["ace"] }, "application/x-amf": { "source": "apache" }, "application/x-apple-diskimage": { "source": "apache", "extensions": ["dmg"] }, "application/x-authorware-bin": { "source": "apache", "extensions": ["aab","x32","u32","vox"] }, "application/x-authorware-map": { "source": "apache", "extensions": ["aam"] }, "application/x-authorware-seg": { "source": "apache", "extensions": ["aas"] }, "application/x-bcpio": { "source": "apache", "extensions": ["bcpio"] }, "application/x-bdoc": { "compressible": false, "extensions": ["bdoc"] }, "application/x-bittorrent": { "source": "apache", "extensions": ["torrent"] }, "application/x-blorb": { "source": "apache", "extensions": ["blb","blorb"] }, "application/x-bzip": { "source": "apache", "compressible": false, "extensions": ["bz"] }, "application/x-bzip2": { "source": "apache", "compressible": false, "extensions": ["bz2","boz"] }, "application/x-cbr": { "source": "apache", "extensions": ["cbr","cba","cbt","cbz","cb7"] }, "application/x-cdlink": { "source": "apache", "extensions": ["vcd"] }, "application/x-cfs-compressed": { "source": "apache", "extensions": ["cfs"] }, "application/x-chat": { "source": "apache", "extensions": ["chat"] }, "application/x-chess-pgn": { "source": "apache", "extensions": ["pgn"] }, "application/x-chrome-extension": { "extensions": ["crx"] }, "application/x-cocoa": { "source": "nginx", "extensions": ["cco"] }, "application/x-compress": { "source": "apache" }, "application/x-conference": { "source": "apache", "extensions": ["nsc"] }, "application/x-cpio": { "source": "apache", "extensions": ["cpio"] }, "application/x-csh": { "source": "apache", "extensions": ["csh"] }, "application/x-deb": { "compressible": false }, "application/x-debian-package": { "source": "apache", "extensions": ["deb","udeb"] }, "application/x-dgc-compressed": { "source": "apache", "extensions": ["dgc"] }, "application/x-director": { "source": "apache", "extensions": ["dir","dcr","dxr","cst","cct","cxt","w3d","fgd","swa"] }, "application/x-doom": { "source": "apache", "extensions": ["wad"] }, "application/x-dtbncx+xml": { "source": "apache", "extensions": ["ncx"] }, "application/x-dtbook+xml": { "source": "apache", "extensions": ["dtb"] }, "application/x-dtbresource+xml": { "source": "apache", "extensions": ["res"] }, "application/x-dvi": { "source": "apache", "compressible": false, "extensions": ["dvi"] }, "application/x-envoy": { "source": "apache", "extensions": ["evy"] }, "application/x-eva": { "source": "apache", "extensions": ["eva"] }, "application/x-font-bdf": { "source": "apache", "extensions": ["bdf"] }, "application/x-font-dos": { "source": "apache" }, "application/x-font-framemaker": { "source": "apache" }, "application/x-font-ghostscript": { "source": "apache", "extensions": ["gsf"] }, "application/x-font-libgrx": { "source": "apache" }, "application/x-font-linux-psf": { "source": "apache", "extensions": ["psf"] }, "application/x-font-otf": { "source": "apache", "compressible": true, "extensions": ["otf"] }, "application/x-font-pcf": { "source": "apache", "extensions": ["pcf"] }, "application/x-font-snf": { "source": "apache", "extensions": ["snf"] }, "application/x-font-speedo": { "source": "apache" }, "application/x-font-sunos-news": { "source": "apache" }, "application/x-font-ttf": { "source": "apache", "compressible": true, "extensions": ["ttf","ttc"] }, "application/x-font-type1": { "source": "apache", "extensions": ["pfa","pfb","pfm","afm"] }, "application/x-font-vfont": { "source": "apache" }, "application/x-freearc": { "source": "apache", "extensions": ["arc"] }, "application/x-futuresplash": { "source": "apache", "extensions": ["spl"] }, "application/x-gca-compressed": { "source": "apache", "extensions": ["gca"] }, "application/x-glulx": { "source": "apache", "extensions": ["ulx"] }, "application/x-gnumeric": { "source": "apache", "extensions": ["gnumeric"] }, "application/x-gramps-xml": { "source": "apache", "extensions": ["gramps"] }, "application/x-gtar": { "source": "apache", "extensions": ["gtar"] }, "application/x-gzip": { "source": "apache" }, "application/x-hdf": { "source": "apache", "extensions": ["hdf"] }, "application/x-httpd-php": { "compressible": true, "extensions": ["php"] }, "application/x-install-instructions": { "source": "apache", "extensions": ["install"] }, "application/x-iso9660-image": { "source": "apache", "extensions": ["iso"] }, "application/x-java-archive-diff": { "source": "nginx", "extensions": ["jardiff"] }, "application/x-java-jnlp-file": { "source": "apache", "compressible": false, "extensions": ["jnlp"] }, "application/x-javascript": { "compressible": true }, "application/x-latex": { "source": "apache", "compressible": false, "extensions": ["latex"] }, "application/x-lua-bytecode": { "extensions": ["luac"] }, "application/x-lzh-compressed": { "source": "apache", "extensions": ["lzh","lha"] }, "application/x-makeself": { "source": "nginx", "extensions": ["run"] }, "application/x-mie": { "source": "apache", "extensions": ["mie"] }, "application/x-mobipocket-ebook": { "source": "apache", "extensions": ["prc","mobi"] }, "application/x-mpegurl": { "compressible": false }, "application/x-ms-application": { "source": "apache", "extensions": ["application"] }, "application/x-ms-shortcut": { "source": "apache", "extensions": ["lnk"] }, "application/x-ms-wmd": { "source": "apache", "extensions": ["wmd"] }, "application/x-ms-wmz": { "source": "apache", "extensions": ["wmz"] }, "application/x-ms-xbap": { "source": "apache", "extensions": ["xbap"] }, "application/x-msaccess": { "source": "apache", "extensions": ["mdb"] }, "application/x-msbinder": { "source": "apache", "extensions": ["obd"] }, "application/x-mscardfile": { "source": "apache", "extensions": ["crd"] }, "application/x-msclip": { "source": "apache", "extensions": ["clp"] }, "application/x-msdos-program": { "extensions": ["exe"] }, "application/x-msdownload": { "source": "apache", "extensions": ["exe","dll","com","bat","msi"] }, "application/x-msmediaview": { "source": "apache", "extensions": ["mvb","m13","m14"] }, "application/x-msmetafile": { "source": "apache", "extensions": ["wmf","wmz","emf","emz"] }, "application/x-msmoney": { "source": "apache", "extensions": ["mny"] }, "application/x-mspublisher": { "source": "apache", "extensions": ["pub"] }, "application/x-msschedule": { "source": "apache", "extensions": ["scd"] }, "application/x-msterminal": { "source": "apache", "extensions": ["trm"] }, "application/x-mswrite": { "source": "apache", "extensions": ["wri"] }, "application/x-netcdf": { "source": "apache", "extensions": ["nc","cdf"] }, "application/x-ns-proxy-autoconfig": { "compressible": true, "extensions": ["pac"] }, "application/x-nzb": { "source": "apache", "extensions": ["nzb"] }, "application/x-perl": { "source": "nginx", "extensions": ["pl","pm"] }, "application/x-pilot": { "source": "nginx", "extensions": ["prc","pdb"] }, "application/x-pkcs12": { "source": "apache", "compressible": false, "extensions": ["p12","pfx"] }, "application/x-pkcs7-certificates": { "source": "apache", "extensions": ["p7b","spc"] }, "application/x-pkcs7-certreqresp": { "source": "apache", "extensions": ["p7r"] }, "application/x-rar-compressed": { "source": "apache", "compressible": false, "extensions": ["rar"] }, "application/x-redhat-package-manager": { "source": "nginx", "extensions": ["rpm"] }, "application/x-research-info-systems": { "source": "apache", "extensions": ["ris"] }, "application/x-sea": { "source": "nginx", "extensions": ["sea"] }, "application/x-sh": { "source": "apache", "compressible": true, "extensions": ["sh"] }, "application/x-shar": { "source": "apache", "extensions": ["shar"] }, "application/x-shockwave-flash": { "source": "apache", "compressible": false, "extensions": ["swf"] }, "application/x-silverlight-app": { "source": "apache", "extensions": ["xap"] }, "application/x-sql": { "source": "apache", "extensions": ["sql"] }, "application/x-stuffit": { "source": "apache", "compressible": false, "extensions": ["sit"] }, "application/x-stuffitx": { "source": "apache", "extensions": ["sitx"] }, "application/x-subrip": { "source": "apache", "extensions": ["srt"] }, "application/x-sv4cpio": { "source": "apache", "extensions": ["sv4cpio"] }, "application/x-sv4crc": { "source": "apache", "extensions": ["sv4crc"] }, "application/x-t3vm-image": { "source": "apache", "extensions": ["t3"] }, "application/x-tads": { "source": "apache", "extensions": ["gam"] }, "application/x-tar": { "source": "apache", "compressible": true, "extensions": ["tar"] }, "application/x-tcl": { "source": "apache", "extensions": ["tcl","tk"] }, "application/x-tex": { "source": "apache", "extensions": ["tex"] }, "application/x-tex-tfm": { "source": "apache", "extensions": ["tfm"] }, "application/x-texinfo": { "source": "apache", "extensions": ["texinfo","texi"] }, "application/x-tgif": { "source": "apache", "extensions": ["obj"] }, "application/x-ustar": { "source": "apache", "extensions": ["ustar"] }, "application/x-wais-source": { "source": "apache", "extensions": ["src"] }, "application/x-web-app-manifest+json": { "compressible": true, "extensions": ["webapp"] }, "application/x-www-form-urlencoded": { "source": "iana", "compressible": true }, "application/x-x509-ca-cert": { "source": "apache", "extensions": ["der","crt","pem"] }, "application/x-xfig": { "source": "apache", "extensions": ["fig"] }, "application/x-xliff+xml": { "source": "apache", "extensions": ["xlf"] }, "application/x-xpinstall": { "source": "apache", "compressible": false, "extensions": ["xpi"] }, "application/x-xz": { "source": "apache", "extensions": ["xz"] }, "application/x-zmachine": { "source": "apache", "extensions": ["z1","z2","z3","z4","z5","z6","z7","z8"] }, "application/x400-bp": { "source": "iana" }, "application/xacml+xml": { "source": "iana" }, "application/xaml+xml": { "source": "apache", "extensions": ["xaml"] }, "application/xcap-att+xml": { "source": "iana" }, "application/xcap-caps+xml": { "source": "iana" }, "application/xcap-diff+xml": { "source": "iana", "extensions": ["xdf"] }, "application/xcap-el+xml": { "source": "iana" }, "application/xcap-error+xml": { "source": "iana" }, "application/xcap-ns+xml": { "source": "iana" }, "application/xcon-conference-info+xml": { "source": "iana" }, "application/xcon-conference-info-diff+xml": { "source": "iana" }, "application/xenc+xml": { "source": "iana", "extensions": ["xenc"] }, "application/xhtml+xml": { "source": "iana", "compressible": true, "extensions": ["xhtml","xht"] }, "application/xhtml-voice+xml": { "source": "apache" }, "application/xml": { "source": "iana", "compressible": true, "extensions": ["xml","xsl","xsd","rng"] }, "application/xml-dtd": { "source": "iana", "compressible": true, "extensions": ["dtd"] }, "application/xml-external-parsed-entity": { "source": "iana" }, "application/xml-patch+xml": { "source": "iana" }, "application/xmpp+xml": { "source": "iana" }, "application/xop+xml": { "source": "iana", "compressible": true, "extensions": ["xop"] }, "application/xproc+xml": { "source": "apache", "extensions": ["xpl"] }, "application/xslt+xml": { "source": "iana", "extensions": ["xslt"] }, "application/xspf+xml": { "source": "apache", "extensions": ["xspf"] }, "application/xv+xml": { "source": "iana", "extensions": ["mxml","xhvml","xvml","xvm"] }, "application/yang": { "source": "iana", "extensions": ["yang"] }, "application/yin+xml": { "source": "iana", "extensions": ["yin"] }, "application/zip": { "source": "iana", "compressible": false, "extensions": ["zip"] }, "application/zlib": { "source": "iana" }, "audio/1d-interleaved-parityfec": { "source": "iana" }, "audio/32kadpcm": { "source": "iana" }, "audio/3gpp": { "source": "iana" }, "audio/3gpp2": { "source": "iana" }, "audio/ac3": { "source": "iana" }, "audio/adpcm": { "source": "apache", "extensions": ["adp"] }, "audio/amr": { "source": "iana" }, "audio/amr-wb": { "source": "iana" }, "audio/amr-wb+": { "source": "iana" }, "audio/aptx": { "source": "iana" }, "audio/asc": { "source": "iana" }, "audio/atrac-advanced-lossless": { "source": "iana" }, "audio/atrac-x": { "source": "iana" }, "audio/atrac3": { "source": "iana" }, "audio/basic": { "source": "iana", "compressible": false, "extensions": ["au","snd"] }, "audio/bv16": { "source": "iana" }, "audio/bv32": { "source": "iana" }, "audio/clearmode": { "source": "iana" }, "audio/cn": { "source": "iana" }, "audio/dat12": { "source": "iana" }, "audio/dls": { "source": "iana" }, "audio/dsr-es201108": { "source": "iana" }, "audio/dsr-es202050": { "source": "iana" }, "audio/dsr-es202211": { "source": "iana" }, "audio/dsr-es202212": { "source": "iana" }, "audio/dv": { "source": "iana" }, "audio/dvi4": { "source": "iana" }, "audio/eac3": { "source": "iana" }, "audio/encaprtp": { "source": "iana" }, "audio/evrc": { "source": "iana" }, "audio/evrc-qcp": { "source": "iana" }, "audio/evrc0": { "source": "iana" }, "audio/evrc1": { "source": "iana" }, "audio/evrcb": { "source": "iana" }, "audio/evrcb0": { "source": "iana" }, "audio/evrcb1": { "source": "iana" }, "audio/evrcnw": { "source": "iana" }, "audio/evrcnw0": { "source": "iana" }, "audio/evrcnw1": { "source": "iana" }, "audio/evrcwb": { "source": "iana" }, "audio/evrcwb0": { "source": "iana" }, "audio/evrcwb1": { "source": "iana" }, "audio/evs": { "source": "iana" }, "audio/fwdred": { "source": "iana" }, "audio/g711-0": { "source": "iana" }, "audio/g719": { "source": "iana" }, "audio/g722": { "source": "iana" }, "audio/g7221": { "source": "iana" }, "audio/g723": { "source": "iana" }, "audio/g726-16": { "source": "iana" }, "audio/g726-24": { "source": "iana" }, "audio/g726-32": { "source": "iana" }, "audio/g726-40": { "source": "iana" }, "audio/g728": { "source": "iana" }, "audio/g729": { "source": "iana" }, "audio/g7291": { "source": "iana" }, "audio/g729d": { "source": "iana" }, "audio/g729e": { "source": "iana" }, "audio/gsm": { "source": "iana" }, "audio/gsm-efr": { "source": "iana" }, "audio/gsm-hr-08": { "source": "iana" }, "audio/ilbc": { "source": "iana" }, "audio/ip-mr_v2.5": { "source": "iana" }, "audio/isac": { "source": "apache" }, "audio/l16": { "source": "iana" }, "audio/l20": { "source": "iana" }, "audio/l24": { "source": "iana", "compressible": false }, "audio/l8": { "source": "iana" }, "audio/lpc": { "source": "iana" }, "audio/midi": { "source": "apache", "extensions": ["mid","midi","kar","rmi"] }, "audio/mobile-xmf": { "source": "iana" }, "audio/mp4": { "source": "iana", "compressible": false, "extensions": ["m4a","mp4a"] }, "audio/mp4a-latm": { "source": "iana" }, "audio/mpa": { "source": "iana" }, "audio/mpa-robust": { "source": "iana" }, "audio/mpeg": { "source": "iana", "compressible": false, "extensions": ["mpga","mp2","mp2a","mp3","m2a","m3a"] }, "audio/mpeg4-generic": { "source": "iana" }, "audio/musepack": { "source": "apache" }, "audio/ogg": { "source": "iana", "compressible": false, "extensions": ["oga","ogg","spx"] }, "audio/opus": { "source": "iana" }, "audio/parityfec": { "source": "iana" }, "audio/pcma": { "source": "iana" }, "audio/pcma-wb": { "source": "iana" }, "audio/pcmu": { "source": "iana" }, "audio/pcmu-wb": { "source": "iana" }, "audio/prs.sid": { "source": "iana" }, "audio/qcelp": { "source": "iana" }, "audio/raptorfec": { "source": "iana" }, "audio/red": { "source": "iana" }, "audio/rtp-enc-aescm128": { "source": "iana" }, "audio/rtp-midi": { "source": "iana" }, "audio/rtploopback": { "source": "iana" }, "audio/rtx": { "source": "iana" }, "audio/s3m": { "source": "apache", "extensions": ["s3m"] }, "audio/silk": { "source": "apache", "extensions": ["sil"] }, "audio/smv": { "source": "iana" }, "audio/smv-qcp": { "source": "iana" }, "audio/smv0": { "source": "iana" }, "audio/sp-midi": { "source": "iana" }, "audio/speex": { "source": "iana" }, "audio/t140c": { "source": "iana" }, "audio/t38": { "source": "iana" }, "audio/telephone-event": { "source": "iana" }, "audio/tone": { "source": "iana" }, "audio/uemclip": { "source": "iana" }, "audio/ulpfec": { "source": "iana" }, "audio/vdvi": { "source": "iana" }, "audio/vmr-wb": { "source": "iana" }, "audio/vnd.3gpp.iufp": { "source": "iana" }, "audio/vnd.4sb": { "source": "iana" }, "audio/vnd.audiokoz": { "source": "iana" }, "audio/vnd.celp": { "source": "iana" }, "audio/vnd.cisco.nse": { "source": "iana" }, "audio/vnd.cmles.radio-events": { "source": "iana" }, "audio/vnd.cns.anp1": { "source": "iana" }, "audio/vnd.cns.inf1": { "source": "iana" }, "audio/vnd.dece.audio": { "source": "iana", "extensions": ["uva","uvva"] }, "audio/vnd.digital-winds": { "source": "iana", "extensions": ["eol"] }, "audio/vnd.dlna.adts": { "source": "iana" }, "audio/vnd.dolby.heaac.1": { "source": "iana" }, "audio/vnd.dolby.heaac.2": { "source": "iana" }, "audio/vnd.dolby.mlp": { "source": "iana" }, "audio/vnd.dolby.mps": { "source": "iana" }, "audio/vnd.dolby.pl2": { "source": "iana" }, "audio/vnd.dolby.pl2x": { "source": "iana" }, "audio/vnd.dolby.pl2z": { "source": "iana" }, "audio/vnd.dolby.pulse.1": { "source": "iana" }, "audio/vnd.dra": { "source": "iana", "extensions": ["dra"] }, "audio/vnd.dts": { "source": "iana", "extensions": ["dts"] }, "audio/vnd.dts.hd": { "source": "iana", "extensions": ["dtshd"] }, "audio/vnd.dvb.file": { "source": "iana" }, "audio/vnd.everad.plj": { "source": "iana" }, "audio/vnd.hns.audio": { "source": "iana" }, "audio/vnd.lucent.voice": { "source": "iana", "extensions": ["lvp"] }, "audio/vnd.ms-playready.media.pya": { "source": "iana", "extensions": ["pya"] }, "audio/vnd.nokia.mobile-xmf": { "source": "iana" }, "audio/vnd.nortel.vbk": { "source": "iana" }, "audio/vnd.nuera.ecelp4800": { "source": "iana", "extensions": ["ecelp4800"] }, "audio/vnd.nuera.ecelp7470": { "source": "iana", "extensions": ["ecelp7470"] }, "audio/vnd.nuera.ecelp9600": { "source": "iana", "extensions": ["ecelp9600"] }, "audio/vnd.octel.sbc": { "source": "iana" }, "audio/vnd.qcelp": { "source": "iana" }, "audio/vnd.rhetorex.32kadpcm": { "source": "iana" }, "audio/vnd.rip": { "source": "iana", "extensions": ["rip"] }, "audio/vnd.rn-realaudio": { "compressible": false }, "audio/vnd.sealedmedia.softseal.mpeg": { "source": "iana" }, "audio/vnd.vmx.cvsd": { "source": "iana" }, "audio/vnd.wave": { "compressible": false }, "audio/vorbis": { "source": "iana", "compressible": false }, "audio/vorbis-config": { "source": "iana" }, "audio/wav": { "compressible": false, "extensions": ["wav"] }, "audio/wave": { "compressible": false, "extensions": ["wav"] }, "audio/webm": { "source": "apache", "compressible": false, "extensions": ["weba"] }, "audio/x-aac": { "source": "apache", "compressible": false, "extensions": ["aac"] }, "audio/x-aiff": { "source": "apache", "extensions": ["aif","aiff","aifc"] }, "audio/x-caf": { "source": "apache", "compressible": false, "extensions": ["caf"] }, "audio/x-flac": { "source": "apache", "extensions": ["flac"] }, "audio/x-m4a": { "source": "nginx", "extensions": ["m4a"] }, "audio/x-matroska": { "source": "apache", "extensions": ["mka"] }, "audio/x-mpegurl": { "source": "apache", "extensions": ["m3u"] }, "audio/x-ms-wax": { "source": "apache", "extensions": ["wax"] }, "audio/x-ms-wma": { "source": "apache", "extensions": ["wma"] }, "audio/x-pn-realaudio": { "source": "apache", "extensions": ["ram","ra"] }, "audio/x-pn-realaudio-plugin": { "source": "apache", "extensions": ["rmp"] }, "audio/x-realaudio": { "source": "nginx", "extensions": ["ra"] }, "audio/x-tta": { "source": "apache" }, "audio/x-wav": { "source": "apache", "extensions": ["wav"] }, "audio/xm": { "source": "apache", "extensions": ["xm"] }, "chemical/x-cdx": { "source": "apache", "extensions": ["cdx"] }, "chemical/x-cif": { "source": "apache", "extensions": ["cif"] }, "chemical/x-cmdf": { "source": "apache", "extensions": ["cmdf"] }, "chemical/x-cml": { "source": "apache", "extensions": ["cml"] }, "chemical/x-csml": { "source": "apache", "extensions": ["csml"] }, "chemical/x-pdb": { "source": "apache" }, "chemical/x-xyz": { "source": "apache", "extensions": ["xyz"] }, "font/opentype": { "compressible": true, "extensions": ["otf"] }, "image/bmp": { "source": "apache", "compressible": true, "extensions": ["bmp"] }, "image/cgm": { "source": "iana", "extensions": ["cgm"] }, "image/fits": { "source": "iana" }, "image/g3fax": { "source": "iana", "extensions": ["g3"] }, "image/gif": { "source": "iana", "compressible": false, "extensions": ["gif"] }, "image/ief": { "source": "iana", "extensions": ["ief"] }, "image/jp2": { "source": "iana" }, "image/jpeg": { "source": "iana", "compressible": false, "extensions": ["jpeg","jpg","jpe"] }, "image/jpm": { "source": "iana" }, "image/jpx": { "source": "iana" }, "image/ktx": { "source": "iana", "extensions": ["ktx"] }, "image/naplps": { "source": "iana" }, "image/pjpeg": { "compressible": false }, "image/png": { "source": "iana", "compressible": false, "extensions": ["png"] }, "image/prs.btif": { "source": "iana", "extensions": ["btif"] }, "image/prs.pti": { "source": "iana" }, "image/pwg-raster": { "source": "iana" }, "image/sgi": { "source": "apache", "extensions": ["sgi"] }, "image/svg+xml": { "source": "iana", "compressible": true, "extensions": ["svg","svgz"] }, "image/t38": { "source": "iana" }, "image/tiff": { "source": "iana", "compressible": false, "extensions": ["tiff","tif"] }, "image/tiff-fx": { "source": "iana" }, "image/vnd.adobe.photoshop": { "source": "iana", "compressible": true, "extensions": ["psd"] }, "image/vnd.airzip.accelerator.azv": { "source": "iana" }, "image/vnd.cns.inf2": { "source": "iana" }, "image/vnd.dece.graphic": { "source": "iana", "extensions": ["uvi","uvvi","uvg","uvvg"] }, "image/vnd.djvu": { "source": "iana", "extensions": ["djvu","djv"] }, "image/vnd.dvb.subtitle": { "source": "iana", "extensions": ["sub"] }, "image/vnd.dwg": { "source": "iana", "extensions": ["dwg"] }, "image/vnd.dxf": { "source": "iana", "extensions": ["dxf"] }, "image/vnd.fastbidsheet": { "source": "iana", "extensions": ["fbs"] }, "image/vnd.fpx": { "source": "iana", "extensions": ["fpx"] }, "image/vnd.fst": { "source": "iana", "extensions": ["fst"] }, "image/vnd.fujixerox.edmics-mmr": { "source": "iana", "extensions": ["mmr"] }, "image/vnd.fujixerox.edmics-rlc": { "source": "iana", "extensions": ["rlc"] }, "image/vnd.globalgraphics.pgb": { "source": "iana" }, "image/vnd.microsoft.icon": { "source": "iana" }, "image/vnd.mix": { "source": "iana" }, "image/vnd.mozilla.apng": { "source": "iana" }, "image/vnd.ms-modi": { "source": "iana", "extensions": ["mdi"] }, "image/vnd.ms-photo": { "source": "apache", "extensions": ["wdp"] }, "image/vnd.net-fpx": { "source": "iana", "extensions": ["npx"] }, "image/vnd.radiance": { "source": "iana" }, "image/vnd.sealed.png": { "source": "iana" }, "image/vnd.sealedmedia.softseal.gif": { "source": "iana" }, "image/vnd.sealedmedia.softseal.jpg": { "source": "iana" }, "image/vnd.svf": { "source": "iana" }, "image/vnd.tencent.tap": { "source": "iana" }, "image/vnd.valve.source.texture": { "source": "iana" }, "image/vnd.wap.wbmp": { "source": "iana", "extensions": ["wbmp"] }, "image/vnd.xiff": { "source": "iana", "extensions": ["xif"] }, "image/vnd.zbrush.pcx": { "source": "iana" }, "image/webp": { "source": "apache", "extensions": ["webp"] }, "image/x-3ds": { "source": "apache", "extensions": ["3ds"] }, "image/x-cmu-raster": { "source": "apache", "extensions": ["ras"] }, "image/x-cmx": { "source": "apache", "extensions": ["cmx"] }, "image/x-freehand": { "source": "apache", "extensions": ["fh","fhc","fh4","fh5","fh7"] }, "image/x-icon": { "source": "apache", "compressible": true, "extensions": ["ico"] }, "image/x-jng": { "source": "nginx", "extensions": ["jng"] }, "image/x-mrsid-image": { "source": "apache", "extensions": ["sid"] }, "image/x-ms-bmp": { "source": "nginx", "compressible": true, "extensions": ["bmp"] }, "image/x-pcx": { "source": "apache", "extensions": ["pcx"] }, "image/x-pict": { "source": "apache", "extensions": ["pic","pct"] }, "image/x-portable-anymap": { "source": "apache", "extensions": ["pnm"] }, "image/x-portable-bitmap": { "source": "apache", "extensions": ["pbm"] }, "image/x-portable-graymap": { "source": "apache", "extensions": ["pgm"] }, "image/x-portable-pixmap": { "source": "apache", "extensions": ["ppm"] }, "image/x-rgb": { "source": "apache", "extensions": ["rgb"] }, "image/x-tga": { "source": "apache", "extensions": ["tga"] }, "image/x-xbitmap": { "source": "apache", "extensions": ["xbm"] }, "image/x-xcf": { "compressible": false }, "image/x-xpixmap": { "source": "apache", "extensions": ["xpm"] }, "image/x-xwindowdump": { "source": "apache", "extensions": ["xwd"] }, "message/cpim": { "source": "iana" }, "message/delivery-status": { "source": "iana" }, "message/disposition-notification": { "source": "iana" }, "message/external-body": { "source": "iana" }, "message/feedback-report": { "source": "iana" }, "message/global": { "source": "iana" }, "message/global-delivery-status": { "source": "iana" }, "message/global-disposition-notification": { "source": "iana" }, "message/global-headers": { "source": "iana" }, "message/http": { "source": "iana", "compressible": false }, "message/imdn+xml": { "source": "iana", "compressible": true }, "message/news": { "source": "iana" }, "message/partial": { "source": "iana", "compressible": false }, "message/rfc822": { "source": "iana", "compressible": true, "extensions": ["eml","mime"] }, "message/s-http": { "source": "iana" }, "message/sip": { "source": "iana" }, "message/sipfrag": { "source": "iana" }, "message/tracking-status": { "source": "iana" }, "message/vnd.si.simp": { "source": "iana" }, "message/vnd.wfa.wsc": { "source": "iana" }, "model/iges": { "source": "iana", "compressible": false, "extensions": ["igs","iges"] }, "model/mesh": { "source": "iana", "compressible": false, "extensions": ["msh","mesh","silo"] }, "model/vnd.collada+xml": { "source": "iana", "extensions": ["dae"] }, "model/vnd.dwf": { "source": "iana", "extensions": ["dwf"] }, "model/vnd.flatland.3dml": { "source": "iana" }, "model/vnd.gdl": { "source": "iana", "extensions": ["gdl"] }, "model/vnd.gs-gdl": { "source": "apache" }, "model/vnd.gs.gdl": { "source": "iana" }, "model/vnd.gtw": { "source": "iana", "extensions": ["gtw"] }, "model/vnd.moml+xml": { "source": "iana" }, "model/vnd.mts": { "source": "iana", "extensions": ["mts"] }, "model/vnd.opengex": { "source": "iana" }, "model/vnd.parasolid.transmit.binary": { "source": "iana" }, "model/vnd.parasolid.transmit.text": { "source": "iana" }, "model/vnd.rosette.annotated-data-model": { "source": "iana" }, "model/vnd.valve.source.compiled-map": { "source": "iana" }, "model/vnd.vtu": { "source": "iana", "extensions": ["vtu"] }, "model/vrml": { "source": "iana", "compressible": false, "extensions": ["wrl","vrml"] }, "model/x3d+binary": { "source": "apache", "compressible": false, "extensions": ["x3db","x3dbz"] }, "model/x3d+fastinfoset": { "source": "iana" }, "model/x3d+vrml": { "source": "apache", "compressible": false, "extensions": ["x3dv","x3dvz"] }, "model/x3d+xml": { "source": "iana", "compressible": true, "extensions": ["x3d","x3dz"] }, "model/x3d-vrml": { "source": "iana" }, "multipart/alternative": { "source": "iana", "compressible": false }, "multipart/appledouble": { "source": "iana" }, "multipart/byteranges": { "source": "iana" }, "multipart/digest": { "source": "iana" }, "multipart/encrypted": { "source": "iana", "compressible": false }, "multipart/form-data": { "source": "iana", "compressible": false }, "multipart/header-set": { "source": "iana" }, "multipart/mixed": { "source": "iana", "compressible": false }, "multipart/parallel": { "source": "iana" }, "multipart/related": { "source": "iana", "compressible": false }, "multipart/report": { "source": "iana" }, "multipart/signed": { "source": "iana", "compressible": false }, "multipart/voice-message": { "source": "iana" }, "multipart/x-mixed-replace": { "source": "iana" }, "text/1d-interleaved-parityfec": { "source": "iana" }, "text/cache-manifest": { "source": "iana", "compressible": true, "extensions": ["appcache","manifest"] }, "text/calendar": { "source": "iana", "extensions": ["ics","ifb"] }, "text/calender": { "compressible": true }, "text/cmd": { "compressible": true }, "text/coffeescript": { "extensions": ["coffee","litcoffee"] }, "text/css": { "source": "iana", "compressible": true, "extensions": ["css"] }, "text/csv": { "source": "iana", "compressible": true, "extensions": ["csv"] }, "text/csv-schema": { "source": "iana" }, "text/directory": { "source": "iana" }, "text/dns": { "source": "iana" }, "text/ecmascript": { "source": "iana" }, "text/encaprtp": { "source": "iana" }, "text/enriched": { "source": "iana" }, "text/fwdred": { "source": "iana" }, "text/grammar-ref-list": { "source": "iana" }, "text/hjson": { "extensions": ["hjson"] }, "text/html": { "source": "iana", "compressible": true, "extensions": ["html","htm","shtml"] }, "text/jade": { "extensions": ["jade"] }, "text/javascript": { "source": "iana", "compressible": true }, "text/jcr-cnd": { "source": "iana" }, "text/jsx": { "compressible": true, "extensions": ["jsx"] }, "text/less": { "extensions": ["less"] }, "text/markdown": { "source": "iana" }, "text/mathml": { "source": "nginx", "extensions": ["mml"] }, "text/mizar": { "source": "iana" }, "text/n3": { "source": "iana", "compressible": true, "extensions": ["n3"] }, "text/parameters": { "source": "iana" }, "text/parityfec": { "source": "iana" }, "text/plain": { "source": "iana", "compressible": true, "extensions": ["txt","text","conf","def","list","log","in","ini"] }, "text/provenance-notation": { "source": "iana" }, "text/prs.fallenstein.rst": { "source": "iana" }, "text/prs.lines.tag": { "source": "iana", "extensions": ["dsc"] }, "text/raptorfec": { "source": "iana" }, "text/red": { "source": "iana" }, "text/rfc822-headers": { "source": "iana" }, "text/richtext": { "source": "iana", "compressible": true, "extensions": ["rtx"] }, "text/rtf": { "source": "iana", "compressible": true, "extensions": ["rtf"] }, "text/rtp-enc-aescm128": { "source": "iana" }, "text/rtploopback": { "source": "iana" }, "text/rtx": { "source": "iana" }, "text/sgml": { "source": "iana", "extensions": ["sgml","sgm"] }, "text/slim": { "extensions": ["slim","slm"] }, "text/stylus": { "extensions": ["stylus","styl"] }, "text/t140": { "source": "iana" }, "text/tab-separated-values": { "source": "iana", "compressible": true, "extensions": ["tsv"] }, "text/troff": { "source": "iana", "extensions": ["t","tr","roff","man","me","ms"] }, "text/turtle": { "source": "iana", "extensions": ["ttl"] }, "text/ulpfec": { "source": "iana" }, "text/uri-list": { "source": "iana", "compressible": true, "extensions": ["uri","uris","urls"] }, "text/vcard": { "source": "iana", "compressible": true, "extensions": ["vcard"] }, "text/vnd.a": { "source": "iana" }, "text/vnd.abc": { "source": "iana" }, "text/vnd.curl": { "source": "iana", "extensions": ["curl"] }, "text/vnd.curl.dcurl": { "source": "apache", "extensions": ["dcurl"] }, "text/vnd.curl.mcurl": { "source": "apache", "extensions": ["mcurl"] }, "text/vnd.curl.scurl": { "source": "apache", "extensions": ["scurl"] }, "text/vnd.debian.copyright": { "source": "iana" }, "text/vnd.dmclientscript": { "source": "iana" }, "text/vnd.dvb.subtitle": { "source": "iana", "extensions": ["sub"] }, "text/vnd.esmertec.theme-descriptor": { "source": "iana" }, "text/vnd.fly": { "source": "iana", "extensions": ["fly"] }, "text/vnd.fmi.flexstor": { "source": "iana", "extensions": ["flx"] }, "text/vnd.graphviz": { "source": "iana", "extensions": ["gv"] }, "text/vnd.in3d.3dml": { "source": "iana", "extensions": ["3dml"] }, "text/vnd.in3d.spot": { "source": "iana", "extensions": ["spot"] }, "text/vnd.iptc.newsml": { "source": "iana" }, "text/vnd.iptc.nitf": { "source": "iana" }, "text/vnd.latex-z": { "source": "iana" }, "text/vnd.motorola.reflex": { "source": "iana" }, "text/vnd.ms-mediapackage": { "source": "iana" }, "text/vnd.net2phone.commcenter.command": { "source": "iana" }, "text/vnd.radisys.msml-basic-layout": { "source": "iana" }, "text/vnd.si.uricatalogue": { "source": "iana" }, "text/vnd.sun.j2me.app-descriptor": { "source": "iana", "extensions": ["jad"] }, "text/vnd.trolltech.linguist": { "source": "iana" }, "text/vnd.wap.si": { "source": "iana" }, "text/vnd.wap.sl": { "source": "iana" }, "text/vnd.wap.wml": { "source": "iana", "extensions": ["wml"] }, "text/vnd.wap.wmlscript": { "source": "iana", "extensions": ["wmls"] }, "text/vtt": { "charset": "UTF-8", "compressible": true, "extensions": ["vtt"] }, "text/x-asm": { "source": "apache", "extensions": ["s","asm"] }, "text/x-c": { "source": "apache", "extensions": ["c","cc","cxx","cpp","h","hh","dic"] }, "text/x-component": { "source": "nginx", "extensions": ["htc"] }, "text/x-fortran": { "source": "apache", "extensions": ["f","for","f77","f90"] }, "text/x-gwt-rpc": { "compressible": true }, "text/x-handlebars-template": { "extensions": ["hbs"] }, "text/x-java-source": { "source": "apache", "extensions": ["java"] }, "text/x-jquery-tmpl": { "compressible": true }, "text/x-lua": { "extensions": ["lua"] }, "text/x-markdown": { "compressible": true, "extensions": ["markdown","md","mkd"] }, "text/x-nfo": { "source": "apache", "extensions": ["nfo"] }, "text/x-opml": { "source": "apache", "extensions": ["opml"] }, "text/x-pascal": { "source": "apache", "extensions": ["p","pas"] }, "text/x-processing": { "compressible": true, "extensions": ["pde"] }, "text/x-sass": { "extensions": ["sass"] }, "text/x-scss": { "extensions": ["scss"] }, "text/x-setext": { "source": "apache", "extensions": ["etx"] }, "text/x-sfv": { "source": "apache", "extensions": ["sfv"] }, "text/x-suse-ymp": { "compressible": true, "extensions": ["ymp"] }, "text/x-uuencode": { "source": "apache", "extensions": ["uu"] }, "text/x-vcalendar": { "source": "apache", "extensions": ["vcs"] }, "text/x-vcard": { "source": "apache", "extensions": ["vcf"] }, "text/xml": { "source": "iana", "compressible": true, "extensions": ["xml"] }, "text/xml-external-parsed-entity": { "source": "iana" }, "text/yaml": { "extensions": ["yaml","yml"] }, "video/1d-interleaved-parityfec": { "source": "apache" }, "video/3gpp": { "source": "apache", "extensions": ["3gp","3gpp"] }, "video/3gpp-tt": { "source": "apache" }, "video/3gpp2": { "source": "apache", "extensions": ["3g2"] }, "video/bmpeg": { "source": "apache" }, "video/bt656": { "source": "apache" }, "video/celb": { "source": "apache" }, "video/dv": { "source": "apache" }, "video/h261": { "source": "apache", "extensions": ["h261"] }, "video/h263": { "source": "apache", "extensions": ["h263"] }, "video/h263-1998": { "source": "apache" }, "video/h263-2000": { "source": "apache" }, "video/h264": { "source": "apache", "extensions": ["h264"] }, "video/h264-rcdo": { "source": "apache" }, "video/h264-svc": { "source": "apache" }, "video/jpeg": { "source": "apache", "extensions": ["jpgv"] }, "video/jpeg2000": { "source": "apache" }, "video/jpm": { "source": "apache", "extensions": ["jpm","jpgm"] }, "video/mj2": { "source": "apache", "extensions": ["mj2","mjp2"] }, "video/mp1s": { "source": "apache" }, "video/mp2p": { "source": "apache" }, "video/mp2t": { "source": "apache", "extensions": ["ts"] }, "video/mp4": { "source": "apache", "compressible": false, "extensions": ["mp4","mp4v","mpg4"] }, "video/mp4v-es": { "source": "apache" }, "video/mpeg": { "source": "apache", "compressible": false, "extensions": ["mpeg","mpg","mpe","m1v","m2v"] }, "video/mpeg4-generic": { "source": "apache" }, "video/mpv": { "source": "apache" }, "video/nv": { "source": "apache" }, "video/ogg": { "source": "apache", "compressible": false, "extensions": ["ogv"] }, "video/parityfec": { "source": "apache" }, "video/pointer": { "source": "apache" }, "video/quicktime": { "source": "apache", "compressible": false, "extensions": ["qt","mov"] }, "video/raw": { "source": "apache" }, "video/rtp-enc-aescm128": { "source": "apache" }, "video/rtx": { "source": "apache" }, "video/smpte292m": { "source": "apache" }, "video/ulpfec": { "source": "apache" }, "video/vc1": { "source": "apache" }, "video/vnd.cctv": { "source": "apache" }, "video/vnd.dece.hd": { "source": "apache", "extensions": ["uvh","uvvh"] }, "video/vnd.dece.mobile": { "source": "apache", "extensions": ["uvm","uvvm"] }, "video/vnd.dece.mp4": { "source": "apache" }, "video/vnd.dece.pd": { "source": "apache", "extensions": ["uvp","uvvp"] }, "video/vnd.dece.sd": { "source": "apache", "extensions": ["uvs","uvvs"] }, "video/vnd.dece.video": { "source": "apache", "extensions": ["uvv","uvvv"] }, "video/vnd.directv.mpeg": { "source": "apache" }, "video/vnd.directv.mpeg-tts": { "source": "apache" }, "video/vnd.dlna.mpeg-tts": { "source": "apache" }, "video/vnd.dvb.file": { "source": "apache", "extensions": ["dvb"] }, "video/vnd.fvt": { "source": "apache", "extensions": ["fvt"] }, "video/vnd.hns.video": { "source": "apache" }, "video/vnd.iptvforum.1dparityfec-1010": { "source": "apache" }, "video/vnd.iptvforum.1dparityfec-2005": { "source": "apache" }, "video/vnd.iptvforum.2dparityfec-1010": { "source": "apache" }, "video/vnd.iptvforum.2dparityfec-2005": { "source": "apache" }, "video/vnd.iptvforum.ttsavc": { "source": "apache" }, "video/vnd.iptvforum.ttsmpeg2": { "source": "apache" }, "video/vnd.motorola.video": { "source": "apache" }, "video/vnd.motorola.videop": { "source": "apache" }, "video/vnd.mpegurl": { "source": "apache", "extensions": ["mxu","m4u"] }, "video/vnd.ms-playready.media.pyv": { "source": "apache", "extensions": ["pyv"] }, "video/vnd.nokia.interleaved-multimedia": { "source": "apache" }, "video/vnd.nokia.videovoip": { "source": "apache" }, "video/vnd.objectvideo": { "source": "apache" }, "video/vnd.sealed.mpeg1": { "source": "apache" }, "video/vnd.sealed.mpeg4": { "source": "apache" }, "video/vnd.sealed.swf": { "source": "apache" }, "video/vnd.sealedmedia.softseal.mov": { "source": "apache" }, "video/vnd.uvvu.mp4": { "source": "apache", "extensions": ["uvu","uvvu"] }, "video/vnd.vivo": { "source": "apache", "extensions": ["viv"] }, "video/webm": { "source": "apache", "compressible": false, "extensions": ["webm"] }, "video/x-f4v": { "source": "apache", "extensions": ["f4v"] }, "video/x-fli": { "source": "apache", "extensions": ["fli"] }, "video/x-flv": { "source": "apache", "compressible": false, "extensions": ["flv"] }, "video/x-m4v": { "source": "apache", "extensions": ["m4v"] }, "video/x-matroska": { "source": "apache", "compressible": false, "extensions": ["mkv","mk3d","mks"] }, "video/x-mng": { "source": "apache", "extensions": ["mng"] }, "video/x-ms-asf": { "source": "apache", "extensions": ["asf","asx"] }, "video/x-ms-vob": { "source": "apache", "extensions": ["vob"] }, "video/x-ms-wm": { "source": "apache", "extensions": ["wm"] }, "video/x-ms-wmv": { "source": "apache", "compressible": false, "extensions": ["wmv"] }, "video/x-ms-wmx": { "source": "apache", "extensions": ["wmx"] }, "video/x-ms-wvx": { "source": "apache", "extensions": ["wvx"] }, "video/x-msvideo": { "source": "apache", "extensions": ["avi"] }, "video/x-sgi-movie": { "source": "apache", "extensions": ["movie"] }, "video/x-smv": { "source": "apache", "extensions": ["smv"] }, "x-conference/x-cooltalk": { "source": "apache", "extensions": ["ice"] }, "x-shader/x-fragment": { "compressible": true }, "x-shader/x-vertex": { "compressible": true } } },{}],244:[function(require,module,exports){ /*! * mime-db * Copyright(c) 2014 Jonathan Ong * MIT Licensed */ /** * Module exports. */ module.exports = require('./db.json') },{"./db.json":243}],245:[function(require,module,exports){ /*! * mime-types * Copyright(c) 2014 Jonathan Ong * Copyright(c) 2015 Douglas Christopher Wilson * MIT Licensed */ 'use strict' /** * Module dependencies. * @private */ var db = require('mime-db') var extname = require('path').extname /** * Module variables. * @private */ var extractTypeRegExp = /^\s*([^;\s]*)(?:;|\s|$)/ var textTypeRegExp = /^text\//i /** * Module exports. * @public */ exports.charset = charset exports.charsets = { lookup: charset } exports.contentType = contentType exports.extension = extension exports.extensions = Object.create(null) exports.lookup = lookup exports.types = Object.create(null) // Populate the extensions/types maps populateMaps(exports.extensions, exports.types) /** * Get the default charset for a MIME type. * * @param {string} type * @return {boolean|string} */ function charset(type) { if (!type || typeof type !== 'string') { return false } // TODO: use media-typer var match = extractTypeRegExp.exec(type) var mime = match && db[match[1].toLowerCase()] if (mime && mime.charset) { return mime.charset } // default text/* to utf-8 if (match && textTypeRegExp.test(match[1])) { return 'UTF-8' } return false } /** * Create a full Content-Type header given a MIME type or extension. * * @param {string} str * @return {boolean|string} */ function contentType(str) { // TODO: should this even be in this module? if (!str || typeof str !== 'string') { return false } var mime = str.indexOf('/') === -1 ? exports.lookup(str) : str if (!mime) { return false } // TODO: use content-type or other module if (mime.indexOf('charset') === -1) { var charset = exports.charset(mime) if (charset) mime += '; charset=' + charset.toLowerCase() } return mime } /** * Get the default extension for a MIME type. * * @param {string} type * @return {boolean|string} */ function extension(type) { if (!type || typeof type !== 'string') { return false } // TODO: use media-typer var match = extractTypeRegExp.exec(type) // get extensions var exts = match && exports.extensions[match[1].toLowerCase()] if (!exts || !exts.length) { return false } return exts[0] } /** * Lookup the MIME type for a file path/extension. * * @param {string} path * @return {boolean|string} */ function lookup(path) { if (!path || typeof path !== 'string') { return false } // get the extension ("ext" or ".ext" or full path) var extension = extname('x.' + path) .toLowerCase() .substr(1) if (!extension) { return false } return exports.types[extension] || false } /** * Populate the extensions and types maps. * @private */ function populateMaps(extensions, types) { // source preference (least -> most) var preference = ['nginx', 'apache', undefined, 'iana'] Object.keys(db).forEach(function forEachMimeType(type) { var mime = db[type] var exts = mime.extensions if (!exts || !exts.length) { return } // mime -> extensions extensions[type] = exts // extension -> mime for (var i = 0; i < exts.length; i++) { var extension = exts[i] if (types[extension]) { var from = preference.indexOf(db[types[extension]].source) var to = preference.indexOf(mime.source) if (types[extension] !== 'application/octet-stream' && from > to || (from === to && types[extension].substr(0, 12) === 'application/')) { // skip the remapping continue } } // set the extension -> mime types[extension] = type } }) } },{"mime-db":244,"path":290}],246:[function(require,module,exports){ module.exports = assert; function assert(val, msg) { if (!val) throw new Error(msg || 'Assertion failed'); } assert.equal = function assertEqual(l, r, msg) { if (l != r) throw new Error(msg || ('Assertion failed: ' + l + ' != ' + r)); }; },{}],247:[function(require,module,exports){ module.exports = minimatch minimatch.Minimatch = Minimatch var path = { sep: '/' } try { path = require('path') } catch (er) {} var GLOBSTAR = minimatch.GLOBSTAR = Minimatch.GLOBSTAR = {} var expand = require('brace-expansion') // any single thing other than / // don't need to escape / when using new RegExp() var qmark = '[^/]' // * => any number of characters var star = qmark + '*?' // ** when dots are allowed. Anything goes, except .. and . // not (^ or / followed by one or two dots followed by $ or /), // followed by anything, any number of times. var twoStarDot = '(?:(?!(?:\\\/|^)(?:\\.{1,2})($|\\\/)).)*?' // not a ^ or / followed by a dot, // followed by anything, any number of times. var twoStarNoDot = '(?:(?!(?:\\\/|^)\\.).)*?' // characters that need to be escaped in RegExp. var reSpecials = charSet('().*{}+?[]^$\\!') // "abc" -> { a:true, b:true, c:true } function charSet (s) { return s.split('').reduce(function (set, c) { set[c] = true return set }, {}) } // normalizes slashes. var slashSplit = /\/+/ minimatch.filter = filter function filter (pattern, options) { options = options || {} return function (p, i, list) { return minimatch(p, pattern, options) } } function ext (a, b) { a = a || {} b = b || {} var t = {} Object.keys(b).forEach(function (k) { t[k] = b[k] }) Object.keys(a).forEach(function (k) { t[k] = a[k] }) return t } minimatch.defaults = function (def) { if (!def || !Object.keys(def).length) return minimatch var orig = minimatch var m = function minimatch (p, pattern, options) { return orig.minimatch(p, pattern, ext(def, options)) } m.Minimatch = function Minimatch (pattern, options) { return new orig.Minimatch(pattern, ext(def, options)) } return m } Minimatch.defaults = function (def) { if (!def || !Object.keys(def).length) return Minimatch return minimatch.defaults(def).Minimatch } function minimatch (p, pattern, options) { if (typeof pattern !== 'string') { throw new TypeError('glob pattern string required') } if (!options) options = {} // shortcut: comments match nothing. if (!options.nocomment && pattern.charAt(0) === '#') { return false } // "" only matches "" if (pattern.trim() === '') return p === '' return new Minimatch(pattern, options).match(p) } function Minimatch (pattern, options) { if (!(this instanceof Minimatch)) { return new Minimatch(pattern, options) } if (typeof pattern !== 'string') { throw new TypeError('glob pattern string required') } if (!options) options = {} pattern = pattern.trim() // windows support: need to use /, not \ if (path.sep !== '/') { pattern = pattern.split(path.sep).join('/') } this.options = options this.set = [] this.pattern = pattern this.regexp = null this.negate = false this.comment = false this.empty = false // make the set of regexps etc. this.make() } Minimatch.prototype.debug = function () {} Minimatch.prototype.make = make function make () { // don't do it more than once. if (this._made) return var pattern = this.pattern var options = this.options // empty patterns and comments match nothing. if (!options.nocomment && pattern.charAt(0) === '#') { this.comment = true return } if (!pattern) { this.empty = true return } // step 1: figure out negation, etc. this.parseNegate() // step 2: expand braces var set = this.globSet = this.braceExpand() if (options.debug) this.debug = console.error this.debug(this.pattern, set) // step 3: now we have a set, so turn each one into a series of path-portion // matching patterns. // These will be regexps, except in the case of "**", which is // set to the GLOBSTAR object for globstar behavior, // and will not contain any / characters set = this.globParts = set.map(function (s) { return s.split(slashSplit) }) this.debug(this.pattern, set) // glob --> regexps set = set.map(function (s, si, set) { return s.map(this.parse, this) }, this) this.debug(this.pattern, set) // filter out everything that didn't compile properly. set = set.filter(function (s) { return s.indexOf(false) === -1 }) this.debug(this.pattern, set) this.set = set } Minimatch.prototype.parseNegate = parseNegate function parseNegate () { var pattern = this.pattern var negate = false var options = this.options var negateOffset = 0 if (options.nonegate) return for (var i = 0, l = pattern.length ; i < l && pattern.charAt(i) === '!' ; i++) { negate = !negate negateOffset++ } if (negateOffset) this.pattern = pattern.substr(negateOffset) this.negate = negate } // Brace expansion: // a{b,c}d -> abd acd // a{b,}c -> abc ac // a{0..3}d -> a0d a1d a2d a3d // a{b,c{d,e}f}g -> abg acdfg acefg // a{b,c}d{e,f}g -> abdeg acdeg abdeg abdfg // // Invalid sets are not expanded. // a{2..}b -> a{2..}b // a{b}c -> a{b}c minimatch.braceExpand = function (pattern, options) { return braceExpand(pattern, options) } Minimatch.prototype.braceExpand = braceExpand function braceExpand (pattern, options) { if (!options) { if (this instanceof Minimatch) { options = this.options } else { options = {} } } pattern = typeof pattern === 'undefined' ? this.pattern : pattern if (typeof pattern === 'undefined') { throw new Error('undefined pattern') } if (options.nobrace || !pattern.match(/\{.*\}/)) { // shortcut. no need to expand. return [pattern] } return expand(pattern) } // parse a component of the expanded set. // At this point, no pattern may contain "/" in it // so we're going to return a 2d array, where each entry is the full // pattern, split on '/', and then turned into a regular expression. // A regexp is made at the end which joins each array with an // escaped /, and another full one which joins each regexp with |. // // Following the lead of Bash 4.1, note that "**" only has special meaning // when it is the *only* thing in a path portion. Otherwise, any series // of * is equivalent to a single *. Globstar behavior is enabled by // default, and can be disabled by setting options.noglobstar. Minimatch.prototype.parse = parse var SUBPARSE = {} function parse (pattern, isSub) { var options = this.options // shortcuts if (!options.noglobstar && pattern === '**') return GLOBSTAR if (pattern === '') return '' var re = '' var hasMagic = !!options.nocase var escaping = false // ? => one single character var patternListStack = [] var negativeLists = [] var plType var stateChar var inClass = false var reClassStart = -1 var classStart = -1 // . and .. never match anything that doesn't start with ., // even when options.dot is set. var patternStart = pattern.charAt(0) === '.' ? '' // anything // not (start or / followed by . or .. followed by / or end) : options.dot ? '(?!(?:^|\\\/)\\.{1,2}(?:$|\\\/))' : '(?!\\.)' var self = this function clearStateChar () { if (stateChar) { // we had some state-tracking character // that wasn't consumed by this pass. switch (stateChar) { case '*': re += star hasMagic = true break case '?': re += qmark hasMagic = true break default: re += '\\' + stateChar break } self.debug('clearStateChar %j %j', stateChar, re) stateChar = false } } for (var i = 0, len = pattern.length, c ; (i < len) && (c = pattern.charAt(i)) ; i++) { this.debug('%s\t%s %s %j', pattern, i, re, c) // skip over any that are escaped. if (escaping && reSpecials[c]) { re += '\\' + c escaping = false continue } switch (c) { case '/': // completely not allowed, even escaped. // Should already be path-split by now. return false case '\\': clearStateChar() escaping = true continue // the various stateChar values // for the "extglob" stuff. case '?': case '*': case '+': case '@': case '!': this.debug('%s\t%s %s %j <-- stateChar', pattern, i, re, c) // all of those are literals inside a class, except that // the glob [!a] means [^a] in regexp if (inClass) { this.debug(' in class') if (c === '!' && i === classStart + 1) c = '^' re += c continue } // if we already have a stateChar, then it means // that there was something like ** or +? in there. // Handle the stateChar, then proceed with this one. self.debug('call clearStateChar %j', stateChar) clearStateChar() stateChar = c // if extglob is disabled, then +(asdf|foo) isn't a thing. // just clear the statechar *now*, rather than even diving into // the patternList stuff. if (options.noext) clearStateChar() continue case '(': if (inClass) { re += '(' continue } if (!stateChar) { re += '\\(' continue } plType = stateChar patternListStack.push({ type: plType, start: i - 1, reStart: re.length }) // negation is (?:(?!js)[^/]*) re += stateChar === '!' ? '(?:(?!(?:' : '(?:' this.debug('plType %j %j', stateChar, re) stateChar = false continue case ')': if (inClass || !patternListStack.length) { re += '\\)' continue } clearStateChar() hasMagic = true re += ')' var pl = patternListStack.pop() plType = pl.type // negation is (?:(?!js)[^/]*) // The others are (?:) switch (plType) { case '!': negativeLists.push(pl) re += ')[^/]*?)' pl.reEnd = re.length break case '?': case '+': case '*': re += plType break case '@': break // the default anyway } continue case '|': if (inClass || !patternListStack.length || escaping) { re += '\\|' escaping = false continue } clearStateChar() re += '|' continue // these are mostly the same in regexp and glob case '[': // swallow any state-tracking char before the [ clearStateChar() if (inClass) { re += '\\' + c continue } inClass = true classStart = i reClassStart = re.length re += c continue case ']': // a right bracket shall lose its special // meaning and represent itself in // a bracket expression if it occurs // first in the list. -- POSIX.2 2.8.3.2 if (i === classStart + 1 || !inClass) { re += '\\' + c escaping = false continue } // handle the case where we left a class open. // "[z-a]" is valid, equivalent to "\[z-a\]" if (inClass) { // split where the last [ was, make sure we don't have // an invalid re. if so, re-walk the contents of the // would-be class to re-translate any characters that // were passed through as-is // TODO: It would probably be faster to determine this // without a try/catch and a new RegExp, but it's tricky // to do safely. For now, this is safe and works. var cs = pattern.substring(classStart + 1, i) try { RegExp('[' + cs + ']') } catch (er) { // not a valid class! var sp = this.parse(cs, SUBPARSE) re = re.substr(0, reClassStart) + '\\[' + sp[0] + '\\]' hasMagic = hasMagic || sp[1] inClass = false continue } } // finish up the class. hasMagic = true inClass = false re += c continue default: // swallow any state char that wasn't consumed clearStateChar() if (escaping) { // no need escaping = false } else if (reSpecials[c] && !(c === '^' && inClass)) { re += '\\' } re += c } // switch } // for // handle the case where we left a class open. // "[abc" is valid, equivalent to "\[abc" if (inClass) { // split where the last [ was, and escape it // this is a huge pita. We now have to re-walk // the contents of the would-be class to re-translate // any characters that were passed through as-is cs = pattern.substr(classStart + 1) sp = this.parse(cs, SUBPARSE) re = re.substr(0, reClassStart) + '\\[' + sp[0] hasMagic = hasMagic || sp[1] } // handle the case where we had a +( thing at the *end* // of the pattern. // each pattern list stack adds 3 chars, and we need to go through // and escape any | chars that were passed through as-is for the regexp. // Go through and escape them, taking care not to double-escape any // | chars that were already escaped. for (pl = patternListStack.pop(); pl; pl = patternListStack.pop()) { var tail = re.slice(pl.reStart + 3) // maybe some even number of \, then maybe 1 \, followed by a | tail = tail.replace(/((?:\\{2})*)(\\?)\|/g, function (_, $1, $2) { if (!$2) { // the | isn't already escaped, so escape it. $2 = '\\' } // need to escape all those slashes *again*, without escaping the // one that we need for escaping the | character. As it works out, // escaping an even number of slashes can be done by simply repeating // it exactly after itself. That's why this trick works. // // I am sorry that you have to see this. return $1 + $1 + $2 + '|' }) this.debug('tail=%j\n %s', tail, tail) var t = pl.type === '*' ? star : pl.type === '?' ? qmark : '\\' + pl.type hasMagic = true re = re.slice(0, pl.reStart) + t + '\\(' + tail } // handle trailing things that only matter at the very end. clearStateChar() if (escaping) { // trailing \\ re += '\\\\' } // only need to apply the nodot start if the re starts with // something that could conceivably capture a dot var addPatternStart = false switch (re.charAt(0)) { case '.': case '[': case '(': addPatternStart = true } // Hack to work around lack of negative lookbehind in JS // A pattern like: *.!(x).!(y|z) needs to ensure that a name // like 'a.xyz.yz' doesn't match. So, the first negative // lookahead, has to look ALL the way ahead, to the end of // the pattern. for (var n = negativeLists.length - 1; n > -1; n--) { var nl = negativeLists[n] var nlBefore = re.slice(0, nl.reStart) var nlFirst = re.slice(nl.reStart, nl.reEnd - 8) var nlLast = re.slice(nl.reEnd - 8, nl.reEnd) var nlAfter = re.slice(nl.reEnd) nlLast += nlAfter // Handle nested stuff like *(*.js|!(*.json)), where open parens // mean that we should *not* include the ) in the bit that is considered // "after" the negated section. var openParensBefore = nlBefore.split('(').length - 1 var cleanAfter = nlAfter for (i = 0; i < openParensBefore; i++) { cleanAfter = cleanAfter.replace(/\)[+*?]?/, '') } nlAfter = cleanAfter var dollar = '' if (nlAfter === '' && isSub !== SUBPARSE) { dollar = '$' } var newRe = nlBefore + nlFirst + nlAfter + dollar + nlLast re = newRe } // if the re is not "" at this point, then we need to make sure // it doesn't match against an empty path part. // Otherwise a/* will match a/, which it should not. if (re !== '' && hasMagic) { re = '(?=.)' + re } if (addPatternStart) { re = patternStart + re } // parsing just a piece of a larger pattern. if (isSub === SUBPARSE) { return [re, hasMagic] } // skip the regexp for non-magical patterns // unescape anything in it, though, so that it'll be // an exact match against a file etc. if (!hasMagic) { return globUnescape(pattern) } var flags = options.nocase ? 'i' : '' var regExp = new RegExp('^' + re + '$', flags) regExp._glob = pattern regExp._src = re return regExp } minimatch.makeRe = function (pattern, options) { return new Minimatch(pattern, options || {}).makeRe() } Minimatch.prototype.makeRe = makeRe function makeRe () { if (this.regexp || this.regexp === false) return this.regexp // at this point, this.set is a 2d array of partial // pattern strings, or "**". // // It's better to use .match(). This function shouldn't // be used, really, but it's pretty convenient sometimes, // when you just want to work with a regex. var set = this.set if (!set.length) { this.regexp = false return this.regexp } var options = this.options var twoStar = options.noglobstar ? star : options.dot ? twoStarDot : twoStarNoDot var flags = options.nocase ? 'i' : '' var re = set.map(function (pattern) { return pattern.map(function (p) { return (p === GLOBSTAR) ? twoStar : (typeof p === 'string') ? regExpEscape(p) : p._src }).join('\\\/') }).join('|') // must match entire pattern // ending in a * or ** will make it less strict. re = '^(?:' + re + ')$' // can match anything, as long as it's not this. if (this.negate) re = '^(?!' + re + ').*$' try { this.regexp = new RegExp(re, flags) } catch (ex) { this.regexp = false } return this.regexp } minimatch.match = function (list, pattern, options) { options = options || {} var mm = new Minimatch(pattern, options) list = list.filter(function (f) { return mm.match(f) }) if (mm.options.nonull && !list.length) { list.push(pattern) } return list } Minimatch.prototype.match = match function match (f, partial) { this.debug('match', f, this.pattern) // short-circuit in the case of busted things. // comments, etc. if (this.comment) return false if (this.empty) return f === '' if (f === '/' && partial) return true var options = this.options // windows: need to use /, not \ if (path.sep !== '/') { f = f.split(path.sep).join('/') } // treat the test path as a set of pathparts. f = f.split(slashSplit) this.debug(this.pattern, 'split', f) // just ONE of the pattern sets in this.set needs to match // in order for it to be valid. If negating, then just one // match means that we have failed. // Either way, return on the first hit. var set = this.set this.debug(this.pattern, 'set', set) // Find the basename of the path by looking for the last non-empty segment var filename var i for (i = f.length - 1; i >= 0; i--) { filename = f[i] if (filename) break } for (i = 0; i < set.length; i++) { var pattern = set[i] var file = f if (options.matchBase && pattern.length === 1) { file = [filename] } var hit = this.matchOne(file, pattern, partial) if (hit) { if (options.flipNegate) return true return !this.negate } } // didn't get any hits. this is success if it's a negative // pattern, failure otherwise. if (options.flipNegate) return false return this.negate } // set partial to true to test if, for example, // "/a/b" matches the start of "/*/b/*/d" // Partial means, if you run out of file before you run // out of pattern, then that's fine, as long as all // the parts match. Minimatch.prototype.matchOne = function (file, pattern, partial) { var options = this.options this.debug('matchOne', { 'this': this, file: file, pattern: pattern }) this.debug('matchOne', file.length, pattern.length) for (var fi = 0, pi = 0, fl = file.length, pl = pattern.length ; (fi < fl) && (pi < pl) ; fi++, pi++) { this.debug('matchOne loop') var p = pattern[pi] var f = file[fi] this.debug(pattern, p, f) // should be impossible. // some invalid regexp stuff in the set. if (p === false) return false if (p === GLOBSTAR) { this.debug('GLOBSTAR', [pattern, p, f]) // "**" // a/**/b/**/c would match the following: // a/b/x/y/z/c // a/x/y/z/b/c // a/b/x/b/x/c // a/b/c // To do this, take the rest of the pattern after // the **, and see if it would match the file remainder. // If so, return success. // If not, the ** "swallows" a segment, and try again. // This is recursively awful. // // a/**/b/**/c matching a/b/x/y/z/c // - a matches a // - doublestar // - matchOne(b/x/y/z/c, b/**/c) // - b matches b // - doublestar // - matchOne(x/y/z/c, c) -> no // - matchOne(y/z/c, c) -> no // - matchOne(z/c, c) -> no // - matchOne(c, c) yes, hit var fr = fi var pr = pi + 1 if (pr === pl) { this.debug('** at the end') // a ** at the end will just swallow the rest. // We have found a match. // however, it will not swallow /.x, unless // options.dot is set. // . and .. are *never* matched by **, for explosively // exponential reasons. for (; fi < fl; fi++) { if (file[fi] === '.' || file[fi] === '..' || (!options.dot && file[fi].charAt(0) === '.')) return false } return true } // ok, let's see if we can swallow whatever we can. while (fr < fl) { var swallowee = file[fr] this.debug('\nglobstar while', file, fr, pattern, pr, swallowee) // XXX remove this slice. Just pass the start index. if (this.matchOne(file.slice(fr), pattern.slice(pr), partial)) { this.debug('globstar found match!', fr, fl, swallowee) // found a match. return true } else { // can't swallow "." or ".." ever. // can only swallow ".foo" when explicitly asked. if (swallowee === '.' || swallowee === '..' || (!options.dot && swallowee.charAt(0) === '.')) { this.debug('dot detected!', file, fr, pattern, pr) break } // ** swallows a segment, and continue. this.debug('globstar swallow a segment, and continue') fr++ } } // no match was found. // However, in partial mode, we can't say this is necessarily over. // If there's more *pattern* left, then if (partial) { // ran out of file this.debug('\n>>> no match, partial?', file, fr, pattern, pr) if (fr === fl) return true } return false } // something other than ** // non-magic patterns just have to match exactly // patterns with magic have been turned into regexps. var hit if (typeof p === 'string') { if (options.nocase) { hit = f.toLowerCase() === p.toLowerCase() } else { hit = f === p } this.debug('string match', p, f, hit) } else { hit = f.match(p) this.debug('pattern match', p, f, hit) } if (!hit) return false } // Note: ending in / means that we'll get a final "" // at the end of the pattern. This can only match a // corresponding "" at the end of the file. // If the file ends in /, then it can only match a // a pattern that ends in /, unless the pattern just // doesn't have any more for it. But, a/b/ should *not* // match "a/b/*", even though "" matches against the // [^/]*? pattern, except in partial mode, where it might // simply not be reached yet. // However, a/b/ should still satisfy a/* // now either we fell off the end of the pattern, or we're done. if (fi === fl && pi === pl) { // ran out of pattern and filename at the same time. // an exact hit! return true } else if (fi === fl) { // ran out of file, but still had pattern left. // this is ok if we're doing the match as part of // a glob fs traversal. return partial } else if (pi === pl) { // ran out of pattern, still have file left. // this is only acceptable if we're on the very last // empty segment of a file with a trailing slash. // a/* should match a/b/ var emptyFileEnd = (fi === fl - 1) && (file[fi] === '') return emptyFileEnd } // should be unreachable. throw new Error('wtf?') } // replace stuff like \* with * function globUnescape (s) { return s.replace(/\\(.)/g, '$1') } function regExpEscape (s) { return s.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&') } },{"brace-expansion":30,"path":290}],248:[function(require,module,exports){ (function (process){ var path = require('path'); var fs = require('fs'); var _0777 = parseInt('0777', 8); module.exports = mkdirP.mkdirp = mkdirP.mkdirP = mkdirP; function mkdirP (p, opts, f, made) { if (typeof opts === 'function') { f = opts; opts = {}; } else if (!opts || typeof opts !== 'object') { opts = { mode: opts }; } var mode = opts.mode; var xfs = opts.fs || fs; if (mode === undefined) { mode = _0777 & (~process.umask()); } if (!made) made = null; var cb = f || function () {}; p = path.resolve(p); xfs.mkdir(p, mode, function (er) { if (!er) { made = made || p; return cb(null, made); } switch (er.code) { case 'ENOENT': mkdirP(path.dirname(p), opts, function (er, made) { if (er) cb(er, made); else mkdirP(p, opts, cb, made); }); break; // In the case of any other error, just see if there's a dir // there already. If so, then hooray! If not, then something // is borked. default: xfs.stat(p, function (er2, stat) { // if the stat fails, then that's super weird. // let the original error be the failure reason. if (er2 || !stat.isDirectory()) cb(er, made) else cb(null, made); }); break; } }); } mkdirP.sync = function sync (p, opts, made) { if (!opts || typeof opts !== 'object') { opts = { mode: opts }; } var mode = opts.mode; var xfs = opts.fs || fs; if (mode === undefined) { mode = _0777 & (~process.umask()); } if (!made) made = null; p = path.resolve(p); try { xfs.mkdirSync(p, mode); made = made || p; } catch (err0) { switch (err0.code) { case 'ENOENT' : made = sync(path.dirname(p), opts, made); sync(p, opts, made); break; // In the case of any other error, just see if there's a dir // there already. If so, then hooray! If not, then something // is borked. default: var stat; try { stat = xfs.statSync(p); } catch (err1) { throw err0; } if (!stat.isDirectory()) throw err0; break; } } return made; }; }).call(this,require('_process')) },{"_process":295,"fs":58,"path":290}],249:[function(require,module,exports){ // If `Date.now()` is invoked twice quickly, it's possible to get two // identical time stamps. To avoid generation duplications, subsequent // calls are manually ordered to force uniqueness. var _last = 0 var _count = 1 var adjusted = 0 var _adjusted = 0 module.exports = function timestamp() { /** Returns NOT an accurate representation of the current time. Since js only measures time as ms, if you call `Date.now()` twice quickly, it's possible to get two identical time stamps. This function guarantees unique but maybe inaccurate results on each call. **/ //uncomment this wen var time = Date.now() //time = ~~ (time / 1000) //^^^uncomment when testing... /** If time returned is same as in last call, adjust it by adding a number based on the counter. Counter is incremented so that next call get's adjusted properly. Because floats have restricted precision, may need to step past some values... **/ if (_last === time) { do { adjusted = time + ((_count++) / (_count + 999)) } while (adjusted === _adjusted) _adjusted = adjusted } // If last time was different reset timer back to `1`. else { _count = 1 adjusted = time } _adjusted = adjusted _last = time return adjusted } },{}],250:[function(require,module,exports){ (function (Buffer){ var cont = require('cont') var pull = require('pull-stream') var defer = require('pull-defer') var path = require('path') var explain = require('explain-error') var mkdirp = require('mkdirp') var rimraf = require('rimraf') var fs = require('fs') var glob = require('pull-glob') var paramap = require('pull-paramap') var cat = require('pull-cat') var Notify = require('pull-notify') var Write = require('pull-write-file') var Read = require('pull-file') var u = require('./util') var createHash = u.createHash function write (filename, cb) { return WriteFile(filename, cb) return toPull.sink(fs.createWriteStream(filename), cb) } function read (filename) { return ReadFile(filename) // return toPull.source(fs.createReadStream(filename)) } function toArray (h) { return Array.isArray(h) ? h : [h] } var Blobs = module.exports = function (config) { var dir if('string' === typeof config) dir = config, config = {dir: dir} var encode = config.encode || u.encode var decode = config.decode || u.decode var isHash = config.isHash || u.isHash function toPath (dir, string) { var d = decode(string) var h = d.hash.toString('hex') return path.join(dir, d.alg, h.substring(0,2), h.substring(2)) } function toHash(filename) { var parts = path.relative(dir, filename).split(path.sep) var alg = parts.shift() return encode(new Buffer(parts.join(''), 'hex'), alg) } var newBlob = Notify() config = config || {} var alg = config.hash = config.hash || config.alg || 'blake2s' dir = config.dir var n = 0 var waiting = [], tmp = false, clean = false function init (cb) { if(tmp) return cb() else waiting.push(cb) } var tmpdir = path.join(dir, 'tmp') rimraf(tmpdir, function () { mkdirp(tmpdir, function () { tmp = true; while(waiting.length) waiting.shift()() }) }) function has (hash) { return function (cb) { fs.stat(toPath(dir, hash), function (err, stat) { cb(null, !!stat) }) } } function size (hash) { return function (cb) { fs.stat(toPath(dir, hash), function (err, stat) { cb(null, stat ? stat.size : null) }) } } function createTester (test) { return function (hashes, cb) { var n = !Array.isArray(hashes) cont.para(toArray(hashes).map(test)) (function (_, ary) { // This will only error if the hash is not present, // so never callback an error. // PS. if you have a situation where you never error // add a comment like this one to explain why. if(n) cb(null, ary[0]) else cb(null, ary) }) return cb } } var listeners = [] return { get: function (opts) { if(isHash(opts)) return Read(toPath(dir, opts)) var hash = opts.key || opts.hash if(!isHash(hash)) return pull.error(new Error( 'multiblob.get: {hash} is mandatory' )) var stream = defer.source() fs.stat(toPath(dir, hash), function (err, stat) { if(opts.size != null && opts.size !== stat.size) stream.abort(new Error('incorrect file length,' + ' requested:' + opts.size + ' file was:' + stat.size + ' for file:' + hash )) else if(opts.max != null && opts.max < stat.size) stream.abort(new Error('incorrect file length,' + ' requested:' + opts.size + ' file was:' + stat.size + ' for file:' + hash )) else stream.resolve(Read(toPath(dir, hash))) }) return stream }, size: createTester(size), has: createTester(has), add: function (hash, cb) { if(!cb) cb = hash, hash = null if(!cb) cb = function (err) { if(err) explain(err, 'no callback provided') } var deferred = defer.sink() init(function () { var tmpfile = path.join(dir, 'tmp', Date.now() + '-' + n++) var hasher = createHash(alg, true) var size = 0 deferred.resolve(pull( hasher, pull.through(function (data) { size += data.length }), Write(tmpfile, function (err) { if(err) return cb(explain(err, 'could not write to tmpfile')) var _hash = encode(hasher.digest, alg) if(hash && hash !== _hash) return cb(new Error('actual hash:'+ _hash + ' did not match expected hash:'+hash), _hash) var p = toPath(dir, hash || _hash) mkdirp(path.dirname(p), function () { fs.rename(tmpfile, p, function (err) { if(err) cb(explain(err, 'could not move file')) else newBlob({id:toHash(p), size: size, ts: Date.now()}), cb(null, _hash) }) }) }) )) }) return deferred }, ls: function (opts) { opts = opts || {} var long = (opts.size || opts.long) var source = pull( glob(path.join(dir, '*', '*', '*')), long ? paramap(function (filename, cb) { fs.stat(filename, function (err, stat) { cb(err, {id: toHash(filename), size: stat.size, ts: +stat.ctime}) }) }, 32) : pull.map(toHash) ) if(!opts.live) return source return cat([ source, pull.once({sync: true}), long ? newBlob.listen() : pull(newBlob.listen(), pull.map(function (e) { return e.id })) ]) }, rm: function (hash, cb) { fs.unlink(toPath(dir, hash), cb) }, resolve: function (hash) { return toPath(dir, hash) } } } }).call(this,require("buffer").Buffer) },{"./util":258,"buffer":61,"cont":86,"explain-error":146,"fs":58,"mkdirp":248,"path":290,"pull-cat":305,"pull-defer":308,"pull-file":312,"pull-glob":321,"pull-notify":251,"pull-paramap":363,"pull-stream":252,"pull-write-file":392,"rimraf":257}],251:[function(require,module,exports){ var pushable = require('pull-pushable') module.exports = function () { var listeners = {}, n = 0 function notify (msg) { for(var k in listeners) listeners[k].push(msg) } notify.listen = function () { var k = ++n return listeners[k] = pushable(function () { delete listeners[k] }) } notify.abort = function (err) { for(var k in listeners) listeners[k].end(err) } notify.end = function () { return notify.abort(true) } return notify } },{"pull-pushable":370}],252:[function(require,module,exports){ arguments[4][232][0].apply(exports,arguments) },{"./pull":253,"./sinks":254,"./sources":255,"./throughs":256,"dup":232}],253:[function(require,module,exports){ arguments[4][233][0].apply(exports,arguments) },{"dup":233}],254:[function(require,module,exports){ arguments[4][234][0].apply(exports,arguments) },{"dup":234}],255:[function(require,module,exports){ arguments[4][235][0].apply(exports,arguments) },{"dup":235}],256:[function(require,module,exports){ arguments[4][236][0].apply(exports,arguments) },{"./sinks":254,"./sources":255,"dup":236}],257:[function(require,module,exports){ (function (process){ module.exports = rimraf rimraf.sync = rimrafSync var assert = require("assert") var path = require("path") var fs = require("fs") // for EMFILE handling var timeout = 0 exports.EMFILE_MAX = 1000 exports.BUSYTRIES_MAX = 3 var isWindows = (process.platform === "win32") function defaults (options) { var methods = [ 'unlink', 'chmod', 'stat', 'rmdir', 'readdir' ] methods.forEach(function(m) { options[m] = options[m] || fs[m] m = m + 'Sync' options[m] = options[m] || fs[m] }) } function rimraf (p, options, cb) { if (typeof options === 'function') { cb = options options = {} } assert(p) assert(options) assert(typeof cb === 'function') defaults(options) if (!cb) throw new Error("No callback passed to rimraf()") var busyTries = 0 rimraf_(p, options, function CB (er) { if (er) { if (isWindows && (er.code === "EBUSY" || er.code === "ENOTEMPTY") && busyTries < exports.BUSYTRIES_MAX) { busyTries ++ var time = busyTries * 100 // try again, with the same exact callback as this one. return setTimeout(function () { rimraf_(p, options, CB) }, time) } // this one won't happen if graceful-fs is used. if (er.code === "EMFILE" && timeout < exports.EMFILE_MAX) { return setTimeout(function () { rimraf_(p, options, CB) }, timeout ++) } // already gone if (er.code === "ENOENT") er = null } timeout = 0 cb(er) }) } // Two possible strategies. // 1. Assume it's a file. unlink it, then do the dir stuff on EPERM or EISDIR // 2. Assume it's a directory. readdir, then do the file stuff on ENOTDIR // // Both result in an extra syscall when you guess wrong. However, there // are likely far more normal files in the world than directories. This // is based on the assumption that a the average number of files per // directory is >= 1. // // If anyone ever complains about this, then I guess the strategy could // be made configurable somehow. But until then, YAGNI. function rimraf_ (p, options, cb) { assert(p) assert(options) assert(typeof cb === 'function') options.unlink(p, function (er) { if (er) { if (er.code === "ENOENT") return cb(null) if (er.code === "EPERM") return (isWindows) ? fixWinEPERM(p, options, er, cb) : rmdir(p, options, er, cb) if (er.code === "EISDIR") return rmdir(p, options, er, cb) } return cb(er) }) } function fixWinEPERM (p, options, er, cb) { assert(p) assert(options) assert(typeof cb === 'function') if (er) assert(er instanceof Error) options.chmod(p, 666, function (er2) { if (er2) cb(er2.code === "ENOENT" ? null : er) else options.stat(p, function(er3, stats) { if (er3) cb(er3.code === "ENOENT" ? null : er) else if (stats.isDirectory()) rmdir(p, options, er, cb) else options.unlink(p, cb) }) }) } function fixWinEPERMSync (p, options, er) { assert(p) assert(options) if (er) assert(er instanceof Error) try { options.chmodSync(p, 666) } catch (er2) { if (er2.code === "ENOENT") return else throw er } try { var stats = options.statSync(p) } catch (er3) { if (er3.code === "ENOENT") return else throw er } if (stats.isDirectory()) rmdirSync(p, options, er) else options.unlinkSync(p) } function rmdir (p, options, originalEr, cb) { assert(p) assert(options) if (originalEr) assert(originalEr instanceof Error) assert(typeof cb === 'function') // try to rmdir first, and only readdir on ENOTEMPTY or EEXIST (SunOS) // if we guessed wrong, and it's not a directory, then // raise the original error. options.rmdir(p, function (er) { if (er && (er.code === "ENOTEMPTY" || er.code === "EEXIST" || er.code === "EPERM")) rmkids(p, options, cb) else if (er && er.code === "ENOTDIR") cb(originalEr) else cb(er) }) } function rmkids(p, options, cb) { assert(p) assert(options) assert(typeof cb === 'function') options.readdir(p, function (er, files) { if (er) return cb(er) var n = files.length if (n === 0) return options.rmdir(p, cb) var errState files.forEach(function (f) { rimraf(path.join(p, f), options, function (er) { if (errState) return if (er) return cb(errState = er) if (--n === 0) options.rmdir(p, cb) }) }) }) } // this looks simpler, and is strictly *faster*, but will // tie up the JavaScript thread and fail on excessively // deep directory trees. function rimrafSync (p, options) { options = options || {} defaults(options) assert(p) assert(options) try { options.unlinkSync(p) } catch (er) { if (er.code === "ENOENT") return if (er.code === "EPERM") return isWindows ? fixWinEPERMSync(p, options, er) : rmdirSync(p, options, er) if (er.code !== "EISDIR") throw er rmdirSync(p, options, er) } } function rmdirSync (p, options, originalEr) { assert(p) assert(options) if (originalEr) assert(originalEr instanceof Error) try { options.rmdirSync(p) } catch (er) { if (er.code === "ENOENT") return if (er.code === "ENOTDIR") throw originalEr if (er.code === "ENOTEMPTY" || er.code === "EEXIST" || er.code === "EPERM") rmkidsSync(p, options) } } function rmkidsSync (p, options) { assert(p) assert(options) options.readdirSync(p).forEach(function (f) { rimrafSync(path.join(p, f), options) }) options.rmdirSync(p, options) } }).call(this,require('_process')) },{"_process":295,"assert":15,"fs":58,"path":290}],258:[function(require,module,exports){ (function (Buffer){ var Blake2s = require('blake2s') var createHash = require('crypto').createHash var hash = require('crypto') var path = require('path') var pull = require('pull-stream') var isBuffer = Buffer.isBuffer var algs = { blake2s: function () { return new Blake2s() }, sha256: function () { return createHash('sha256') } } exports.encode = function (buf, alg) { if(!isBuffer(buf)) throw new Error('hash should be a buffer, was:'+buf) return buf.toString('base64')+'.'+alg } exports.decode = function (str) { var i = str.indexOf('.') var alg = str.substring(i+1) return {hash: new Buffer(str.substring(0, i), 'base64'), alg: alg} } exports.createHash = function (alg, noCompat) { alg = alg || 'blake2s' var hash = algs[alg]() var hasher = pull.through(function (data) { data = isBuffer(data) ? data : new Buffer(data) hasher.size += data.length hash.update(data) }, function () { return hasher.digest = noCompat === true ? hash.digest() : hash.digest('base64') + '.' + alg // hasher.digest = digest }) hasher.size = 0 return hasher } function isString (s) { return 'string' === typeof s } exports.isHash = function (data) { return isString(data) && /^[A-Za-z0-9\/+]{43}=\.(?:blake2s|sha256)$/.test(data) } }).call(this,require("buffer").Buffer) },{"blake2s":28,"buffer":61,"crypto":110,"path":290,"pull-stream":252}],259:[function(require,module,exports){ var zerr = require('zerr') var pull = require('pull-stream') module.exports = function (addedValidators) { var api = {} var validators = {} // validator control api.get = function (name) { return validators[name] } api.set = function (name, fn) { if (name && typeof name == 'object') for (var k in name) api.set(k, name[k].bind(api)) else validators[name] = fn } // set validator registry api.set({ number: function (param, n) { var asNum = +param if (isNaN(asNum) || asNum != param) return 'type' }, string: function (param, n) { var asString = ''+param if (asString != param) return 'type' }, boolean: function (param, n) { if (typeof param != 'boolean') return 'type' }, object: function (param, n) { if (typeof param != 'object' || !param) return 'type' }, array: function (param, n) { if (!Array.isArray(param)) return 'type' }, function: function (param, n) { if (typeof param != 'function') return 'type' } }) api.set(addedValidators) // rpc method wrappers api.sync = function (fn) { var spec = Array.prototype.slice.call(arguments, 1) return function () { var args = Array.prototype.slice.call(arguments) // run validation var err = validate(args, spec) if (err) throw err // run sync fn return apply(this, fn, args) } } api.sink = api.async = function (fn) { var spec = Array.prototype.slice.call(arguments, 1) return function () { var args = Array.prototype.slice.call(arguments) var hasCb = (typeof args[args.length - 1] == 'function') // get cb var cb = (hasCb) ? args[args.length - 1] : function (err) { if (err) { throw err; } } // run validation var err = validate((hasCb) ? args.slice(0,args.length-1) : args, spec) if (err) return cb(err) // run async fn return apply(this, fn, args) } } api.source = function (fn) { var spec = Array.prototype.slice.call(arguments, 1) return function () { var args = Array.prototype.slice.call(arguments) // run validation var err = validate(args, spec) if (err) return pull.error(err) // run stream fn return apply(this, fn, args) } } // run validation against a spec function validate (args, spec) { var err // multiple specs? if (Array.isArray(spec[0])) { for (var i=0; i < spec.length; i++) { err = validate(args, spec[i]) if (!err) return false // spec passed } return err // give the last error } // iterate the spec for (var i=0; i < spec.length; i++) { var types = parse(spec[i]) for (var j=0; j < types.length; j++) { var type = types[j] // falsey? if (!args[i]) { err = (type.optional) ? false : errs.MissingParam(''+i) break } // get & run validator var validator = validators[type.name] if (!validator) throw new Error('Validator not found: ' + type.name) err = validator(args[i], ''+i) // did the validator pass? break out of this type if (!err) break // error aliases if (err == 'type') err = errs.Type(''+i, type.name) } // none of the types passed? return the error if (err) return err } return false } return api } var errs = module.exports.errors = { MissingParam: zerr('Usage', 'Param % is required'), Type: zerr('Type', 'Param % must by of type %') } // parse spec token function parse (token) { return token.split('|').map(function (token) { if (token.charAt(token.length - 1) == '?') return { name: token.slice(0, token.length - 1), optional: true } return { name: token, optional: false } }) } // helper to avoid apply, for performance function apply (self, fn, args) { if (args.length == 0) return fn.call(self) if (args.length == 1) return fn.call(self, args[0]) if (args.length == 2) return fn.call(self, args[0], args[1]) if (args.length == 3) return fn.call(self, args[0], args[1], args[2]) if (args.length == 4) return fn.call(self, args[0], args[1], args[2], args[3]) return fn.apply(self, args) } },{"pull-stream":381,"zerr":643}],260:[function(require,module,exports){ 'use strict'; var EventEmitter = require('events').EventEmitter var u = require('./util') var explain = require('explain-error') function isFunction (f) { return 'function' === typeof f } function isObject (o) { return o && 'object' === typeof o } function noop (err) { if (err) throw explain(err, 'callback not provided') } module.exports = function (path, remoteApi, _remoteCall) { var emitter = new EventEmitter() function remoteCall(type, name, args) { var cb = isFunction (args[args.length - 1]) ? args.pop() : noop var value try { value = _remoteCall(type, name, args, cb) } catch(err) { return u.errorAsStreamOrCb(type, err, cb)} return value } //add all the api methods to emitter recursively ;(function recurse (obj, api, path) { for(var name in api) (function (name, type) { var _path = path ? path.concat(name) : [name] obj[name] = isObject(type) ? recurse({}, type, _path) : function () { return remoteCall(type, _path, [].slice.call(arguments)) } })(name, api[name]) return obj })(emitter, remoteApi, path) //legacy local emit, from when remote emit was supported. emitter._emit = emitter.emit return emitter } },{"./util":271,"events":144,"explain-error":146}],261:[function(require,module,exports){ 'use strict' var PSC = require('packet-stream-codec') var u = require('./util') var initStream = require('./stream') var createApi = require('./api') var createLocalCall = require('./local-api') function createMuxrpc (remoteApi, localApi, local, id, perms, codec, legacy) { localApi = localApi || {} remoteApi = remoteApi || {} var emitter if(!codec) codec = PSC //pass the manifest to the permissions so that it can know //what something should be. var _cb, ws var context = { _emit: function (event, value) { emitter && emitter._emit(event, value) return context }, id: id } var ws = initStream( createLocalCall(local, localApi, perms).bind(context), codec, function (err) { if(emitter.closed) return emitter.closed = true emitter.emit('closed') if(_cb) { var cb = _cb; _cb = null; cb(err) } } ) emitter = createApi([], remoteApi, function (type, name, args, cb) { if(ws.closed) throw new Error('stream is closed') return ws.remoteCall(type, name, args, cb) }) if(legacy) { Object.__defineGetter__.call(emitter, 'id', function () { return context.id }) Object.__defineSetter__.call(emitter, 'id', function (value) { context.id = value }) var first = true emitter.createStream = function (cb) { _cb = cb if(first) { first = false; return ws } else throw new Error('one stream per rpc') } } else emitter.stream = ws emitter.closed = false emitter.close = function (err, cb) { ws.close(err, cb) return this } return emitter } module.exports = function (remoteApi, localApi, codec) { if(arguments.length > 3) return createMuxrpc.apply(this, arguments) return function (local, perms, id) { return createMuxrpc(remoteApi, localApi, local, id, perms, codec, true) } } },{"./api":260,"./local-api":262,"./stream":270,"./util":271,"packet-stream-codec":283}],262:[function(require,module,exports){ var Permissions = require('./permissions') var u = require('./util') module.exports = function createLocalCall(local, localApi, perms) { perms = Permissions(perms) function has(type, name) { return type === u.get(localApi, name) } function localCall(type, name, args) { if(name === 'emit') throw new Error('emit has been removed') //is there a way to know whether it's sync or async? if(type === 'async') if(has('sync', name)) { var cb = args.pop(), value try { value = u.get(local, name).apply(this, args) } catch (err) { return cb(err) } return cb(null, value) } if (!has(type, name)) throw new Error('no '+type+':'+name) return u.get(local, name).apply(this, args) } return function (type, name, args) { var err = perms.pre(name, args) if(err) throw err return localCall.call(this, type, name, args) } } },{"./permissions":268,"./util":271}],263:[function(require,module,exports){ arguments[4][232][0].apply(exports,arguments) },{"./pull":264,"./sinks":265,"./sources":266,"./throughs":267,"dup":232}],264:[function(require,module,exports){ arguments[4][233][0].apply(exports,arguments) },{"dup":233}],265:[function(require,module,exports){ arguments[4][234][0].apply(exports,arguments) },{"dup":234}],266:[function(require,module,exports){ arguments[4][235][0].apply(exports,arguments) },{"dup":235}],267:[function(require,module,exports){ arguments[4][236][0].apply(exports,arguments) },{"./sinks":265,"./sources":266,"dup":236}],268:[function(require,module,exports){ 'use strict'; var u = require('./util') var isArray = Array.isArray function isFunction (f) { return 'function' === typeof f } function join (str) { return Array.isArray(str) ? str.join('.') : str } function toArray(str) { return isArray(str) ? str : str.split('.') } function isPerms (p) { return ( p && isFunction(p.pre) && isFunction(p.test) && isFunction(p.post) ) } /* perms: a given capability may be permitted to call a particular api. but only if a perms function returns true for the arguments it passes. suppose, an app may be given access, but may only create functions with it's own properties. create perms: { allow: ['add', 'query'], deny: [...], rules: { add: { call: function (value) { return (value.type === 'task' || value.type === '_task') }, query: { call: function (value) { safe.contains(value, {path: ['content', 'type'], eq: 'task'}) || safe.contains(value, {path: ['content', 'type'], eq: '_task'}) }, filter: function (value) { return (value.type === 'task' || value.type === '_task') } } } } */ module.exports = function (opts) { if(isPerms(opts)) return opts if(isFunction(opts)) return {pre: opts} var allow = null var deny = {} function perms (opts) { if(opts.allow) { allow = {} opts.allow.forEach(function (path) { u.set(allow, toArray(path), true) }) } else allow = null if(opts.deny) opts.deny.forEach(function (path) { u.set(deny, toArray(path), true) }) else deny = {} return this } if(opts) perms(opts) perms.pre = function (name, args) { name = isArray(name) ? name : [name] if(allow && !u.prefix(allow, name)) return new Error('method:'+name + ' is not on whitelist') if(deny && u.prefix(deny, name)) return new Error('method:'+name + ' is on blacklist') } perms.post = function (err, value) { //TODO } //alias for pre, used in tests. perms.test = function (name, args) { return perms.pre(name, args) } perms.get = function () { return {allow: allow, deny: deny} } return perms } },{"./util":271}],269:[function(require,module,exports){ 'use strict' var pull = require('pull-stream') // wrap pull streams around packet-stream's weird streams. function once (fn) { var done = false return function (err, val) { if(done) return done = true fn(err, val) } } module.exports = function (weird, _done) { var buffer = [], ended = false, waiting, abort var done = once(function (err, v) { _done && _done(err, v) // deallocate weird = null _done = null waiting = null if(abort) abort(err || true, function () {}) }) weird.read = function (data, end) { ended = ended || end if(waiting) { var cb = waiting waiting = null cb(ended, data) } else if(!ended) buffer.push(data) if(ended) done(ended !== true ? ended : null) } return { source: function (abort, cb) { if(abort) { weird && weird.write(null, abort) cb(abort); done(abort !== true ? abort : null) } else if(buffer.length) cb(null, buffer.shift()) else if(ended) cb(ended) else waiting = cb }, sink : function (read) { if(ended) return read(ended, function () {}), abort = null abort = read pull.drain(function (data) { //TODO: make this should only happen on a UNIPLEX stream. if(ended) return false weird.write(data) }, function (err) { if(weird && !weird.writeEnd) weird.write(null, err || true) done && done(err) }) (read) } } } function uniplex (s, done) { return module.exports(s, function (err) { if(!s.writeEnd) s.write(null, err || true) if(done) done(err) }) } module.exports.source = function (s) { return uniplex(s).source } module.exports.sink = function (s, done) { return uniplex(s, done).sink } module.exports.duplex = module.exports },{"pull-stream":263}],270:[function(require,module,exports){ 'use strict'; var PacketStream = require('packet-stream') var pull = require('pull-stream') var pullWeird = require('./pull-weird') var goodbye = require('pull-goodbye') var u = require('./util') var explain = require('explain-error') function isFunction (f) { return 'function' === typeof f } function isString (s) { return 'string' === typeof s } function isObject (o) { return o && 'object' === typeof o } function isSource (t) { return 'source' === t } function isSink (t) { return 'sink' === t } function isDuplex (t) { return 'duplex' === t } function isSync (t) { return 'sync' === t } function isAsync (t) { return 'async' === t } function isRequest (t) { return isSync(t) || isAsync(t) } function isStream (t) { return isSource(t) || isSink(t) || isDuplex(t) } module.exports = function initStream (localCall, codec, onClose) { var ps = PacketStream({ message: function (msg) { // if(isString(msg)) return // if(msg.length > 0 && isString(msg[0])) // localCall('msg', 'emit', msg) }, request: function (opts, cb) { var name = opts.name, args = opts.args var inCB = false, called = false, async = false, value args.push(function (err, value) { called = true inCB = true; cb(err, value) }) try { value = localCall('async', name, args) } catch (err) { if(inCB || called) throw explain(err, 'no callback provided to muxrpc async funtion') return cb(err) } }, stream: function (stream) { stream.read = function (data, end) { var name = data.name var type = data.type var err, value stream.read = null if(!isStream(type)) return stream.write(null, new Error('unsupported stream type:'+type)) //how would this actually happen? if(end) return stream.write(null, end) try { value = localCall(type, name, data.args) } catch (_err) { err = _err } var _stream = pullWeird[ {source: 'sink', sink: 'source'}[type] || 'duplex' ](stream) return u.pipeToStream( type, _stream, err ? u.errorAsStream(type, err) : value ) // if(isSource(type)) // _stream(err ? pull.error(err) : value) // else if (isSink(type)) // (err ? abortSink(err) : value)(_stream) // else if (isDuplex(type)) // pull(_stream, err ? abortDuplex(err) : value, _stream) } }, close: function (err) { ps = null // deallocate ws.ended = true if(ws.closed) return ws.closed = true if(onClose) { var close = onClose; onClose = null; close(err) } } }) var ws = goodbye(pullWeird(ps, function (_) { //this error will be handled in PacketStream.close })) ws = codec ? codec(ws) : ws ws.remoteCall = function (type, name, args, cb) { if(name === 'emit') return ps.message(args) if(!(isRequest(type) || isStream(type))) throw new Error('unsupported type:' + JSON.stringify(type)) if(isRequest(type)) return ps.request({name: name, args: args}, cb) var ws = ps.stream(), s = pullWeird[type](ws, cb) ws.write({name: name, args: args, type: type}) return s } //hack to work around ordering in setting ps.ended. //Question: if an object has subobjects, which //all have close events, should the subobjects fire close //before the parent? or should parents close after? //should there be a preclose event on the parent //that fires when it's about to close all the children? ws.isOpen = function () { return !ps.ended } ws.close = function (err, cb) { if(isFunction(err)) cb = err, err = false if(!ps) return (cb && cb()) if(err) return ps.destroy(err), (cb && cb()) ps.close(function (err) { if(cb) cb(err) else if(err) throw explain(err, 'no callback provided for muxrpc close') }) return this } ws.closed = false return ws } },{"./pull-weird":269,"./util":271,"explain-error":146,"packet-stream":284,"pull-goodbye":328,"pull-stream":263}],271:[function(require,module,exports){ 'use strict'; var pull = require('pull-stream') function isString (s) { return 'string' === typeof s } var isArray = Array.isArray function isObject (o) { return o && 'object' === typeof o && !isArray(o) } function isEmpty (obj) { for(var k in obj) return false; return true } //I wrote set as part of permissions.js //and then later mount, they do nearly the same thing //but not quite. this should be refactored sometime. //what differs is that set updates the last key in the path //to the new value, but mount merges the last value //which makes sense if it's an object, and set makes sense if it's //a string/number/boolean. exports.set = function (obj, path, value) { var _obj, _k for(var i = 0; i < path.length; i++) { var k = path[i] obj[k] = obj[k] || {} _obj = obj; _k = k obj = obj[k] } _obj[_k] = value } exports.get = function (obj, path) { if(isString(path)) return obj[path] var value for(var i = 0; i < path.length; i++) { var k = path[i] value = obj = obj[k] if(null == obj) return obj } return value } exports.prefix = function (obj, path) { var value, parent = obj for(var i = 0; i < path.length; i++) { var k = path[i] value = obj = obj[k] if('object' !== typeof obj) { return obj } parent = obj } return 'object' !== typeof value ? !!value : false } function mkPath(obj, path) { for(var i in path) { var key = path[i] if(!obj[key]) obj[key]={} obj = obj[key] } return obj } function rmPath (obj, path) { (function r (obj, i) { var key = path[i] if(!obj) return else if(path.length - 1 === i) delete obj[key] else if(i < path.length) r(obj[key], i+1) if(isEmpty(obj[key])) delete obj[key] })(obj, 0) } function merge (obj, _obj) { for(var k in _obj) obj[k] = _obj[k] return obj } var mount = exports.mount = function (obj, path, _obj) { if(!Array.isArray(path)) throw new Error('path must be array of strings') return merge(mkPath(obj, path), _obj) } var unmount = exports.unmount = function (obj, path) { return rmPath(obj, path) } function isSource (t) { return 'source' === t } function isSink (t) { return 'sink' === t } function isDuplex (t) { return 'duplex' === t } function isSync (t) { return 'sync' === t } function isAsync (t) { return 'async' === t } function isRequest (t) { return isSync(t) || isAsync(t) } function isStream (t) { return isSource(t) || isSink(t) || isDuplex(t) } function abortSink (err) { return function (read) { read(err || true, function () {}) } } function abortDuplex (err) { return {source: pull.error(err), sink: abortSink(err)} } exports.errorAsStream = function (type, err) { return ( isSource(type) ? pull.error(err) : isSink(type) ? abortSink(err) : abortDuplex(err) ) } exports.errorAsStreamOrCb = function (type, err, cb) { return ( isRequest(type) ? cb(err) : isSource(type) ? pull.error(err) : isSink(type) ? abortSink(err) : cb(err), abortDuplex(err) ) } exports.pipeToStream = function (type, _stream, stream) { if(isSource(type)) _stream(stream) else if (isSink(type)) stream(_stream) else if (isDuplex(type)) pull(_stream, stream, _stream) } },{"pull-stream":263}],272:[function(require,module,exports){ (function (process){ var os = require('os') var ip = require('ip') //pick the first reasonable looking host. //this should *just work* when running on a vps. var isPrivate = ip.isPrivate function isNonPrivate (e) { return !isPrivate(e) } module.exports = function (inter, filter) { inter = inter || os.networkInterfaces() filter = filter || isNonPrivate for(var k in inter) { for(var i in inter[k]) { var e = inter[k][i] // find a reasonable looking address if(!e.internal && filter(e.address)) return e.address } } } module.exports.private = function (inter) { return module.exports(inter, isPrivate) } if(!module.parent) { var h = module.exports() if(!h) { console.error('no non-private address') console.error('private:', module.exports.private()) process.exit(1) } console.log(h) } }).call(this,require('_process')) },{"_process":295,"ip":169,"os":279}],273:[function(require,module,exports){ 'use strict'; /** * Normalize `uri`. This only works when both `encodeURI` * and `decodeURI` are available, and when * decoding/encoding fails, just returns `uri`. * * @example * normalizeURI('foo bar'); // 'foo%20bar' * normalizeURI('foo%20bar'); // 'foo%20bar' * * @param {string} uri - Value with and/or without * encoded, entities. * @return {string} - Encoded URI (when encoding succeeds, * or `uri`). */ function normalizeURI(uri) { try { uri = encodeURI(decodeURI(uri)); } catch (exception) { /* empty */ } return uri; } /* * Expose. */ module.exports = normalizeURI; },{}],274:[function(require,module,exports){ /* eslint-disable no-unused-vars */ 'use strict'; var hasOwnProperty = Object.prototype.hasOwnProperty; var propIsEnumerable = Object.prototype.propertyIsEnumerable; function toObject(val) { if (val === null || val === undefined) { throw new TypeError('Object.assign cannot be called with null or undefined'); } return Object(val); } module.exports = Object.assign || function (target, source) { var from; var to = toObject(target); var symbols; for (var s = 1; s < arguments.length; s++) { from = Object(arguments[s]); for (var key in from) { if (hasOwnProperty.call(from, key)) { to[key] = from[key]; } } if (Object.getOwnPropertySymbols) { symbols = Object.getOwnPropertySymbols(from); for (var i = 0; i < symbols.length; i++) { if (propIsEnumerable.call(from, symbols[i])) { to[symbols[i]] = from[symbols[i]]; } } } } return to; }; },{}],275:[function(require,module,exports){ var Observ = require('observ') module.exports = function (delay) { delay = delay || 200 var o = Observ(), set = o.set, ts = 0, timer, v o.set = function (v) { value = v var next = (ts + delay) - Date.now() if(next >= 0) { if(!timer) timer = setTimeout(function () { timer = null ts = Date.now() set(value) }, next) return } ts = Date.now() set(v) } o.immediate = function (v) { ts = 0 clearTimeout(timer) return o.set(v) } return o } },{"observ":276}],276:[function(require,module,exports){ module.exports = Observable function Observable(value) { var listeners = [] value = value === undefined ? null : value observable.set = function (v) { value = v listeners.forEach(function (f) { f(v) }) } return observable function observable(listener) { if (!listener) { return value } listeners.push(listener) return function remove() { listeners.splice(listeners.indexOf(listener), 1) } } } },{}],277:[function(require,module,exports){ var sleepCheckInterval var lastSleepCheck = false var SLEEP_CHECK_INTERVAL = 10e3 var NUM_MISSABLE_INTERVALS = 3 var EE = require('events') var emitter = new EE() module.exports = function (cb) { emitter.on('wakeup', cb) if (!sleepCheckInterval) { // setup interval sleepCheckInterval = setInterval(function () { var t = Date.now() if (lastSleepCheck && (t - lastSleepCheck) > SLEEP_CHECK_INTERVAL*NUM_MISSABLE_INTERVALS) emitter.emit('wakeup') // missed NUM_MISSABLE_INTERVALS checks, let's run the callbacks lastSleepCheck = t }, SLEEP_CHECK_INTERVAL) } // unreference the timer so that the program can close if (sleepCheckInterval.unref) sleepCheckInterval.unref() return sleepCheckInterval } },{"events":144}],278:[function(require,module,exports){ var wrappy = require('wrappy') module.exports = wrappy(once) once.proto = once(function () { Object.defineProperty(Function.prototype, 'once', { value: function () { return once(this) }, configurable: true }) }) function once (fn) { var f = function () { if (f.called) return f.value f.called = true return f.value = fn.apply(this, arguments) } f.called = false return f } },{"wrappy":641}],279:[function(require,module,exports){ exports.endianness = function () { return 'LE' }; exports.hostname = function () { if (typeof location !== 'undefined') { return location.hostname } else return ''; }; exports.loadavg = function () { return [] }; exports.uptime = function () { return 0 }; exports.freemem = function () { return Number.MAX_VALUE; }; exports.totalmem = function () { return Number.MAX_VALUE; }; exports.cpus = function () { return [] }; exports.type = function () { return 'Browser' }; exports.release = function () { if (typeof navigator !== 'undefined') { return navigator.appVersion; } return ''; }; exports.networkInterfaces = exports.getNetworkInterfaces = function () { return {} }; exports.arch = function () { return 'javascript' }; exports.platform = function () { return 'browser' }; exports.tmpdir = exports.tmpDir = function () { return '/tmp'; }; exports.EOL = '\n'; },{}],280:[function(require,module,exports){ (function (process){ 'use strict'; var os = require('os'); function homedir() { var env = process.env; var home = env.HOME; var user = env.LOGNAME || env.USER || env.LNAME || env.USERNAME; if (process.platform === 'win32') { return env.USERPROFILE || env.HOMEDRIVE + env.HOMEPATH || home || null; } if (process.platform === 'darwin') { return home || (user ? '/Users/' + user : null); } if (process.platform === 'linux') { return home || (process.getuid() === 0 ? '/root' : (user ? '/home/' + user : null)); } return home || null; } module.exports = typeof os.homedir === 'function' ? os.homedir : homedir; }).call(this,require('_process')) },{"_process":295,"os":279}],281:[function(require,module,exports){ (function (process){ 'use strict'; var isWindows = process.platform === 'win32'; var trailingSlashRe = isWindows ? /[^:]\\$/ : /.\/$/; // https://github.com/nodejs/io.js/blob/3e7a14381497a3b73dda68d05b5130563cdab420/lib/os.js#L25-L43 module.exports = function () { var path; if (isWindows) { path = process.env.TEMP || process.env.TMP || (process.env.SystemRoot || process.env.windir) + '\\temp'; } else { path = process.env.TMPDIR || process.env.TMP || process.env.TEMP || '/tmp'; } if (trailingSlashRe.test(path)) { path = path.slice(0, -1); } return path; }; }).call(this,require('_process')) },{"_process":295}],282:[function(require,module,exports){ (function (process){ var isWindows = process.platform === 'win32' var path = require('path') var exec = require('child_process').exec var osTmpdir = require('os-tmpdir') var osHomedir = require('os-homedir') // looking up envs is a bit costly. // Also, sometimes we want to have a fallback // Pass in a callback to wait for the fallback on failures // After the first lookup, always returns the same thing. function memo (key, lookup, fallback) { var fell = false var falling = false exports[key] = function (cb) { var val = lookup() if (!val && !fell && !falling && fallback) { fell = true falling = true exec(fallback, function (er, output, stderr) { falling = false if (er) return // oh well, we tried val = output.trim() }) } exports[key] = function (cb) { if (cb) process.nextTick(cb.bind(null, null, val)) return val } if (cb && !falling) process.nextTick(cb.bind(null, null, val)) return val } } memo('user', function () { return ( isWindows ? process.env.USERDOMAIN + '\\' + process.env.USERNAME : process.env.USER ) }, 'whoami') memo('prompt', function () { return isWindows ? process.env.PROMPT : process.env.PS1 }) memo('hostname', function () { return isWindows ? process.env.COMPUTERNAME : process.env.HOSTNAME }, 'hostname') memo('tmpdir', function () { return osTmpdir() }) memo('home', function () { return osHomedir() }) memo('path', function () { return (process.env.PATH || process.env.Path || process.env.path).split(isWindows ? ';' : ':') }) memo('editor', function () { return process.env.EDITOR || process.env.VISUAL || (isWindows ? 'notepad.exe' : 'vi') }) memo('shell', function () { return isWindows ? process.env.ComSpec || 'cmd' : process.env.SHELL || 'bash' }) }).call(this,require('_process')) },{"_process":295,"child_process":58,"os-homedir":280,"os-tmpdir":281,"path":290}],283:[function(require,module,exports){ (function (Buffer){ var Through = require('pull-through') var Reader = require('pull-reader') var BUFFER = 0, STRING = 1, OBJECT = 2 var GOODBYE = 'GOODBYE' var isBuffer = Buffer.isBuffer function isString (s) { return 'string' === typeof s } function encodePair (msg) { var head = new Buffer(9) var flags = 0 var value = msg.value !== undefined ? msg.value : msg.end //final packet if(isString(msg) && msg === GOODBYE) { head.fill(0) return [head, null] } if(isString(value)) { flags = STRING value = new Buffer(value) } else if(isBuffer(value)) { flags = BUFFER } else { flags = OBJECT value = new Buffer(JSON.stringify(value)) } // does this frame represent a msg, a req, or a stream? //end, stream flags = msg.stream << 3 | msg.end << 2 | flags head[0] = flags head.writeUInt32BE(value.length, 1) head.writeInt32BE(msg.req || 0, 5) return [head, value] } function decodeHead (bytes) { if(bytes.length != 9) throw new Error('expected header to be 9 bytes long') var flags = bytes[0] var length = bytes.readUInt32BE(1) var req = bytes.readInt32BE(5) return { req : req, stream : !!(flags & 8), end : !!(flags & 4), value : null, length : length, type : flags & 3 } } function decodeBody (bytes, msg) { if(bytes.length !== msg.length) throw new Error('incorrect length, expected:'+msg.length+' found:'+bytes.length) if(BUFFER === msg.type) msg.value = bytes else if(STRING === msg.type) msg.value = bytes.toString() else if(OBJECT === msg.type) msg.value = JSON.parse(bytes.toString()) else throw new Error('unknown message type') return msg } function encode () { return Through(function (d) { var c = encodePair(d) this.queue(c[0]) if(c[1] !== null) this.queue(c[1]) }) } function decode () { var reader = Reader(), ended = false return function (read) { reader(read) return function (abort, cb) { if(ended) return cb(true) if(abort) return reader.abort(abort, cb) reader.read(9, function (err, head) { if(err) return cb(err) var msg = decodeHead(head) if(msg.length === 0) { //final packet ended = true return cb(null, GOODBYE) } reader.read(msg.length, function (err, body) { if(err) return cb(err) decodeBody(body, msg) cb(null, msg) }) }) } } } exports = module.exports = function (stream) { return { source: encode()(stream.source), sink: function (read) { return stream.sink(decode()(read)) } } } exports.encodePair = encodePair exports.decodeHead = decodeHead exports.decodeBody = decodeBody exports.encode = encode exports.decode = decode }).call(this,require("buffer").Buffer) },{"buffer":61,"pull-reader":372,"pull-through":386}],284:[function(require,module,exports){ function flat(err) { if(!err) return err if(err === true) return true return {message: err.message, name: err.name, stack: err.stack} } module.exports = function (opts) { return new PacketStream(opts) } function PacketStream (opts) { this.ended = false this.opts = opts // must release, may capture `this` this._req_counter = 1 this._requests = {} // must release, may capture `this` this._instreams = {} // must release, may capture `this` this._outstreams = {} // must release, may capture `this` this._closecbs = [] // must release, may capture `this` this._closing = false this._closed = false if (opts.close) this._closecbs.push(opts.close) } // Sends a single message to the other end PacketStream.prototype.message = function (obj) { this.read({req: 0, stream: false, end: false, value: obj}) } // Sends a message to the other end, expects an (err, obj) response PacketStream.prototype.request = function (obj, cb) { var rid = this._req_counter++ var self = this this._requests[rid] = function (err, value) { delete self._requests[rid] cb(err, value) self._maybedone() } this.read({ req:rid, stream: false, end: false, value: obj }) } // Sends a request to the other end for a stream PacketStream.prototype.stream = function () { var rid = this._req_counter++ var self = this this._outstreams[rid] = new PacketStreamSubstream(rid, this, function() { delete self._outstreams[rid] }) return this._outstreams[rid] } // Marks the packetstream to close when all current IO is finished PacketStream.prototype.close = function (cb) { if(!cb) throw new Error('packet-stream.close *must* have callback') if (this._closed) return cb() this._closecbs.push(cb) this._closing = true this._maybedone() } // Forces immediate close of the PacketStream // - usually triggered by an `end` packet from the other end PacketStream.prototype.destroy = function (end) { end = end || flat(end) this.ended = end var err = (end === true) ? new Error('unexpected end of parent stream') : end // force-close all requests and substreams var numended = 0 for (var k in this._requests) { numended++; this._requests[k](err) } for (var k in this._instreams) { numended++; this._instreams[k].destroy(err) } for (var k in this._outstreams) { numended++; this._outstreams[k].destroy(err) } //from the perspective of the outside stream it's not an error //if the stream was in a state that where end was okay. (no open requests/streams) if (numended === 0 && end === true) err = null this._closing = true this._maybedone(err) } PacketStream.prototype._maybedone = function (err) { if (this._closed || !this._closing) return // check if all requests and streams finished if (Object.keys(this._requests).length !== 0 || Object.keys(this._instreams).length !== 0 || Object.keys(this._outstreams).length !== 0) return // not yet // close this._closed = true this._closecbs.forEach(function (cb) { cb(err) }) this.read(null, err || true) // deallocate this.opts = null this._closecbs.length = 0 this.read = closedread } function closedread (msg) { console.error('packet-stream asked to read after closed', msg) } // Sends data out to the other end // - to be overridden by the PacketStream consumer PacketStream.prototype.read = function (msg) { console.error('please overwrite read method to do IO', msg) } // Accepts data from the other end PacketStream.prototype.write = function (msg, end) { if (this.ended) return if (end) this.destroy(end) else if (msg.req && !msg.stream) this._onrequest(msg) else if (msg.req && msg.stream) this._onstream(msg) else this._onmessage(msg) } // Internal handler of incoming message msgs PacketStream.prototype._onmessage = function (msg) { if (this.opts && 'function' === typeof this.opts.message) this.opts.message(msg.value) } // Internal handler of incoming request msgs PacketStream.prototype._onrequest = function (msg) { var rid = msg.req*-1 if(msg.req < 0) { // A incoming response if (typeof this._requests[rid] == 'function') this._requests[rid]( msg.end ? msg.value: null, msg.end ? null : msg.value ) } else { // An incoming request if (this.opts && typeof this.opts.request == 'function') { var once = false var self = this this.opts.request(msg.value, function (err, value) { if(once) throw new Error('cb called twice from local api') once = true if(err) self.read({ value: flat(err), end: true, req: rid }) else self.read({ value: value, end: false, req: rid }) self._maybedone() }) } else { if (this.ended) { var err = (this.ended === true) ? new Error('unexpected end of parent stream') : this.ended this.read({ value: flat(err), end: true, stream: false, req: rid }) } else this.read({ value: { message: 'Unable to handle requests', name: 'NO_REQUEST_HANDLER', stack: null }, end: true, stream: false, req: rid }) this._maybedone() } } } // Internal handler of incoming stream msgs PacketStream.prototype._onstream = function (msg) { if(msg.req < 0) { // Incoming stream data var rid = msg.req*-1 var outs = this._outstreams[rid] if (!outs) return console.error('no stream for incoming msg', msg) if (msg.end) { if (outs.writeEnd) delete this._outstreams[rid] outs.readEnd = true outs.read(null, msg.value) this._maybedone() } else outs.read(msg.value) } else { // Incoming stream request var rid = msg.req var ins = this._instreams[rid] if (!ins) { // New stream var self = this ins = this._instreams[rid] = new PacketStreamSubstream(rid*-1, this, function() { delete self._instreams[rid] }) if (this.opts && typeof this.opts.stream == 'function') this.opts.stream(ins) } if (!ins.read) return console.error('no .read for stream:', ins.id, 'dropped:', msg) if (msg.end) { if (ins.writeEnd) delete this._instreams[rid] ins.readEnd = true ins.read(null, msg.value) this._maybedone() } else ins.read(msg.value) } } function PacketStreamSubstream (id, ps, remove) { this.id = id this.read = null // must release, may capture `this` this.writeEnd = null this.readEnd = null this._ps = ps // must release, may capture `this` this._remove = remove // must release, may capture `this` this._seq_counter = 1 } PacketStreamSubstream.prototype.write = function (data, err) { if (err) { this.writeEnd = err var ps = this._ps if (ps) { ps.read({ req: this.id, stream: true, end: true, value: flat(err) }) if (this.readEnd) this.destroy() ps._maybedone() } } else { if (this._ps) this._ps.read({ req: this.id, stream: true, end: false, value: data }) } } // Send the `end` message for the substream PacketStreamSubstream.prototype.end = function (err) { this.write(null, flat(err || true)) } PacketStreamSubstream.prototype.destroy = function (err) { if (!this.writeEnd) { this.writeEnd = true if (!this.readEnd) { this.readEnd = true try { // catch errors to ensure cleanup this.read(null, err) } catch (e) { console.error('Exception thrown by PacketStream substream end handler', e) console.error(e.stack) } } this.write(null, err) } else if (!this.readEnd) { this.readEnd = true try { // catch errors to ensure cleanup this.read(null, err) } catch (e) { console.error('Exception thrown by PacketStream substream end handler', e) console.error(e.stack) } } // deallocate if (this._ps) { this._remove() this._remove = null this.read = closedread this._ps = null } } },{}],285:[function(require,module,exports){ module.exports={"2.16.840.1.101.3.4.1.1": "aes-128-ecb", "2.16.840.1.101.3.4.1.2": "aes-128-cbc", "2.16.840.1.101.3.4.1.3": "aes-128-ofb", "2.16.840.1.101.3.4.1.4": "aes-128-cfb", "2.16.840.1.101.3.4.1.21": "aes-192-ecb", "2.16.840.1.101.3.4.1.22": "aes-192-cbc", "2.16.840.1.101.3.4.1.23": "aes-192-ofb", "2.16.840.1.101.3.4.1.24": "aes-192-cfb", "2.16.840.1.101.3.4.1.41": "aes-256-ecb", "2.16.840.1.101.3.4.1.42": "aes-256-cbc", "2.16.840.1.101.3.4.1.43": "aes-256-ofb", "2.16.840.1.101.3.4.1.44": "aes-256-cfb" } },{}],286:[function(require,module,exports){ // from https://github.com/indutny/self-signed/blob/gh-pages/lib/asn1.js // Fedor, you are amazing. var asn1 = require('asn1.js') var RSAPrivateKey = asn1.define('RSAPrivateKey', function () { this.seq().obj( this.key('version').int(), this.key('modulus').int(), this.key('publicExponent').int(), this.key('privateExponent').int(), this.key('prime1').int(), this.key('prime2').int(), this.key('exponent1').int(), this.key('exponent2').int(), this.key('coefficient').int() ) }) exports.RSAPrivateKey = RSAPrivateKey var RSAPublicKey = asn1.define('RSAPublicKey', function () { this.seq().obj( this.key('modulus').int(), this.key('publicExponent').int() ) }) exports.RSAPublicKey = RSAPublicKey var PublicKey = asn1.define('SubjectPublicKeyInfo', function () { this.seq().obj( this.key('algorithm').use(AlgorithmIdentifier), this.key('subjectPublicKey').bitstr() ) }) exports.PublicKey = PublicKey var AlgorithmIdentifier = asn1.define('AlgorithmIdentifier', function () { this.seq().obj( this.key('algorithm').objid(), this.key('none').null_().optional(), this.key('curve').objid().optional(), this.key('params').seq().obj( this.key('p').int(), this.key('q').int(), this.key('g').int() ).optional() ) }) var PrivateKeyInfo = asn1.define('PrivateKeyInfo', function () { this.seq().obj( this.key('version').int(), this.key('algorithm').use(AlgorithmIdentifier), this.key('subjectPrivateKey').octstr() ) }) exports.PrivateKey = PrivateKeyInfo var EncryptedPrivateKeyInfo = asn1.define('EncryptedPrivateKeyInfo', function () { this.seq().obj( this.key('algorithm').seq().obj( this.key('id').objid(), this.key('decrypt').seq().obj( this.key('kde').seq().obj( this.key('id').objid(), this.key('kdeparams').seq().obj( this.key('salt').octstr(), this.key('iters').int() ) ), this.key('cipher').seq().obj( this.key('algo').objid(), this.key('iv').octstr() ) ) ), this.key('subjectPrivateKey').octstr() ) }) exports.EncryptedPrivateKey = EncryptedPrivateKeyInfo var DSAPrivateKey = asn1.define('DSAPrivateKey', function () { this.seq().obj( this.key('version').int(), this.key('p').int(), this.key('q').int(), this.key('g').int(), this.key('pub_key').int(), this.key('priv_key').int() ) }) exports.DSAPrivateKey = DSAPrivateKey exports.DSAparam = asn1.define('DSAparam', function () { this.int() }) var ECPrivateKey = asn1.define('ECPrivateKey', function () { this.seq().obj( this.key('version').int(), this.key('privateKey').octstr(), this.key('parameters').optional().explicit(0).use(ECParameters), this.key('publicKey').optional().explicit(1).bitstr() ) }) exports.ECPrivateKey = ECPrivateKey var ECParameters = asn1.define('ECParameters', function () { this.choice({ namedCurve: this.objid() }) }) exports.signature = asn1.define('signature', function () { this.seq().obj( this.key('r').int(), this.key('s').int() ) }) },{"asn1.js":1}],287:[function(require,module,exports){ (function (Buffer){ // adapted from https://github.com/apatil/pemstrip var findProc = /Proc-Type: 4,ENCRYPTED\r?\nDEK-Info: AES-((?:128)|(?:192)|(?:256))-CBC,([0-9A-H]+)\r?\n\r?\n([0-9A-z\n\r\+\/\=]+)\r?\n/m var startRegex = /^-----BEGIN (.*) KEY-----\r?\n/m var fullRegex = /^-----BEGIN (.*) KEY-----\r?\n([0-9A-z\n\r\+\/\=]+)\r?\n-----END \1 KEY-----$/m var evp = require('evp_bytestokey') var ciphers = require('browserify-aes') module.exports = function (okey, password) { var key = okey.toString() var match = key.match(findProc) var decrypted if (!match) { var match2 = key.match(fullRegex) decrypted = new Buffer(match2[2].replace(/\r?\n/g, ''), 'base64') } else { var suite = 'aes' + match[1] var iv = new Buffer(match[2], 'hex') var cipherText = new Buffer(match[3].replace(/\r?\n/g, ''), 'base64') var cipherKey = evp(password, iv.slice(0, 8), parseInt(match[1], 10)).key var out = [] var cipher = ciphers.createDecipheriv(suite, cipherKey, iv) out.push(cipher.update(cipherText)) out.push(cipher.final()) decrypted = Buffer.concat(out) } var tag = key.match(startRegex)[1] + ' KEY' return { tag: tag, data: decrypted } } }).call(this,require("buffer").Buffer) },{"browserify-aes":36,"buffer":61,"evp_bytestokey":145}],288:[function(require,module,exports){ (function (Buffer){ var asn1 = require('./asn1') var aesid = require('./aesid.json') var fixProc = require('./fixProc') var ciphers = require('browserify-aes') var compat = require('pbkdf2') module.exports = parseKeys function parseKeys (buffer) { var password if (typeof buffer === 'object' && !Buffer.isBuffer(buffer)) { password = buffer.passphrase buffer = buffer.key } if (typeof buffer === 'string') { buffer = new Buffer(buffer) } var stripped = fixProc(buffer, password) var type = stripped.tag var data = stripped.data var subtype, ndata switch (type) { case 'PUBLIC KEY': ndata = asn1.PublicKey.decode(data, 'der') subtype = ndata.algorithm.algorithm.join('.') switch (subtype) { case '1.2.840.113549.1.1.1': return asn1.RSAPublicKey.decode(ndata.subjectPublicKey.data, 'der') case '1.2.840.10045.2.1': ndata.subjectPrivateKey = ndata.subjectPublicKey return { type: 'ec', data: ndata } case '1.2.840.10040.4.1': ndata.algorithm.params.pub_key = asn1.DSAparam.decode(ndata.subjectPublicKey.data, 'der') return { type: 'dsa', data: ndata.algorithm.params } default: throw new Error('unknown key id ' + subtype) } throw new Error('unknown key type ' + type) case 'ENCRYPTED PRIVATE KEY': data = asn1.EncryptedPrivateKey.decode(data, 'der') data = decrypt(data, password) // falls through case 'PRIVATE KEY': ndata = asn1.PrivateKey.decode(data, 'der') subtype = ndata.algorithm.algorithm.join('.') switch (subtype) { case '1.2.840.113549.1.1.1': return asn1.RSAPrivateKey.decode(ndata.subjectPrivateKey, 'der') case '1.2.840.10045.2.1': return { curve: ndata.algorithm.curve, privateKey: asn1.ECPrivateKey.decode(ndata.subjectPrivateKey, 'der').privateKey } case '1.2.840.10040.4.1': ndata.algorithm.params.priv_key = asn1.DSAparam.decode(ndata.subjectPrivateKey, 'der') return { type: 'dsa', params: ndata.algorithm.params } default: throw new Error('unknown key id ' + subtype) } throw new Error('unknown key type ' + type) case 'RSA PUBLIC KEY': return asn1.RSAPublicKey.decode(data, 'der') case 'RSA PRIVATE KEY': return asn1.RSAPrivateKey.decode(data, 'der') case 'DSA PRIVATE KEY': return { type: 'dsa', params: asn1.DSAPrivateKey.decode(data, 'der') } case 'EC PRIVATE KEY': data = asn1.ECPrivateKey.decode(data, 'der') return { curve: data.parameters.value, privateKey: data.privateKey } default: throw new Error('unknown key type ' + type) } } parseKeys.signature = asn1.signature function decrypt (data, password) { var salt = data.algorithm.decrypt.kde.kdeparams.salt var iters = parseInt(data.algorithm.decrypt.kde.kdeparams.iters.toString(), 10) var algo = aesid[data.algorithm.decrypt.cipher.algo.join('.')] var iv = data.algorithm.decrypt.cipher.iv var cipherText = data.subjectPrivateKey var keylen = parseInt(algo.split('-')[1], 10) / 8 var key = compat.pbkdf2Sync(password, salt, iters, keylen) var cipher = ciphers.createDecipheriv(algo, key, iv) var out = [] out.push(cipher.update(cipherText)) out.push(cipher.final()) return Buffer.concat(out) } }).call(this,require("buffer").Buffer) },{"./aesid.json":285,"./asn1":286,"./fixProc":287,"browserify-aes":36,"buffer":61,"pbkdf2":292}],289:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015 Titus Wormer * @license MIT * @module parse-entities * @fileoverview Parse HTML character references: fast, spec-compliant, * positional information. */ 'use strict'; /* eslint-env commonjs */ /* * Dependencies. */ var characterEntities = require('character-entities'); var legacy = require('character-entities-legacy'); var invalid = require('character-reference-invalid'); /* * Methods. */ var fromCharCode = String.fromCharCode; var has = Object.prototype.hasOwnProperty; var noop = Function.prototype; /* * Reference types. */ var NAMED = 'named'; var HEXADECIMAL = 'hexadecimal'; var DECIMAL = 'decimal'; /* * Map of bases. */ var BASE = {}; BASE[HEXADECIMAL] = 16; BASE[DECIMAL] = 10; /* * Warning messages. */ var NUMERIC_REFERENCE = 'Numeric character references'; var NAMED_REFERENCE = 'Named character references'; var TERMINATED = ' must be terminated by a semicolon'; var VOID = ' cannot be empty'; var NAMED_NOT_TERMINATED = 1; var NUMERIC_NOT_TERMINATED = 2; var NAMED_EMPTY = 3; var NUMERIC_EMPTY = 4; var NAMED_UNKNOWN = 5; var NUMERIC_DISALLOWED = 6; var NUMERIC_PROHIBITED = 7; var MESSAGES = {}; MESSAGES[NAMED_NOT_TERMINATED] = NAMED_REFERENCE + TERMINATED; MESSAGES[NUMERIC_NOT_TERMINATED] = NUMERIC_REFERENCE + TERMINATED; MESSAGES[NAMED_EMPTY] = NAMED_REFERENCE + VOID; MESSAGES[NUMERIC_EMPTY] = NUMERIC_REFERENCE + VOID; MESSAGES[NAMED_UNKNOWN] = NAMED_REFERENCE + ' must be known'; MESSAGES[NUMERIC_DISALLOWED] = NUMERIC_REFERENCE + ' cannot be disallowed'; MESSAGES[NUMERIC_PROHIBITED] = NUMERIC_REFERENCE + ' cannot be outside the ' + 'permissible Unicode range'; /* * Characters. */ var REPLACEMENT = '\uFFFD'; var FORM_FEED = '\f'; var AMPERSAND = '&'; var OCTOTHORP = '#'; var SEMICOLON = ';'; var NEWLINE = '\n'; var X_LOWER = 'x'; var X_UPPER = 'X'; var SPACE = ' '; var LESS_THAN = '<'; var EQUAL = '='; var EMPTY = ''; var TAB = '\t'; /** * Get the character-code at the first indice in * `character`. * * @param {string} character - Value. * @return {number} - Character-code at the first indice * in `character`. */ function charCode(character) { return character.charCodeAt(0); } /** * Check whether `character` is a decimal. * * @param {string} character - Value. * @return {boolean} - Whether `character` is a decimal. */ function isDecimal(character) { var code = charCode(character); return code >= 48 /* 0 */ && code <= 57 /* 9 */; } /** * Check whether `character` is a hexadecimal. * * @param {string} character - Value. * @return {boolean} - Whether `character` is a * hexadecimal. */ function isHexadecimal(character) { var code = charCode(character); return (code >= 48 /* 0 */ && code <= 57 /* 9 */) || (code >= 65 /* A */ && code <= 70 /* F */) || (code >= 97 /* a */ && code <= 102 /* f */); } /** * Check whether `character` is an alphanumeric. * * @param {string} character - Value. * @return {boolean} - Whether `character` is an * alphanumeric. */ function isAlphanumeric(character) { var code = charCode(character); return (code >= 48 /* 0 */ && code <= 57 /* 9 */) || (code >= 65 /* A */ && code <= 90 /* Z */) || (code >= 97 /* a */ && code <= 122 /* z */); } /** * Check whether `character` is outside the permissible * unicode range. * * @param {number} characterCode - Value. * @return {boolean} - Whether `character` is an * outside the permissible unicode range. */ function isProhibited(characterCode) { return (characterCode >= 0xD800 && characterCode <= 0xDFFF) || (characterCode > 0x10FFFF); } /** * Check whether `character` is disallowed. * * @param {number} characterCode - Value. * @return {boolean} - Whether `character` is disallowed. */ function isWarning(characterCode) { return (characterCode >= 0x0001 && characterCode <= 0x0008) || (characterCode >= 0x000D && characterCode <= 0x001F) || (characterCode >= 0x007F && characterCode <= 0x009F) || (characterCode >= 0xFDD0 && characterCode <= 0xFDEF) || characterCode === 0x000B || characterCode === 0xFFFE || characterCode === 0xFFFF || characterCode === 0x1FFFE || characterCode === 0x1FFFF || characterCode === 0x2FFFE || characterCode === 0x2FFFF || characterCode === 0x3FFFE || characterCode === 0x3FFFF || characterCode === 0x4FFFE || characterCode === 0x4FFFF || characterCode === 0x5FFFE || characterCode === 0x5FFFF || characterCode === 0x6FFFE || characterCode === 0x6FFFF || characterCode === 0x7FFFE || characterCode === 0x7FFFF || characterCode === 0x8FFFE || characterCode === 0x8FFFF || characterCode === 0x9FFFE || characterCode === 0x9FFFF || characterCode === 0xAFFFE || characterCode === 0xAFFFF || characterCode === 0xBFFFE || characterCode === 0xBFFFF || characterCode === 0xCFFFE || characterCode === 0xCFFFF || characterCode === 0xDFFFE || characterCode === 0xDFFFF || characterCode === 0xEFFFE || characterCode === 0xEFFFF || characterCode === 0xFFFFE || characterCode === 0xFFFFF || characterCode === 0x10FFFE || characterCode === 0x10FFFF; } /* * Map of types to tests. Each type of character reference * accepts different characters. This test is used to * detect whether a reference has ended (as the semicolon * is not strictly needed). */ var TESTS = {}; TESTS[NAMED] = isAlphanumeric; TESTS[DECIMAL] = isDecimal; TESTS[HEXADECIMAL] = isHexadecimal; /** * Parse entities. * * @param {string} value - Value to tokenise. * @param {Object?} [settings] - Configuration. */ function parse(value, settings) { var additional = settings.additional; var handleText = settings.text; var handleReference = settings.reference; var handleWarning = settings.warning; var textContext = settings.textContext; var referenceContext = settings.referenceContext; var warningContext = settings.warningContext; var pos = settings.position; var indent = settings.indent || []; var length = value.length; var index = 0; var lines = -1; var column = pos.column || 1; var line = pos.line || 1; var queue = EMPTY; var result = []; var entityCharacters; var terminated; var characters; var character; var reference; var following; var warning; var reason; var output; var entity; var begin; var start; var type; var test; var prev; var next; var diff; var end; /** * Get current position. * * @return {Object} - Positional information of a * single point. */ function now() { return { 'line': line, 'column': column, 'offset': index + (pos.offset || 0) }; } /** * “Throw” a parse-error: a warning. * * @param {number} code - Identifier of reason for * failing. * @param {number} offset - Offset in characters from * the current position point at which the * parse-error ocurred, cannot point past newlines. */ function parseError(code, offset) { var position = now(); position.column += offset; position.offset += offset; handleWarning.call(warningContext, MESSAGES[code], position, code); } /** * Get character at position. * * @param {number} position - Indice of character in `value`. * @return {string} - Character at `position` in * `value`. */ function at(position) { return value.charAt(position); } /** * Flush `queue` (normal text). Macro invoked before * each entity and at the end of `value`. * * Does nothing when `queue` is empty. */ function flush() { if (queue) { result.push(queue); if (handleText) { handleText.call(textContext, queue, { 'start': prev, 'end': now() }); } queue = EMPTY; } } /* * Cache the current point. */ prev = now(); /* * Wrap `handleWarning`. */ warning = handleWarning ? parseError : noop; /* * Ensure the algorithm walks over the first character * and the end (inclusive). */ index--; length++; while (++index < length) { /* * If the previous character was a newline. */ if (character === NEWLINE) { column = indent[lines] || 1; } character = at(index); /* * Handle anything other than an ampersand, * including newlines and EOF. */ if (character !== AMPERSAND) { if (character === NEWLINE) { line++; lines++; column = 0; } if (character) { queue += character; column++; } else { flush(); } } else { following = at(index + 1); /* * The behaviour depends on the identity of the next character. */ if ( following === TAB || following === NEWLINE || following === FORM_FEED || following === SPACE || following === LESS_THAN || following === AMPERSAND || following === EMPTY || (additional && following === additional) ) { /* * Not a character reference. No characters * are consumed, and nothing is returned. * This is not an error, either. */ queue += character; column++; continue; } start = begin = end = index + 1; /* * Numerical entity. */ if (following !== OCTOTHORP) { type = NAMED; } else { end = ++begin; /* * The behaviour further depends on the * character after the U+0023 NUMBER SIGN. */ following = at(end); if (following === X_LOWER || following === X_UPPER) { /* * ASCII hex digits. */ type = HEXADECIMAL; end = ++begin; } else { /* * ASCII digits. */ type = DECIMAL; } } entityCharacters = entity = characters = EMPTY; test = TESTS[type]; end--; while (++end < length) { following = at(end); if (!test(following)) { break; } characters += following; /* * Check if we can match a legacy named * reference. If so, we cache that as the * last viable named reference. This * ensures we do not need to walk backwards * later. */ if ( type === NAMED && has.call(legacy, characters) ) { entityCharacters = characters; entity = legacy[characters]; } } terminated = at(end) === SEMICOLON; if (terminated) { end++; if ( type === NAMED && has.call(characterEntities, characters) ) { entityCharacters = characters; entity = characterEntities[characters]; } } diff = 1 + end - start; if (!characters) { /* * An empty (possible) entity is valid, unless * its numeric (thus an ampersand followed by * an octothorp). */ if (type !== NAMED) { warning(NUMERIC_EMPTY, diff); } } else if (type === NAMED) { /* * An ampersand followed by anything * unknown, and not terminated, is invalid. */ if (terminated && !entity) { warning(NAMED_UNKNOWN, 1); } else { /* * If theres something after an entity * name which is not known, cap the * reference. */ if (entityCharacters !== characters) { end = begin + entityCharacters.length; diff = 1 + end - begin; terminated = false; } /* * If the reference is not terminated, * warn. */ if (!terminated) { reason = entityCharacters ? NAMED_NOT_TERMINATED : NAMED_EMPTY; if (!settings.attribute) { warning(reason, diff); } else { following = at(end); if (following === EQUAL) { warning(reason, diff); entity = null; } else if (isAlphanumeric(following)) { entity = null; } else { warning(reason, diff); } } } } reference = entity; } else { if (!terminated) { /* * All non-terminated numeric entities are * not rendered, and trigger a warning. */ warning(NUMERIC_NOT_TERMINATED, diff); } /* * When terminated and number, parse as * either hexadecimal or decimal. */ reference = parseInt(characters, BASE[type]); /* * Trigger a warning when the parsed number * is prohibited, and replace with * replacement character. */ if (isProhibited(reference)) { warning(NUMERIC_PROHIBITED, diff); reference = REPLACEMENT; } else if (reference in invalid) { /* * Trigger a warning when the parsed number * is disallowed, and replace by an * alternative. */ warning(NUMERIC_DISALLOWED, diff); reference = invalid[reference]; } else { /* * Parse the number. */ output = EMPTY; /* * Trigger a warning when the parsed * number should not be used. */ if (isWarning(reference)) { warning(NUMERIC_DISALLOWED, diff); } /* * Stringify the number. */ if (reference > 0xFFFF) { reference -= 0x10000; output += fromCharCode( reference >>> 10 & 0x3FF | 0xD800 ); reference = 0xDC00 | reference & 0x3FF; } reference = output + fromCharCode(reference); } } /* * If we could not find a reference, queue the * checked characters (as normal characters), * and move the pointer to their end. This is * possible because we can be certain neither * newlines nor ampersands are included. */ if (!reference) { characters = value.slice(start - 1, end); queue += characters; column += characters.length; index = end - 1; } else { /* * Found it! First eat the queued * characters as normal text, then eat * an entity. */ flush(); prev = now(); index = end - 1; column += end - start + 1; result.push(reference); next = now(); next.offset++; if (handleReference) { handleReference.call(referenceContext, reference, { 'start': prev, 'end': next }, value.slice(start - 1, end)); } prev = next; } } } /* * Return the reduced nodes, and any possible warnings. */ return result.join(EMPTY); } var defaults = { 'warning': null, 'reference': null, 'text': null, 'warningContext': null, 'referenceContext': null, 'textContext': null, 'position': {}, 'additional': null, 'attribute': false }; /** * Wrap to ensure clean parameters are given to `parse`. * * @param {string} value - Value with entities. * @param {Object?} [options] - Configuration. */ function wrapper(value, options) { var settings = {}; var key; if (!options) { options = {}; } for (key in defaults) { settings[key] = options[key] || defaults[key]; } if (settings.position.indent || settings.position.start) { settings.indent = settings.position.indent || []; settings.position = settings.position.start; } return parse(value, settings); } /* * Expose. */ module.exports = wrapper; },{"character-entities":75,"character-entities-legacy":73,"character-reference-invalid":77}],290:[function(require,module,exports){ (function (process){ // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. // resolves . and .. elements in a path array with directory names there // must be no slashes, empty elements, or device names (c:\) in the array // (so also no leading and trailing slashes - it does not distinguish // relative and absolute paths) function normalizeArray(parts, allowAboveRoot) { // if the path tries to go above the root, `up` ends up > 0 var up = 0; for (var i = parts.length - 1; i >= 0; i--) { var last = parts[i]; if (last === '.') { parts.splice(i, 1); } else if (last === '..') { parts.splice(i, 1); up++; } else if (up) { parts.splice(i, 1); up--; } } // if the path is allowed to go above the root, restore leading ..s if (allowAboveRoot) { for (; up--; up) { parts.unshift('..'); } } return parts; } // Split a filename into [root, dir, basename, ext], unix version // 'root' is just a slash, or nothing. var splitPathRe = /^(\/?|)([\s\S]*?)((?:\.{1,2}|[^\/]+?|)(\.[^.\/]*|))(?:[\/]*)$/; var splitPath = function(filename) { return splitPathRe.exec(filename).slice(1); }; // path.resolve([from ...], to) // posix version exports.resolve = function() { var resolvedPath = '', resolvedAbsolute = false; for (var i = arguments.length - 1; i >= -1 && !resolvedAbsolute; i--) { var path = (i >= 0) ? arguments[i] : process.cwd(); // Skip empty and invalid entries if (typeof path !== 'string') { throw new TypeError('Arguments to path.resolve must be strings'); } else if (!path) { continue; } resolvedPath = path + '/' + resolvedPath; resolvedAbsolute = path.charAt(0) === '/'; } // At this point the path should be resolved to a full absolute path, but // handle relative paths to be safe (might happen when process.cwd() fails) // Normalize the path resolvedPath = normalizeArray(filter(resolvedPath.split('/'), function(p) { return !!p; }), !resolvedAbsolute).join('/'); return ((resolvedAbsolute ? '/' : '') + resolvedPath) || '.'; }; // path.normalize(path) // posix version exports.normalize = function(path) { var isAbsolute = exports.isAbsolute(path), trailingSlash = substr(path, -1) === '/'; // Normalize the path path = normalizeArray(filter(path.split('/'), function(p) { return !!p; }), !isAbsolute).join('/'); if (!path && !isAbsolute) { path = '.'; } if (path && trailingSlash) { path += '/'; } return (isAbsolute ? '/' : '') + path; }; // posix version exports.isAbsolute = function(path) { return path.charAt(0) === '/'; }; // posix version exports.join = function() { var paths = Array.prototype.slice.call(arguments, 0); return exports.normalize(filter(paths, function(p, index) { if (typeof p !== 'string') { throw new TypeError('Arguments to path.join must be strings'); } return p; }).join('/')); }; // path.relative(from, to) // posix version exports.relative = function(from, to) { from = exports.resolve(from).substr(1); to = exports.resolve(to).substr(1); function trim(arr) { var start = 0; for (; start < arr.length; start++) { if (arr[start] !== '') break; } var end = arr.length - 1; for (; end >= 0; end--) { if (arr[end] !== '') break; } if (start > end) return []; return arr.slice(start, end - start + 1); } var fromParts = trim(from.split('/')); var toParts = trim(to.split('/')); var length = Math.min(fromParts.length, toParts.length); var samePartsLength = length; for (var i = 0; i < length; i++) { if (fromParts[i] !== toParts[i]) { samePartsLength = i; break; } } var outputParts = []; for (var i = samePartsLength; i < fromParts.length; i++) { outputParts.push('..'); } outputParts = outputParts.concat(toParts.slice(samePartsLength)); return outputParts.join('/'); }; exports.sep = '/'; exports.delimiter = ':'; exports.dirname = function(path) { var result = splitPath(path), root = result[0], dir = result[1]; if (!root && !dir) { // No dirname whatsoever return '.'; } if (dir) { // It has a dirname, strip trailing slash dir = dir.substr(0, dir.length - 1); } return root + dir; }; exports.basename = function(path, ext) { var f = splitPath(path)[2]; // TODO: make this comparison case-insensitive on windows? if (ext && f.substr(-1 * ext.length) === ext) { f = f.substr(0, f.length - ext.length); } return f; }; exports.extname = function(path) { return splitPath(path)[3]; }; function filter (xs, f) { if (xs.filter) return xs.filter(f); var res = []; for (var i = 0; i < xs.length; i++) { if (f(xs[i], i, xs)) res.push(xs[i]); } return res; } // String.prototype.substr - negative index don't work in IE8 var substr = 'ab'.substr(-1) === 'b' ? function (str, start, len) { return str.substr(start, len) } : function (str, start, len) { if (start < 0) start = str.length + start; return str.substr(start, len); } ; }).call(this,require('_process')) },{"_process":295}],291:[function(require,module,exports){ (function (process){ 'use strict'; function posix(path) { return path.charAt(0) === '/'; }; function win32(path) { // https://github.com/joyent/node/blob/b3fcc245fb25539909ef1d5eaa01dbf92e168633/lib/path.js#L56 var splitDeviceRe = /^([a-zA-Z]:|[\\\/]{2}[^\\\/]+[\\\/]+[^\\\/]+)?([\\\/])?([\s\S]*?)$/; var result = splitDeviceRe.exec(path); var device = result[1] || ''; var isUnc = !!device && device.charAt(1) !== ':'; // UNC paths are always absolute return !!result[2] || isUnc; }; module.exports = process.platform === 'win32' ? win32 : posix; module.exports.posix = posix; module.exports.win32 = win32; }).call(this,require('_process')) },{"_process":295}],292:[function(require,module,exports){ (function (Buffer){ var createHmac = require('create-hmac') var MAX_ALLOC = Math.pow(2, 30) - 1 // default in iojs exports.pbkdf2 = pbkdf2 function pbkdf2 (password, salt, iterations, keylen, digest, callback) { if (typeof digest === 'function') { callback = digest digest = undefined } if (typeof callback !== 'function') { throw new Error('No callback provided to pbkdf2') } var result = pbkdf2Sync(password, salt, iterations, keylen, digest) setTimeout(function () { callback(undefined, result) }) } exports.pbkdf2Sync = pbkdf2Sync function pbkdf2Sync (password, salt, iterations, keylen, digest) { if (typeof iterations !== 'number') { throw new TypeError('Iterations not a number') } if (iterations < 0) { throw new TypeError('Bad iterations') } if (typeof keylen !== 'number') { throw new TypeError('Key length not a number') } if (keylen < 0 || keylen > MAX_ALLOC) { throw new TypeError('Bad key length') } digest = digest || 'sha1' if (!Buffer.isBuffer(password)) password = new Buffer(password, 'binary') if (!Buffer.isBuffer(salt)) salt = new Buffer(salt, 'binary') var hLen var l = 1 var DK = new Buffer(keylen) var block1 = new Buffer(salt.length + 4) salt.copy(block1, 0, 0, salt.length) var r var T for (var i = 1; i <= l; i++) { block1.writeUInt32BE(i, salt.length) var U = createHmac(digest, password).update(block1).digest() if (!hLen) { hLen = U.length T = new Buffer(hLen) l = Math.ceil(keylen / hLen) r = keylen - (l - 1) * hLen } U.copy(T, 0, 0, hLen) for (var j = 1; j < iterations; j++) { U = createHmac(digest, password).update(U).digest() for (var k = 0; k < hLen; k++) { T[k] ^= U[k] } } var destPos = (i - 1) * hLen var len = (i === l ? r : hLen) T.copy(DK, destPos, 0, len) } return DK } }).call(this,require("buffer").Buffer) },{"buffer":61,"create-hmac":109}],293:[function(require,module,exports){ (function (Buffer){ var sodium = require('chloride') var crypto = require('crypto') var scalarmult = sodium.crypto_scalarmult var box = sodium.crypto_box_easy var secretbox = sodium.crypto_secretbox_easy var secretbox_open = sodium.crypto_secretbox_open_easy var keypair = sodium.crypto_box_keypair var concat = Buffer.concat function randombytes(n) { return crypto.randomBytes(n) } const MAX = 7 exports.multibox = function (msg, recipients) { if(recipients.length > MAX) throw new Error('max recipients is:'+MAX+' found:'+recipients.length) var nonce = randombytes(24) var key = randombytes(32) var onetime = keypair() var _key = concat([new Buffer([recipients.length & MAX]), key]) return concat([ nonce, onetime.publicKey, concat(recipients.map(function (r_pk, i) { return secretbox(_key, nonce, scalarmult(onetime.secretKey, r_pk)) })), secretbox(msg, nonce, key) ]) } function get_key(ctxt, my_key) { } exports.multibox_open = function (ctxt, sk) { //, groups... var nonce = ctxt.slice(0, 24) var onetime_pk = ctxt.slice(24, 24+32) var my_key = scalarmult(sk, onetime_pk) var _key, key, length, start = 24+32, size = 32+1+16 for(var i = 0; i <= MAX; i++) { var s = start+size*i if(s + size > (ctxt.length - 16)) continue _key = secretbox_open(ctxt.slice(s, s + size), nonce, my_key) if(_key) { length = _key[0] key = _key.slice(1) continue } } if(!key) return return secretbox_open(ctxt.slice(start+length*size), nonce, key) } }).call(this,require("buffer").Buffer) },{"buffer":61,"chloride":80,"crypto":110}],294:[function(require,module,exports){ (function (process){ 'use strict'; if (!process.version || process.version.indexOf('v0.') === 0 || process.version.indexOf('v1.') === 0 && process.version.indexOf('v1.8.') !== 0) { module.exports = nextTick; } else { module.exports = process.nextTick; } function nextTick(fn) { var args = new Array(arguments.length - 1); var i = 0; while (i < args.length) { args[i++] = arguments[i]; } process.nextTick(function afterTick() { fn.apply(null, args); }); } }).call(this,require('_process')) },{"_process":295}],295:[function(require,module,exports){ // shim for using process in browser var process = module.exports = {}; var queue = []; var draining = false; var currentQueue; var queueIndex = -1; function cleanUpNextTick() { draining = false; if (currentQueue.length) { queue = currentQueue.concat(queue); } else { queueIndex = -1; } if (queue.length) { drainQueue(); } } function drainQueue() { if (draining) { return; } var timeout = setTimeout(cleanUpNextTick); draining = true; var len = queue.length; while(len) { currentQueue = queue; queue = []; while (++queueIndex < len) { if (currentQueue) { currentQueue[queueIndex].run(); } } queueIndex = -1; len = queue.length; } currentQueue = null; draining = false; clearTimeout(timeout); } process.nextTick = function (fun) { var args = new Array(arguments.length - 1); if (arguments.length > 1) { for (var i = 1; i < arguments.length; i++) { args[i - 1] = arguments[i]; } } queue.push(new Item(fun, args)); if (queue.length === 1 && !draining) { setTimeout(drainQueue, 0); } }; // v8 likes predictible objects function Item(fun, array) { this.fun = fun; this.array = array; } Item.prototype.run = function () { this.fun.apply(null, this.array); }; process.title = 'browser'; process.browser = true; process.env = {}; process.argv = []; process.version = ''; // empty string to avoid regexp issues process.versions = {}; function noop() {} process.on = noop; process.addListener = noop; process.once = noop; process.off = noop; process.removeListener = noop; process.removeAllListeners = noop; process.emit = noop; process.binding = function (name) { throw new Error('process.binding is not supported'); }; process.cwd = function () { return '/' }; process.chdir = function (dir) { throw new Error('process.chdir is not supported'); }; process.umask = function() { return 0; }; },{}],296:[function(require,module,exports){ arguments[4][196][0].apply(exports,arguments) },{"dup":196}],297:[function(require,module,exports){ exports.publicEncrypt = require('./publicEncrypt'); exports.privateDecrypt = require('./privateDecrypt'); exports.privateEncrypt = function privateEncrypt(key, buf) { return exports.publicEncrypt(key, buf, true); }; exports.publicDecrypt = function publicDecrypt(key, buf) { return exports.privateDecrypt(key, buf, true); }; },{"./privateDecrypt":299,"./publicEncrypt":300}],298:[function(require,module,exports){ (function (Buffer){ var createHash = require('create-hash'); module.exports = function (seed, len) { var t = new Buffer(''); var i = 0, c; while (t.length < len) { c = i2ops(i++); t = Buffer.concat([t, createHash('sha1').update(seed).update(c).digest()]); } return t.slice(0, len); }; function i2ops(c) { var out = new Buffer(4); out.writeUInt32BE(c,0); return out; } }).call(this,require("buffer").Buffer) },{"buffer":61,"create-hash":106}],299:[function(require,module,exports){ (function (Buffer){ var parseKeys = require('parse-asn1'); var mgf = require('./mgf'); var xor = require('./xor'); var bn = require('bn.js'); var crt = require('browserify-rsa'); var createHash = require('create-hash'); var withPublic = require('./withPublic'); module.exports = function privateDecrypt(private_key, enc, reverse) { var padding; if (private_key.padding) { padding = private_key.padding; } else if (reverse) { padding = 1; } else { padding = 4; } var key = parseKeys(private_key); var k = key.modulus.byteLength(); if (enc.length > k || new bn(enc).cmp(key.modulus) >= 0) { throw new Error('decryption error'); } var msg; if (reverse) { msg = withPublic(new bn(enc), key); } else { msg = crt(enc, key); } var zBuffer = new Buffer(k - msg.length); zBuffer.fill(0); msg = Buffer.concat([zBuffer, msg], k); if (padding === 4) { return oaep(key, msg); } else if (padding === 1) { return pkcs1(key, msg, reverse); } else if (padding === 3) { return msg; } else { throw new Error('unknown padding'); } }; function oaep(key, msg){ var n = key.modulus; var k = key.modulus.byteLength(); var mLen = msg.length; var iHash = createHash('sha1').update(new Buffer('')).digest(); var hLen = iHash.length; var hLen2 = 2 * hLen; if (msg[0] !== 0) { throw new Error('decryption error'); } var maskedSeed = msg.slice(1, hLen + 1); var maskedDb = msg.slice(hLen + 1); var seed = xor(maskedSeed, mgf(maskedDb, hLen)); var db = xor(maskedDb, mgf(seed, k - hLen - 1)); if (compare(iHash, db.slice(0, hLen))) { throw new Error('decryption error'); } var i = hLen; while (db[i] === 0) { i++; } if (db[i++] !== 1) { throw new Error('decryption error'); } return db.slice(i); } function pkcs1(key, msg, reverse){ var p1 = msg.slice(0, 2); var i = 2; var status = 0; while (msg[i++] !== 0) { if (i >= msg.length) { status++; break; } } var ps = msg.slice(2, i - 1); var p2 = msg.slice(i - 1, i); if ((p1.toString('hex') !== '0002' && !reverse) || (p1.toString('hex') !== '0001' && reverse)){ status++; } if (ps.length < 8) { status++; } if (status) { throw new Error('decryption error'); } return msg.slice(i); } function compare(a, b){ a = new Buffer(a); b = new Buffer(b); var dif = 0; var len = a.length; if (a.length !== b.length) { dif++; len = Math.min(a.length, b.length); } var i = -1; while (++i < len) { dif += (a[i] ^ b[i]); } return dif; } }).call(this,require("buffer").Buffer) },{"./mgf":298,"./withPublic":301,"./xor":302,"bn.js":29,"browserify-rsa":52,"buffer":61,"create-hash":106,"parse-asn1":288}],300:[function(require,module,exports){ (function (Buffer){ var parseKeys = require('parse-asn1'); var randomBytes = require('randombytes'); var createHash = require('create-hash'); var mgf = require('./mgf'); var xor = require('./xor'); var bn = require('bn.js'); var withPublic = require('./withPublic'); var crt = require('browserify-rsa'); var constants = { RSA_PKCS1_OAEP_PADDING: 4, RSA_PKCS1_PADDIN: 1, RSA_NO_PADDING: 3 }; module.exports = function publicEncrypt(public_key, msg, reverse) { var padding; if (public_key.padding) { padding = public_key.padding; } else if (reverse) { padding = 1; } else { padding = 4; } var key = parseKeys(public_key); var paddedMsg; if (padding === 4) { paddedMsg = oaep(key, msg); } else if (padding === 1) { paddedMsg = pkcs1(key, msg, reverse); } else if (padding === 3) { paddedMsg = new bn(msg); if (paddedMsg.cmp(key.modulus) >= 0) { throw new Error('data too long for modulus'); } } else { throw new Error('unknown padding'); } if (reverse) { return crt(paddedMsg, key); } else { return withPublic(paddedMsg, key); } }; function oaep(key, msg){ var k = key.modulus.byteLength(); var mLen = msg.length; var iHash = createHash('sha1').update(new Buffer('')).digest(); var hLen = iHash.length; var hLen2 = 2 * hLen; if (mLen > k - hLen2 - 2) { throw new Error('message too long'); } var ps = new Buffer(k - mLen - hLen2 - 2); ps.fill(0); var dblen = k - hLen - 1; var seed = randomBytes(hLen); var maskedDb = xor(Buffer.concat([iHash, ps, new Buffer([1]), msg], dblen), mgf(seed, dblen)); var maskedSeed = xor(seed, mgf(maskedDb, hLen)); return new bn(Buffer.concat([new Buffer([0]), maskedSeed, maskedDb], k)); } function pkcs1(key, msg, reverse){ var mLen = msg.length; var k = key.modulus.byteLength(); if (mLen > k - 11) { throw new Error('message too long'); } var ps; if (reverse) { ps = new Buffer(k - mLen - 3); ps.fill(0xff); } else { ps = nonZero(k - mLen - 3); } return new bn(Buffer.concat([new Buffer([0, reverse?1:2]), ps, new Buffer([0]), msg], k)); } function nonZero(len, crypto) { var out = new Buffer(len); var i = 0; var cache = randomBytes(len*2); var cur = 0; var num; while (i < len) { if (cur === cache.length) { cache = randomBytes(len*2); cur = 0; } num = cache[cur++]; if (num) { out[i++] = num; } } return out; } }).call(this,require("buffer").Buffer) },{"./mgf":298,"./withPublic":301,"./xor":302,"bn.js":29,"browserify-rsa":52,"buffer":61,"create-hash":106,"parse-asn1":288,"randombytes":403}],301:[function(require,module,exports){ (function (Buffer){ var bn = require('bn.js'); function withPublic(paddedMsg, key) { return new Buffer(paddedMsg .toRed(bn.mont(key.modulus)) .redPow(new bn(key.publicExponent)) .fromRed() .toArray()); } module.exports = withPublic; }).call(this,require("buffer").Buffer) },{"bn.js":29,"buffer":61}],302:[function(require,module,exports){ module.exports = function xor(a, b) { var len = a.length; var i = -1; while (++i < len) { a[i] ^= b[i]; } return a }; },{}],303:[function(require,module,exports){ function abortable(onEnd) { var aborted = false, reading = false, ended = false, _cb, _read function terminate (err) { if(onEnd) onEnd(ended === true ? null : ended) var cb = _cb; _cb = null if(cb) cb(ended) } function cancel () { ended = ended || true terminate(aborted || ended) _read(aborted, function (err) { if(_cb) _cb(err) }) } function reader (read) { _read = read return function (abort, cb) { _cb = cb if(abort) aborted = abort if(ended) return cb(ended) if(aborted) return reading = true read(abort, function (end, data) { reading = false if(aborted) return !abort && read(aborted, function () {}) if(!_cb) return var cb = _cb _cb = null if(end) { ended = end onEnd && onEnd(ended === true ? null : ended) cb(end) } else { cb(end, data) } }) } } reader.abort = function () { aborted = true if(ended) return cancel() } return reader } module.exports = abortable },{}],304:[function(require,module,exports){ (function (Buffer){ 'use strict' var sodium = require('chloride') var Reader = require('pull-reader') var increment = require('increment-buffer') var through = require('pull-through') var split = require('split-buffer') var isBuffer = Buffer.isBuffer var concat = Buffer.concat var box = sodium.crypto_secretbox_easy var unbox = sodium.crypto_secretbox_open_easy function unbox_detached (mac, boxed, nonce, key) { return sodium.crypto_secretbox_open_easy(concat([mac, boxed]), nonce, key) } var max = 1024*4 var NONCE_LEN = 24 var HEADER_LEN = 2+16+16 function isZeros(b) { for(var i = 0; i < b.length; i++) if(b[i] !== 0) return false return true } function randomSecret(n) { var rand = new Buffer(n) sodium.randombytes(rand) return rand } function copy (a) { var b = new Buffer(a.length) a.copy(b, 0, 0, a.length) return b } exports.createBoxStream = exports.createEncryptStream = function (key, init_nonce) { if(key.length === 56) { init_nonce = key.slice(32, 56) key = key.slice(0, 32) } else if(!(key.length === 32 && init_nonce.length === 24)) throw new Error('nonce must be 24 bytes') // we need two nonces because increment mutates, // and we need the next for the header, // and the next next nonce for the packet var nonce1 = copy(init_nonce), nonce2 = copy(init_nonce) var head = new Buffer(18) return through(function (data) { if('string' === typeof data) data = new Buffer(data, 'utf8') else if(!isBuffer(data)) return this.emit('error', new Error('must be buffer')) if(data.length === 0) return var input = split(data, max) for(var i = 0; i < input.length; i++) { head.writeUInt16BE(input[i].length, 0) var boxed = box(input[i], increment(nonce2), key) //write the mac into the header. boxed.copy(head, 2, 0, 16) this.queue(box(head, nonce1, key)) this.queue(boxed.slice(16, 16 + input[i].length)) increment(increment(nonce1)); increment(nonce2) } }, function (err) { if(err) return this.queue(null) //handle special-case of empty session //final header is same length as header except all zeros (inside box) var final = new Buffer(2+16); final.fill(0) this.queue(box(final, nonce1, key)) this.queue(null) }) } exports.createUnboxStream = exports.createDecryptStream = function (key, nonce) { if(key.length == 56) { nonce = key.slice(32, 56) key = key.slice(0, 32) } else if(!(key.length === 32 && nonce.length === 24)) throw new Error('nonce must be 24 bytes') var reader = Reader(), first = true, ended var first = true return function (read) { reader(read) return function (end, cb) { if(end) return reader.abort(end, cb) //use abort when the input was invalid, //but the source hasn't actually ended yet. function abort(err) { reader.abort(ended = err || true, cb) } if(ended) return cb(ended) reader.read(HEADER_LEN, function (err, cipherheader) { if(err === true) return cb(ended = new Error('unexpected hangup')) if(err) return cb(ended = err) var header = unbox(cipherheader, nonce, key) if(!header) return abort(new Error('invalid header')) //valid end of stream if(isZeros(header)) return cb(ended = true) var length = header.readUInt16BE(0) var mac = header.slice(2, 34) reader.read(length, function (err, cipherpacket) { if(err) return cb(ended = err) //recreate a valid packet //TODO: PR to sodium bindings for detached box/open var plainpacket = unbox_detached(mac, cipherpacket, increment(nonce), key) if(!plainpacket) return abort(new Error('invalid packet')) increment(nonce) cb(null, plainpacket) }) }) } } } }).call(this,require("buffer").Buffer) },{"buffer":61,"chloride":80,"increment-buffer":164,"pull-reader":372,"pull-through":386,"split-buffer":516}],305:[function(require,module,exports){ var noop = function () {} function abortAll(ary, abort, cb) { var n = ary.length if(!n) return cb(abort) ary.forEach(function (f) { if(f) f(abort, next) else next() }) function next() { if(--n) return cb(abort) } if(!n) next() } module.exports = function (streams) { return function (abort, cb) { ;(function next () { if(abort) abortAll(streams, abort, cb) else if(!streams.length) cb(true) else if(!streams[0]) streams.shift(), next() else streams[0](null, function (err, data) { if(err) { streams.shift() //drop the first, has already ended. if(err === true) next() else abortAll(streams, err, cb) } else cb(null, data) }) })() } } },{}],306:[function(require,module,exports){ exports.id = function (item) { return item } exports.prop = function (map) { if('string' == typeof map) { var key = map return function (data) { return data[key] } } return map } exports.tester = function (test) { if(!test) return exports.id if('object' === typeof test && 'function' === typeof test.test) return test.test.bind(test) return exports.prop(test) || exports.id } exports.addPipe = addPipe function addPipe(read) { if('function' !== typeof read) return read read.pipe = read.pipe || function (reader) { if('function' != typeof reader && 'function' != typeof reader.sink) throw new Error('must pipe to reader') var pipe = addPipe(reader.sink ? reader.sink(read) : reader(read)) return reader.source || pipe; } read.type = 'Source' return read } var Source = exports.Source = function Source (createRead) { function s() { var args = [].slice.call(arguments) return addPipe(createRead.apply(null, args)) } s.type = 'Source' return s } var Through = exports.Through = function (createRead) { return function () { var args = [].slice.call(arguments) var piped = [] function reader (read) { args.unshift(read) read = createRead.apply(null, args) while(piped.length) read = piped.shift()(read) return read //pipeing to from this reader should compose... } reader.pipe = function (read) { piped.push(read) if(read.type === 'Source') throw new Error('cannot pipe ' + reader.type + ' to Source') reader.type = read.type === 'Sink' ? 'Sink' : 'Through' return reader } reader.type = 'Through' return reader } } var Sink = exports.Sink = function Sink(createReader) { return function () { var args = [].slice.call(arguments) if(!createReader) throw new Error('must be createReader function') function s (read) { args.unshift(read) return createReader.apply(null, args) } s.type = 'Sink' return s } } exports.maybeSink = exports.maybeDrain = function (createSink, cb) { if(!cb) return Through(function (read) { var ended return function (close, cb) { if(close) return read(close, cb) if(ended) return cb(ended) createSink(function (err, data) { ended = err || true if(!err) cb(null, data) else cb(ended) }) (read) } })() return Sink(function (read) { return createSink(cb) (read) })() } },{}],307:[function(require,module,exports){ var Source = require('./source') var Sink = require('./sink') module.exports = function () { var source = Source() var sink = Sink() return { source: source, sink: sink, resolve: function (duplex) { source.resolve(duplex.source) sink.resolve(duplex.sink) } } } },{"./sink":309,"./source":310}],308:[function(require,module,exports){ exports.source = require('./source') exports.through = require('./through') exports.sink = require('./sink') exports.duplex = require('./duplex') },{"./duplex":307,"./sink":309,"./source":310,"./through":311}],309:[function(require,module,exports){ module.exports = function (stream) { var read, started = false, id = Math.random() function consume (_read) { if(!_read) throw new Error('must be passed a readable') read = _read if(started) stream(read) } consume.resolve = consume.ready = consume.start = function (_stream) { started = true; stream = _stream || stream if(read) stream(read) return consume } return consume } },{}],310:[function(require,module,exports){ module.exports = function () { var _read, _cb, abortCb, _end var read = function (end, cb) { if(!_read) { if(end) { _end = end abortCb = cb } else _cb = cb } else _read(end, cb) } read.resolve = function (read) { if(_read) throw new Error('already resolved') _read = read if(!_read) throw new Error('no read cannot resolve!' + _read) if(_cb) read(null, _cb) if(abortCb) read(_end, abortCb) } read.abort = function(err) { read.resolve(function (_, cb) { cb(err || true) }) } return read } },{}],311:[function(require,module,exports){ module.exports = function () { var read, reader, cb, abort, stream function delayed (_read) { //if we already have the stream, go! if(stream) return stream(_read) read = _read return function (_abort, _cb) { if(reader) reader(_abort, _cb) else abort = _abort, cb = _cb } } delayed.resolve = function (_stream) { if(stream) throw new Error('already resolved') stream = _stream if(!stream) throw new Error('resolve *must* be passed a transform stream') if(read) { reader = stream(read) if(cb) reader(abort, cb) } } return delayed } },{}],312:[function(require,module,exports){ (function (Buffer){ /* jshint node: true */ 'use strict'; var fs = require('fs'); var Decoder = require('pull-utf8-decoder') /** # pull-file This is a simple module which uses raw file reading methods available in the node `fs` module to read files on-demand. It's a work in progress and feedback is welcome :) ## Example Usage <<< examples/ipsum-chunks.js **/ module.exports = function(filename, opts) { var mode = opts && opts.mode || 0x1B6; // 0666 var bufferSize = opts && opts.bufferSize || 1024*64; var start = opts && opts.start || 0 var end = opts && opts.end || Number.MAX_SAFE_INTEGER var fd = opts && opts.fd var ended, closeNext, busy, _cb; var _buffer = new Buffer(bufferSize) var flags = opts && opts.flags || 'r' function readNext(cb) { if(closeNext) return close(cb) var toRead = Math.min(end - start, bufferSize); busy = true fs.read( fd, _buffer, 0, toRead, start, function(err, count, buffer) { busy = false start += count; // if we have received an end noticiation, just discard this data if(closeNext) { close(_cb) return cb(closeNext) } if (ended) { return cb(err || ended); } // if we encountered a read error pass it on if (err) { return cb(err); } if(count === buffer.length) { cb(null, buffer); } else { closeNext = true; cb(null, buffer.slice(0, count)); } } ); _buffer = new Buffer(Math.min(end - start, bufferSize)) } function open(cb) { busy = true fs.open(filename, flags, mode, function(err, descriptor) { // save the file descriptor fd = descriptor; busy = false if(closeNext) { close(_cb) return cb(closeNext) } if (err) { return cb(err); } // read the next bytes return readNext(cb); }); } function close (cb) { //if auto close is disabled, then user manages fd. if(opts && opts.autoClose === false) return cb(true) //wait until we have got out of bed, then go back to bed. //or if we are reading, wait till we read, then go back to bed. else if(busy) { _cb = cb return closeNext = true } //first read was close, don't even get out of bed. else if(!fd) { return cb(true) } //go back to bed else { fs.close(fd, function(err) { fd = null; cb(err || true); }); } } function source (end, cb) { if (end) { ended = end; close(cb); } // if we have already received the end notification, abort further else if (ended) { cb(ended) } else if (! fd) { open(cb); } else readNext(cb); }; //read directly to text if(opts && opts.encoding) return Decoder(opts.encoding)(source) return source }; }).call(this,require("buffer").Buffer) },{"buffer":61,"fs":58,"pull-utf8-decoder":389}],313:[function(require,module,exports){ var pull = require('pull-stream') var fs = require('fs') var path = require('path') var Read = require('pull-file') var Write = require('pull-write-file') var readdir = exports.readdir = function (dir, match, ignore) { var ls, ended = false match = ( !match ? null : 'function' === typeof match ? match : 'function' === typeof match.test ? match.test.bind(match) : null ) return function (abort, cb) { if(ended || abort) { cb(ended = ended || abort) } else if(!ls) fs.readdir(dir, function (err, _ls) { if(err && err.code == 'ENOTDIR') cb(ended = true) else if(err) cb(ended = err) else if(!_ls.length) cb(ended = true) else { if(match) _ls = _ls.filter(match) ls = _ls.map(function (f) { return path.resolve(dir, f) }) if(ls.length) cb(null, ls.shift()) else cb(true) } }) else if(!ls.length) cb(ended = true) else cb(null, ls.shift()) } } var blocksize = 512 var read = exports.read = Read var write = exports.write = Write var exists = exports.exists = function (test) { test = test || function (e) { return !!e } return pull( pull.asyncMap(function (e, cb) { fs.stat(e, function (err, stat) { if(stat && test(stat)) cb(null, e) else cb(null, null) }) }), pull.filter(Boolean) ) } function testStat(test) { return function () { return exists(test) } } var isFile = exports.isFile = testStat(function (e) { return e.isFile() }) var isDirectory = exports.isDirectory = testStat(function (e) { return e.isDirectory() }) var isBlockDevice = exports.isBlockDevice = testStat(function (e) { return e.isBlockDevice() }) var isCharacterDevice = exports.isCharacterDevice = testStat(function (e) { return e.isCharacterDevice() }) var isSymbolicLink = exports.isSymbolicLink = testStat(function (e) { return e.isSymbolicLink() }) var isFIFO = exports.isFIFO = testStat(function (e) { return e.isFIFO() }) var isSocket = exports.isSocket = testStat(function (e) { return e.isSocket() }) },{"fs":58,"path":290,"pull-file":312,"pull-stream":315,"pull-write-file":392}],314:[function(require,module,exports){ var core = require('./core') var util = require('./util') for(var k in core) exports[k] = core[k] for(var k in util) exports[k] = util[k] },{"./core":313,"./util":320}],315:[function(require,module,exports){ arguments[4][232][0].apply(exports,arguments) },{"./pull":316,"./sinks":317,"./sources":318,"./throughs":319,"dup":232}],316:[function(require,module,exports){ arguments[4][233][0].apply(exports,arguments) },{"dup":233}],317:[function(require,module,exports){ arguments[4][234][0].apply(exports,arguments) },{"dup":234}],318:[function(require,module,exports){ arguments[4][235][0].apply(exports,arguments) },{"dup":235}],319:[function(require,module,exports){ arguments[4][236][0].apply(exports,arguments) },{"./sinks":317,"./sources":318,"dup":236}],320:[function(require,module,exports){ (function (process){ var path = require('path') var pull = require('pull-stream') var core = require('./core') var fs = require('fs') var DepthFirst = require('pull-traverse').depthFirst var ancestors = exports.ancestors = function (dir) { dir = dir || process.cwd() var paths = [] while(dir) { paths.push(dir) dir = path.dirname(dir) if(dir === '/') { paths.push(dir) break } } return pull.values(paths) } var star = exports.star = function (match) { return pull( pull.map(function (dir) { return core.readdir(dir, match) }), pull.flatten(), pull.filter() ) } var starStar = exports.starStar = function (match) { var seen = {} return pull( pull.map(function (dir) { var first = true return DepthFirst(path.resolve(dir), function (_dir) { return pull( core.readdir(_dir, match, true), pull.filter(function (e) { if(seen[e]) return false return seen[e] = true }) ) }) }), pull.flatten(), pull.filter() ) } var resolve = exports.resolve = function (rel) { return pull.map(function (dir) { //map to $dir/node_modules if(rel) return path.resolve(dir, rel) return path.resolve(dir) }) } var relative = exports.relative = function (rel) { rel = rel || process.cwd() return pull.map(function (file) { return path.relative(rel, file) }) } var absolute = exports.absolute = function () { return resolve() } var readFile = exports.readFile = function (parse) { return pull.asyncMap(function (file, cb) { fs.readFile(file, 'utf-8', function (err, data) { if(err) return cb(err) try { data = parse ? parse(data) : data } catch (err) { return cb(err) } return cb(null, data) }) }) } if(!module.parent) { pull( pull.values(['.']), starStar(), pull.drain(console.log) ) } }).call(this,require('_process')) },{"./core":313,"_process":295,"fs":58,"path":290,"pull-stream":315,"pull-traverse":388}],321:[function(require,module,exports){ (function (process){ var pfs = require('pull-fs') var pull = require('pull-stream') var path = require('path') var glob = module.exports = function (x) { var rest = path.normalize(x).split('/') var stream var pipe = [] if(rest[0] == '...') { pipe.push(pfs.ancestors()) rest.shift() } else if(rest[0] === '~' || rest[0] === '') { pipe.push(pull.values([rest.shift() ? process.env.HOME : '/'])) } else { pipe.push(pull.values(['.'])) } //this should be tidied up. //need a more betterer glob parser //that handles escapes... rest.forEach(function (e) { if('**' === e) { pipe.push(pfs.starStar()) } else if(/[*?{}]/.test(e)) { //literal e = e .split('.').join('\\.') .split('?').join('.') .split(/({.*?})/).map(function (e, i) { if(i % 2) return e.replace('{', '(?:') .replace('}', ')') .split(',').join('|') return e }).join('') var x = new RegExp('^'+e.split('*').join('.*')+'$') pipe.push(pfs.star(x)) } else if(e === '') //will only happen in the last position //if you do */ pipe.push(pfs.isDirectory()) else pipe.push(pull(pfs.resolve(e), pfs.exists())) }) return pull.apply(null, pipe) } }).call(this,require('_process')) },{"_process":295,"path":290,"pull-fs":314,"pull-stream":322}],322:[function(require,module,exports){ arguments[4][232][0].apply(exports,arguments) },{"./pull":323,"./sinks":324,"./sources":325,"./throughs":326,"dup":232}],323:[function(require,module,exports){ arguments[4][233][0].apply(exports,arguments) },{"dup":233}],324:[function(require,module,exports){ arguments[4][234][0].apply(exports,arguments) },{"dup":234}],325:[function(require,module,exports){ arguments[4][235][0].apply(exports,arguments) },{"dup":235}],326:[function(require,module,exports){ arguments[4][236][0].apply(exports,arguments) },{"./sinks":324,"./sources":325,"dup":236}],327:[function(require,module,exports){ module.exports = function endable (goodbye) { var ended, waiting, sentEnd function h (read) { return function (abort, cb) { read(abort, function (end, data) { if(end && !sentEnd) { sentEnd = true return cb(null, goodbye) } //send end message... if(end && ended) cb(end) else if(end) waiting = cb else cb(null, data) }) } } h.end = function () { ended = true if(waiting) waiting(ended) return h } return h } },{}],328:[function(require,module,exports){ var endable = require('./endable') var pull = require('pull-stream') module.exports = function (stream, goodbye) { goodbye = goodbye || 'GOODBYE' var e = endable(goodbye) return { // when the source ends, // send the goodbye and then wait to recieve // the other goodbye. source: pull(stream.source, e), sink: pull( //when the goodbye is received, allow the source to end. pull.filter(function (data) { if(data !== goodbye) return true e.end() }), stream.sink ) } } },{"./endable":327,"pull-stream":381}],329:[function(require,module,exports){ var Reader = require('pull-reader') var pull = require('pull-stream') var deferred = require('pull-defer') var Writer = require('pull-pushable') var cat = require('pull-cat') var pair = require('pull-pair') function once (cb) { var called = 0 return function (a, b, c) { if(called++) return cb(a, b, c) } } function isFunction (f) { return 'function' === typeof f } module.exports = function (opts, _cb) { if(isFunction(opts)) _cb = opts, opts = {} _cb = once(_cb) var reader = Reader(opts && opts.timeout || 5e3) var writer = Writer(function (err) { if(err) _cb(err) }) var source = deferred.source() var p = pair() return { handshake: { read: reader.read, abort: function (err) { writer.end(err) reader.abort(err, function (err) { }) _cb(err) }, write: writer.push, rest: function () { writer.end() return { source: reader.read(), sink: p.sink } } }, sink: reader, source: cat([writer, p.source]) } } },{"pull-cat":305,"pull-defer":308,"pull-pair":362,"pull-pushable":370,"pull-reader":372,"pull-stream":330}],330:[function(require,module,exports){ arguments[4][232][0].apply(exports,arguments) },{"./pull":331,"./sinks":332,"./sources":333,"./throughs":334,"dup":232}],331:[function(require,module,exports){ arguments[4][233][0].apply(exports,arguments) },{"dup":233}],332:[function(require,module,exports){ arguments[4][234][0].apply(exports,arguments) },{"dup":234}],333:[function(require,module,exports){ arguments[4][235][0].apply(exports,arguments) },{"dup":235}],334:[function(require,module,exports){ arguments[4][236][0].apply(exports,arguments) },{"./sinks":332,"./sources":333,"dup":236}],335:[function(require,module,exports){ (function (Buffer){ var pull = require('pull-stream') var mns = require('./magic-numbers') module.exports = function (cb) { var done = false return pull.through(function (buf) { if (done) return done = true if (!Buffer.isBuffer(buf)) return cb(false) // compare the first bytes against the magic numbers var hex = buf.slice(0, (buf.length > 10) ? 10 : buf.length).toString('hex') for (var magicNumber in mns) { if (hex.indexOf(magicNumber) === 0) return cb(mns[magicNumber]) } // convert to string, check the plaintext types var asStr = buf.slice(0, (buf.length > 512) ? 512 : buf.length).toString('utf-8') if (asStr.indexOf('= highWaterMark) return reading = true return read(ended || ending, function (end, data) { reading = false ending = ending || end if(data != null) buffer.push(data) next(); readAhead() }) } process.nextTick(next) return function (end, cb) { ended = ended || end waiting.push(cb) next(); readAhead() } } var flatMap = exports.flatMap = function (read, mapper) { mapper = mapper || id var queue = [], ended return function (abort, cb) { if(queue.length) return cb(null, queue.shift()) else if(ended) return cb(ended) read(abort, function next (end, data) { if(end) ended = end else { var add = mapper(data) while(add && add.length) queue.push(add.shift()) } if(queue.length) cb(null, queue.shift()) else if(ended) cb(ended) else read(null, next) }) } } }).call(this,require('_process')) },{"./sinks":340,"./sources":341,"_process":295,"pull-core":306}],343:[function(require,module,exports){ var pull = require('pull-stream') function rate (s) { var recent = [] var stream = pull.through(function (d) { stream.ts = Date.now() recent.push({size: d.length, ts: stream.ts}) if(recent.length > 5) recent.shift() }) stream.ts = Date.now() stream.rate = function () { var ts = Date.now() if(recent.length > 1) { var rate = (recent.reduce(function (size, item) { return size + item.size }, 0)/1000000) / ((ts - recent[0].ts)/1000) return rate } } return stream } module.exports = rate },{"pull-stream":338}],344:[function(require,module,exports){ var pull = require('pull-stream') var toPull = require('stream-to-pull-stream') var pushable = require('pull-pushable') var cat = require('pull-cat') var pw = require('pull-window') var post = require('level-post') function read(db, opts) { return toPull.read1(db.createReadStream(opts)) } var live = exports.live = function (db, opts) { opts = opts || {} var l = pushable() var cleanup = post(db, opts, function (ch) { if(opts.keys === false) l.push(ch.value) else if(opts.values === false) l.push(ch.key) else l.push(ch) }) return pull(l, pull.through(null, cleanup)) } exports.read = exports.readStream = exports.createReadStream = function (db, opts) { opts = opts || {} if(!(opts.tail || opts.live)) return read(db, opts) //optionally notify when we switch from reading history to realtime var sync = opts.onSync && function (abort, cb) { opts.onSync(abort); cb(abort || true) } return cat([read(db, opts), sync, live(db, opts)]) } exports.write = exports.writeStream = exports.createWriteStream = function (db, opts, done) { if('function' === typeof opts) done = opts, opts = null opts = opts || {} return pull( pull.map(function (e) { if(e.type) return e return { key : e.key, value : e.value, type : e.value == null ? 'del' : 'put' } }), pw.recent(opts.windowSize, opts.windowTime), pull.asyncMap(function (batch, cb) { db.batch(batch, cb) }), pull.drain(null, done) ) } },{"level-post":198,"pull-cat":305,"pull-pushable":346,"pull-stream":381,"pull-window":390,"stream-to-pull-stream":352}],345:[function(require,module,exports){ exports.id = function (item) { return item } exports.prop = function (map) { if('string' == typeof map) { var key = map return function (data) { return data[key] } } return map } exports.tester = function (test) { if(!test) return exports.id if('object' === typeof test && 'function' === typeof test.test) return test.test.bind(test) return exports.prop(test) || exports.id } exports.addPipe = addPipe function addPipe(read) { if('function' !== typeof read) return read read.pipe = read.pipe || function (reader) { if('function' != typeof reader) throw new Error('must pipe to reader') return addPipe(reader(read)) } read.type = 'Source' return read } var Source = exports.Source = function Source (createRead) { function s() { var args = [].slice.call(arguments) return addPipe(createRead.apply(null, args)) } s.type = 'Source' return s } var Through = exports.Through = function (createRead) { return function () { var args = [].slice.call(arguments) var piped = [] function reader (read) { args.unshift(read) read = createRead.apply(null, args) while(piped.length) read = piped.shift()(read) return read //pipeing to from this reader should compose... } reader.pipe = function (read) { piped.push(read) if(read.type === 'Source') throw new Error('cannot pipe ' + reader.type + ' to Source') reader.type = read.type === 'Sink' ? 'Sink' : 'Through' return reader } reader.type = 'Through' return reader } } var Sink = exports.Sink = function Sink(createReader) { return function () { var args = [].slice.call(arguments) if(!createReader) throw new Error('must be createReader function') function s (read) { args.unshift(read) return createReader.apply(null, args) } s.type = 'Sink' return s } } exports.maybeSink = exports.maybeDrain = function (createSink, cb) { if(!cb) return Through(function (read) { var ended return function (close, cb) { if(close) return read(close, cb) if(ended) return cb(ended) createSink(function (err, data) { ended = err || true if(!err) cb(null, data) else cb(ended) }) (read) } })() return Sink(function (read) { return createSink(cb) (read) })() } },{}],346:[function(require,module,exports){ var pull = require('pull-stream') module.exports = pull.Source(function (onClose) { var buffer = [], cbs = [], waiting = [], ended function drain() { var l while(waiting.length && ((l = buffer.length) || ended)) { var data = buffer.shift() var cb = cbs.shift() waiting.shift()(l ? null : ended, data) cb && cb(ended === true ? null : ended) } } function read (end, cb) { ended = ended || end waiting.push(cb) drain() if(ended) onClose && onClose(ended === true ? null : ended) } read.push = function (data, cb) { if(ended) return cb && cb(ended === true ? null : ended) buffer.push(data); cbs.push(cb) drain() } read.end = function (end, cb) { if('function' === typeof end) cb = end, end = true ended = ended || end || true; if(cb) cbs.push(cb) drain() if(ended) onClose && onClose(ended === true ? null : ended) } return read }) },{"pull-stream":347}],347:[function(require,module,exports){ var sources = require('./sources') var sinks = require('./sinks') var throughs = require('./throughs') var u = require('pull-core') for(var k in sources) exports[k] = u.Source(sources[k]) for(var k in throughs) exports[k] = u.Through(throughs[k]) for(var k in sinks) exports[k] = u.Sink(sinks[k]) var maybe = require('./maybe')(exports) for(var k in maybe) exports[k] = maybe[k] exports.Duplex = exports.Through = exports.pipeable = u.Through exports.Source = exports.pipeableSource = u.Source exports.Sink = exports.pipeableSink = u.Sink },{"./maybe":348,"./sinks":349,"./sources":350,"./throughs":351,"pull-core":345}],348:[function(require,module,exports){ var u = require('pull-core') var prop = u.prop var id = u.id var maybeSink = u.maybeSink module.exports = function (pull) { var exports = {} var drain = pull.drain var find = exports.find = function (test, cb) { return maybeSink(function (cb) { var ended = false if(!cb) cb = test, test = id else test = prop(test) || id return drain(function (data) { if(test(data)) { ended = true cb(null, data) return false } }, function (err) { if(ended) return //already called back cb(err === true ? null : err, null) }) }, cb) } var reduce = exports.reduce = function (reduce, acc, cb) { return maybeSink(function (cb) { return drain(function (data) { acc = reduce(acc, data) }, function (err) { cb(err, acc) }) }, cb) } var collect = exports.collect = exports.writeArray = function (cb) { return reduce(function (arr, item) { arr.push(item) return arr }, [], cb) } return exports } },{"pull-core":345}],349:[function(require,module,exports){ var drain = exports.drain = function (read, op, done) { ;(function next() { var loop = true, cbed = false while(loop) { cbed = false read(null, function (end, data) { cbed = true if(end) { loop = false done && done(end === true ? null : end) } else if(op && false === op(data)) { loop = false read(true, done || function () {}) } else if(!loop){ next() } }) if(!cbed) { loop = false return } } })() } var onEnd = exports.onEnd = function (read, done) { return drain(read, null, done) } var log = exports.log = function (read, done) { return drain(read, function (data) { console.log(data) }, done) } },{}],350:[function(require,module,exports){ var keys = exports.keys = function (object) { return values(Object.keys(object)) } var once = exports.once = function (value) { return function (abort, cb) { if(abort) return cb(abort) if(value != null) { var _value = value; value = null cb(null, _value) } else cb(true) } } var values = exports.values = exports.readArray = function (array) { if(!Array.isArray(array)) array = Object.keys(array).map(function (k) { return array[k] }) var i = 0 return function (end, cb) { if(end) return cb && cb(end) cb(i >= array.length || null, array[i++]) } } var count = exports.count = function (max) { var i = 0; max = max || Infinity return function (end, cb) { if(end) return cb && cb(end) if(i > max) return cb(true) cb(null, i++) } } var infinite = exports.infinite = function (generate) { generate = generate || Math.random return function (end, cb) { if(end) return cb && cb(end) return cb(null, generate()) } } var defer = exports.defer = function () { var _read, cbs = [], _end var read = function (end, cb) { if(!_read) { _end = end cbs.push(cb) } else _read(end, cb) } read.resolve = function (read) { if(_read) throw new Error('already resolved') _read = read if(!_read) throw new Error('no read cannot resolve!' + _read) while(cbs.length) _read(_end, cbs.shift()) } read.abort = function(err) { read.resolve(function (_, cb) { cb(err || true) }) } return read } var empty = exports.empty = function () { return function (abort, cb) { cb(true) } } var depthFirst = exports.depthFirst = function (start, createStream) { var reads = [] reads.unshift(once(start)) return function next (end, cb) { if(!reads.length) return cb(true) reads[0](end, function (end, data) { if(end) { //if this stream has ended, go to the next queue reads.shift() return next(null, cb) } reads.unshift(createStream(data)) cb(end, data) }) } } //width first is just like depth first, //but push each new stream onto the end of the queue var widthFirst = exports.widthFirst = function (start, createStream) { var reads = [] reads.push(once(start)) return function next (end, cb) { if(!reads.length) return cb(true) reads[0](end, function (end, data) { if(end) { reads.shift() return next(null, cb) } reads.push(createStream(data)) cb(end, data) }) } } //this came out different to the first (strm) //attempt at leafFirst, but it's still a valid //topological sort. var leafFirst = exports.leafFirst = function (start, createStream) { var reads = [] var output = [] reads.push(once(start)) return function next (end, cb) { reads[0](end, function (end, data) { if(end) { reads.shift() if(!output.length) return cb(true) return cb(null, output.shift()) } reads.unshift(createStream(data)) output.unshift(data) next(null, cb) }) } } },{}],351:[function(require,module,exports){ (function (process){ var u = require('pull-core') var sources = require('./sources') var sinks = require('./sinks') var prop = u.prop var id = u.id var tester = u.tester var map = exports.map = function (read, map) { map = prop(map) || id return function (end, cb) { read(end, function (end, data) { var data = !end ? map(data) : null cb(end, data) }) } } var asyncMap = exports.asyncMap = function (read, map) { if(!map) return read return function (end, cb) { if(end) return read(end, cb) //abort read(null, function (end, data) { if(end) return cb(end, data) map(data, cb) }) } } var paraMap = exports.paraMap = function (read, map, width) { if(!map) return read var ended = false, queue = [], _cb function drain () { if(!_cb) return var cb = _cb _cb = null if(queue.length) return cb(null, queue.shift()) else if(ended && !n) return cb(ended) _cb = cb } function pull () { read(null, function (end, data) { if(end) { ended = end return drain() } n++ map(data, function (err, data) { n-- queue.push(data) drain() }) if(n < width && !ended) pull() }) } var n = 0 return function (end, cb) { if(end) return read(end, cb) //abort //continue to read while there are less than 3 maps in flight _cb = cb if(queue.length || ended) pull(), drain() else pull() } return highWaterMark(asyncMap(read, map), width) } var filter = exports.filter = function (read, test) { //regexp test = tester(test) return function next (end, cb) { read(end, function (end, data) { if(!end && !test(data)) return next(end, cb) cb(end, data) }) } } var filterNot = exports.filterNot = function (read, test) { test = tester(test) return filter(read, function (e) { return !test(e) }) } var through = exports.through = function (read, op, onEnd) { var a = false function once (abort) { if(a || !onEnd) return a = true onEnd(abort === true ? null : abort) } return function (end, cb) { if(end) once(end) return read(end, function (end, data) { if(!end) op && op(data) else once(end) cb(end, data) }) } } var take = exports.take = function (read, test) { var ended = false if('number' === typeof test) { var n = test; test = function () { return n -- } } return function (end, cb) { if(ended) return cb(ended) if(ended = end) return read(ended, cb) read(null, function (end, data) { if(ended = ended || end) return cb(ended) if(!test(data)) { ended = true read(true, function (end, data) { cb(ended, data) }) } else cb(null, data) }) } } var unique = exports.unique = function (read, field, invert) { field = prop(field) || id var seen = {} return filter(read, function (data) { var key = field(data) if(seen[key]) return !!invert //false, by default else seen[key] = true return !invert //true by default }) } var nonUnique = exports.nonUnique = function (read, field) { return unique(read, field, true) } var group = exports.group = function (read, size) { var ended; size = size || 5 var queue = [] return function (end, cb) { //this means that the upstream is sending an error. if(end) return read(ended = end, cb) //this means that we read an end before. if(ended) return cb(ended) read(null, function next(end, data) { if(ended = ended || end) { if(!queue.length) return cb(ended) var _queue = queue; queue = [] return cb(null, _queue) } queue.push(data) if(queue.length < size) return read(null, next) var _queue = queue; queue = [] cb(null, _queue) }) } } var flatten = exports.flatten = function (read) { var _read return function (abort, cb) { if(_read) nextChunk() else nextStream() function nextChunk () { _read(null, function (end, data) { if(end) nextStream() else cb(null, data) }) } function nextStream () { read(null, function (end, stream) { if(end) return cb(end) if(Array.isArray(stream)) stream = sources.values(stream) else if('function' != typeof stream) throw new Error('expected stream of streams') _read = stream nextChunk() }) } } } var prepend = exports.prepend = function (read, head) { return function (abort, cb) { if(head !== null) { if(abort) return read(abort, cb) var _head = head head = null cb(null, _head) } else { read(abort, cb) } } } //var drainIf = exports.drainIf = function (op, done) { // sinks.drain( //} var _reduce = exports._reduce = function (read, reduce, initial) { return function (close, cb) { if(close) return read(close, cb) if(ended) return cb(ended) sinks.drain(function (item) { initial = reduce(initial, item) }, function (err, data) { ended = err || true if(!err) cb(null, initial) else cb(ended) }) (read) } } var nextTick = process.nextTick var highWaterMark = exports.highWaterMark = function (read, highWaterMark) { var buffer = [], waiting = [], ended, reading = false highWaterMark = highWaterMark || 10 function readAhead () { while(waiting.length && (buffer.length || ended)) waiting.shift()(ended, ended ? null : buffer.shift()) } function next () { if(ended || reading || buffer.length >= highWaterMark) return reading = true return read(ended, function (end, data) { reading = false ended = ended || end if(data != null) buffer.push(data) next(); readAhead() }) } nextTick(next) return function (end, cb) { ended = ended || end waiting.push(cb) next(); readAhead() } } }).call(this,require('_process')) },{"./sinks":349,"./sources":350,"_process":295,"pull-core":345}],352:[function(require,module,exports){ (function (process){ var pull = require('pull-core') function destroy(stream, cb) { function onClose () { cleanup(); cb() } function onError (err) { cleanup(); cb(err) } function cleanup() { stream.removeListener('close', onClose) stream.removeListener('error', onError) } stream.on('close', onClose) stream.on('error', onError) } function write(read, stream) { var ended function onClose () { cleanup() if(!ended) read(ended = true, function () {}) } function onError (err) { cleanup() if(!ended) read(ended = err, function () {}) } function cleanup() { stream.removeListener('close', onClose) stream.removeListener('error', onError) } stream.on('close', onClose) stream.on('error', onError) process.nextTick(function next() { read(null, function (end, data) { if(end === true) return stream._isStdio || stream.end() if(ended = ended || end) return stream.emit('error', end) var pause = stream.write(data) if(pause === false) stream.once('drain', next) else next() }) }) } function first (emitter, events, handler) { function listener (val) { events.forEach(function (e) { emitter.removeListener(e, listener) }) handler(val) } events.forEach(function (e) { emitter.on(e, listener) }) return emitter } function read2(stream) { var ended = false, waiting = false var _cb function read () { var data = stream.read() if(data !== null && _cb) { var cb = _cb; _cb = null cb(null, data) } } stream.on('readable', function () { waiting = true _cb && read() }) .on('end', function () { ended = true _cb && _cb(ended) }) .on('error', function (err) { ended = err _cb && _cb(ended) }) return function (end, cb) { _cb = cb if(ended) cb(ended) else if(waiting) read() } } function read1(stream) { var buffer = [], cbs = [], ended, paused = false var draining function drain() { while((buffer.length || ended) && cbs.length) cbs.shift()(buffer.length ? null : ended, buffer.shift()) if(!buffer.length && (paused)) { paused = false stream.resume() } } stream.on('data', function (data) { buffer.push(data) drain() if(buffer.length && stream.pause) { paused = true stream.pause() } }) stream.on('end', function () { ended = true drain() }) stream.on('error', function (err) { ended = err drain() }) return function (abort, cb) { if(!cb) throw new Error('*must* provide cb') if(abort) { stream.once('close', function () { cb(abort) }) stream.destroy() } cbs.push(cb) drain() } } function read (stream) { if('function' === typeof stream.read) return read2(stream) return read1(stream) } var sink = function (stream) { return pull.Sink(function (read) { return write(read, stream) })() } var source = function (stream) { return pull.Source(function () { return read(stream) })() } exports = module.exports = function (stream) { return ( stream.writable ? stream.readable ? pull.Through(function(_read) { write(_read, stream); return read(stream) })() : sink(stream) : source(stream) ) } exports.sink = sink exports.source = source exports.read = read exports.read1 = read1 exports.read2 = read2 }).call(this,require('_process')) },{"_process":295,"pull-core":345}],353:[function(require,module,exports){ /* all pull streams have these states: { START: { read: READING, abort: ABORTING }, READY: { read: READING, abort: ABORTING }, READING: { cb: READY, err: ERROR, end: END }, ABORTING: { cb: END }, ERROR: {}, END: {} } this module takes a collection of pull-streams, and interleaves their states. if all the streams have ended, it ends. If it is in reading state, and one stream goes has READING->cb it goes into READY on read, trigger read on every stream in START or READY on abort, trigger abort on every stream in START or READY if a stream is in READY, and big stream is in ABORT, trigger abort if every stream is in END or ERROR, trigger end or error could you describe this declaritively or something? */ module.exports = function (ary) { var capped = !!ary var inputs = (ary || []).map(create), i = 0, abort, cb function create (stream) { return {ready: false, reading: false, ended: false, read: stream, data: null} } function check () { if(!cb) return clean() var l = inputs.length var _cb = cb if(l === 0 && (abort || capped)) { cb = null; _cb(abort || true) return } //scan the inputs to check whether there is one we can use. for(var j = 0; j < l; j++) { var current = inputs[(i + j) % l] if(current.ready && !current.ended) { var data = current.data current.ready = false current.data = null i ++; cb = null return _cb(null, data) } } } function clean () { var l = inputs.length //iterate backwards so that we can remove items. while(l--) { if(inputs[l].ended) inputs.splice(l, 1) } } function next () { var l = inputs.length while(l--) (function (current) { //read the next item if we aren't already if(l > inputs.length) throw new Error('this should never happen') if(current.reading || current.ended || current.ready) return current.reading = true var sync = true current.read(abort, function next (end, data) { current.data = data current.ready = true current.reading = false if(end === true || abort) current.ended = true else if(end) abort = current.ended = end //check whether we need to abort this stream. if(abort && !end) current.read(abort, next) if(!sync) check() }) sync = false })(inputs[l]) //scan the feed check() } function read (_abort, _cb) { abort = abort || _abort; cb = _cb; next() } read.add = function (stream) { if(!stream) { //the stream will now end when all the streams end. capped = true //we just changed state, so we may need to cb return next() } inputs.push(create(stream)) next() } read.cap = function (err) { read.add(null) } return read } },{}],354:[function(require,module,exports){ arguments[4][251][0].apply(exports,arguments) },{"dup":251,"pull-pushable":356}],355:[function(require,module,exports){ arguments[4][345][0].apply(exports,arguments) },{"dup":345}],356:[function(require,module,exports){ arguments[4][346][0].apply(exports,arguments) },{"dup":346,"pull-stream":357}],357:[function(require,module,exports){ arguments[4][347][0].apply(exports,arguments) },{"./maybe":358,"./sinks":359,"./sources":360,"./throughs":361,"dup":347,"pull-core":355}],358:[function(require,module,exports){ arguments[4][348][0].apply(exports,arguments) },{"dup":348,"pull-core":355}],359:[function(require,module,exports){ arguments[4][349][0].apply(exports,arguments) },{"dup":349}],360:[function(require,module,exports){ arguments[4][350][0].apply(exports,arguments) },{"dup":350}],361:[function(require,module,exports){ (function (process){ var u = require('pull-core') var sources = require('./sources') var sinks = require('./sinks') var prop = u.prop var id = u.id var tester = u.tester var map = exports.map = function (read, map) { map = prop(map) || id return function (end, cb) { read(end, function (end, data) { var data = !end ? map(data) : null cb(end, data) }) } } var asyncMap = exports.asyncMap = function (read, map) { if(!map) return read return function (end, cb) { if(end) return read(end, cb) //abort read(null, function (end, data) { if(end) return cb(end, data) map(data, cb) }) } } var paraMap = exports.paraMap = function (read, map, width) { if(!map) return read var ended = false, queue = [], _cb function drain () { if(!_cb) return var cb = _cb _cb = null if(queue.length) return cb(null, queue.shift()) else if(ended && !n) return cb(ended) _cb = cb } function pull () { read(null, function (end, data) { if(end) { ended = end return drain() } n++ map(data, function (err, data) { n-- queue.push(data) drain() }) if(n < width && !ended) pull() }) } var n = 0 return function (end, cb) { if(end) return read(end, cb) //abort //continue to read while there are less than 3 maps in flight _cb = cb if(queue.length || ended) pull(), drain() else pull() } return highWaterMark(asyncMap(read, map), width) } var filter = exports.filter = function (read, test) { //regexp test = tester(test) return function next (end, cb) { read(end, function (end, data) { if(!end && !test(data)) return next(end, cb) cb(end, data) }) } } var filterNot = exports.filterNot = function (read, test) { test = tester(test) return filter(read, function (e) { return !test(e) }) } var through = exports.through = function (read, op, onEnd) { var a = false function once (abort) { if(a || !onEnd) return a = true onEnd(abort === true ? null : abort) } return function (end, cb) { if(end) once(end) return read(end, function (end, data) { if(!end) op && op(data) else once(end) cb(end, data) }) } } var take = exports.take = function (read, test) { var ended = false if('number' === typeof test) { var n = test; test = function () { return n -- } } return function (end, cb) { if(ended) return cb(ended) if(ended = end) return read(ended, cb) read(null, function (end, data) { if(ended = ended || end) return cb(ended) if(!test(data)) { ended = true read(true, function (end, data) { cb(ended, data) }) } else cb(null, data) }) } } var unique = exports.unique = function (read, field, invert) { field = prop(field) || id var seen = {} return filter(read, function (data) { var key = field(data) if(seen[key]) return !!invert //false, by default else seen[key] = true return !invert //true by default }) } var nonUnique = exports.nonUnique = function (read, field) { return unique(read, field, true) } var group = exports.group = function (read, size) { var ended; size = size || 5 var queue = [] return function (end, cb) { //this means that the upstream is sending an error. if(end) return read(ended = end, cb) //this means that we read an end before. if(ended) return cb(ended) read(null, function next(end, data) { if(ended = ended || end) { if(!queue.length) return cb(ended) var _queue = queue; queue = [] return cb(null, _queue) } queue.push(data) if(queue.length < size) return read(null, next) var _queue = queue; queue = [] cb(null, _queue) }) } } var flatten = exports.flatten = function (read) { var _read return function (abort, cb) { if(_read) nextChunk() else nextStream() function nextChunk () { _read(null, function (end, data) { if(end) nextStream() else cb(null, data) }) } function nextStream () { read(null, function (end, stream) { if(end) return cb(end) if(Array.isArray(stream)) stream = sources.values(stream) else if('function' != typeof stream) throw new Error('expected stream of streams') _read = stream nextChunk() }) } } } var prepend = exports.prepend = function (read, head) { return function (abort, cb) { if(head !== null) { if(abort) return read(abort, cb) var _head = head head = null cb(null, _head) } else { read(abort, cb) } } } //var drainIf = exports.drainIf = function (op, done) { // sinks.drain( //} var _reduce = exports._reduce = function (read, reduce, initial) { return function (close, cb) { if(close) return read(close, cb) if(ended) return cb(ended) sinks.drain(function (item) { initial = reduce(initial, item) }, function (err, data) { ended = err || true if(!err) cb(null, initial) else cb(ended) }) (read) } } var nextTick = process.nextTick var highWaterMark = exports.highWaterMark = function (read, highWaterMark) { var buffer = [], waiting = [], ended, reading = false highWaterMark = highWaterMark || 10 function readAhead () { while(waiting.length && (buffer.length || ended)) waiting.shift()(ended, ended ? null : buffer.shift()) } function next () { if(ended || reading || buffer.length >= highWaterMark) return reading = true return read(ended, function (end, data) { reading = false ended = ended || end if(data != null) buffer.push(data) next(); readAhead() }) } nextTick(next) return function (end, cb) { ended = ended || end waiting.push(cb) next(); readAhead() } } }).call(this,require('_process')) },{"./sinks":359,"./sources":360,"_process":295,"pull-core":355}],362:[function(require,module,exports){ 'use strict' //a pair of pull streams where one drains from the other module.exports = function () { var _read, waiting function sink (read) { if('function' !== typeof read) throw new Error('read must be function') if(_read) throw new Error('already piped') _read = read if(waiting) { var _waiting = waiting waiting = null _read.apply(null, _waiting) } } function source (abort, cb) { if(_read) _read(abort, cb) else waiting = [abort, cb] } return { source: source, sink: sink } } },{}],363:[function(require,module,exports){ module.exports = function (map, width) { var reading = false, abort return function (read) { var i = 0, j = 0, last = 0 var seen = [], started = false, ended = false, _cb, error function drain () { if(_cb) { var cb = _cb if(error) { _cb = null return cb(error) } if(Object.hasOwnProperty.call(seen, j)) { _cb = null var data = seen[j]; delete seen[j]; j++ cb(null, data) if(width) start() } else if(j >= last && ended) { _cb = null cb(true) } } } function start () { started = true if(ended) return drain() if(reading || width && (i - width >= j)) return reading = true read(abort, function (end, data) { reading = false if(end) { last = i; ended = end drain() } else { var k = i++ map(data, function (err, data) { seen[k] = data if(err) error = err drain() }) if(!ended) start() } }) } return function (_abort, cb) { if(_abort) { return read(ended = abort = _abort, function (err) { if(_cb) return cb(err) }) } _cb = cb if(!started) start() drain() } } } },{}],364:[function(require,module,exports){ var Pushable = require('pull-pushable') var Stats = require('statistics') var pull = require('pull-stream') module.exports = function (opts) { var timeout = opts && opts.timeout || 5*60*1000 //default: 5 minutes var serve = false, timer var source = Pushable() var rtt = Stats(), skew = Stats() function ping () { //serve the ping pong, opponent //will volley it back to us, keeping connection alive //and revealing clock skew. serve = true source.push(ts = Date.now()) } //we send the first ping if(opts && opts.serve) ping() return { source: source, sink: pull.drain(function (remote_ts) { if(serve) { var ts2 = Date.now() rtt.value(ts2 - ts) //if their time is behind half a round trip behing ts2 //consider that to be negative skew. skew.value(remote_ts - ((ts2 + ts)/2)) serve = false } else { //volley timestamp back to opponent. source.push(ts = Date.now()) //we'll serve next time. timer = setTimeout(ping, timeout) } }, function (err) { clearTimeout(timer) }), rtt: rtt, skew: skew } } },{"pull-pushable":370,"pull-stream":365,"statistics":575}],365:[function(require,module,exports){ arguments[4][232][0].apply(exports,arguments) },{"./pull":366,"./sinks":367,"./sources":368,"./throughs":369,"dup":232}],366:[function(require,module,exports){ arguments[4][233][0].apply(exports,arguments) },{"dup":233}],367:[function(require,module,exports){ arguments[4][234][0].apply(exports,arguments) },{"dup":234}],368:[function(require,module,exports){ arguments[4][235][0].apply(exports,arguments) },{"dup":235}],369:[function(require,module,exports){ arguments[4][236][0].apply(exports,arguments) },{"./sinks":367,"./sources":368,"dup":236}],370:[function(require,module,exports){ module.exports = function (onClose) { var buffer = [], ended, abort, cb function callback (err, val) { var _cb = cb if(err && onClose) { var c = onClose onClose = null c(err === true ? null : err) } cb = null _cb(err, val) } function drain() { if(!cb) return if(abort) callback(abort) else if(!buffer.length && ended) callback(ended) else if(buffer.length) callback(null, buffer.shift()) } function read (_abort, _cb) { if(_abort) { abort = _abort //if there is already a cb waiting, abort it. if(cb) callback(abort) } cb = _cb drain() } read.push = function (data) { if(ended) return buffer.push(data) drain() } read.end = function (end) { ended = ended || end || true; drain() } return read } },{}],371:[function(require,module,exports){ (function (Buffer){ var BufferList = require('bl') module.exports = function () { var bl = new BufferList() function get (n) { var len = n == null ? bl.length : n var data = bl.slice(0, len) bl.consume(n) return data } return { data: bl, add: function (data) { bl.append(data) return this }, has: function (n) { if(n == null) return bl.length > 0 return bl.length >= n }, get: function (n) { if(n == null) return get() if(!this.has(n)) throw new Error( 'current length is:'+bl.length + ', could not get:'+n + ' bytes' ) return get(n) } } var soFar = new Buffer(0) return { data: soFar, add: function (data) { if(!Buffer.isBuffer(data)) throw new Error('data must be a buffer, was: ' + JSON.stringify(data)) this.data = soFar = Buffer.concat([soFar, data]) return this }, has: function (n) { if(null == n) return soFar.length > 0 return soFar.length - (n || 0) >= 0 }, get: function (n) { var next if(null == n) { next = soFar soFar = new Buffer(0) return next } next = soFar.slice(0, n) if(soFar.length < n) throw new Error('current length is:'+soFar.length + ', could not get:'+n + ' bytes') soFar = soFar.slice(n, soFar.length) return next } } } }).call(this,require("buffer").Buffer) },{"bl":22,"buffer":61}],372:[function(require,module,exports){ 'use strict' var State = require('./bl-state') function isInteger (i) { return Number.isFinite(i) } function isFunction (f) { return 'function' === typeof f } function maxDelay(fn, delay) { if(!delay) return fn return function (a, cb) { var timer = setTimeout(function () { fn(new Error('pull-reader: read exceeded timeout'), cb) }, delay) fn(a, function (err, value) { clearTimeout(timer) cb(err, value) }) } } module.exports = function (timeout) { var queue = [], read, readTimed, reading = false var state = State(), ended, streaming, abort function drain () { while (queue.length) { if(null == queue[0].length && state.has(1)) { queue.shift().cb(null, state.get()) } else if(state.has(queue[0].length)) { var next = queue.shift() next.cb(null, state.get(next.length)) } else if(ended) queue.shift().cb(ended) else return !!queue.length } //always read a little data return queue.length || !state.has(1) || abort } function more () { var d = drain() if(d && !reading) if(read && !reading && !streaming) { reading = true readTimed (null, function (err, data) { reading = false if(err) { ended = err return drain() } state.add(data) more() }) } } function reader (_read) { if(abort) { while(queue.length) queue.shift().cb(abort) return cb && cb(abort) } readTimed = maxDelay(_read, timeout) read = _read more() } reader.abort = function (err, cb) { abort = err || true if(read) { reading = true read(abort, function () { while(queue.length) queue.shift().cb(abort) cb && cb(abort) }) } else cb() } reader.read = function (len, timeout, cb) { if(isFunction(timeout)) cb = timeout, timeout = 0 if(isFunction(cb)) { queue.push({length: isInteger(len) ? len : null, cb: cb}) more() } else { //switch into streaming mode for the rest of the stream. streaming = true //wait for the current read to complete return function (abort, cb) { //if there is anything still in the queue, if(reading || state.has(1)) { if(abort) return read(abort, cb) queue.push({length: null, cb: cb}) more() } else maxDelay(read, timeout)(abort, function (err, data) { cb(err, data) }) } } } return reader } },{"./bl-state":371}],373:[function(require,module,exports){ var pull = require('pull-stream') var splitter = require('pull-split') module.exports = function (ps, _JSON, opts) { _JSON = _JSON || JSON opts = opts || {} var separator = opts.separator || '\n' return { sink: pull( splitter(separator), pull.map(function(data) { if (data === '') return data try { return _JSON.parse(data) } catch (e) { if (!opts.ignoreErrors) throw e } }), pull.filter(), ps.sink ), source: pull( ps.source, pull.map(function(data) { if (data !== void 0) return _JSON.stringify(data) + separator }) ) } } },{"pull-split":380,"pull-stream":374}],374:[function(require,module,exports){ arguments[4][179][0].apply(exports,arguments) },{"./maybe":375,"./sinks":376,"./sources":377,"./throughs":378,"dup":179,"pull-core":306}],375:[function(require,module,exports){ arguments[4][180][0].apply(exports,arguments) },{"dup":180,"pull-core":306}],376:[function(require,module,exports){ arguments[4][181][0].apply(exports,arguments) },{"dup":181}],377:[function(require,module,exports){ arguments[4][182][0].apply(exports,arguments) },{"dup":182}],378:[function(require,module,exports){ (function (process){ var u = require('pull-core') var sources = require('./sources') var sinks = require('./sinks') var prop = u.prop var id = u.id var tester = u.tester var map = exports.map = function (read, map) { map = prop(map) || id return function (abort, cb) { read(abort, function (end, data) { try { data = !end ? map(data) : null } catch (err) { return read(err, function () { return cb(err) }) } cb(end, data) }) } } var asyncMap = exports.asyncMap = function (read, map) { if(!map) return read return function (end, cb) { if(end) return read(end, cb) //abort read(null, function (end, data) { if(end) return cb(end, data) map(data, cb) }) } } var paraMap = exports.paraMap = function (read, map, width) { if(!map) return read var ended = false, queue = [], _cb function drain () { if(!_cb) return var cb = _cb _cb = null if(queue.length) return cb(null, queue.shift()) else if(ended && !n) return cb(ended) _cb = cb } function pull () { read(null, function (end, data) { if(end) { ended = end return drain() } n++ map(data, function (err, data) { n-- queue.push(data) drain() }) if(n < width && !ended) pull() }) } var n = 0 return function (end, cb) { if(end) return read(end, cb) //abort //continue to read while there are less than 3 maps in flight _cb = cb if(queue.length || ended) pull(), drain() else pull() } return highWaterMark(asyncMap(read, map), width) } var filter = exports.filter = function (read, test) { //regexp test = tester(test) return function next (end, cb) { var sync, loop = true while(loop) { loop = false sync = true read(end, function (end, data) { if(!end && !test(data)) return sync ? loop = true : next(end, cb) cb(end, data) }) sync = false } } } var filterNot = exports.filterNot = function (read, test) { test = tester(test) return filter(read, function (e) { return !test(e) }) } var through = exports.through = function (read, op, onEnd) { var a = false function once (abort) { if(a || !onEnd) return a = true onEnd(abort === true ? null : abort) } return function (end, cb) { if(end) once(end) return read(end, function (end, data) { if(!end) op && op(data) else once(end) cb(end, data) }) } } var take = exports.take = function (read, test) { var ended = false if('number' === typeof test) { var n = test; test = function () { return n -- } } return function (end, cb) { if(ended) return cb(ended) if(ended = end) return read(ended, cb) read(null, function (end, data) { if(ended = ended || end) return cb(ended) if(!test(data)) { ended = true read(true, function (end, data) { cb(ended, data) }) } else cb(null, data) }) } } var unique = exports.unique = function (read, field, invert) { field = prop(field) || id var seen = {} return filter(read, function (data) { var key = field(data) if(seen[key]) return !!invert //false, by default else seen[key] = true return !invert //true by default }) } var nonUnique = exports.nonUnique = function (read, field) { return unique(read, field, true) } var group = exports.group = function (read, size) { var ended; size = size || 5 var queue = [] return function (end, cb) { //this means that the upstream is sending an error. if(end) return read(ended = end, cb) //this means that we read an end before. if(ended) return cb(ended) read(null, function next(end, data) { if(ended = ended || end) { if(!queue.length) return cb(ended) var _queue = queue; queue = [] return cb(null, _queue) } queue.push(data) if(queue.length < size) return read(null, next) var _queue = queue; queue = [] cb(null, _queue) }) } } var flatten = exports.flatten = function (read) { var _read return function (abort, cb) { if(_read) nextChunk() else nextStream() function nextChunk () { _read(null, function (end, data) { if(end) nextStream() else cb(null, data) }) } function nextStream () { read(null, function (end, stream) { if(end) return cb(end) if(Array.isArray(stream) || stream && 'object' === typeof stream) stream = sources.values(stream) else if('function' != typeof stream) throw new Error('expected stream of streams') _read = stream nextChunk() }) } } } var prepend = exports.prepend = function (read, head) { return function (abort, cb) { if(head !== null) { if(abort) return read(abort, cb) var _head = head head = null cb(null, _head) } else { read(abort, cb) } } } //var drainIf = exports.drainIf = function (op, done) { // sinks.drain( //} var _reduce = exports._reduce = function (read, reduce, initial) { return function (close, cb) { if(close) return read(close, cb) if(ended) return cb(ended) sinks.drain(function (item) { initial = reduce(initial, item) }, function (err, data) { ended = err || true if(!err) cb(null, initial) else cb(ended) }) (read) } } var nextTick = process.nextTick var highWaterMark = exports.highWaterMark = function (read, highWaterMark) { var buffer = [], waiting = [], ended, ending, reading = false highWaterMark = highWaterMark || 10 function readAhead () { while(waiting.length && (buffer.length || ended)) waiting.shift()(ended, ended ? null : buffer.shift()) if (!buffer.length && ending) ended = ending; } function next () { if(ended || ending || reading || buffer.length >= highWaterMark) return reading = true return read(ended || ending, function (end, data) { reading = false ending = ending || end if(data != null) buffer.push(data) next(); readAhead() }) } process.nextTick(next) return function (end, cb) { ended = ended || end waiting.push(cb) next(); readAhead() } } var flatMap = exports.flatMap = function (read, mapper) { mapper = mapper || id var queue = [], ended return function (abort, cb) { if(queue.length) return cb(null, queue.shift()) else if(ended) return cb(ended) read(abort, function next (end, data) { if(end) ended = end else { var add = mapper(data) while(add && add.length) queue.push(add.shift()) } if(queue.length) cb(null, queue.shift()) else if(ended) cb(ended) else read(null, next) }) } } }).call(this,require('_process')) },{"./sinks":376,"./sources":377,"_process":295,"pull-core":306}],379:[function(require,module,exports){ module.exports = function (create) { var reader = null return function (read) { if('function' !== typeof read) throw new Error('read must be function') return function (abort, cb) { if(abort) (reader ? reader.abort : read)(abort, cb) else if(!reader) (reader = create(cb))(read) else //there will only be one value, so assume this is the end cb(true) } } } },{}],380:[function(require,module,exports){ var through = require('pull-through') module.exports = function split (matcher, mapper, reverse) { var soFar = '' if('function' === typeof matcher) mapper = matcher, matcher = null if (!matcher) matcher = '\n' return through(function (buffer) { var stream = this , pieces = ( reverse ? buffer + soFar : soFar + buffer ).split(matcher) soFar = reverse ? pieces.shift() : pieces.pop() var l = pieces.length for (var i = 0; i < l; i++) { var piece = pieces[reverse ? l - 1 - i : i ] if(mapper) { piece = mapper(piece) if('undefined' !== typeof piece) stream.queue(piece) } else stream.queue(piece) } }, function () { if(soFar != null) this.queue(soFar) this.queue(null) }) } },{"pull-through":386}],381:[function(require,module,exports){ arguments[4][179][0].apply(exports,arguments) },{"./maybe":382,"./sinks":383,"./sources":384,"./throughs":385,"dup":179,"pull-core":306}],382:[function(require,module,exports){ arguments[4][180][0].apply(exports,arguments) },{"dup":180,"pull-core":306}],383:[function(require,module,exports){ arguments[4][181][0].apply(exports,arguments) },{"dup":181}],384:[function(require,module,exports){ var keys = exports.keys = function (object) { return values(Object.keys(object)) } function abortCb(cb, abort, onAbort) { cb(abort) onAbort && onAbort(abort === true ? null: abort) return } var once = exports.once = function (value, onAbort) { return function (abort, cb) { if(abort) return abortCb(cb, abort, onAbort) if(value != null) { var _value = value; value = null cb(null, _value) } else cb(true) } } var values = exports.values = exports.readArray = function (array, onAbort) { if(!array) return function (abort, cb) { if(abort) return abortCb(cb, abort, onAbort) return cb(true) } if(!Array.isArray(array)) array = Object.keys(array).map(function (k) { return array[k] }) var i = 0 return function (abort, cb) { if(abort) return abortCb(cb, abort, onAbort) cb(i >= array.length || null, array[i++]) } } var count = exports.count = function (max) { var i = 0; max = max || Infinity return function (end, cb) { if(end) return cb && cb(end) if(i > max) return cb(true) cb(null, i++) } } var infinite = exports.infinite = function (generate) { generate = generate || Math.random return function (end, cb) { if(end) return cb && cb(end) return cb(null, generate()) } } var defer = exports.defer = function () { var _read, cbs = [], _end var read = function (end, cb) { if(!_read) { _end = end cbs.push(cb) } else _read(end, cb) } read.resolve = function (read) { if(_read) throw new Error('already resolved') _read = read if(!_read) throw new Error('no read cannot resolve!' + _read) while(cbs.length) _read(_end, cbs.shift()) } read.abort = function(err) { read.resolve(function (_, cb) { cb(err || true) }) } return read } var empty = exports.empty = function () { return function (abort, cb) { cb(true) } } var error = exports.error = function (err) { return function (abort, cb) { cb(err) } } var depthFirst = exports.depthFirst = function (start, createStream) { var reads = [] reads.unshift(once(start)) return function next (end, cb) { if(!reads.length) return cb(true) reads[0](end, function (end, data) { if(end) { //if this stream has ended, go to the next queue reads.shift() return next(null, cb) } reads.unshift(createStream(data)) cb(end, data) }) } } //width first is just like depth first, //but push each new stream onto the end of the queue var widthFirst = exports.widthFirst = function (start, createStream) { var reads = [] reads.push(once(start)) return function next (end, cb) { if(!reads.length) return cb(true) reads[0](end, function (end, data) { if(end) { reads.shift() return next(null, cb) } reads.push(createStream(data)) cb(end, data) }) } } //this came out different to the first (strm) //attempt at leafFirst, but it's still a valid //topological sort. var leafFirst = exports.leafFirst = function (start, createStream) { var reads = [] var output = [] reads.push(once(start)) return function next (end, cb) { reads[0](end, function (end, data) { if(end) { reads.shift() if(!output.length) return cb(true) return cb(null, output.shift()) } reads.unshift(createStream(data)) output.unshift(data) next(null, cb) }) } } },{}],385:[function(require,module,exports){ (function (process){ var u = require('pull-core') var sources = require('./sources') var sinks = require('./sinks') var prop = u.prop var id = u.id var tester = u.tester var map = exports.map = function (read, map) { map = prop(map) || id return function (abort, cb) { read(abort, function (end, data) { try { data = !end ? map(data) : null } catch (err) { return read(err, function () { return cb(err) }) } cb(end, data) }) } } var asyncMap = exports.asyncMap = function (read, map) { if(!map) return read return function (end, cb) { if(end) return read(end, cb) //abort read(null, function (end, data) { if(end) return cb(end, data) map(data, cb) }) } } var paraMap = exports.paraMap = function (read, map, width) { if(!map) return read var ended = false, queue = [], _cb function drain () { if(!_cb) return var cb = _cb _cb = null if(queue.length) return cb(null, queue.shift()) else if(ended && !n) return cb(ended) _cb = cb } function pull () { read(null, function (end, data) { if(end) { ended = end return drain() } n++ map(data, function (err, data) { n-- queue.push(data) drain() }) if(n < width && !ended) pull() }) } var n = 0 return function (end, cb) { if(end) return read(end, cb) //abort //continue to read while there are less than 3 maps in flight _cb = cb if(queue.length || ended) pull(), drain() else pull() } return highWaterMark(asyncMap(read, map), width) } var filter = exports.filter = function (read, test) { //regexp test = tester(test) return function next (end, cb) { var sync, loop = true while(loop) { loop = false sync = true read(end, function (end, data) { if(!end && !test(data)) return sync ? loop = true : next(end, cb) cb(end, data) }) sync = false } } } var filterNot = exports.filterNot = function (read, test) { test = tester(test) return filter(read, function (e) { return !test(e) }) } var through = exports.through = function (read, op, onEnd) { var a = false function once (abort) { if(a || !onEnd) return a = true onEnd(abort === true ? null : abort) } return function (end, cb) { if(end) once(end) return read(end, function (end, data) { if(!end) op && op(data) else once(end) cb(end, data) }) } } var take = exports.take = function (read, test, opts) { opts = opts || {} var last = opts.last || false // whether the first item for which !test(item) should still pass var ended = false if('number' === typeof test) { last = true var n = test; test = function () { return --n } } function terminate (cb) { read(true, function (err) { last = false; cb(err || true) }) } return function (end, cb) { if(ended) last ? terminate(cb) : cb(ended) else if(ended = end) read(ended, cb) else read(null, function (end, data) { if(ended = ended || end) { //last ? terminate(cb) : cb(ended) } else if(!test(data)) { ended = true last ? cb(null, data) : terminate(cb) } else cb(null, data) }) } } var unique = exports.unique = function (read, field, invert) { field = prop(field) || id var seen = {} return filter(read, function (data) { var key = field(data) if(seen[key]) return !!invert //false, by default else seen[key] = true return !invert //true by default }) } var nonUnique = exports.nonUnique = function (read, field) { return unique(read, field, true) } var group = exports.group = function (read, size) { var ended; size = size || 5 var queue = [] return function (end, cb) { //this means that the upstream is sending an error. if(end) return read(ended = end, cb) //this means that we read an end before. if(ended) return cb(ended) read(null, function next(end, data) { if(ended = ended || end) { if(!queue.length) return cb(ended) var _queue = queue; queue = [] return cb(null, _queue) } queue.push(data) if(queue.length < size) return read(null, next) var _queue = queue; queue = [] cb(null, _queue) }) } } var flatten = exports.flatten = function (read) { var _read return function (abort, cb) { if (abort) { _read ? _read(abort, function(err) { read(err || abort, cb) }) : read(abort, cb) } else if(_read) nextChunk() else nextStream() function nextChunk () { _read(null, function (err, data) { if (err === true) nextStream() else if (err) { read(true, function(abortErr) { // TODO: what do we do with the abortErr? cb(err) }) } else cb(null, data) }) } function nextStream () { read(null, function (end, stream) { if(end) return cb(end) if(Array.isArray(stream) || stream && 'object' === typeof stream) stream = sources.values(stream) else if('function' != typeof stream) throw new Error('expected stream of streams') _read = stream nextChunk() }) } } } var prepend = exports.prepend = function (read, head) { return function (abort, cb) { if(head !== null) { if(abort) return read(abort, cb) var _head = head head = null cb(null, _head) } else { read(abort, cb) } } } //var drainIf = exports.drainIf = function (op, done) { // sinks.drain( //} var _reduce = exports._reduce = function (read, reduce, initial) { return function (close, cb) { if(close) return read(close, cb) if(ended) return cb(ended) sinks.drain(function (item) { initial = reduce(initial, item) }, function (err, data) { ended = err || true if(!err) cb(null, initial) else cb(ended) }) (read) } } var nextTick = process.nextTick var highWaterMark = exports.highWaterMark = function (read, highWaterMark) { var buffer = [], waiting = [], ended, ending, reading = false highWaterMark = highWaterMark || 10 function readAhead () { while(waiting.length && (buffer.length || ended)) waiting.shift()(ended, ended ? null : buffer.shift()) if (!buffer.length && ending) ended = ending; } function next () { if(ended || ending || reading || buffer.length >= highWaterMark) return reading = true return read(ended || ending, function (end, data) { reading = false ending = ending || end if(data != null) buffer.push(data) next(); readAhead() }) } process.nextTick(next) return function (end, cb) { ended = ended || end waiting.push(cb) next(); readAhead() } } var flatMap = exports.flatMap = function (read, mapper) { mapper = mapper || id var queue = [], ended return function (abort, cb) { if(queue.length) return cb(null, queue.shift()) else if(ended) return cb(ended) read(abort, function next (end, data) { if(end) ended = end else { var add = mapper(data) while(add && add.length) queue.push(add.shift()) } if(queue.length) cb(null, queue.shift()) else if(ended) cb(ended) else read(null, next) }) } } }).call(this,require('_process')) },{"./sinks":383,"./sources":384,"_process":295,"pull-core":306}],386:[function(require,module,exports){ var looper = require('looper') module.exports = function (writer, ender) { return function (read) { var queue = [], ended, error function enqueue (data) { queue.push(data) } writer = writer || function (data) { this.queue(data) } ender = ender || function () { this.queue(null) } var emitter = { emit: function (event, data) { if(event == 'data') enqueue(data) if(event == 'end') ended = true, enqueue(null) if(event == 'error') error = data }, queue: enqueue } var _cb return function (end, cb) { ended = ended || end if(end) return read(end, function () { if(_cb) { var t = _cb; _cb = null; t(end) } cb(end) }) _cb = cb looper(function pull (next) { //if it's an error if(!_cb) return cb = _cb if(error) _cb = null, cb(error) else if(queue.length) { var data = queue.shift() _cb = null,cb(data === null, data) } else { read(ended, function (end, data) { //null has no special meaning for pull-stream if(end && end !== true) { error = end; return next() } if(ended = ended || end) ender.call(emitter) else if(data !== null) { writer.call(emitter, data) if(error || ended) return read(error || ended, function () { _cb = null; cb(error || ended) }) } next(pull) }) } }) } } } },{"looper":387}],387:[function(require,module,exports){ var looper = module.exports = function (fun) { (function next () { var loop = true, returned = false, sync = false do { sync = true; loop = false fun.call(this, function () { if(sync) loop = true else next() }) sync = false } while(loop) })() } },{}],388:[function(require,module,exports){ var once = exports.once = function (value) { return function (abort, cb) { if(abort) return cb(abort) if(value != null) { var _value = value; value = null cb(null, _value) } else cb(true) } } var depthFirst = exports.depthFirst = function (start, createStream) { var reads = [], ended reads.unshift(once(start)) return function next (end, cb) { if(!reads.length) return cb(true) if(ended) return cb(ended) reads[0](end, function (end, data) { if(end) { if(end !== true) { ended = end reads.shift() while(reads.length) reads.shift()(end, function () {}) return cb(end) } //if this stream has ended, go to the next queue reads.shift() return next(null, cb) } reads.unshift(createStream(data)) cb(end, data) }) } } //width first is just like depth first, //but push each new stream onto the end of the queue var widthFirst = exports.widthFirst = function (start, createStream) { var reads = [] reads.push(once(start)) return function next (end, cb) { if(!reads.length) return cb(true) reads[0](end, function (end, data) { if(end) { reads.shift() return next(null, cb) } reads.push(createStream(data)) cb(end, data) }) } } //this came out different to the first (strm) //attempt at leafFirst, but it's still a valid //topological sort. var leafFirst = exports.leafFirst = function (start, createStream) { var reads = [] var output = [] reads.push(once(start)) return function next (end, cb) { reads[0](end, function (end, data) { if(end) { reads.shift() if(!output.length) return cb(true) return cb(null, output.shift()) } reads.unshift(createStream(data)) output.unshift(data) next(null, cb) }) } } },{}],389:[function(require,module,exports){ var Decode = require('string_decoder').StringDecoder module.exports = function (enc) { var decoder = new Decode(enc), ended return function (read) { return function (abort, cb) { if(ended) return cb(ended) read(abort, function (end, data) { ended = end if(true === end) { if(data = decoder.end()) cb(null, data) else cb(true) } else if(end && (true !== end)) cb(end) else cb(null, decoder.write(data)) }) } } } },{"string_decoder":616}],390:[function(require,module,exports){ var looper = require('looper') var Through = require('pull-core').Through var window = module.exports = Through(function (read, init, start) { start = start || function (start, data) { return {start: start, data: data} } var windows = [], output = [], ended = null var data, end var j = 0 return function (abort, cb) { if(output.length) return cb(null, output.shift()) if(ended) return cb(ended) var i = 0 var k = j ++ read(abort, looper(function (end, data) { var next = this var reduce, update, once = false if(end) ended = end function _update (end, _data) { if(once) return once = true delete windows[windows.indexOf(update)] output.push(start(data, _data)) } if(!ended) update = init(data, _update) if(update) windows.push(update) else //don't allow data unless a window started here! once = true windows.forEach(function (update, i) { update(end, data) }) if(output.length) return cb(null, output.shift()) else if(ended) return cb(ended) else read(null, next) })) } }) window.recent = function (size, time) { var current = null return window(function (data, cb) { if(current) return current = [] var timer function done () { var _current = current current = null clearTimeout(timer) cb(null, _current) } if(time) timer = setTimeout(done, time) return function (end, data) { if(end) return done() current.push(data) if(size != null && current.length >= size) done() } }, function (_, data) { return data }) } window.sliding = function (reduce, width) { width = width || 10 var k = 0 return window(function (data, cb) { var acc var i = 0 var l = k++ return function (end, data) { if(end) return acc = reduce(acc, data) if(width <= ++ i) cb(null, acc) } }) } },{"looper":225,"pull-core":391}],391:[function(require,module,exports){ arguments[4][345][0].apply(exports,arguments) },{"dup":345}],392:[function(require,module,exports){ var fs = require('fs') module.exports = function (path, opts, cb) { if('function' == typeof opts) cb = opts, opts = null var flags = opts && opts.flags || 'w' var mode = opts && opts.mode || 0666 var pos = 0 return function (read) { fs.open(path, flags, mode, function (err, fd) { read(null, function next (end, data) { if(end === true) fs.close(fd, cb) else if(end) cb(end) //error! else fs.write(fd, data, 0, data.length, pos, function (err, bytes) { if(err) read(err, function () { fs.close(fd, cb) }) else pos += bytes, read(null, next) }) }) }) } } },{"fs":58}],393:[function(require,module,exports){ //another idea: buffer 2* the max, but only call write with half of that, //this could manage cases where the read ahead is latent. Hmm, we probably //shouldn't guess at that here, just handle write latency. //how would we measure this anyway? function append (array, item) { (array = array || []).push(item) return array } module.exports = function (write, reduce, max, cb) { reduce = reduce || append var ended return function (read) { var queue = null, writing = false, length = 0 function flush () { if(writing) return var _queue = queue queue = null; writing = true; length = 0 write(_queue, function (err) { writing = false if(ended === true && !length) cb(err) else if(ended && ended !== true) cb(err || ended) else if(err) read(ended = err, cb) //abort upstream. else if(length) flush() else read(null, next) }) } function next (end, data) { if(ended) return ended = end if(!ended) { queue = reduce(queue, data) length = (queue && queue.length) || 0 if(queue != null) flush() if(length < max) read(null, next) } else if(!writing) cb(ended === true ? null : ended) } read(null, next) } } },{}],394:[function(require,module,exports){ 'use strict'; var ws = require('pull-ws') var WebSocket = require('ws') var url = require('url') function isFunction (f) { return 'function' === typeof f } exports.connect = function (addr, opts) { var stream if(isFunction(opts)) { var cb = opts var called = false opts = { onOpen: function () { if(called) return called = true cb(null, stream) }, onClose: function (err) { if(called) return called = true cb(err) } } } var u = ( 'string' === typeof addr ? addr : url.format({ protocol: 'ws', slashes: true, hostname: addr.host || addr.hostname, port: addr.port, pathname: addr.pathname }) ) var socket = new WebSocket(u) stream = ws(socket) stream.remoteAddress = u if (opts && typeof opts.onOpen == 'function') { socket.addEventListener('open', opts.onOpen) } if (opts && typeof opts.onClose == 'function') { socket.addEventListener('close', opts.onClose) } stream.close = function (cb) { if (cb && typeof cb == 'function') socket.addEventListener('close', cb) socket.close() } return stream } },{"pull-ws":395,"url":632,"ws":642}],395:[function(require,module,exports){ exports = module.exports = duplex; exports.source = require('./source'); exports.sink = require('./sink'); function duplex (ws, opts) { return { source: exports.source(ws), sink: exports.sink(ws, opts) }; }; },{"./sink":397,"./source":398}],396:[function(require,module,exports){ module.exports = function(socket, callback) { var remove = socket && (socket.removeEventListener || socket.removeListener); function cleanup () { if (typeof remove == 'function') { remove.call(socket, 'open', handleOpen); remove.call(socket, 'error', handleErr); } } function handleOpen(evt) { cleanup(); callback(); } function handleErr (evt) { cleanup(); callback(evt); } // if the socket is closing or closed, return end if (socket.readyState >= 2) { return callback(true); } // if open, trigger the callback if (socket.readyState === 1) { return callback(); } socket.addEventListener('open', handleOpen); socket.addEventListener('error', handleErr); }; },{}],397:[function(require,module,exports){ (function (process){ var pull = require('pull-core'); var ready = require('./ready'); /** ### `sink(socket, opts?)` Create a pull-stream `Sink` that will write data to the `socket`. <<< examples/write.js **/ module.exports = pull.Sink(function(read, socket, opts) { opts = opts || {} var closeOnEnd = opts.closeOnEnd !== false; var onClose = 'function' === typeof opts ? opts : opts.onClose; function next(end, data) { // if the stream has ended, simply return if (end) { if (closeOnEnd && socket.readyState <= 1) { if(onClose) socket.addEventListener('close', function (ev) { if(ev.wasClean) onClose() else { var err = new Error('ws error') err.event = ev onClose(err) } }); socket.close(); } return; } // socket ready? ready(socket, function(end) { if (end) { return read(end, function () {}); } socket.send(data); process.nextTick(function() { read(null, next); }); }); } read(null, next); }); }).call(this,require('_process')) },{"./ready":396,"_process":295,"pull-core":306}],398:[function(require,module,exports){ var pull = require('pull-core'); var ready = require('./ready'); /** ### `source(socket)` Create a pull-stream `Source` that will read data from the `socket`. <<< examples/read.js **/ module.exports = pull.Source(function(socket) { var buffer = []; var receiver; var ended; socket.addEventListener('message', function(evt) { if (receiver) { return receiver(null, evt.data); } buffer.push(evt.data); }); socket.addEventListener('close', function(evt) { if (ended) return; if (receiver) { return receiver(ended = true); } }); socket.addEventListener('error', function (evt) { if (ended) return; ended = evt; if (receiver) { receiver(ended); } }); function read(abort, cb) { receiver = null; //if stream has already ended. if (ended) return cb(ended) // if ended, abort if (abort) { //this will callback when socket closes receiver = cb return socket.close() } ready(socket, function(end) { if (end) { return cb(ended = end); } // read from the socket if (ended && ended !== true) { return cb(ended); } else if (buffer.length > 0) { return cb(null, buffer.shift()); } else if (ended) { return cb(true); } receiver = cb; }); }; return read; }); },{"./ready":396,"pull-core":306}],399:[function(require,module,exports){ (function (global){ /*! https://mths.be/punycode v1.3.2 by @mathias */ ;(function(root) { /** Detect free variables */ var freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports; var freeModule = typeof module == 'object' && module && !module.nodeType && module; var freeGlobal = typeof global == 'object' && global; if ( freeGlobal.global === freeGlobal || freeGlobal.window === freeGlobal || freeGlobal.self === freeGlobal ) { root = freeGlobal; } /** * The `punycode` object. * @name punycode * @type Object */ var punycode, /** Highest positive signed 32-bit float value */ maxInt = 2147483647, // aka. 0x7FFFFFFF or 2^31-1 /** Bootstring parameters */ base = 36, tMin = 1, tMax = 26, skew = 38, damp = 700, initialBias = 72, initialN = 128, // 0x80 delimiter = '-', // '\x2D' /** Regular expressions */ regexPunycode = /^xn--/, regexNonASCII = /[^\x20-\x7E]/, // unprintable ASCII chars + non-ASCII chars regexSeparators = /[\x2E\u3002\uFF0E\uFF61]/g, // RFC 3490 separators /** Error messages */ errors = { 'overflow': 'Overflow: input needs wider integers to process', 'not-basic': 'Illegal input >= 0x80 (not a basic code point)', 'invalid-input': 'Invalid input' }, /** Convenience shortcuts */ baseMinusTMin = base - tMin, floor = Math.floor, stringFromCharCode = String.fromCharCode, /** Temporary variable */ key; /*--------------------------------------------------------------------------*/ /** * A generic error utility function. * @private * @param {String} type The error type. * @returns {Error} Throws a `RangeError` with the applicable error message. */ function error(type) { throw RangeError(errors[type]); } /** * A generic `Array#map` utility function. * @private * @param {Array} array The array to iterate over. * @param {Function} callback The function that gets called for every array * item. * @returns {Array} A new array of values returned by the callback function. */ function map(array, fn) { var length = array.length; var result = []; while (length--) { result[length] = fn(array[length]); } return result; } /** * A simple `Array#map`-like wrapper to work with domain name strings or email * addresses. * @private * @param {String} domain The domain name or email address. * @param {Function} callback The function that gets called for every * character. * @returns {Array} A new string of characters returned by the callback * function. */ function mapDomain(string, fn) { var parts = string.split('@'); var result = ''; if (parts.length > 1) { // In email addresses, only the domain name should be punycoded. Leave // the local part (i.e. everything up to `@`) intact. result = parts[0] + '@'; string = parts[1]; } // Avoid `split(regex)` for IE8 compatibility. See #17. string = string.replace(regexSeparators, '\x2E'); var labels = string.split('.'); var encoded = map(labels, fn).join('.'); return result + encoded; } /** * Creates an array containing the numeric code points of each Unicode * character in the string. While JavaScript uses UCS-2 internally, * this function will convert a pair of surrogate halves (each of which * UCS-2 exposes as separate characters) into a single code point, * matching UTF-16. * @see `punycode.ucs2.encode` * @see * @memberOf punycode.ucs2 * @name decode * @param {String} string The Unicode input string (UCS-2). * @returns {Array} The new array of code points. */ function ucs2decode(string) { var output = [], counter = 0, length = string.length, value, extra; while (counter < length) { value = string.charCodeAt(counter++); if (value >= 0xD800 && value <= 0xDBFF && counter < length) { // high surrogate, and there is a next character extra = string.charCodeAt(counter++); if ((extra & 0xFC00) == 0xDC00) { // low surrogate output.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000); } else { // unmatched surrogate; only append this code unit, in case the next // code unit is the high surrogate of a surrogate pair output.push(value); counter--; } } else { output.push(value); } } return output; } /** * Creates a string based on an array of numeric code points. * @see `punycode.ucs2.decode` * @memberOf punycode.ucs2 * @name encode * @param {Array} codePoints The array of numeric code points. * @returns {String} The new Unicode string (UCS-2). */ function ucs2encode(array) { return map(array, function(value) { var output = ''; if (value > 0xFFFF) { value -= 0x10000; output += stringFromCharCode(value >>> 10 & 0x3FF | 0xD800); value = 0xDC00 | value & 0x3FF; } output += stringFromCharCode(value); return output; }).join(''); } /** * Converts a basic code point into a digit/integer. * @see `digitToBasic()` * @private * @param {Number} codePoint The basic numeric code point value. * @returns {Number} The numeric value of a basic code point (for use in * representing integers) in the range `0` to `base - 1`, or `base` if * the code point does not represent a value. */ function basicToDigit(codePoint) { if (codePoint - 48 < 10) { return codePoint - 22; } if (codePoint - 65 < 26) { return codePoint - 65; } if (codePoint - 97 < 26) { return codePoint - 97; } return base; } /** * Converts a digit/integer into a basic code point. * @see `basicToDigit()` * @private * @param {Number} digit The numeric value of a basic code point. * @returns {Number} The basic code point whose value (when used for * representing integers) is `digit`, which needs to be in the range * `0` to `base - 1`. If `flag` is non-zero, the uppercase form is * used; else, the lowercase form is used. The behavior is undefined * if `flag` is non-zero and `digit` has no uppercase form. */ function digitToBasic(digit, flag) { // 0..25 map to ASCII a..z or A..Z // 26..35 map to ASCII 0..9 return digit + 22 + 75 * (digit < 26) - ((flag != 0) << 5); } /** * Bias adaptation function as per section 3.4 of RFC 3492. * http://tools.ietf.org/html/rfc3492#section-3.4 * @private */ function adapt(delta, numPoints, firstTime) { var k = 0; delta = firstTime ? floor(delta / damp) : delta >> 1; delta += floor(delta / numPoints); for (/* no initialization */; delta > baseMinusTMin * tMax >> 1; k += base) { delta = floor(delta / baseMinusTMin); } return floor(k + (baseMinusTMin + 1) * delta / (delta + skew)); } /** * Converts a Punycode string of ASCII-only symbols to a string of Unicode * symbols. * @memberOf punycode * @param {String} input The Punycode string of ASCII-only symbols. * @returns {String} The resulting string of Unicode symbols. */ function decode(input) { // Don't use UCS-2 var output = [], inputLength = input.length, out, i = 0, n = initialN, bias = initialBias, basic, j, index, oldi, w, k, digit, t, /** Cached calculation results */ baseMinusT; // Handle the basic code points: let `basic` be the number of input code // points before the last delimiter, or `0` if there is none, then copy // the first basic code points to the output. basic = input.lastIndexOf(delimiter); if (basic < 0) { basic = 0; } for (j = 0; j < basic; ++j) { // if it's not a basic code point if (input.charCodeAt(j) >= 0x80) { error('not-basic'); } output.push(input.charCodeAt(j)); } // Main decoding loop: start just after the last delimiter if any basic code // points were copied; start at the beginning otherwise. for (index = basic > 0 ? basic + 1 : 0; index < inputLength; /* no final expression */) { // `index` is the index of the next character to be consumed. // Decode a generalized variable-length integer into `delta`, // which gets added to `i`. The overflow checking is easier // if we increase `i` as we go, then subtract off its starting // value at the end to obtain `delta`. for (oldi = i, w = 1, k = base; /* no condition */; k += base) { if (index >= inputLength) { error('invalid-input'); } digit = basicToDigit(input.charCodeAt(index++)); if (digit >= base || digit > floor((maxInt - i) / w)) { error('overflow'); } i += digit * w; t = k <= bias ? tMin : (k >= bias + tMax ? tMax : k - bias); if (digit < t) { break; } baseMinusT = base - t; if (w > floor(maxInt / baseMinusT)) { error('overflow'); } w *= baseMinusT; } out = output.length + 1; bias = adapt(i - oldi, out, oldi == 0); // `i` was supposed to wrap around from `out` to `0`, // incrementing `n` each time, so we'll fix that now: if (floor(i / out) > maxInt - n) { error('overflow'); } n += floor(i / out); i %= out; // Insert `n` at position `i` of the output output.splice(i++, 0, n); } return ucs2encode(output); } /** * Converts a string of Unicode symbols (e.g. a domain name label) to a * Punycode string of ASCII-only symbols. * @memberOf punycode * @param {String} input The string of Unicode symbols. * @returns {String} The resulting Punycode string of ASCII-only symbols. */ function encode(input) { var n, delta, handledCPCount, basicLength, bias, j, m, q, k, t, currentValue, output = [], /** `inputLength` will hold the number of code points in `input`. */ inputLength, /** Cached calculation results */ handledCPCountPlusOne, baseMinusT, qMinusT; // Convert the input in UCS-2 to Unicode input = ucs2decode(input); // Cache the length inputLength = input.length; // Initialize the state n = initialN; delta = 0; bias = initialBias; // Handle the basic code points for (j = 0; j < inputLength; ++j) { currentValue = input[j]; if (currentValue < 0x80) { output.push(stringFromCharCode(currentValue)); } } handledCPCount = basicLength = output.length; // `handledCPCount` is the number of code points that have been handled; // `basicLength` is the number of basic code points. // Finish the basic string - if it is not empty - with a delimiter if (basicLength) { output.push(delimiter); } // Main encoding loop: while (handledCPCount < inputLength) { // All non-basic code points < n have been handled already. Find the next // larger one: for (m = maxInt, j = 0; j < inputLength; ++j) { currentValue = input[j]; if (currentValue >= n && currentValue < m) { m = currentValue; } } // Increase `delta` enough to advance the decoder's state to , // but guard against overflow handledCPCountPlusOne = handledCPCount + 1; if (m - n > floor((maxInt - delta) / handledCPCountPlusOne)) { error('overflow'); } delta += (m - n) * handledCPCountPlusOne; n = m; for (j = 0; j < inputLength; ++j) { currentValue = input[j]; if (currentValue < n && ++delta > maxInt) { error('overflow'); } if (currentValue == n) { // Represent delta as a generalized variable-length integer for (q = delta, k = base; /* no condition */; k += base) { t = k <= bias ? tMin : (k >= bias + tMax ? tMax : k - bias); if (q < t) { break; } qMinusT = q - t; baseMinusT = base - t; output.push( stringFromCharCode(digitToBasic(t + qMinusT % baseMinusT, 0)) ); q = floor(qMinusT / baseMinusT); } output.push(stringFromCharCode(digitToBasic(q, 0))); bias = adapt(delta, handledCPCountPlusOne, handledCPCount == basicLength); delta = 0; ++handledCPCount; } } ++delta; ++n; } return output.join(''); } /** * Converts a Punycode string representing a domain name or an email address * to Unicode. Only the Punycoded parts of the input will be converted, i.e. * it doesn't matter if you call it on a string that has already been * converted to Unicode. * @memberOf punycode * @param {String} input The Punycoded domain name or email address to * convert to Unicode. * @returns {String} The Unicode representation of the given Punycode * string. */ function toUnicode(input) { return mapDomain(input, function(string) { return regexPunycode.test(string) ? decode(string.slice(4).toLowerCase()) : string; }); } /** * Converts a Unicode string representing a domain name or an email address to * Punycode. Only the non-ASCII parts of the domain name will be converted, * i.e. it doesn't matter if you call it with a domain that's already in * ASCII. * @memberOf punycode * @param {String} input The domain name or email address to convert, as a * Unicode string. * @returns {String} The Punycode representation of the given domain name or * email address. */ function toASCII(input) { return mapDomain(input, function(string) { return regexNonASCII.test(string) ? 'xn--' + encode(string) : string; }); } /*--------------------------------------------------------------------------*/ /** Define the public API */ punycode = { /** * A string representing the current Punycode.js version number. * @memberOf punycode * @type String */ 'version': '1.3.2', /** * An object of methods to convert from JavaScript's internal character * representation (UCS-2) to Unicode code points, and back. * @see * @memberOf punycode * @type Object */ 'ucs2': { 'decode': ucs2decode, 'encode': ucs2encode }, 'decode': decode, 'encode': encode, 'toASCII': toASCII, 'toUnicode': toUnicode }; /** Expose `punycode` */ // Some AMD build optimizers, like r.js, check for specific condition patterns // like the following: if ( typeof define == 'function' && typeof define.amd == 'object' && define.amd ) { define('punycode', function() { return punycode; }); } else if (freeExports && freeModule) { if (module.exports == freeExports) { // in Node.js or RingoJS v0.8.0+ freeModule.exports = punycode; } else { // in Narwhal or RingoJS v0.7.0- for (key in punycode) { punycode.hasOwnProperty(key) && (freeExports[key] = punycode[key]); } } } else { // in Rhino or a web browser root.punycode = punycode; } }(this)); }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) },{}],400:[function(require,module,exports){ // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. 'use strict'; // If obj.hasOwnProperty has been overridden, then calling // obj.hasOwnProperty(prop) will break. // See: https://github.com/joyent/node/issues/1707 function hasOwnProperty(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); } module.exports = function(qs, sep, eq, options) { sep = sep || '&'; eq = eq || '='; var obj = {}; if (typeof qs !== 'string' || qs.length === 0) { return obj; } var regexp = /\+/g; qs = qs.split(sep); var maxKeys = 1000; if (options && typeof options.maxKeys === 'number') { maxKeys = options.maxKeys; } var len = qs.length; // maxKeys <= 0 means that we should not limit keys count if (maxKeys > 0 && len > maxKeys) { len = maxKeys; } for (var i = 0; i < len; ++i) { var x = qs[i].replace(regexp, '%20'), idx = x.indexOf(eq), kstr, vstr, k, v; if (idx >= 0) { kstr = x.substr(0, idx); vstr = x.substr(idx + 1); } else { kstr = x; vstr = ''; } k = decodeURIComponent(kstr); v = decodeURIComponent(vstr); if (!hasOwnProperty(obj, k)) { obj[k] = v; } else if (isArray(obj[k])) { obj[k].push(v); } else { obj[k] = [obj[k], v]; } } return obj; }; var isArray = Array.isArray || function (xs) { return Object.prototype.toString.call(xs) === '[object Array]'; }; },{}],401:[function(require,module,exports){ // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. 'use strict'; var stringifyPrimitive = function(v) { switch (typeof v) { case 'string': return v; case 'boolean': return v ? 'true' : 'false'; case 'number': return isFinite(v) ? v : ''; default: return ''; } }; module.exports = function(obj, sep, eq, name) { sep = sep || '&'; eq = eq || '='; if (obj === null) { obj = undefined; } if (typeof obj === 'object') { return map(objectKeys(obj), function(k) { var ks = encodeURIComponent(stringifyPrimitive(k)) + eq; if (isArray(obj[k])) { return map(obj[k], function(v) { return ks + encodeURIComponent(stringifyPrimitive(v)); }).join(sep); } else { return ks + encodeURIComponent(stringifyPrimitive(obj[k])); } }).join(sep); } if (!name) return ''; return encodeURIComponent(stringifyPrimitive(name)) + eq + encodeURIComponent(stringifyPrimitive(obj)); }; var isArray = Array.isArray || function (xs) { return Object.prototype.toString.call(xs) === '[object Array]'; }; function map (xs, f) { if (xs.map) return xs.map(f); var res = []; for (var i = 0; i < xs.length; i++) { res.push(f(xs[i], i)); } return res; } var objectKeys = Object.keys || function (obj) { var res = []; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) res.push(key); } return res; }; },{}],402:[function(require,module,exports){ 'use strict'; exports.decode = exports.parse = require('./decode'); exports.encode = exports.stringify = require('./encode'); },{"./decode":400,"./encode":401}],403:[function(require,module,exports){ (function (process,global,Buffer){ 'use strict' function oldBrowser () { throw new Error('secure random number generation not supported by this browser\nuse chrome, FireFox or Internet Explorer 11') } var crypto = global.crypto || global.msCrypto if (crypto && crypto.getRandomValues) { module.exports = randomBytes } else { module.exports = oldBrowser } function randomBytes (size, cb) { // phantomjs needs to throw if (size > 65536) throw new Error('requested too many random bytes') // in case browserify isn't using the Uint8Array version var rawBytes = new global.Uint8Array(size) // This will not work in older browsers. // See https://developer.mozilla.org/en-US/docs/Web/API/window.crypto.getRandomValues if (size > 0) { // getRandomValues fails on IE if size == 0 crypto.getRandomValues(rawBytes) } // phantomjs doesn't like a buffer being passed here var bytes = new Buffer(rawBytes.buffer) if (typeof cb === 'function') { return process.nextTick(function () { cb(null, bytes) }) } return bytes } }).call(this,require('_process'),typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {},require("buffer").Buffer) },{"_process":295,"buffer":61}],404:[function(require,module,exports){ // when this is loaded into the browser, // just use the defaults... module.exports = function (name, defaults) { return defaults } },{}],405:[function(require,module,exports){ (function (process){ // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. // a duplex stream is just a stream that is both readable and writable. // Since JS doesn't have multiple prototypal inheritance, this class // prototypally inherits from Readable, and then parasitically from // Writable. module.exports = Duplex; /**/ var objectKeys = Object.keys || function (obj) { var keys = []; for (var key in obj) keys.push(key); return keys; } /**/ /**/ var util = require('core-util-is'); util.inherits = require('inherits'); /**/ var Readable = require('./_stream_readable'); var Writable = require('./_stream_writable'); util.inherits(Duplex, Readable); forEach(objectKeys(Writable.prototype), function(method) { if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method]; }); function Duplex(options) { if (!(this instanceof Duplex)) return new Duplex(options); Readable.call(this, options); Writable.call(this, options); if (options && options.readable === false) this.readable = false; if (options && options.writable === false) this.writable = false; this.allowHalfOpen = true; if (options && options.allowHalfOpen === false) this.allowHalfOpen = false; this.once('end', onend); } // the no-half-open enforcer function onend() { // if we allow half-open state, or if the writable side ended, // then we're ok. if (this.allowHalfOpen || this._writableState.ended) return; // no more data can be written. // But allow more writes to happen in this tick. process.nextTick(this.end.bind(this)); } function forEach (xs, f) { for (var i = 0, l = xs.length; i < l; i++) { f(xs[i], i); } } }).call(this,require('_process')) },{"./_stream_readable":407,"./_stream_writable":409,"_process":295,"core-util-is":104,"inherits":167}],406:[function(require,module,exports){ arguments[4][215][0].apply(exports,arguments) },{"./_stream_transform":408,"core-util-is":104,"dup":215,"inherits":167}],407:[function(require,module,exports){ (function (process){ // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. module.exports = Readable; /**/ var isArray = require('isarray'); /**/ /**/ var Buffer = require('buffer').Buffer; /**/ Readable.ReadableState = ReadableState; var EE = require('events').EventEmitter; /**/ if (!EE.listenerCount) EE.listenerCount = function(emitter, type) { return emitter.listeners(type).length; }; /**/ var Stream = require('stream'); /**/ var util = require('core-util-is'); util.inherits = require('inherits'); /**/ var StringDecoder; /**/ var debug = require('util'); if (debug && debug.debuglog) { debug = debug.debuglog('stream'); } else { debug = function () {}; } /**/ util.inherits(Readable, Stream); function ReadableState(options, stream) { var Duplex = require('./_stream_duplex'); options = options || {}; // the point at which it stops calling _read() to fill the buffer // Note: 0 is a valid value, means "don't call _read preemptively ever" var hwm = options.highWaterMark; var defaultHwm = options.objectMode ? 16 : 16 * 1024; this.highWaterMark = (hwm || hwm === 0) ? hwm : defaultHwm; // cast to ints. this.highWaterMark = ~~this.highWaterMark; this.buffer = []; this.length = 0; this.pipes = null; this.pipesCount = 0; this.flowing = null; this.ended = false; this.endEmitted = false; this.reading = false; // a flag to be able to tell if the onwrite cb is called immediately, // or on a later tick. We set this to true at first, because any // actions that shouldn't happen until "later" should generally also // not happen before the first write call. this.sync = true; // whenever we return null, then we set a flag to say // that we're awaiting a 'readable' event emission. this.needReadable = false; this.emittedReadable = false; this.readableListening = false; // object stream flag. Used to make read(n) ignore n and to // make all the buffer merging and length checks go away this.objectMode = !!options.objectMode; if (stream instanceof Duplex) this.objectMode = this.objectMode || !!options.readableObjectMode; // Crypto is kind of old and crusty. Historically, its default string // encoding is 'binary' so we have to make this configurable. // Everything else in the universe uses 'utf8', though. this.defaultEncoding = options.defaultEncoding || 'utf8'; // when piping, we only care about 'readable' events that happen // after read()ing all the bytes and not getting any pushback. this.ranOut = false; // the number of writers that are awaiting a drain event in .pipe()s this.awaitDrain = 0; // if true, a maybeReadMore has been scheduled this.readingMore = false; this.decoder = null; this.encoding = null; if (options.encoding) { if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder; this.decoder = new StringDecoder(options.encoding); this.encoding = options.encoding; } } function Readable(options) { var Duplex = require('./_stream_duplex'); if (!(this instanceof Readable)) return new Readable(options); this._readableState = new ReadableState(options, this); // legacy this.readable = true; Stream.call(this); } // Manually shove something into the read() buffer. // This returns true if the highWaterMark has not been hit yet, // similar to how Writable.write() returns true if you should // write() some more. Readable.prototype.push = function(chunk, encoding) { var state = this._readableState; if (util.isString(chunk) && !state.objectMode) { encoding = encoding || state.defaultEncoding; if (encoding !== state.encoding) { chunk = new Buffer(chunk, encoding); encoding = ''; } } return readableAddChunk(this, state, chunk, encoding, false); }; // Unshift should *always* be something directly out of read() Readable.prototype.unshift = function(chunk) { var state = this._readableState; return readableAddChunk(this, state, chunk, '', true); }; function readableAddChunk(stream, state, chunk, encoding, addToFront) { var er = chunkInvalid(state, chunk); if (er) { stream.emit('error', er); } else if (util.isNullOrUndefined(chunk)) { state.reading = false; if (!state.ended) onEofChunk(stream, state); } else if (state.objectMode || chunk && chunk.length > 0) { if (state.ended && !addToFront) { var e = new Error('stream.push() after EOF'); stream.emit('error', e); } else if (state.endEmitted && addToFront) { var e = new Error('stream.unshift() after end event'); stream.emit('error', e); } else { if (state.decoder && !addToFront && !encoding) chunk = state.decoder.write(chunk); if (!addToFront) state.reading = false; // if we want the data now, just emit it. if (state.flowing && state.length === 0 && !state.sync) { stream.emit('data', chunk); stream.read(0); } else { // update the buffer info. state.length += state.objectMode ? 1 : chunk.length; if (addToFront) state.buffer.unshift(chunk); else state.buffer.push(chunk); if (state.needReadable) emitReadable(stream); } maybeReadMore(stream, state); } } else if (!addToFront) { state.reading = false; } return needMoreData(state); } // if it's past the high water mark, we can push in some more. // Also, if we have no data yet, we can stand some // more bytes. This is to work around cases where hwm=0, // such as the repl. Also, if the push() triggered a // readable event, and the user called read(largeNumber) such that // needReadable was set, then we ought to push more, so that another // 'readable' event will be triggered. function needMoreData(state) { return !state.ended && (state.needReadable || state.length < state.highWaterMark || state.length === 0); } // backwards compatibility. Readable.prototype.setEncoding = function(enc) { if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder; this._readableState.decoder = new StringDecoder(enc); this._readableState.encoding = enc; return this; }; // Don't raise the hwm > 128MB var MAX_HWM = 0x800000; function roundUpToNextPowerOf2(n) { if (n >= MAX_HWM) { n = MAX_HWM; } else { // Get the next highest power of 2 n--; for (var p = 1; p < 32; p <<= 1) n |= n >> p; n++; } return n; } function howMuchToRead(n, state) { if (state.length === 0 && state.ended) return 0; if (state.objectMode) return n === 0 ? 0 : 1; if (isNaN(n) || util.isNull(n)) { // only flow one buffer at a time if (state.flowing && state.buffer.length) return state.buffer[0].length; else return state.length; } if (n <= 0) return 0; // If we're asking for more than the target buffer level, // then raise the water mark. Bump up to the next highest // power of 2, to prevent increasing it excessively in tiny // amounts. if (n > state.highWaterMark) state.highWaterMark = roundUpToNextPowerOf2(n); // don't have that much. return null, unless we've ended. if (n > state.length) { if (!state.ended) { state.needReadable = true; return 0; } else return state.length; } return n; } // you can override either this method, or the async _read(n) below. Readable.prototype.read = function(n) { debug('read', n); var state = this._readableState; var nOrig = n; if (!util.isNumber(n) || n > 0) state.emittedReadable = false; // if we're doing read(0) to trigger a readable event, but we // already have a bunch of data in the buffer, then just trigger // the 'readable' event and move on. if (n === 0 && state.needReadable && (state.length >= state.highWaterMark || state.ended)) { debug('read: emitReadable', state.length, state.ended); if (state.length === 0 && state.ended) endReadable(this); else emitReadable(this); return null; } n = howMuchToRead(n, state); // if we've ended, and we're now clear, then finish it up. if (n === 0 && state.ended) { if (state.length === 0) endReadable(this); return null; } // All the actual chunk generation logic needs to be // *below* the call to _read. The reason is that in certain // synthetic stream cases, such as passthrough streams, _read // may be a completely synchronous operation which may change // the state of the read buffer, providing enough data when // before there was *not* enough. // // So, the steps are: // 1. Figure out what the state of things will be after we do // a read from the buffer. // // 2. If that resulting state will trigger a _read, then call _read. // Note that this may be asynchronous, or synchronous. Yes, it is // deeply ugly to write APIs this way, but that still doesn't mean // that the Readable class should behave improperly, as streams are // designed to be sync/async agnostic. // Take note if the _read call is sync or async (ie, if the read call // has returned yet), so that we know whether or not it's safe to emit // 'readable' etc. // // 3. Actually pull the requested chunks out of the buffer and return. // if we need a readable event, then we need to do some reading. var doRead = state.needReadable; debug('need readable', doRead); // if we currently have less than the highWaterMark, then also read some if (state.length === 0 || state.length - n < state.highWaterMark) { doRead = true; debug('length less than watermark', doRead); } // however, if we've ended, then there's no point, and if we're already // reading, then it's unnecessary. if (state.ended || state.reading) { doRead = false; debug('reading or ended', doRead); } if (doRead) { debug('do read'); state.reading = true; state.sync = true; // if the length is currently zero, then we *need* a readable event. if (state.length === 0) state.needReadable = true; // call internal read method this._read(state.highWaterMark); state.sync = false; } // If _read pushed data synchronously, then `reading` will be false, // and we need to re-evaluate how much data we can return to the user. if (doRead && !state.reading) n = howMuchToRead(nOrig, state); var ret; if (n > 0) ret = fromList(n, state); else ret = null; if (util.isNull(ret)) { state.needReadable = true; n = 0; } state.length -= n; // If we have nothing in the buffer, then we want to know // as soon as we *do* get something into the buffer. if (state.length === 0 && !state.ended) state.needReadable = true; // If we tried to read() past the EOF, then emit end on the next tick. if (nOrig !== n && state.ended && state.length === 0) endReadable(this); if (!util.isNull(ret)) this.emit('data', ret); return ret; }; function chunkInvalid(state, chunk) { var er = null; if (!util.isBuffer(chunk) && !util.isString(chunk) && !util.isNullOrUndefined(chunk) && !state.objectMode) { er = new TypeError('Invalid non-string/buffer chunk'); } return er; } function onEofChunk(stream, state) { if (state.decoder && !state.ended) { var chunk = state.decoder.end(); if (chunk && chunk.length) { state.buffer.push(chunk); state.length += state.objectMode ? 1 : chunk.length; } } state.ended = true; // emit 'readable' now to make sure it gets picked up. emitReadable(stream); } // Don't emit readable right away in sync mode, because this can trigger // another read() call => stack overflow. This way, it might trigger // a nextTick recursion warning, but that's not so bad. function emitReadable(stream) { var state = stream._readableState; state.needReadable = false; if (!state.emittedReadable) { debug('emitReadable', state.flowing); state.emittedReadable = true; if (state.sync) process.nextTick(function() { emitReadable_(stream); }); else emitReadable_(stream); } } function emitReadable_(stream) { debug('emit readable'); stream.emit('readable'); flow(stream); } // at this point, the user has presumably seen the 'readable' event, // and called read() to consume some data. that may have triggered // in turn another _read(n) call, in which case reading = true if // it's in progress. // However, if we're not ended, or reading, and the length < hwm, // then go ahead and try to read some more preemptively. function maybeReadMore(stream, state) { if (!state.readingMore) { state.readingMore = true; process.nextTick(function() { maybeReadMore_(stream, state); }); } } function maybeReadMore_(stream, state) { var len = state.length; while (!state.reading && !state.flowing && !state.ended && state.length < state.highWaterMark) { debug('maybeReadMore read 0'); stream.read(0); if (len === state.length) // didn't get any data, stop spinning. break; else len = state.length; } state.readingMore = false; } // abstract method. to be overridden in specific implementation classes. // call cb(er, data) where data is <= n in length. // for virtual (non-string, non-buffer) streams, "length" is somewhat // arbitrary, and perhaps not very meaningful. Readable.prototype._read = function(n) { this.emit('error', new Error('not implemented')); }; Readable.prototype.pipe = function(dest, pipeOpts) { var src = this; var state = this._readableState; switch (state.pipesCount) { case 0: state.pipes = dest; break; case 1: state.pipes = [state.pipes, dest]; break; default: state.pipes.push(dest); break; } state.pipesCount += 1; debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts); var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr; var endFn = doEnd ? onend : cleanup; if (state.endEmitted) process.nextTick(endFn); else src.once('end', endFn); dest.on('unpipe', onunpipe); function onunpipe(readable) { debug('onunpipe'); if (readable === src) { cleanup(); } } function onend() { debug('onend'); dest.end(); } // when the dest drains, it reduces the awaitDrain counter // on the source. This would be more elegant with a .once() // handler in flow(), but adding and removing repeatedly is // too slow. var ondrain = pipeOnDrain(src); dest.on('drain', ondrain); function cleanup() { debug('cleanup'); // cleanup event handlers once the pipe is broken dest.removeListener('close', onclose); dest.removeListener('finish', onfinish); dest.removeListener('drain', ondrain); dest.removeListener('error', onerror); dest.removeListener('unpipe', onunpipe); src.removeListener('end', onend); src.removeListener('end', cleanup); src.removeListener('data', ondata); // if the reader is waiting for a drain event from this // specific writer, then it would cause it to never start // flowing again. // So, if this is awaiting a drain, then we just call it now. // If we don't know, then assume that we are waiting for one. if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain(); } src.on('data', ondata); function ondata(chunk) { debug('ondata'); var ret = dest.write(chunk); if (false === ret) { debug('false write response, pause', src._readableState.awaitDrain); src._readableState.awaitDrain++; src.pause(); } } // if the dest has an error, then stop piping into it. // however, don't suppress the throwing behavior for this. function onerror(er) { debug('onerror', er); unpipe(); dest.removeListener('error', onerror); if (EE.listenerCount(dest, 'error') === 0) dest.emit('error', er); } // This is a brutally ugly hack to make sure that our error handler // is attached before any userland ones. NEVER DO THIS. if (!dest._events || !dest._events.error) dest.on('error', onerror); else if (isArray(dest._events.error)) dest._events.error.unshift(onerror); else dest._events.error = [onerror, dest._events.error]; // Both close and finish should trigger unpipe, but only once. function onclose() { dest.removeListener('finish', onfinish); unpipe(); } dest.once('close', onclose); function onfinish() { debug('onfinish'); dest.removeListener('close', onclose); unpipe(); } dest.once('finish', onfinish); function unpipe() { debug('unpipe'); src.unpipe(dest); } // tell the dest that it's being piped to dest.emit('pipe', src); // start the flow if it hasn't been started already. if (!state.flowing) { debug('pipe resume'); src.resume(); } return dest; }; function pipeOnDrain(src) { return function() { var state = src._readableState; debug('pipeOnDrain', state.awaitDrain); if (state.awaitDrain) state.awaitDrain--; if (state.awaitDrain === 0 && EE.listenerCount(src, 'data')) { state.flowing = true; flow(src); } }; } Readable.prototype.unpipe = function(dest) { var state = this._readableState; // if we're not piping anywhere, then do nothing. if (state.pipesCount === 0) return this; // just one destination. most common case. if (state.pipesCount === 1) { // passed in one, but it's not the right one. if (dest && dest !== state.pipes) return this; if (!dest) dest = state.pipes; // got a match. state.pipes = null; state.pipesCount = 0; state.flowing = false; if (dest) dest.emit('unpipe', this); return this; } // slow case. multiple pipe destinations. if (!dest) { // remove all. var dests = state.pipes; var len = state.pipesCount; state.pipes = null; state.pipesCount = 0; state.flowing = false; for (var i = 0; i < len; i++) dests[i].emit('unpipe', this); return this; } // try to find the right one. var i = indexOf(state.pipes, dest); if (i === -1) return this; state.pipes.splice(i, 1); state.pipesCount -= 1; if (state.pipesCount === 1) state.pipes = state.pipes[0]; dest.emit('unpipe', this); return this; }; // set up data events if they are asked for // Ensure readable listeners eventually get something Readable.prototype.on = function(ev, fn) { var res = Stream.prototype.on.call(this, ev, fn); // If listening to data, and it has not explicitly been paused, // then call resume to start the flow of data on the next tick. if (ev === 'data' && false !== this._readableState.flowing) { this.resume(); } if (ev === 'readable' && this.readable) { var state = this._readableState; if (!state.readableListening) { state.readableListening = true; state.emittedReadable = false; state.needReadable = true; if (!state.reading) { var self = this; process.nextTick(function() { debug('readable nexttick read 0'); self.read(0); }); } else if (state.length) { emitReadable(this, state); } } } return res; }; Readable.prototype.addListener = Readable.prototype.on; // pause() and resume() are remnants of the legacy readable stream API // If the user uses them, then switch into old mode. Readable.prototype.resume = function() { var state = this._readableState; if (!state.flowing) { debug('resume'); state.flowing = true; if (!state.reading) { debug('resume read 0'); this.read(0); } resume(this, state); } return this; }; function resume(stream, state) { if (!state.resumeScheduled) { state.resumeScheduled = true; process.nextTick(function() { resume_(stream, state); }); } } function resume_(stream, state) { state.resumeScheduled = false; stream.emit('resume'); flow(stream); if (state.flowing && !state.reading) stream.read(0); } Readable.prototype.pause = function() { debug('call pause flowing=%j', this._readableState.flowing); if (false !== this._readableState.flowing) { debug('pause'); this._readableState.flowing = false; this.emit('pause'); } return this; }; function flow(stream) { var state = stream._readableState; debug('flow', state.flowing); if (state.flowing) { do { var chunk = stream.read(); } while (null !== chunk && state.flowing); } } // wrap an old-style stream as the async data source. // This is *not* part of the readable stream interface. // It is an ugly unfortunate mess of history. Readable.prototype.wrap = function(stream) { var state = this._readableState; var paused = false; var self = this; stream.on('end', function() { debug('wrapped end'); if (state.decoder && !state.ended) { var chunk = state.decoder.end(); if (chunk && chunk.length) self.push(chunk); } self.push(null); }); stream.on('data', function(chunk) { debug('wrapped data'); if (state.decoder) chunk = state.decoder.write(chunk); if (!chunk || !state.objectMode && !chunk.length) return; var ret = self.push(chunk); if (!ret) { paused = true; stream.pause(); } }); // proxy all the other methods. // important when wrapping filters and duplexes. for (var i in stream) { if (util.isFunction(stream[i]) && util.isUndefined(this[i])) { this[i] = function(method) { return function() { return stream[method].apply(stream, arguments); }}(i); } } // proxy certain important events. var events = ['error', 'close', 'destroy', 'pause', 'resume']; forEach(events, function(ev) { stream.on(ev, self.emit.bind(self, ev)); }); // when we try to consume some more bytes, simply unpause the // underlying stream. self._read = function(n) { debug('wrapped _read', n); if (paused) { paused = false; stream.resume(); } }; return self; }; // exposed for testing purposes only. Readable._fromList = fromList; // Pluck off n bytes from an array of buffers. // Length is the combined lengths of all the buffers in the list. function fromList(n, state) { var list = state.buffer; var length = state.length; var stringMode = !!state.decoder; var objectMode = !!state.objectMode; var ret; // nothing in the list, definitely empty. if (list.length === 0) return null; if (length === 0) ret = null; else if (objectMode) ret = list.shift(); else if (!n || n >= length) { // read it all, truncate the array. if (stringMode) ret = list.join(''); else ret = Buffer.concat(list, length); list.length = 0; } else { // read just some of it. if (n < list[0].length) { // just take a part of the first list item. // slice is the same for buffers and strings. var buf = list[0]; ret = buf.slice(0, n); list[0] = buf.slice(n); } else if (n === list[0].length) { // first list is a perfect match ret = list.shift(); } else { // complex case. // we have enough to cover it, but it spans past the first buffer. if (stringMode) ret = ''; else ret = new Buffer(n); var c = 0; for (var i = 0, l = list.length; i < l && c < n; i++) { var buf = list[0]; var cpy = Math.min(n - c, buf.length); if (stringMode) ret += buf.slice(0, cpy); else buf.copy(ret, c, 0, cpy); if (cpy < buf.length) list[0] = buf.slice(cpy); else list.shift(); c += cpy; } } } return ret; } function endReadable(stream) { var state = stream._readableState; // If we get here before consuming all the bytes, then that is a // bug in node. Should never happen. if (state.length > 0) throw new Error('endReadable called on non-empty stream'); if (!state.endEmitted) { state.ended = true; process.nextTick(function() { // Check that we didn't get one last unshift. if (!state.endEmitted && state.length === 0) { state.endEmitted = true; stream.readable = false; stream.emit('end'); } }); } } function forEach (xs, f) { for (var i = 0, l = xs.length; i < l; i++) { f(xs[i], i); } } function indexOf (xs, x) { for (var i = 0, l = xs.length; i < l; i++) { if (xs[i] === x) return i; } return -1; } }).call(this,require('_process')) },{"./_stream_duplex":405,"_process":295,"buffer":61,"core-util-is":104,"events":144,"inherits":167,"isarray":172,"stream":576,"string_decoder/":616,"util":33}],408:[function(require,module,exports){ // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. // a transform stream is a readable/writable stream where you do // something with the data. Sometimes it's called a "filter", // but that's not a great name for it, since that implies a thing where // some bits pass through, and others are simply ignored. (That would // be a valid example of a transform, of course.) // // While the output is causally related to the input, it's not a // necessarily symmetric or synchronous transformation. For example, // a zlib stream might take multiple plain-text writes(), and then // emit a single compressed chunk some time in the future. // // Here's how this works: // // The Transform stream has all the aspects of the readable and writable // stream classes. When you write(chunk), that calls _write(chunk,cb) // internally, and returns false if there's a lot of pending writes // buffered up. When you call read(), that calls _read(n) until // there's enough pending readable data buffered up. // // In a transform stream, the written data is placed in a buffer. When // _read(n) is called, it transforms the queued up data, calling the // buffered _write cb's as it consumes chunks. If consuming a single // written chunk would result in multiple output chunks, then the first // outputted bit calls the readcb, and subsequent chunks just go into // the read buffer, and will cause it to emit 'readable' if necessary. // // This way, back-pressure is actually determined by the reading side, // since _read has to be called to start processing a new chunk. However, // a pathological inflate type of transform can cause excessive buffering // here. For example, imagine a stream where every byte of input is // interpreted as an integer from 0-255, and then results in that many // bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in // 1kb of data being output. In this case, you could write a very small // amount of input, and end up with a very large amount of output. In // such a pathological inflating mechanism, there'd be no way to tell // the system to stop doing the transform. A single 4MB write could // cause the system to run out of memory. // // However, even in such a pathological case, only a single written chunk // would be consumed, and then the rest would wait (un-transformed) until // the results of the previous transformed chunk were consumed. module.exports = Transform; var Duplex = require('./_stream_duplex'); /**/ var util = require('core-util-is'); util.inherits = require('inherits'); /**/ util.inherits(Transform, Duplex); function TransformState(options, stream) { this.afterTransform = function(er, data) { return afterTransform(stream, er, data); }; this.needTransform = false; this.transforming = false; this.writecb = null; this.writechunk = null; } function afterTransform(stream, er, data) { var ts = stream._transformState; ts.transforming = false; var cb = ts.writecb; if (!cb) return stream.emit('error', new Error('no writecb in Transform class')); ts.writechunk = null; ts.writecb = null; if (!util.isNullOrUndefined(data)) stream.push(data); if (cb) cb(er); var rs = stream._readableState; rs.reading = false; if (rs.needReadable || rs.length < rs.highWaterMark) { stream._read(rs.highWaterMark); } } function Transform(options) { if (!(this instanceof Transform)) return new Transform(options); Duplex.call(this, options); this._transformState = new TransformState(options, this); // when the writable side finishes, then flush out anything remaining. var stream = this; // start out asking for a readable event once data is transformed. this._readableState.needReadable = true; // we have implemented the _read method, and done the other things // that Readable wants before the first _read call, so unset the // sync guard flag. this._readableState.sync = false; this.once('prefinish', function() { if (util.isFunction(this._flush)) this._flush(function(er) { done(stream, er); }); else done(stream); }); } Transform.prototype.push = function(chunk, encoding) { this._transformState.needTransform = false; return Duplex.prototype.push.call(this, chunk, encoding); }; // This is the part where you do stuff! // override this function in implementation classes. // 'chunk' is an input chunk. // // Call `push(newChunk)` to pass along transformed output // to the readable side. You may call 'push' zero or more times. // // Call `cb(err)` when you are done with this chunk. If you pass // an error, then that'll put the hurt on the whole operation. If you // never call cb(), then you'll never get another chunk. Transform.prototype._transform = function(chunk, encoding, cb) { throw new Error('not implemented'); }; Transform.prototype._write = function(chunk, encoding, cb) { var ts = this._transformState; ts.writecb = cb; ts.writechunk = chunk; ts.writeencoding = encoding; if (!ts.transforming) { var rs = this._readableState; if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark); } }; // Doesn't matter what the args are here. // _transform does all the work. // That we got here means that the readable side wants more data. Transform.prototype._read = function(n) { var ts = this._transformState; if (!util.isNull(ts.writechunk) && ts.writecb && !ts.transforming) { ts.transforming = true; this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform); } else { // mark that we need a transform, so that any data that comes in // will get processed, now that we've asked for it. ts.needTransform = true; } }; function done(stream, er) { if (er) return stream.emit('error', er); // if there's nothing in the write buffer, then that means // that nothing more will ever be provided var ws = stream._writableState; var ts = stream._transformState; if (ws.length) throw new Error('calling transform done when ws.length != 0'); if (ts.transforming) throw new Error('calling transform done when still transforming'); return stream.push(null); } },{"./_stream_duplex":405,"core-util-is":104,"inherits":167}],409:[function(require,module,exports){ (function (process){ // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. // A bit simpler than readable streams. // Implement an async ._write(chunk, cb), and it'll handle all // the drain event emission and buffering. module.exports = Writable; /**/ var Buffer = require('buffer').Buffer; /**/ Writable.WritableState = WritableState; /**/ var util = require('core-util-is'); util.inherits = require('inherits'); /**/ var Stream = require('stream'); util.inherits(Writable, Stream); function WriteReq(chunk, encoding, cb) { this.chunk = chunk; this.encoding = encoding; this.callback = cb; } function WritableState(options, stream) { var Duplex = require('./_stream_duplex'); options = options || {}; // the point at which write() starts returning false // Note: 0 is a valid value, means that we always return false if // the entire buffer is not flushed immediately on write() var hwm = options.highWaterMark; var defaultHwm = options.objectMode ? 16 : 16 * 1024; this.highWaterMark = (hwm || hwm === 0) ? hwm : defaultHwm; // object stream flag to indicate whether or not this stream // contains buffers or objects. this.objectMode = !!options.objectMode; if (stream instanceof Duplex) this.objectMode = this.objectMode || !!options.writableObjectMode; // cast to ints. this.highWaterMark = ~~this.highWaterMark; this.needDrain = false; // at the start of calling end() this.ending = false; // when end() has been called, and returned this.ended = false; // when 'finish' is emitted this.finished = false; // should we decode strings into buffers before passing to _write? // this is here so that some node-core streams can optimize string // handling at a lower level. var noDecode = options.decodeStrings === false; this.decodeStrings = !noDecode; // Crypto is kind of old and crusty. Historically, its default string // encoding is 'binary' so we have to make this configurable. // Everything else in the universe uses 'utf8', though. this.defaultEncoding = options.defaultEncoding || 'utf8'; // not an actual buffer we keep track of, but a measurement // of how much we're waiting to get pushed to some underlying // socket or file. this.length = 0; // a flag to see when we're in the middle of a write. this.writing = false; // when true all writes will be buffered until .uncork() call this.corked = 0; // a flag to be able to tell if the onwrite cb is called immediately, // or on a later tick. We set this to true at first, because any // actions that shouldn't happen until "later" should generally also // not happen before the first write call. this.sync = true; // a flag to know if we're processing previously buffered items, which // may call the _write() callback in the same tick, so that we don't // end up in an overlapped onwrite situation. this.bufferProcessing = false; // the callback that's passed to _write(chunk,cb) this.onwrite = function(er) { onwrite(stream, er); }; // the callback that the user supplies to write(chunk,encoding,cb) this.writecb = null; // the amount that is being written when _write is called. this.writelen = 0; this.buffer = []; // number of pending user-supplied write callbacks // this must be 0 before 'finish' can be emitted this.pendingcb = 0; // emit prefinish if the only thing we're waiting for is _write cbs // This is relevant for synchronous Transform streams this.prefinished = false; // True if the error was already emitted and should not be thrown again this.errorEmitted = false; } function Writable(options) { var Duplex = require('./_stream_duplex'); // Writable ctor is applied to Duplexes, though they're not // instanceof Writable, they're instanceof Readable. if (!(this instanceof Writable) && !(this instanceof Duplex)) return new Writable(options); this._writableState = new WritableState(options, this); // legacy. this.writable = true; Stream.call(this); } // Otherwise people can pipe Writable streams, which is just wrong. Writable.prototype.pipe = function() { this.emit('error', new Error('Cannot pipe. Not readable.')); }; function writeAfterEnd(stream, state, cb) { var er = new Error('write after end'); // TODO: defer error events consistently everywhere, not just the cb stream.emit('error', er); process.nextTick(function() { cb(er); }); } // If we get something that is not a buffer, string, null, or undefined, // and we're not in objectMode, then that's an error. // Otherwise stream chunks are all considered to be of length=1, and the // watermarks determine how many objects to keep in the buffer, rather than // how many bytes or characters. function validChunk(stream, state, chunk, cb) { var valid = true; if (!util.isBuffer(chunk) && !util.isString(chunk) && !util.isNullOrUndefined(chunk) && !state.objectMode) { var er = new TypeError('Invalid non-string/buffer chunk'); stream.emit('error', er); process.nextTick(function() { cb(er); }); valid = false; } return valid; } Writable.prototype.write = function(chunk, encoding, cb) { var state = this._writableState; var ret = false; if (util.isFunction(encoding)) { cb = encoding; encoding = null; } if (util.isBuffer(chunk)) encoding = 'buffer'; else if (!encoding) encoding = state.defaultEncoding; if (!util.isFunction(cb)) cb = function() {}; if (state.ended) writeAfterEnd(this, state, cb); else if (validChunk(this, state, chunk, cb)) { state.pendingcb++; ret = writeOrBuffer(this, state, chunk, encoding, cb); } return ret; }; Writable.prototype.cork = function() { var state = this._writableState; state.corked++; }; Writable.prototype.uncork = function() { var state = this._writableState; if (state.corked) { state.corked--; if (!state.writing && !state.corked && !state.finished && !state.bufferProcessing && state.buffer.length) clearBuffer(this, state); } }; function decodeChunk(state, chunk, encoding) { if (!state.objectMode && state.decodeStrings !== false && util.isString(chunk)) { chunk = new Buffer(chunk, encoding); } return chunk; } // if we're already writing something, then just put this // in the queue, and wait our turn. Otherwise, call _write // If we return false, then we need a drain event, so set that flag. function writeOrBuffer(stream, state, chunk, encoding, cb) { chunk = decodeChunk(state, chunk, encoding); if (util.isBuffer(chunk)) encoding = 'buffer'; var len = state.objectMode ? 1 : chunk.length; state.length += len; var ret = state.length < state.highWaterMark; // we must ensure that previous needDrain will not be reset to false. if (!ret) state.needDrain = true; if (state.writing || state.corked) state.buffer.push(new WriteReq(chunk, encoding, cb)); else doWrite(stream, state, false, len, chunk, encoding, cb); return ret; } function doWrite(stream, state, writev, len, chunk, encoding, cb) { state.writelen = len; state.writecb = cb; state.writing = true; state.sync = true; if (writev) stream._writev(chunk, state.onwrite); else stream._write(chunk, encoding, state.onwrite); state.sync = false; } function onwriteError(stream, state, sync, er, cb) { if (sync) process.nextTick(function() { state.pendingcb--; cb(er); }); else { state.pendingcb--; cb(er); } stream._writableState.errorEmitted = true; stream.emit('error', er); } function onwriteStateUpdate(state) { state.writing = false; state.writecb = null; state.length -= state.writelen; state.writelen = 0; } function onwrite(stream, er) { var state = stream._writableState; var sync = state.sync; var cb = state.writecb; onwriteStateUpdate(state); if (er) onwriteError(stream, state, sync, er, cb); else { // Check if we're actually ready to finish, but don't emit yet var finished = needFinish(stream, state); if (!finished && !state.corked && !state.bufferProcessing && state.buffer.length) { clearBuffer(stream, state); } if (sync) { process.nextTick(function() { afterWrite(stream, state, finished, cb); }); } else { afterWrite(stream, state, finished, cb); } } } function afterWrite(stream, state, finished, cb) { if (!finished) onwriteDrain(stream, state); state.pendingcb--; cb(); finishMaybe(stream, state); } // Must force callback to be called on nextTick, so that we don't // emit 'drain' before the write() consumer gets the 'false' return // value, and has a chance to attach a 'drain' listener. function onwriteDrain(stream, state) { if (state.length === 0 && state.needDrain) { state.needDrain = false; stream.emit('drain'); } } // if there's something in the buffer waiting, then process it function clearBuffer(stream, state) { state.bufferProcessing = true; if (stream._writev && state.buffer.length > 1) { // Fast case, write everything using _writev() var cbs = []; for (var c = 0; c < state.buffer.length; c++) cbs.push(state.buffer[c].callback); // count the one we are adding, as well. // TODO(isaacs) clean this up state.pendingcb++; doWrite(stream, state, true, state.length, state.buffer, '', function(err) { for (var i = 0; i < cbs.length; i++) { state.pendingcb--; cbs[i](err); } }); // Clear buffer state.buffer = []; } else { // Slow case, write chunks one-by-one for (var c = 0; c < state.buffer.length; c++) { var entry = state.buffer[c]; var chunk = entry.chunk; var encoding = entry.encoding; var cb = entry.callback; var len = state.objectMode ? 1 : chunk.length; doWrite(stream, state, false, len, chunk, encoding, cb); // if we didn't call the onwrite immediately, then // it means that we need to wait until it does. // also, that means that the chunk and cb are currently // being processed, so move the buffer counter past them. if (state.writing) { c++; break; } } if (c < state.buffer.length) state.buffer = state.buffer.slice(c); else state.buffer.length = 0; } state.bufferProcessing = false; } Writable.prototype._write = function(chunk, encoding, cb) { cb(new Error('not implemented')); }; Writable.prototype._writev = null; Writable.prototype.end = function(chunk, encoding, cb) { var state = this._writableState; if (util.isFunction(chunk)) { cb = chunk; chunk = null; encoding = null; } else if (util.isFunction(encoding)) { cb = encoding; encoding = null; } if (!util.isNullOrUndefined(chunk)) this.write(chunk, encoding); // .end() fully uncorks if (state.corked) { state.corked = 1; this.uncork(); } // ignore unnecessary end() calls. if (!state.ending && !state.finished) endWritable(this, state, cb); }; function needFinish(stream, state) { return (state.ending && state.length === 0 && !state.finished && !state.writing); } function prefinish(stream, state) { if (!state.prefinished) { state.prefinished = true; stream.emit('prefinish'); } } function finishMaybe(stream, state) { var need = needFinish(stream, state); if (need) { if (state.pendingcb === 0) { prefinish(stream, state); state.finished = true; stream.emit('finish'); } else prefinish(stream, state); } return need; } function endWritable(stream, state, cb) { state.ending = true; finishMaybe(stream, state); if (cb) { if (state.finished) process.nextTick(cb); else stream.once('finish', cb); } state.ended = true; } }).call(this,require('_process')) },{"./_stream_duplex":405,"_process":295,"buffer":61,"core-util-is":104,"inherits":167,"stream":576}],410:[function(require,module,exports){ (function (process){ exports = module.exports = require('./lib/_stream_readable.js'); exports.Stream = require('stream'); exports.Readable = exports; exports.Writable = require('./lib/_stream_writable.js'); exports.Duplex = require('./lib/_stream_duplex.js'); exports.Transform = require('./lib/_stream_transform.js'); exports.PassThrough = require('./lib/_stream_passthrough.js'); if (!process.browser && process.env.READABLE_STREAM === 'disable') { module.exports = require('stream'); } }).call(this,require('_process')) },{"./lib/_stream_duplex.js":405,"./lib/_stream_passthrough.js":406,"./lib/_stream_readable.js":407,"./lib/_stream_transform.js":408,"./lib/_stream_writable.js":409,"_process":295,"stream":576}],411:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015 Titus Wormer * @license MIT * @module remark:html * @fileoverview Compile Markdown to HTML with remark. */ 'use strict'; /* eslint-env commonjs */ /* * Dependencies. */ var compilers = require('./lib/compilers'); var transformer = require('./lib/transformer'); /** * Attach an HTML compiler. * * @param {Remark} remark - Instance. * @param {Object?} [options] - Configuration. */ function plugin(remark, options) { var MarkdownCompiler = remark.Compiler; var ancestor = MarkdownCompiler.prototype; var proto; var key; /** * Extensible prototype. */ function HTMLCompilerPrototype() {} HTMLCompilerPrototype.prototype = ancestor; proto = new HTMLCompilerPrototype(); proto.options.xhtml = false; proto.options.sanitize = false; proto.options.entities = 'true'; /** * Extensible constructor. * * @param {VFile} file - Virtual file. */ function HTMLCompiler(file) { if (file.extension) { file.move({ 'extension': 'html' }); } MarkdownCompiler.apply(this, [file, options]); } HTMLCompiler.prototype = proto; /* * Expose compilers. */ for (key in compilers) { proto[key] = compilers[key]; } remark.Compiler = HTMLCompiler; return transformer; } /* * Expose `plugin`. */ module.exports = plugin; },{"./lib/compilers":412,"./lib/transformer":414}],412:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015 Titus Wormer * @license MIT * @module remark:html:compilers * @fileoverview Compilers to transform mdast nodes to HTML. */ 'use strict'; /* eslint-env commonjs */ /* * Dependencies. */ var trim = require('trim'); var detab = require('detab'); var collapse = require('collapse-white-space'); var normalizeURI = require('normalize-uri'); var trimLines = require('trim-lines'); var visit = require('unist-util-visit'); var h = require('./h.js'); /* * Compilers. */ var visitors = {}; /** * Return the content of a reference without definition * as markdown. * * @example * failsafe({ * identifier: 'foo', * referenceType: 'shortcut', * children: [ * { * type: 'text', * value: 'foo' * } * ] * }, {}); // '[foo]' * * @param {Node} node - Node to compile. * @param {Node?} definition - Definition node, when * existing. * @param {HTMLCompiler} context - Instance. * @return {string?} - If without definition, returns a * string, returns nothing otherwise. */ function failsafe(node, definition, context) { var result; if (node.referenceType === 'shortcut' && !definition.link) { result = node.children ? context.all(node).join('') : node.alt; return (node.type === 'imageReference' ? '!' : '') + '[' + result + ']'; } return ''; } /** * Stringify all footnote definitions, if any. * * @example * generateFootnotes(); // '
\n
\n...' * * @return {string} - Compiled footnotes, if any. * @this {HTMLCompiler} */ function generateFootnotes() { var self = this; var definitions = self.footnotes; var length = definitions.length; var index = -1; var results = []; var def; if (!length) { return ''; } while (++index < length) { def = definitions[index]; results[index] = self.listItem({ 'type': 'listItem', 'data': { 'htmlAttributes': { 'id': 'fn-' + def.identifier } }, 'children': def.children.concat({ 'type': 'link', 'href': '#fnref-' + def.identifier, 'data': { 'htmlAttributes': { 'class': 'footnote-backref' } }, 'children': [{ 'type': 'text', 'value': '↩' }] }), 'position': def.position }, {}); } return h(self, null, { 'name': 'div', 'attributes': { 'class': 'footnotes' }, 'content': h(self, null, { 'name': 'hr' }) + '\n' + h(self, null, { 'name': 'ol', 'content': results.join('\n') }, null, true) }, null, true) + '\n'; } /** * Stringify an unknown node. * * @example * unknown({ * data: { * htmlName: 'section' * }, * children: [ * { * type: 'text', * value: 'foo' * } * ] * }); // '
foo
' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function unknown(node) { var content = 'children' in node ? this.all(node).join('') : node.value; return h(this, node, { 'name': 'div', 'content': content || '' }, node.data); } /** * Visit a node. * * @example * var compiler = new Compiler(); * * compiler.visit({ * type: 'strong', * children: [{ * type: 'text', * value: 'Foo' * }] * }); * // '**Foo**' * * @param {Object} node - Node. * @param {Object?} [parent] - `node`s parent. * @return {string} - Compiled `node`. */ function one(node, parent) { var self = this; var type = node && node.type; var fn = typeof self[type] === 'function' ? type : 'unknown'; if (!type) { self.file.fail('Expected node `' + node + '`'); } return self[fn](node, parent); } /** * Stringify the children of `node`. * * @example * all({ * children: [ * { * type: 'text', * value: 'foo' * } * ] * }); // 'foo' * * @param {Node} parent - Parent to visit. * @return {Array.} - List of compiled nodes. * @this {HTMLCompiler} */ function all(parent) { var self = this; var nodes = parent.children; var values = []; var index = -1; var length = nodes.length; var value; var prev; while (++index < length) { value = self.visit(nodes[index], parent); if (value) { if (prev && prev.type === 'break') { value = trim.left(value); } values.push(value); } prev = nodes[index]; } return values; } /** * Stringify a root object. * * @example * // This will additionally include defined footnotes, * // when applicable. * root({ * children: [ * { * type: 'paragraph', * children: [ * { * type: 'text', * value: 'foo' * } * ] * } * ] * }); // '

foo

\n' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function root(node) { var self = this; var definitions = {}; var footnotes = []; var result; self.definitions = definitions; self.footnotes = footnotes; visit(node, 'definition', function (definition) { definitions[definition.identifier.toUpperCase()] = definition; }); visit(node, 'footnoteDefinition', function (definition) { footnotes.push(definition); }); result = self.all(node).join('\n'); return (result ? result + '\n' : '') + self.generateFootnotes(); } /** * Stringify a block quote. * * @example * blockquote({ * children: [ * { * type: 'paragraph', * children: [ * { * type: 'text', * value: 'foo' * } * ] * } * ] * }); // '
\n

foo

\n
' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function blockquote(node) { return h(this, node, { 'name': 'blockquote', 'content': this.all(node).join('\n') }, node.data, true); } /** * Stringify an inline footnote. * * @example * // This additionally adds a definition at the bottem * // of the document. * footnote({ * children: [ * { * type: 'text', * value: 'foo' * } * ] * }); // '
1' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function footnote(node) { var self = this; var definitions = self.footnotes; var index = -1; var length = definitions.length; var identifiers = []; var identifier; while (++index < length) { identifiers[index] = definitions[index].identifier; } index = -1; identifier = 1; while (identifiers.indexOf(String(identifier)) !== -1) { identifier++; } identifier = String(identifier); self.footnotes.push({ 'type': 'footnoteDefinition', 'identifier': identifier, 'children': node.children, 'position': node.position }); return self.footnoteReference({ 'type': 'footnoteReference', 'identifier': identifier, 'position': node.position }); } /** * Stringify a list. * * @example * list({ * ordered: true * loose: false * children: [ * { * type: 'listItem', * children: [ * { * type: 'paragraph', * children: [ * { * type: 'text', * value: 'foo' * } * ] * } * ] * } * ] * }); // '
    \n
  1. foo
  2. \n
' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function list(node) { return h(this, node, { 'name': node.ordered ? 'ol' : 'ul', 'attributes': { 'start': node.start !== 1 ? node.start : null }, 'content': this.all(node).join('\n') }, node.data, true); } /** * Stringify a list-item. * * @example * listItem({ * children: [ * { * type: 'paragraph', * children: [ * { * type: 'text', * value: 'foo' * } * ] * } * ] * }, { * loose: false * }); // '
  • foo
  • ' * * @param {Node} node - Node to compile. * @param {Node} parent - Parent of `node`. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function listItem(node, parent) { var single; var result; single = !parent.loose && node.children.length === 1 && node.children[0].children; result = this.all(single ? node.children[0] : node) .join(single ? '' : '\n'); return h(this, node, { 'name': 'li', 'content': result }, node.data, !single); } /** * Stringify a heading. * * @example * heading({ * depth: 3, * children: [ * { * type: 'text', * value: 'foo' * } * ] * }); // '

    foo

    ' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function heading(node) { return h(this, node, { 'name': 'h' + node.depth, 'content': this.all(node).join('') }, node.data); } /** * Stringify a paragraph. * * @example * paragraph({ * children: [ * { * type: 'text', * value: 'foo' * } * ] * }); // 'foo' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function paragraph(node) { return h(this, node, { 'name': 'p', 'content': trim(detab(this.all(node).join(''))) }, node.data); } /** * Stringify a code block. * * @example * code({ * value: 'foo & bar;' * }); // '
    foo &amp; bar\n
    ' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function code(node) { var self = this; var value = node.value ? detab(node.value + '\n') : ''; return h(self, node, { 'name': 'pre', 'content': h(self, node, { 'name': 'code', 'content': self.encode(value) }, node.data) }); } /** * Stringify a table. * * @example * table({ * children: [ * { * type: 'tableRow', * ... * } * ] * }); // '...' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function table(node) { var self = this; var rows = node.children; var index = rows.length; var align = node.align; var alignLength = align.length; var pos; var result = []; var row; var out; var name; var cell; while (index--) { pos = alignLength; row = rows[index].children; out = []; name = index === 0 ? 'th' : 'td'; while (pos--) { cell = row[pos]; out[pos] = h(self, cell, { 'name': name, 'attributes': { 'align': align[pos] }, 'content': cell ? self.all(cell).join('\n') : '' }, cell && cell.data); } result[index] = h(self, rows[index], { 'name': 'tr', 'content': out.join('\n') }, rows[index], true); } return h(self, node, { 'name': 'table', 'content': h(self, node, { 'name': 'thead', 'content': result[0] }, null, true) + '\n' + h(self, node, { 'name': 'tbody', 'content': result.slice(1).join('\n') }, null, true) }, node.data, true); } /** * Stringify a literal HTML. * * @example * html({ * value: 'italic' * }); // 'italic' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function html(node) { return this.options.sanitize ? this.encode(node.value) : node.value; } /** * Stringify a horizontal rule. * * @example * rule(); // '
    ' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function rule(node) { return h(this, node, { 'name': 'hr' }, node.data); } /** * Stringify inline code. * * @example * inlineCode({ * value: 'foo & bar;' * }); // 'foo &amp; bar;' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function inlineCode(node) { return h(this, node, { 'name': 'code', 'content': collapse(this.encode(node.value)) }, node.data); } /** * Stringify strongly emphasised content. * * @example * strong({ * children: [ * { * type: 'text', * value: 'foo' * } * ] * }); // 'foo' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function strong(node) { return h(this, node, { 'name': 'strong', 'content': this.all(node).join('') }, node.data); } /** * Stringify emphasised content. * * @example * emphasis({ * children: [ * { * type: 'text', * value: 'foo' * } * ] * }); // 'foo' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function emphasis(node) { return h(this, node, { 'name': 'em', 'content': this.all(node).join('') }, node.data); } /** * Stringify an inline break. * * @example * hardBreak(); // '
    \n' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function hardBreak(node) { return h(this, node, { 'name': 'br' }, node.data) + '\n'; } /** * Stringify a link. * * @example * link({ * href: 'http://example.com', * children: [ * { * type: 'text', * value: 'foo' * } * ] * }); // 'foo' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function link(node) { return h(this, node, { 'name': 'a', 'attributes': { 'href': normalizeURI(node.href), 'title': node.title }, 'content': this.all(node).join('') }, node.data); } /** * Stringify a reference to a footnote. * * @example * // If a definition was added previously: * footnoteReference({ * identifier: 'foo' * }); * // * // foo * // * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function footnoteReference(node) { var identifier = node.identifier; return h(this, node, { 'name': 'sup', 'attributes': { 'id': 'fnref-' + identifier }, 'content': h(this, node, { 'name': 'a', 'attributes': { 'href': '#fn-' + identifier, 'class': 'footnote-ref' }, 'content': identifier }) }, node.data); } /** * Stringify a reference to a link. * * @example * // If a definition was added previously: * linkReference({ * identifier: 'foo' * }); // '' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function linkReference(node) { var self = this; var def = self.definitions[node.identifier.toUpperCase()] || {}; return failsafe(node, def, self) || h(self, node, { 'name': 'a', 'attributes': { 'href': normalizeURI(def.link || ''), 'title': def.title }, 'content': self.all(node).join('') }, node.data); } /** * Stringify a reference to an image. * * @example * // If a definition was added previously: * imageReference({ * identifier: 'foo' * }); // '' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function imageReference(node) { var self = this; var def = self.definitions[node.identifier.toUpperCase()] || {}; return failsafe(node, def, self) || h(self, node, { 'name': 'img', 'attributes': { 'src': normalizeURI(def.link || ''), 'alt': node.alt || '', 'title': def.title } }, node.data); } /** * Stringify an image. * * @example * image({ * src: 'http://example.com/fav.ico' * }); // '' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function image(node) { return h(this, node, { 'name': 'img', 'attributes': { 'src': normalizeURI(node.src), 'alt': node.alt || '', 'title': node.title } }, node.data); } /** * Stringify a deletion. * * @example * strikethrough({ * children: [ * { * type: 'text', * value: 'foo' * } * ] * }); // 'foo' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function strikethrough(node) { return h(this, node, { 'name': 'del', 'content': this.all(node).join('') }, node.data); } /** * Stringify text. * * @example * text({value: '&'}); // '&' * * text({value: 'foo'}); // 'foo' * * @param {Node} node - Node to compile. * @return {string} - Compiled node. * @this {HTMLCompiler} */ function text(node) { return trimLines(this.encode(node.value)); } /** * Return an empty string for nodes which are ignored. * * @example * ignore(); // '' * * @return {string} - Empty string. * @this {HTMLCompiler} */ function ignore() { return ''; } /* * Helpers. */ visitors.visit = one; visitors.all = all; visitors.unknown = unknown; visitors.generateFootnotes = generateFootnotes; /* * Ignored nodes. */ visitors.yaml = ignore; visitors.definition = ignore; visitors.footnoteDefinition = ignore; /* * Compilers. */ visitors.footnote = footnote; visitors.root = root; visitors.blockquote = blockquote; visitors.list = list; visitors.listItem = listItem; visitors.paragraph = paragraph; visitors.heading = heading; visitors.table = table; visitors.code = code; visitors.html = html; visitors.horizontalRule = rule; visitors.inlineCode = inlineCode; visitors.strong = strong; visitors.emphasis = emphasis; visitors.break = hardBreak; visitors.link = link; visitors.image = image; visitors.footnoteReference = footnoteReference; visitors.linkReference = linkReference; visitors.imageReference = imageReference; visitors.delete = strikethrough; visitors.text = text; visitors.escape = escape; /* * Expose. */ module.exports = visitors; },{"./h.js":413,"collapse-white-space":84,"detab":119,"normalize-uri":273,"trim":622,"trim-lines":620,"unist-util-visit":631}],413:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015 Titus Wormer * @license MIT * @module remark:html:h * @fileoverview * Create HTML nodes. Loosely inspired by * https://github.com/Matt-Esch/virtual-dom/blob/master/ * virtual-hyperscript/index.js */ 'use strict'; /* eslint-env commonjs */ /* * Dependencies. */ var assign = require('object-assign'); /* * Constants. */ var LINE = '\n'; var EMPTY = ''; var SPACE = ' '; var GT = '>'; var LT = '<'; var SLASH = '/'; var QUOTE = '"'; var EQUALS = '='; /* * List of self-closing tags. */ var CLOSING = ['hr', 'img', 'br']; /** * Compile attributes. * * @param {Object?} attributes - Map of attributes. * @param {function(string): string} encode - Strategy * to use. * @param {Node} node - mdast node currently being * compiled. * @return {string} - HTML attributes. */ function toAttributes(attributes, encode, node) { var parameters = []; var key; var value; for (key in attributes) { value = attributes[key]; if (value !== null && value !== undefined) { value = encode(String(value || EMPTY), node); parameters.push(key + EQUALS + QUOTE + value + QUOTE); } } return parameters.length ? parameters.join(SPACE) : EMPTY; } /** * Compile a `node`, in `context`, into HTML. * * @example * h(compiler, { * 'type': 'break' * 'attributes': { * 'id': 'foo' * } * }, 'br') // '
    ' * * h(compiler, { * 'type': 'break' * }, 'br', { * 'id': 'foo' * }) // '
    ' * * @param {HTMLCompiler} context - Context compiler. * @param {Node} node - mdast node. Used for positions * on errors. * @param {Object?} [defaults] - Default HTML configuration. * @param {Object?} [defaults.attributes] - Default Attributes. * @param {Object?} [defaults.content] - Default content. * @param {Object?} [defaults.name] - Default tag-name. * @param {Object?} [data] - Node configuration. * @param {Object?} [data.htmlAttributes] - HTML Attributes. * @param {Object?} [data.htmlContent] - Content of element. * @param {Object?} [data.htmlName] - Tag-name. * @param {boolean} [loose] - Whether to add an initial and * a trailing newline character inside the opening and * closing tags. * @return {string} - HTML representation of `node`, based * on the given options. */ function h(context, node, defaults, data, loose) { var name; var value; var parameters; var content; if (!data) { data = {}; } name = context.encode(data.htmlName || defaults.name); if (data.htmlContent && !context.options.sanitize) { content = data.htmlContent; } else { content = defaults.content || EMPTY; } parameters = toAttributes( assign({}, defaults.attributes, data.htmlAttributes ), context.encode, node); value = LT + name + (parameters ? SPACE + parameters : EMPTY); if (CLOSING.indexOf(name) !== -1) { return value + (context.options.xhtml ? SPACE + SLASH : EMPTY) + GT; } return value + GT + (loose ? LINE : EMPTY) + content + (loose && content ? LINE : EMPTY) + LT + SLASH + name + GT; } /* * Expose. */ module.exports = h; },{"object-assign":274}],414:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015 Titus Wormer * @license MIT * @module remark:html:compilers * @fileoverview AST transformer for HTML. */ 'use strict'; /* eslint-env commonjs */ /* * Dependencies. */ var visit = require('unist-util-visit'); /* * Constants. */ var FIRST_WORD = /^[^\ \t]+(?=[\ \t]|$)/; /** * Helper to get/set `htmlAttributes`. * * @param {Node} node - Node to get data from. * @return {Object} - Attributes. */ function getAttributes(node) { var data = node.data || (node.data = {}); return data.htmlAttributes || (data.htmlAttributes = {}); } /** * Augment a code node. * * @param {Node} node - Code node. */ function code(node) { var lang = node.lang && node.lang.match(FIRST_WORD); var attrs; if (!lang) { return; } attrs = getAttributes(node); attrs.class = (attrs.class ? attrs.class + ' ' : '') + 'language-' + lang; } /* * Map of node-type handlers. */ var handlers = {}; handlers.code = code; /** * Transform `ast`. * * @param {Node} ast - Tree. */ function transformer(ast) { visit(ast, function (node) { if (node.type in handlers) { handlers[node.type](node); } }); } /* * Expose. */ module.exports = transformer; },{"unist-util-visit":631}],415:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015-2016 Titus Wormer * @license MIT * @module remark * @version 3.2.2 * @fileoverview Markdown processor powered by plugins. */ 'use strict'; /* eslint-env commonjs */ /* * Dependencies. */ var unified = require('unified'); var Parser = require('./lib/parse.js'); var Compiler = require('./lib/stringify.js'); var escape = require('./lib/escape.json'); /* * Exports. */ module.exports = unified({ 'name': 'mdast', 'Parser': Parser, 'Compiler': Compiler, 'data': { 'escape': escape } }); },{"./lib/escape.json":418,"./lib/parse.js":419,"./lib/stringify.js":420,"unified":630}],416:[function(require,module,exports){ module.exports=[ "article", "header", "aside", "hgroup", "blockquote", "hr", "iframe", "body", "li", "map", "button", "object", "canvas", "ol", "caption", "output", "col", "p", "colgroup", "pre", "dd", "progress", "div", "section", "dl", "table", "td", "dt", "tbody", "embed", "textarea", "fieldset", "tfoot", "figcaption", "th", "figure", "thead", "footer", "tr", "form", "ul", "h1", "h2", "h3", "h4", "h5", "h6", "video", "script", "style" ] },{}],417:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015-2016 Titus Wormer * @license MIT * @module remark:defaults * @version 3.2.2 * @fileoverview Default values for parse and * stringification settings. */ 'use strict'; /* eslint-env commonjs */ /* * Note that `stringify.entities` is a string. */ module.exports = { 'parse': { 'position': true, 'gfm': true, 'yaml': true, 'commonmark': false, 'footnotes': false, 'pedantic': false, 'breaks': false }, 'stringify': { 'gfm': true, 'commonmark': false, 'entities': 'false', 'setext': false, 'closeAtx': false, 'looseTable': false, 'spacedTable': true, 'incrementListMarker': true, 'fences': false, 'fence': '`', 'bullet': '-', 'listItemIndent': 'tab', 'rule': '*', 'ruleSpaces': true, 'ruleRepetition': 3, 'strong': '*', 'emphasis': '_' } }; },{}],418:[function(require,module,exports){ module.exports={ "default": [ "\\", "`", "*", "{", "}", "[", "]", "(", ")", "#", "+", "-", ".", "!", "_", ">" ], "gfm": [ "\\", "`", "*", "{", "}", "[", "]", "(", ")", "#", "+", "-", ".", "!", "_", ">", "~", "|" ], "commonmark": [ "\\", "`", "*", "{", "}", "[", "]", "(", ")", "#", "+", "-", ".", "!", "_", ">", "~", "|", "\n", "\"", "$", "%", "&", "'", ",", "/", ":", ";", "<", "=", "?", "@", "^" ] } },{}],419:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015-2016 Titus Wormer * @license MIT * @module remark:parse * @version 3.2.2 * @fileoverview Parse a markdown document into an * abstract syntax tree. */ 'use strict'; /* eslint-env commonjs */ /* * Dependencies. */ var decode = require('parse-entities'); var repeat = require('repeat-string'); var trim = require('trim'); var trimTrailingLines = require('trim-trailing-lines'); var extend = require('extend.js'); var utilities = require('./utilities.js'); var defaultOptions = require('./defaults.js').parse; var blockElements = require('./block-elements.json'); /* * Methods. */ var raise = utilities.raise; var clean = utilities.clean; var validate = utilities.validate; var normalize = utilities.normalizeIdentifier; var stateToggler = utilities.stateToggler; var mergeable = utilities.mergeable; var MERGEABLE_NODES = utilities.MERGEABLE_NODES; var has = {}.hasOwnProperty; /* * Numeric constants. */ var SPACE_SIZE = 1; var TAB_SIZE = 4; var CODE_INDENT_LENGTH = 4; var MIN_FENCE_COUNT = 3; var MAX_ATX_COUNT = 6; var MAX_LINE_HEADING_INDENT = 3; var HORIZONTAL_RULE_MARKER_COUNT = 3; var MIN_CLOSING_HTML_NEWLINE_COUNT = 2; var MIN_BREAK_LENGTH = 2; var MIN_TABLE_COLUMNS = 2; var MIN_TABLE_ROWS = 2; /* * Error messages. */ var ERR_INFINITE_LOOP = 'Infinite loop'; var ERR_MISSING_LOCATOR = 'Missing locator: '; var ERR_INCORRECTLY_EATEN = 'Incorrectly eaten value: please report this ' + 'warning on http://git.io/vUYWz'; /* * Expressions. */ var EXPRESSION_BULLET = /^([ \t]*)([*+-]|\d+[.)])( {1,4}(?! )| |\t|$|(?=\n))([^\n]*)/; var EXPRESSION_PEDANTIC_BULLET = /^([ \t]*)([*+-]|\d+[.)])([ \t]+)/; var EXPRESSION_INITIAL_INDENT = /^( {1,4}|\t)?/gm; var EXPRESSION_INITIAL_TAB = /^( {4}|\t)?/gm; var EXPRESSION_HTML_LINK_OPEN = /^/i; var EXPRESSION_LOOSE_LIST_ITEM = /\n\n(?!\s*$)/; var EXPRESSION_TASK_ITEM = /^\[([\ \t]|x|X)\][\ \t]/; /* * Characters. */ var C_BACKSLASH = '\\'; var C_UNDERSCORE = '_'; var C_ASTERISK = '*'; var C_TICK = '`'; var C_AT_SIGN = '@'; var C_HASH = '#'; var C_PLUS = '+'; var C_DASH = '-'; var C_DOT = '.'; var C_PIPE = '|'; var C_DOUBLE_QUOTE = '"'; var C_SINGLE_QUOTE = '\''; var C_COMMA = ','; var C_SLASH = '/'; var C_COLON = ':'; var C_SEMI_COLON = ';'; var C_QUESTION_MARK = '?'; var C_CARET = '^'; var C_EQUALS = '='; var C_EXCLAMATION_MARK = '!'; var C_TILDE = '~'; var C_LT = '<'; var C_GT = '>'; var C_BRACKET_OPEN = '['; var C_BRACKET_CLOSE = ']'; var C_PAREN_OPEN = '('; var C_PAREN_CLOSE = ')'; var C_SPACE = ' '; var C_FORM_FEED = '\f'; var C_NEWLINE = '\n'; var C_CARRIAGE_RETURN = '\r'; var C_TAB = '\t'; var C_VERTICAL_TAB = '\v'; var C_NO_BREAK_SPACE = '\u00a0'; var C_OGHAM_SPACE = '\u1680'; var C_MONGOLIAN_VOWEL_SEPARATOR = '\u180e'; var C_EN_QUAD = '\u2000'; var C_EM_QUAD = '\u2001'; var C_EN_SPACE = '\u2002'; var C_EM_SPACE = '\u2003'; var C_THREE_PER_EM_SPACE = '\u2004'; var C_FOUR_PER_EM_SPACE = '\u2005'; var C_SIX_PER_EM_SPACE = '\u2006'; var C_FIGURE_SPACE = '\u2007'; var C_PUNCTUATION_SPACE = '\u2008'; var C_THIN_SPACE = '\u2009'; var C_HAIR_SPACE = '\u200a'; var C_LINE_SEPARATOR = '​\u2028'; var C_PARAGRAPH_SEPARATOR = '​\u2029'; var C_NARROW_NO_BREAK_SPACE = '\u202f'; var C_IDEOGRAPHIC_SPACE = '\u3000'; var C_ZERO_WIDTH_NO_BREAK_SPACE = '\ufeff'; var C_X_LOWER = 'x'; /* * Character codes. */ var CC_A_LOWER = 'a'.charCodeAt(0); var CC_A_UPPER = 'A'.charCodeAt(0); var CC_Z_LOWER = 'z'.charCodeAt(0); var CC_Z_UPPER = 'Z'.charCodeAt(0); var CC_0 = '0'.charCodeAt(0); var CC_9 = '9'.charCodeAt(0); /* * Protocols. */ var HTTP_PROTOCOL = 'http://'; var HTTPS_PROTOCOL = 'https://'; var MAILTO_PROTOCOL = 'mailto:'; var PROTOCOLS = [ HTTP_PROTOCOL, HTTPS_PROTOCOL, MAILTO_PROTOCOL ]; var PROTOCOLS_LENGTH = PROTOCOLS.length; /* * Textual constants. */ var YAML_FENCE = repeat(C_DASH, 3); var CODE_INDENT = repeat(C_SPACE, CODE_INDENT_LENGTH); var EMPTY = ''; var BLOCK = 'block'; var INLINE = 'inline'; var COMMENT_START = ''; var CDATA_START = ''; var COMMENT_END_CHAR = COMMENT_END.charAt(0); var CDATA_END_CHAR = CDATA_END.charAt(0); var COMMENT_START_LENGTH = COMMENT_START.length; var COMMENT_END_LENGTH = COMMENT_END.length; var CDATA_START_LENGTH = CDATA_START.length; var CDATA_END_LENGTH = CDATA_END.length; /* * Node types. */ var T_HORIZONTAL_RULE = 'horizontalRule'; var T_HTML = 'html'; var T_YAML = 'yaml'; var T_TABLE = 'table'; var T_TABLE_CELL = 'tableCell'; var T_TABLE_HEADER = 'tableHeader'; var T_TABLE_ROW = 'tableRow'; var T_PARAGRAPH = 'paragraph'; var T_TEXT = 'text'; var T_CODE = 'code'; var T_LIST = 'list'; var T_LIST_ITEM = 'listItem'; var T_DEFINITION = 'definition'; var T_FOOTNOTE_DEFINITION = 'footnoteDefinition'; var T_HEADING = 'heading'; var T_BLOCKQUOTE = 'blockquote'; var T_LINK = 'link'; var T_IMAGE = 'image'; var T_FOOTNOTE = 'footnote'; var T_STRONG = 'strong'; var T_EMPHASIS = 'emphasis'; var T_DELETE = 'delete'; var T_INLINE_CODE = 'inlineCode'; var T_BREAK = 'break'; var T_ROOT = 'root'; /* * Available table alignments. */ var TABLE_ALIGN_LEFT = 'left'; var TABLE_ALIGN_CENTER = 'center'; var TABLE_ALIGN_RIGHT = 'right'; var TABLE_ALIGN_NONE = null; /* * Available reference types. */ var REFERENCE_TYPE_SHORTCUT = 'shortcut'; var REFERENCE_TYPE_COLLAPSED = 'collapsed'; var REFERENCE_TYPE_FULL = 'full'; /* * A map of characters, and their column length, * which can be used as indentation. */ var INDENTATION_CHARACTERS = {}; INDENTATION_CHARACTERS[C_SPACE] = SPACE_SIZE; INDENTATION_CHARACTERS[C_TAB] = TAB_SIZE; /* * A map of characters, which can be used to mark emphasis. */ var EMPHASIS_MARKERS = {}; EMPHASIS_MARKERS[C_ASTERISK] = true; EMPHASIS_MARKERS[C_UNDERSCORE] = true; /* * A map of characters, which can be used to mark rules. */ var RULE_MARKERS = {}; RULE_MARKERS[C_ASTERISK] = true; RULE_MARKERS[C_UNDERSCORE] = true; RULE_MARKERS[C_DASH] = true; /* * A map of characters which can be used to mark * list-items. */ var LIST_UNORDERED_MARKERS = {}; LIST_UNORDERED_MARKERS[C_ASTERISK] = true; LIST_UNORDERED_MARKERS[C_PLUS] = true; LIST_UNORDERED_MARKERS[C_DASH] = true; /* * A map of characters which can be used to mark * list-items after a digit. */ var LIST_ORDERED_MARKERS = {}; LIST_ORDERED_MARKERS[C_DOT] = true; /* * A map of characters which can be used to mark * list-items after a digit. */ var LIST_ORDERED_COMMONMARK_MARKERS = {}; LIST_ORDERED_COMMONMARK_MARKERS[C_DOT] = true; LIST_ORDERED_COMMONMARK_MARKERS[C_PAREN_CLOSE] = true; /* * A map of characters, which can be used to mark link * and image titles. */ var LINK_TITLE_MARKERS = {}; LINK_TITLE_MARKERS[C_DOUBLE_QUOTE] = C_DOUBLE_QUOTE; LINK_TITLE_MARKERS[C_SINGLE_QUOTE] = C_SINGLE_QUOTE; /* * A map of characters, which can be used to mark link * and image titles in commonmark-mode. */ var COMMONMARK_LINK_TITLE_MARKERS = {}; COMMONMARK_LINK_TITLE_MARKERS[C_DOUBLE_QUOTE] = C_DOUBLE_QUOTE; COMMONMARK_LINK_TITLE_MARKERS[C_SINGLE_QUOTE] = C_SINGLE_QUOTE; COMMONMARK_LINK_TITLE_MARKERS[C_PAREN_OPEN] = C_PAREN_CLOSE; /* * A map of characters which can be used to mark setext * headers, mapping to their corresponding depth. */ var SETEXT_MARKERS = {}; SETEXT_MARKERS[C_EQUALS] = 1; SETEXT_MARKERS[C_DASH] = 2; /* * A map of two functions which can create list items. */ var LIST_ITEM_MAP = {}; LIST_ITEM_MAP.true = renderPedanticListItem; LIST_ITEM_MAP.false = renderNormalListItem; /** * Check whether `character` is alphabetic. * * @param {string} character - Single character to check. * @return {boolean} - Whether or not `character` is * alphabetic. */ function isAlphabetic(character) { var code = character.charCodeAt(0); return (code >= CC_A_LOWER && code <= CC_Z_LOWER) || (code >= CC_A_UPPER && code <= CC_Z_UPPER); } /** * Check whether `character` is numeric. * * @param {string} character - Single character to check. * @return {boolean} - Whether or not `character` is * numeric. */ function isNumeric(character) { var code = character.charCodeAt(0); return code >= CC_0 && code <= CC_9; } /** * Check whether `character` is a word character. * * @param {string} character - Single character to check. * @return {boolean} - Whether or not `character` is a * word character. */ function isWordCharacter(character) { return character === C_UNDERSCORE || isAlphabetic(character) || isNumeric(character); } /** * Check whether `character` is white-space. * * @param {string} character - Single character to check. * @return {boolean} - Whether or not `character` is * white-space. */ function isWhiteSpace(character) { return character === C_SPACE || character === C_FORM_FEED || character === C_NEWLINE || character === C_CARRIAGE_RETURN || character === C_TAB || character === C_VERTICAL_TAB || character === C_NO_BREAK_SPACE || character === C_OGHAM_SPACE || character === C_MONGOLIAN_VOWEL_SEPARATOR || character === C_EN_QUAD || character === C_EM_QUAD || character === C_EN_SPACE || character === C_EM_SPACE || character === C_THREE_PER_EM_SPACE || character === C_FOUR_PER_EM_SPACE || character === C_SIX_PER_EM_SPACE || character === C_FIGURE_SPACE || character === C_PUNCTUATION_SPACE || character === C_THIN_SPACE || character === C_HAIR_SPACE || character === C_LINE_SEPARATOR || character === C_PARAGRAPH_SEPARATOR || character === C_NARROW_NO_BREAK_SPACE || character === C_IDEOGRAPHIC_SPACE || character === C_ZERO_WIDTH_NO_BREAK_SPACE; } /** * Check whether `character` can be inside an unquoted * attribute value. * * @param {string} character - Single character to check. * @return {boolean} - Whether or not `character` can be * inside an unquoted attribute value. */ function isUnquotedAttributeCharacter(character) { return character !== C_DOUBLE_QUOTE && character !== C_SINGLE_QUOTE && character !== C_EQUALS && character !== C_LT && character !== C_GT && character !== C_TICK; } /** * Check whether `character` can be inside a double-quoted * attribute value. * * @property {string} delimiter - Closing delimiter. * @param {string} character - Single character to check. * @return {boolean} - Whether or not `character` can be * inside a double-quoted attribute value. */ function isDoubleQuotedAttributeCharacter(character) { return character !== C_DOUBLE_QUOTE; } isDoubleQuotedAttributeCharacter.delimiter = C_DOUBLE_QUOTE; /** * Check whether `character` can be inside a single-quoted * attribute value. * * @property {string} delimiter - Closing delimiter. * @param {string} character - Single character to check. * @return {boolean} - Whether or not `character` can be * inside a single-quoted attribute value. */ function isSingleQuotedAttributeCharacter(character) { return character !== C_SINGLE_QUOTE; } isSingleQuotedAttributeCharacter.delimiter = C_SINGLE_QUOTE; /** * Check whether `character` can be inside an enclosed * URI. * * @property {string} delimiter - Closing delimiter. * @param {string} character - Character to test. * @return {boolean} - Whether or not `character` can be * inside an enclosed URI. */ function isEnclosedURLCharacter(character) { return character !== C_GT && character !== C_BRACKET_OPEN && character !== C_BRACKET_CLOSE; } isEnclosedURLCharacter.delimiter = C_GT; /** * Check whether `character` can be inside an unclosed * URI. * * @param {string} character - Character to test. * @return {boolean} - Whether or not `character` can be * inside an unclosed URI. */ function isUnclosedURLCharacter(character) { return character !== C_BRACKET_OPEN && character !== C_BRACKET_CLOSE && !isWhiteSpace(character); } /** * Factory to create an entity decoder. * * @param {Object} context - Context to attach to, e.g., * a parser. * @return {Function} - See `decode`. */ function decodeFactory(context) { /** * Normalize `position` to add an `indent`. * * @param {Position} position - Reference * @return {Position} - Augmented with `indent`. */ function normalize(position) { return { 'start': position, 'indent': context.getIndent(position.line) }; } /** * Handle a warning. * * @this {VFile} - Virtual file. * @param {string} reason - Reason for warning. * @param {Position} position - Place of warning. * @param {number} code - Code for warning. */ function handleWarning(reason, position, code) { if (code === 3) { return; } context.file.warn(reason, position); } /** * Decode `value` (at `position`) into text-nodes. * * @param {string} value - Value to parse. * @param {Position} position - Position to start parsing at. * @param {Function} handler - Node handler. */ function decoder(value, position, handler) { var hasPosition = context.options.position; decode(value, { 'position': position && normalize(position), 'warning': hasPosition && handleWarning, 'text': handler, 'reference': handler, 'textContext': context, 'referenceContext': context }); } /** * Decode `value` (at `position`) into a string. * * @param {string} value - Value to parse. * @param {Position} position - Position to start * parsing at. * @return {string} - Plain-text. */ function decodeRaw(value, position) { return decode(value, { 'position': position && normalize(position), 'warning': context.options.position && handleWarning }); } decoder.raw = decodeRaw; return decoder; } /** * Factory to de-escape a value, based on a list at `key` * in `scope`. * * @example * var scope = {escape: ['a']} * var descape = descapeFactory(scope, 'escape'); * * @param {Object} scope - List of escapable characters. * @param {string} key - Key in `map` at which the list * exists. * @return {function(string): string} - Function which * takes a value and returns its unescaped version. */ function descapeFactory(scope, key) { /** * De-escape a string using the expression at `key` * in `scope`. * * @example * var scope = {escape: ['a']} * var descape = descapeFactory(scope, 'escape'); * descape('\a \b'); // 'a \b' * * @param {string} value - Escaped string. * @return {string} - Unescaped string. */ function descape(value) { var prev = 0; var index = value.indexOf(C_BACKSLASH); var escape = scope[key]; var queue = []; var character; while (index !== -1) { queue.push(value.slice(prev, index)); prev = index + 1; character = value.charAt(prev); /* * If the following character is not a valid escape, * add the slash. */ if (!character || escape.indexOf(character) === -1) { queue.push(C_BACKSLASH); } index = value.indexOf(C_BACKSLASH, prev); } queue.push(value.slice(prev)); return queue.join(EMPTY); } return descape; } /** * Gets indentation information for a line. * * @example * getIndent(' foo'); * // {indent: 2, stops: {1: 0, 2: 1}} * * getIndent('\tfoo'); * // {indent: 4, stops: {4: 0}} * * getIndent(' \tfoo'); * // {indent: 4, stops: {1: 0, 2: 1, 4: 2}} * * getIndent('\t foo') * // {indent: 6, stops: {4: 0, 5: 1, 6: 2}} * * @param {string} value - Indented line. * @return {Object} - Indetation information. */ function getIndent(value) { var index = 0; var indent = 0; var character = value.charAt(index); var stops = {}; var size; while (character in INDENTATION_CHARACTERS) { size = INDENTATION_CHARACTERS[character]; indent += size; if (size > 1) { indent = Math.floor(indent / size) * size; } stops[indent] = index; character = value.charAt(++index); } return { 'indent': indent, 'stops': stops }; } /** * Remove the minimum indent from every line in `value`. * Supports both tab, spaced, and mixed indentation (as * well as possible). * * @example * removeIndentation(' foo'); // 'foo' * removeIndentation(' foo', 2); // ' foo' * removeIndentation('\tfoo', 2); // ' foo' * removeIndentation(' foo\n bar'); // ' foo\n bar' * * @param {string} value - Value to trim. * @param {number?} [maximum] - Maximum indentation * to remove. * @return {string} - Unindented `value`. */ function removeIndentation(value, maximum) { var values = value.split(C_NEWLINE); var position = values.length + 1; var minIndent = Infinity; var matrix = []; var index; var indentation; var stops; var padding; values.unshift(repeat(C_SPACE, maximum) + C_EXCLAMATION_MARK); while (position--) { indentation = getIndent(values[position]); matrix[position] = indentation.stops; if (trim(values[position]).length === 0) { continue; } if (indentation.indent) { if (indentation.indent > 0 && indentation.indent < minIndent) { minIndent = indentation.indent; } } else { minIndent = Infinity; break; } } if (minIndent !== Infinity) { position = values.length; while (position--) { stops = matrix[position]; index = minIndent; while (index && !(index in stops)) { index--; } if ( trim(values[position]).length !== 0 && minIndent && index !== minIndent ) { padding = C_TAB; } else { padding = EMPTY; } values[position] = padding + values[position].slice( index in stops ? stops[index] + 1 : 0 ); } } values.shift(); return values.join(C_NEWLINE); } /** * Tokenise a line. * * @example * tokenizeNewline(eat, '\n\n'); * * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {boolean?} - `true` when matching. */ function tokenizeNewline(eat, value, silent) { var character = value.charAt(0); var length; var subvalue; var queue; var index; if (character !== C_NEWLINE) { return; } /* istanbul ignore if - never used (yet) */ if (silent) { return true; } index = 1; length = value.length; subvalue = C_NEWLINE; queue = EMPTY; while (index < length) { character = value.charAt(index); if (!isWhiteSpace(character)) { break; } queue += character; if (character === C_NEWLINE) { subvalue += queue; queue = EMPTY; } index++; } eat(subvalue); } /** * Tokenise an indented code block. * * @example * tokenizeCode(eat, '\tfoo'); * * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `code` node. */ function tokenizeCode(eat, value, silent) { var self = this; var index = -1; var length = value.length; var character; var subvalue = EMPTY; var content = EMPTY; var subvalueQueue = EMPTY; var contentQueue = EMPTY; var blankQueue; var indent; while (++index < length) { character = value.charAt(index); if (indent) { indent = false; subvalue += subvalueQueue; content += contentQueue; subvalueQueue = contentQueue = EMPTY; if (character === C_NEWLINE) { subvalueQueue = contentQueue = character; } else { subvalue += character; content += character; while (++index < length) { character = value.charAt(index); if (!character || character === C_NEWLINE) { contentQueue = subvalueQueue = character; break; } subvalue += character; content += character; } } } else if ( character === C_SPACE && value.charAt(index + 1) === C_SPACE && value.charAt(index + 2) === C_SPACE && value.charAt(index + 3) === C_SPACE ) { subvalueQueue += CODE_INDENT; index += 3; indent = true; } else if (character === C_TAB) { subvalueQueue += character; indent = true; } else { blankQueue = EMPTY; while (character === C_TAB || character === C_SPACE) { blankQueue += character; character = value.charAt(++index); } if (character !== C_NEWLINE) { break; } subvalueQueue += blankQueue + character; contentQueue += character; } } if (content) { if (silent) { return true; } return eat(subvalue)(self.renderCodeBlock(content)); } } /** * Tokenise a fenced code block. * * @example * tokenizeFences(eat, '```js\nfoo()\n```'); * * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `code` node. */ function tokenizeFences(eat, value, silent) { var self = this; var settings = self.options; var length = value.length + 1; var index = 0; var subvalue = EMPTY; var fenceCount; var marker; var character; var flag; var queue; var content; var exdentedContent; var closing; var exdentedClosing; var indent; var now; if (!settings.gfm) { return; } /* * Eat initial spacing. */ while (index < length) { character = value.charAt(index); if (character !== C_SPACE && character !== C_TAB) { break; } subvalue += character; index++; } indent = index; // TODO: CHECK. /* * Eat the fence. */ character = value.charAt(index); if (character !== C_TILDE && character !== C_TICK) { return; } index++; marker = character; fenceCount = 1; subvalue += character; while (index < length) { character = value.charAt(index); if (character !== marker) { break; } subvalue += character; fenceCount++; index++; } if (fenceCount < MIN_FENCE_COUNT) { return; } /* * Eat spacing before flag. */ while (index < length) { character = value.charAt(index); if (character !== C_SPACE && character !== C_TAB) { break; } subvalue += character; index++; } /* * Eat flag. */ flag = queue = EMPTY; while (index < length) { character = value.charAt(index); if ( character === C_NEWLINE || character === C_TILDE || character === C_TICK ) { break; } if (character === C_SPACE || character === C_TAB) { queue += character; } else { flag += queue + character; queue = EMPTY; } index++; } character = value.charAt(index); if (character && character !== C_NEWLINE) { return; } if (silent) { return true; } now = eat.now(); now.column += subvalue.length; subvalue += flag; flag = self.decode.raw(self.descape(flag), now); if (queue) { subvalue += queue; } queue = closing = exdentedClosing = content = exdentedContent = EMPTY; /* * Eat content. */ while (index < length) { character = value.charAt(index); content += closing; exdentedContent += exdentedClosing; closing = exdentedClosing = EMPTY; if (character !== C_NEWLINE) { content += character; exdentedClosing += character; index++; continue; } /* * Add the newline to `subvalue` if its the first * character. Otherwise, add it to the `closing` * queue. */ if (!content) { subvalue += character; } else { closing += character; exdentedClosing += character; } queue = EMPTY; index++; while (index < length) { character = value.charAt(index); if (character !== C_SPACE) { break; } queue += character; index++; } closing += queue; exdentedClosing += queue.slice(indent); if (queue.length >= CODE_INDENT_LENGTH) { continue; } queue = EMPTY; while (index < length) { character = value.charAt(index); if (character !== marker) { break; } queue += character; index++; } closing += queue; exdentedClosing += queue; if (queue.length < fenceCount) { continue; } queue = EMPTY; while (index < length) { character = value.charAt(index); if (character !== C_SPACE && character !== C_TAB) { break; } closing += character; exdentedClosing += character; index++; } if (!character || character === C_NEWLINE) { break; } } subvalue += content + closing; return eat(subvalue)(self.renderCodeBlock(exdentedContent, flag)); } /** * Tokenise an ATX-style heading. * * @example * tokenizeHeading(eat, ' # foo'); * * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `heading` node. */ function tokenizeHeading(eat, value, silent) { var self = this; var settings = self.options; var length = value.length + 1; var index = -1; var now = eat.now(); var subvalue = EMPTY; var content = EMPTY; var character; var queue; var depth; /* * Eat initial spacing. */ while (++index < length) { character = value.charAt(index); if (character !== C_SPACE && character !== C_TAB) { index--; break; } subvalue += character; } /* * Eat hashes. */ depth = 0; length = index + MAX_ATX_COUNT + 1; while (++index <= length) { character = value.charAt(index); if (character !== C_HASH) { index--; break; } subvalue += character; depth++; } if ( !depth || (!settings.pedantic && value.charAt(index + 1) === C_HASH) ) { return; } length = value.length + 1; /* * Eat intermediate white-space. */ queue = EMPTY; while (++index < length) { character = value.charAt(index); if (character !== C_SPACE && character !== C_TAB) { index--; break; } queue += character; } /* * Exit when not in pedantic mode without spacing. */ if ( !settings.pedantic && !queue.length && character && character !== C_NEWLINE ) { return; } if (silent) { return true; } /* * Eat content. */ subvalue += queue; queue = content = EMPTY; while (++index < length) { character = value.charAt(index); if (!character || character === C_NEWLINE) { break; } if ( character !== C_SPACE && character !== C_TAB && character !== C_HASH ) { content += queue + character; queue = EMPTY; continue; } while (character === C_SPACE || character === C_TAB) { queue += character; character = value.charAt(++index); } while (character === C_HASH) { queue += character; character = value.charAt(++index); } while (character === C_SPACE || character === C_TAB) { queue += character; character = value.charAt(++index); } index--; } now.column += subvalue.length; subvalue += content + queue; return eat(subvalue)(self.renderHeading(content, depth, now)); } /** * Tokenise a Setext-style heading. * * @example * tokenizeLineHeading(eat, 'foo\n==='); * * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `heading` node. */ function tokenizeLineHeading(eat, value, silent) { var self = this; var now = eat.now(); var length = value.length; var index = -1; var subvalue = EMPTY; var content; var queue; var character; var marker; var depth; /* * Eat initial indentation. */ while (++index < length) { character = value.charAt(index); if (character !== C_SPACE || index >= MAX_LINE_HEADING_INDENT) { index--; break; } subvalue += character; } /* * Eat content. */ content = queue = EMPTY; while (++index < length) { character = value.charAt(index); if (character === C_NEWLINE) { index--; break; } if (character === C_SPACE || character === C_TAB) { queue += character; } else { content += queue + character; queue = EMPTY; } } now.column += subvalue.length; subvalue += content + queue; /* * Ensure the content is followed by a newline and a * valid marker. */ character = value.charAt(++index); marker = value.charAt(++index); if ( character !== C_NEWLINE || !SETEXT_MARKERS[marker] ) { return; } if (silent) { return true; } subvalue += character; /* * Eat Setext-line. */ queue = marker; depth = SETEXT_MARKERS[marker]; while (++index < length) { character = value.charAt(index); if (character !== marker) { if (character !== C_NEWLINE) { return; } index--; break; } queue += character; } return eat(subvalue + queue)(self.renderHeading(content, depth, now)); } /** * Tokenise a horizontal rule. * * @example * tokenizeHorizontalRule(eat, '***'); * * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `horizontalRule` node. */ function tokenizeHorizontalRule(eat, value, silent) { var self = this; var index = -1; var length = value.length + 1; var subvalue = EMPTY; var character; var marker; var markerCount; var queue; while (++index < length) { character = value.charAt(index); if (character !== C_TAB && character !== C_SPACE) { break; } subvalue += character; } if (RULE_MARKERS[character] !== true) { return; } marker = character; subvalue += character; markerCount = 1; queue = EMPTY; while (++index < length) { character = value.charAt(index); if (character === marker) { markerCount++; subvalue += queue + marker; queue = EMPTY; } else if (character === C_SPACE) { queue += character; } else if ( markerCount >= HORIZONTAL_RULE_MARKER_COUNT && (!character || character === C_NEWLINE) ) { subvalue += queue; if (silent) { return true; } return eat(subvalue)(self.renderVoid(T_HORIZONTAL_RULE)); } else { return; } } } /** * Tokenise a blockquote. * * @example * tokenizeBlockquote(eat, '> Foo'); * * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `blockquote` node. */ function tokenizeBlockquote(eat, value, silent) { var self = this; var commonmark = self.options.commonmark; var now = eat.now(); var indent = self.indent(now.line); var length = value.length; var values = []; var contents = []; var indents = []; var add; var tokenizers; var index = 0; var character; var rest; var nextIndex; var content; var line; var startIndex; var prefixed; while (index < length) { character = value.charAt(index); if (character !== C_SPACE && character !== C_TAB) { break; } index++; } if (value.charAt(index) !== C_GT) { return; } if (silent) { return true; } tokenizers = self.blockTokenizers; index = 0; while (index < length) { nextIndex = value.indexOf(C_NEWLINE, index); startIndex = index; prefixed = false; if (nextIndex === -1) { nextIndex = length; } while (index < length) { character = value.charAt(index); if (character !== C_SPACE && character !== C_TAB) { break; } index++; } if (value.charAt(index) === C_GT) { index++; prefixed = true; if (value.charAt(index) === C_SPACE) { index++; } } else { index = startIndex; } content = value.slice(index, nextIndex); if (!prefixed && !trim(content)) { index = startIndex; break; } if (!prefixed) { rest = value.slice(index); if ( commonmark && ( tokenizers.code.call(self, eat, rest, true) || tokenizers.fences.call(self, eat, rest, true) || tokenizers.heading.call(self, eat, rest, true) || tokenizers.lineHeading.call(self, eat, rest, true) || tokenizers.horizontalRule.call(self, eat, rest, true) || tokenizers.html.call(self, eat, rest, true) || tokenizers.list.call(self, eat, rest, true) ) ) { break; } if ( !commonmark && ( tokenizers.definition.call(self, eat, rest, true) || tokenizers.footnoteDefinition.call(self, eat, rest, true) ) ) { break; } } line = startIndex === index ? content : value.slice(startIndex, nextIndex); indents.push(index - startIndex); values.push(line); contents.push(content); index = nextIndex + 1; } index = -1; length = indents.length; add = eat(values.join(C_NEWLINE)); while (++index < length) { indent(indents[index]); } return add(self.renderBlockquote(contents.join(C_NEWLINE), now)); } /** * Tokenise a list. * * @example * tokenizeList(eat, '- Foo'); * * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `list` node. */ function tokenizeList(eat, value, silent) { var self = this; var commonmark = self.options.commonmark; var pedantic = self.options.pedantic; var tokenizers = self.blockTokenizers; var markers; var index = 0; var length = value.length; var start = null; var queue; var ordered; var character; var marker; var nextIndex; var startIndex; var prefixed; var currentMarker; var content; var line; var prevEmpty; var empty; var items; var allLines; var emptyLines; var item; var enterTop; var exitBlockquote; var isLoose; var node; var now; var end; var indented; var size; while (index < length) { character = value.charAt(index); if (character !== C_SPACE && character !== C_TAB) { break; } index++; } character = value.charAt(index); markers = commonmark ? LIST_ORDERED_COMMONMARK_MARKERS : LIST_ORDERED_MARKERS; if (LIST_UNORDERED_MARKERS[character] === true) { marker = character; ordered = false; } else { ordered = true; queue = EMPTY; while (index < length) { character = value.charAt(index); if (!isNumeric(character)) { break; } queue += character; index++; } character = value.charAt(index); if (!queue || markers[character] !== true) { return; } start = parseInt(queue, 10); marker = character; } character = value.charAt(++index); if (character !== C_SPACE && character !== C_TAB) { return; } if (silent) { return true; } index = 0; items = []; allLines = []; emptyLines = []; while (index < length) { nextIndex = value.indexOf(C_NEWLINE, index); startIndex = index; prefixed = false; indented = false; if (nextIndex === -1) { nextIndex = length; } end = index + TAB_SIZE; size = 0; while (index < length) { character = value.charAt(index); if (character === C_TAB) { size += TAB_SIZE - size % TAB_SIZE; } else if (character === C_SPACE) { size++; } else { break; } index++; } if (size >= TAB_SIZE) { indented = true; } if (item && size >= item.indent) { indented = true; } character = value.charAt(index); currentMarker = null; if (!indented) { if (LIST_UNORDERED_MARKERS[character] === true) { currentMarker = character; index++; size++; } else { queue = EMPTY; while (index < length) { character = value.charAt(index); if (!isNumeric(character)) { break; } queue += character; index++; } character = value.charAt(index); index++; if (queue && markers[character] === true) { currentMarker = character; size += queue.length + 1; } } if (currentMarker) { character = value.charAt(index); if (character === C_TAB) { size += TAB_SIZE - size % TAB_SIZE; index++; } else if (character === C_SPACE) { end = index + TAB_SIZE; while (index < end) { if (value.charAt(index) !== C_SPACE) { break; } index++; size++; } if (index === end && value.charAt(index) === C_SPACE) { index -= TAB_SIZE - 1; size -= TAB_SIZE - 1; } } else if ( character !== C_NEWLINE && character !== EMPTY ) { currentMarker = null; } } } if (currentMarker) { if (commonmark && marker !== currentMarker) { break; } prefixed = true; } else { if ( !commonmark && !indented && value.charAt(startIndex) === C_SPACE ) { indented = true; } else if ( commonmark && item ) { indented = size >= item.indent || size > TAB_SIZE; } prefixed = false; index = startIndex; } line = value.slice(startIndex, nextIndex); content = startIndex === index ? line : value.slice(index, nextIndex); if (currentMarker && RULE_MARKERS[currentMarker] === true) { if ( tokenizers.horizontalRule.call(self, eat, line, true) ) { break; } } prevEmpty = empty; empty = !trim(content).length; if (indented && item) { item.value = item.value.concat(emptyLines, line); allLines = allLines.concat(emptyLines, line); emptyLines = []; } else if (prefixed) { if (emptyLines.length) { item.value.push(EMPTY); item.trail = emptyLines.concat(); } item = { // 'bullet': value.slice(startIndex, index), 'value': [line], 'indent': size, 'trail': [] }; items.push(item); allLines = allLines.concat(emptyLines, line); emptyLines = []; } else if (empty) { // TODO: disable when in pedantic-mode. if (prevEmpty) { break; } emptyLines.push(line); } else { if (prevEmpty) { break; } if ( !pedantic && tokenizers.horizontalRule.call(self, eat, line, true) ) { break; } if (!commonmark) { if ( tokenizers.definition.call(self, eat, line, true) || tokenizers.footnoteDefinition.call(self, eat, line, true) ) { break; } } item.value = item.value.concat(emptyLines, line); allLines = allLines.concat(emptyLines, line); emptyLines = []; } index = nextIndex + 1; } node = eat(allLines.join(C_NEWLINE)).reset({ 'type': T_LIST, 'ordered': ordered, 'start': start, 'loose': null, 'children': [] }); enterTop = self.exitTop(); exitBlockquote = self.enterBlockquote(); isLoose = false; index = -1; length = items.length; while (++index < length) { item = items[index].value.join(C_NEWLINE); now = eat.now(); item = eat(item)(self.renderListItem(item, now), node); if (item.loose) { isLoose = true; } item = items[index].trail.join(C_NEWLINE); if (index !== length - 1) { item += C_NEWLINE; } eat(item); } enterTop(); exitBlockquote(); node.loose = isLoose; return node; } /** * Try to match comment. * * @param {string} value - Value to parse. * @param {Object} settings - Configuration as available on * a parser. * @return {string?} - When applicable, the comment at the * start of `value`. */ function eatHTMLComment(value, settings) { var index = COMMENT_START_LENGTH; var queue = COMMENT_START; var length = value.length; var commonmark = settings.commonmark; var character; var hasNonDash; if (value.slice(0, index) === queue) { while (index < length) { character = value.charAt(index); if ( character === COMMENT_END_CHAR && value.slice(index, index + COMMENT_END_LENGTH) === COMMENT_END ) { return queue + COMMENT_END; } if (commonmark) { if (character === C_GT && !hasNonDash) { return; } if (character === C_DASH) { if (value.charAt(index + 1) === C_DASH) { return; } } else { hasNonDash = true; } } queue += character; index++; } } } /** * Try to match CDATA. * * @param {string} value - Value to parse. * @return {string?} - When applicable, the CDATA at the * start of `value`. */ function eatHTMLCDATA(value) { var index = CDATA_START_LENGTH; var queue = value.slice(0, index); var length = value.length; var character; if (queue.toUpperCase() === CDATA_START) { while (index < length) { character = value.charAt(index); if ( character === CDATA_END_CHAR && value.slice(index, index + CDATA_END_LENGTH) === CDATA_END ) { return queue + CDATA_END; } queue += character; index++; } } } /** * Try to match a processing instruction. * * @param {string} value - Value to parse. * @return {string?} - When applicable, the processing * instruction at the start of `value`. */ function eatHTMLProcessingInstruction(value) { var index = 0; var queue = EMPTY; var length = value.length; var character; if ( value.charAt(index) === C_LT && value.charAt(++index) === C_QUESTION_MARK ) { queue = C_LT + C_QUESTION_MARK; index++; while (index < length) { character = value.charAt(index); if ( character === C_QUESTION_MARK && value.charAt(index + 1) === C_GT ) { return queue + character + C_GT; } queue += character; index++; } } } /** * Try to match a declaration. * * @param {string} value - Value to parse. * @return {string?} - When applicable, the declaration at * the start of `value`. */ function eatHTMLDeclaration(value) { var index = 0; var length = value.length; var queue = EMPTY; var subqueue = EMPTY; var character; if ( value.charAt(index) === C_LT && value.charAt(++index) === C_EXCLAMATION_MARK ) { queue = C_LT + C_EXCLAMATION_MARK; index++; /* * Eat as many alphabetic characters as * possible. */ while (index < length) { character = value.charAt(index); if (!isAlphabetic(character)) { break; } subqueue += character; index++; } character = value.charAt(index); if (!subqueue || !isWhiteSpace(character)) { return; } queue += subqueue + character; index++; while (index < length) { character = value.charAt(index); if (character === C_GT) { return queue; } queue += character; index++; } } } /** * Try to match a closing tag. * * @param {string} value - Value to parse. * @param {boolean?} [isBlock] - Whether the tag-name * must be a known block-level node to match. * @return {string?} - When applicable, the closing tag at * the start of `value`. */ function eatHTMLClosingTag(value, isBlock) { var index = 0; var length = value.length; var queue = EMPTY; var subqueue = EMPTY; var character; if ( value.charAt(index) === C_LT && value.charAt(++index) === C_SLASH ) { queue = C_LT + C_SLASH; subqueue = character = value.charAt(++index); if (!isAlphabetic(character)) { return; } index++; /* * Eat as many alphabetic characters as * possible. */ while (index < length) { character = value.charAt(index); if (!isAlphabetic(character) && !isNumeric(character)) { break; } subqueue += character; index++; } if (isBlock && blockElements.indexOf(subqueue.toLowerCase()) === -1) { return; } queue += subqueue; /* * Eat white-space. */ while (index < length) { character = value.charAt(index); if (!isWhiteSpace(character)) { break; } queue += character; index++; } if (value.charAt(index) === C_GT) { return queue + C_GT; } } } /** * Try to match an opening tag. * * @param {string} value - Value to parse. * @param {boolean?} [isBlock] - Whether the tag-name * must be a known block-level node to match. * @return {string?} - When applicable, the opening tag at * the start of `value`. */ function eatHTMLOpeningTag(value, isBlock) { var index = 0; var length = value.length; var queue = EMPTY; var subqueue = EMPTY; var character = value.charAt(index); var hasEquals; var test; if (character === C_LT) { queue = character; subqueue = character = value.charAt(++index); if (!isAlphabetic(character)) { return; } index++; /* * Eat as many alphabetic characters as * possible. */ while (index < length) { character = value.charAt(index); if (!isAlphabetic(character) && !isNumeric(character)) { break; } subqueue += character; index++; } if (isBlock && blockElements.indexOf(subqueue.toLowerCase()) === -1) { return; } queue += subqueue; subqueue = EMPTY; /* * Find attributes. */ while (index < length) { /* * Eat white-space. */ while (index < length) { character = value.charAt(index); if (!isWhiteSpace(character)) { break; } subqueue += character; index++; } if (!subqueue) { break; } /* * Eat an attribute name. */ queue += subqueue; subqueue = EMPTY; character = value.charAt(index); if ( isAlphabetic(character) || character === C_UNDERSCORE || character === C_COLON ) { subqueue = character; index++; while (index < length) { character = value.charAt(index); if ( !isAlphabetic(character) && !isNumeric(character) && character !== C_UNDERSCORE && character !== C_COLON && character !== C_DOT && character !== C_DASH ) { break; } subqueue += character; index++; } } if (!subqueue) { break; } queue += subqueue; subqueue = EMPTY; hasEquals = false; /* * Eat zero or more white-space and one * equals sign. */ while (index < length) { character = value.charAt(index); if (!isWhiteSpace(character)) { if (!hasEquals && character === C_EQUALS) { hasEquals = true; } else { break; } } subqueue += character; index++; } queue += subqueue; subqueue = EMPTY; if (!hasEquals) { queue += subqueue; } else { character = value.charAt(index); queue += subqueue; if (character === C_DOUBLE_QUOTE) { test = isDoubleQuotedAttributeCharacter; subqueue = character; index++; } else if (character === C_SINGLE_QUOTE) { test = isSingleQuotedAttributeCharacter; subqueue = character; index++; } else { test = isUnquotedAttributeCharacter; subqueue = EMPTY; } while (index < length) { character = value.charAt(index); if (!test(character)) { break; } subqueue += character; index++; } character = value.charAt(index); index++; if (!test.delimiter) { if (!subqueue.length) { return; } index--; } else if (character === test.delimiter) { subqueue += character; } else { return; } queue += subqueue; subqueue = EMPTY; } } /* * More white-space is already eaten by the * attributes subroutine. */ character = value.charAt(index); /* * Eat an optional backslash (for self-closing * tags). */ if (character === C_SLASH) { queue += character; character = value.charAt(++index); } return character === C_GT ? queue + character : null; } } /** * Tokenise HTML. * * @example * tokenizeHTML(eat, 'foo'); * * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `html` node. */ function tokenizeHTML(eat, value, silent) { var self = this; var index = 0; var length = value.length; var subvalue = EMPTY; var offset; var lineCount; var character; var queue; /* * Eat initial spacing. */ while (index < length) { character = value.charAt(index); if (character !== C_TAB && character !== C_SPACE) { break; } subvalue += character; index++; } offset = index; value = value.slice(offset); /* * Try to eat an HTML thing. */ queue = eatHTMLComment(value, self.options) || eatHTMLCDATA(value) || eatHTMLProcessingInstruction(value) || eatHTMLDeclaration(value) || eatHTMLClosingTag(value, true) || eatHTMLOpeningTag(value, true); if (!queue) { return; } if (silent) { return true; } subvalue += queue; index = subvalue.length - offset; queue = EMPTY; while (index < length) { character = value.charAt(index); if (character === C_NEWLINE) { queue += character; lineCount++; } else if (queue.length < MIN_CLOSING_HTML_NEWLINE_COUNT) { subvalue += queue + character; queue = EMPTY; } else { break; } index++; } return eat(subvalue)(self.renderRaw(T_HTML, subvalue)); } /** * Tokenise a definition. * * @example * var value = '[foo]: http://example.com "Example Domain"'; * tokenizeDefinition(eat, value); * * @property {boolean} onlyAtTop * @property {boolean} notInBlockquote * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `definition` node. */ function tokenizeDefinition(eat, value, silent) { var self = this; var commonmark = self.options.commonmark; var index = 0; var length = value.length; var subvalue = EMPTY; var beforeURL; var beforeTitle; var queue; var character; var test; var identifier; var url; var title; while (index < length) { character = value.charAt(index); if (character !== C_SPACE && character !== C_TAB) { break; } subvalue += character; index++; } character = value.charAt(index); if (character !== C_BRACKET_OPEN) { return; } index++; subvalue += character; queue = EMPTY; while (index < length) { character = value.charAt(index); if (character === C_BRACKET_CLOSE) { break; } else if (character === C_BACKSLASH) { queue += character; index++; character = value.charAt(index); } queue += character; index++; } if ( !queue || value.charAt(index) !== C_BRACKET_CLOSE || value.charAt(index + 1) !== C_COLON ) { return; } identifier = queue; subvalue += queue + C_BRACKET_CLOSE + C_COLON; index = subvalue.length; queue = EMPTY; while (index < length) { character = value.charAt(index); if ( character !== C_TAB && character !== C_SPACE && character !== C_NEWLINE ) { break; } subvalue += character; index++; } character = value.charAt(index); queue = EMPTY; beforeURL = subvalue; if (character === C_LT) { index++; while (index < length) { character = value.charAt(index); if (!isEnclosedURLCharacter(character)) { break; } queue += character; index++; } character = value.charAt(index); if (character !== isEnclosedURLCharacter.delimiter) { if (commonmark) { return; } index -= queue.length + 1; queue = EMPTY; } else { subvalue += C_LT + queue + character; index++; } } if (!queue) { while (index < length) { character = value.charAt(index); if (!isUnclosedURLCharacter(character)) { break; } queue += character; index++; } subvalue += queue; } if (!queue) { return; } url = queue; queue = EMPTY; while (index < length) { character = value.charAt(index); if ( character !== C_TAB && character !== C_SPACE && character !== C_NEWLINE ) { break; } queue += character; index++; } character = value.charAt(index); test = null; if (character === C_DOUBLE_QUOTE) { test = C_DOUBLE_QUOTE; } else if (character === C_SINGLE_QUOTE) { test = C_SINGLE_QUOTE; } else if (character === C_PAREN_OPEN) { test = C_PAREN_CLOSE; } if (!test) { queue = EMPTY; index = subvalue.length; } else if (!queue) { return; } else { subvalue += queue + character; index = subvalue.length; queue = EMPTY; while (index < length) { character = value.charAt(index); if (character === test) { break; } if (character === C_NEWLINE) { index++; character = value.charAt(index); if (character === C_NEWLINE || character === test) { return; } queue += C_NEWLINE; } queue += character; index++; } character = value.charAt(index); if (character !== test) { return; } beforeTitle = subvalue; subvalue += queue + character; index++; title = queue; queue = EMPTY; } while (index < length) { character = value.charAt(index); if (character !== C_TAB && character !== C_SPACE) { break; } subvalue += character; index++; } character = value.charAt(index); if (!character || character === C_NEWLINE) { if (silent) { return true; } beforeURL = eat(beforeURL).test().end; url = self.decode.raw(self.descape(url), beforeURL); if (title) { beforeTitle = eat(beforeTitle).test().end; title = self.decode.raw(self.descape(title), beforeTitle); } return eat(subvalue)({ 'type': T_DEFINITION, 'identifier': normalize(identifier), 'title': title || null, 'link': url }); } } tokenizeDefinition.onlyAtTop = true; tokenizeDefinition.notInBlockquote = true; /** * Tokenise YAML front matter. * * @example * tokenizeYAMLFrontMatter(eat, '---\nfoo: bar\n---'); * * @property {boolean} onlyAtStart * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `yaml` node. */ function tokenizeYAMLFrontMatter(eat, value, silent) { var self = this; var subvalue; var content; var index; var length; var character; var queue; if ( !self.options.yaml || value.charAt(0) !== C_DASH || value.charAt(1) !== C_DASH || value.charAt(2) !== C_DASH || value.charAt(3) !== C_NEWLINE ) { return; } subvalue = YAML_FENCE + C_NEWLINE; content = queue = EMPTY; index = 3; length = value.length; while (++index < length) { character = value.charAt(index); if ( character === C_DASH && (queue || !content) && value.charAt(index + 1) === C_DASH && value.charAt(index + 2) === C_DASH ) { /* istanbul ignore if - never used (yet) */ if (silent) { return true; } subvalue += queue + YAML_FENCE; return eat(subvalue)(self.renderRaw(T_YAML, content)); } if (character === C_NEWLINE) { queue += character; } else { subvalue += queue + character; content += queue + character; queue = EMPTY; } } } tokenizeYAMLFrontMatter.onlyAtStart = true; /** * Tokenise a footnote definition. * * @example * tokenizeFootnoteDefinition(eat, '[^foo]: Bar.'); * * @property {boolean} onlyAtTop * @property {boolean} notInBlockquote * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `footnoteDefinition` node. */ function tokenizeFootnoteDefinition(eat, value, silent) { var self = this; var index; var length; var subvalue; var now; var indent; var content; var queue; var subqueue; var character; var identifier; if (!self.options.footnotes) { return; } index = 0; length = value.length; subvalue = EMPTY; now = eat.now(); indent = self.indent(now.line); while (index < length) { character = value.charAt(index); if (!isWhiteSpace(character)) { break; } subvalue += character; index++; } if ( value.charAt(index) !== C_BRACKET_OPEN || value.charAt(index + 1) !== C_CARET ) { return; } subvalue += C_BRACKET_OPEN + C_CARET; index = subvalue.length; queue = EMPTY; while (index < length) { character = value.charAt(index); if (character === C_BRACKET_CLOSE) { break; } else if (character === C_BACKSLASH) { queue += character; index++; character = value.charAt(index); } queue += character; index++; } if ( !queue || value.charAt(index) !== C_BRACKET_CLOSE || value.charAt(index + 1) !== C_COLON ) { return; } if (silent) { return true; } identifier = normalize(queue); subvalue += queue + C_BRACKET_CLOSE + C_COLON; index = subvalue.length; while (index < length) { character = value.charAt(index); if ( character !== C_TAB && character !== C_SPACE ) { break; } subvalue += character; index++; } now.column += subvalue.length; queue = content = subqueue = EMPTY; while (index < length) { character = value.charAt(index); if (character === C_NEWLINE) { subqueue = character; index++; while (index < length) { character = value.charAt(index); if (character !== C_NEWLINE) { break; } subqueue += character; index++; } queue += subqueue; subqueue = EMPTY; while (index < length) { character = value.charAt(index); if (character !== C_SPACE) { break; } subqueue += character; index++; } if (!subqueue.length) { break; } queue += subqueue; } if (queue) { content += queue; queue = EMPTY; } content += character; index++; } subvalue += content; content = content.replace(EXPRESSION_INITIAL_TAB, function (line) { indent(line.length); return EMPTY; }); return eat(subvalue)( self.renderFootnoteDefinition(identifier, content, now) ); } tokenizeFootnoteDefinition.onlyAtTop = true; tokenizeFootnoteDefinition.notInBlockquote = true; /** * Tokenise a table. * * @example * tokenizeTable(eat, ' | foo |\n | --- |\n | bar |'); * * @property {boolean} onlyAtTop * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `table` node. */ function tokenizeTable(eat, value, silent) { var self = this; var index; var alignments; var alignment; var subvalue; var row; var length; var lines; var queue; var character; var hasDash; var align; var cell; var preamble; var count; var opening; var now; var position; var lineCount; var line; var rows; var table; var lineIndex; var pipeIndex; var first; /* * Exit when not in gfm-mode. */ if (!self.options.gfm) { return; } /* * Get the rows. * Detecting tables soon is hard, so there are some * checks for performance here, such as the minimum * number of rows, and allowed characters in the * alignment row. */ index = lineCount = 0; length = value.length + 1; lines = []; while (index < length) { lineIndex = value.indexOf(C_NEWLINE, index); pipeIndex = value.indexOf(C_PIPE, index + 1); if (lineIndex === -1) { lineIndex = value.length; } if ( pipeIndex === -1 || pipeIndex > lineIndex ) { if (lineCount < MIN_TABLE_ROWS) { return; } break; } lines.push(value.slice(index, lineIndex)); lineCount++; index = lineIndex + 1; } /* * Parse the alignment row. */ subvalue = lines.join(C_NEWLINE); alignments = lines.splice(1, 1)[0]; index = 0; length = alignments.length; lineCount--; alignment = false; align = []; while (index < length) { character = alignments.charAt(index); if (character === C_PIPE) { hasDash = null; if (alignment === false) { if (first === false) { return; } } else { align.push(alignment); alignment = false; } first = false; } else if (character === C_DASH) { hasDash = true; alignment = alignment || TABLE_ALIGN_NONE; } else if (character === C_COLON) { if (alignment === TABLE_ALIGN_LEFT) { alignment = TABLE_ALIGN_CENTER; } else if (hasDash && alignment === TABLE_ALIGN_NONE) { alignment = TABLE_ALIGN_RIGHT; } else { alignment = TABLE_ALIGN_LEFT; } } else if (!isWhiteSpace(character)) { return; } index++; } if (alignment !== false) { align.push(alignment); } /* * Exit when without enough columns. */ if (align.length < MIN_TABLE_COLUMNS) { return; } /* istanbul ignore if - never used (yet) */ if (silent) { return true; } /* * Parse the rows. */ position = -1; rows = []; table = eat(subvalue).reset({ 'type': T_TABLE, 'align': align, 'children': rows }); while (++position < lineCount) { line = lines[position]; row = self.renderParent(position ? T_TABLE_ROW : T_TABLE_HEADER, []); /* * Eat a newline character when this is not the * first row. */ if (position) { eat(C_NEWLINE); } /* * Eat the row. */ eat(line).reset(row, table); length = line.length + 1; index = 0; queue = EMPTY; cell = EMPTY; preamble = true; count = opening = null; while (index < length) { character = line.charAt(index); if (character === C_TAB || character === C_SPACE) { if (cell) { queue += character; } else { eat(character); } index++; continue; } if (character === EMPTY || character === C_PIPE) { if (preamble) { eat(character); } else { if (character && opening) { queue += character; index++; continue; } if ((cell || character) && !preamble) { subvalue = cell; if (queue.length > 1) { if (character) { subvalue += queue.slice(0, queue.length - 1); queue = queue.charAt(queue.length - 1); } else { subvalue += queue; queue = EMPTY; } } now = eat.now(); eat(subvalue)( self.renderInline(T_TABLE_CELL, cell, now), row ); } eat(queue + character); queue = EMPTY; cell = EMPTY; } } else { if (queue) { cell += queue; queue = EMPTY; } cell += character; if (character === C_BACKSLASH && index !== length - 2) { cell += line.charAt(index + 1); index++; } if (character === C_TICK) { count = 1; while (line.charAt(index + 1) === character) { cell += character; index++; count++; } if (!opening) { opening = count; } else if (count >= opening) { opening = 0; } } } preamble = false; index++; } /* * Eat the alignment row. */ if (!position) { eat(C_NEWLINE + alignments); } } return table; } tokenizeTable.onlyAtTop = true; /** * Tokenise a paragraph node. * * @example * tokenizeParagraph(eat, 'Foo.'); * * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `paragraph` node. */ function tokenizeParagraph(eat, value, silent) { var self = this; var settings = self.options; var commonmark = settings.commonmark; var gfm = settings.gfm; var tokenizers = self.blockTokenizers; var index = value.indexOf(C_NEWLINE); var length = value.length; var position; var subvalue; var character; var size; var now; while (index < length) { /* * Eat everything if there’s no following newline. */ if (index === -1) { index = length; break; } /* * Stop if the next character is NEWLINE. */ if (value.charAt(index + 1) === C_NEWLINE) { break; } /* * In commonmark-mode, following indented lines * are part of the paragraph. */ if (commonmark) { size = 0; position = index + 1; while (position < length) { character = value.charAt(position); if (character === C_TAB) { size = TAB_SIZE; break; } else if (character === C_SPACE) { size++; } else { break; } position++; } if (size >= TAB_SIZE) { index = value.indexOf(C_NEWLINE, index + 1); continue; } } /* * Check if the following code contains a possible * block. */ subvalue = value.slice(index + 1); if ( tokenizers.horizontalRule.call(self, eat, subvalue, true) || tokenizers.heading.call(self, eat, subvalue, true) || tokenizers.fences.call(self, eat, subvalue, true) || tokenizers.blockquote.call(self, eat, subvalue, true) || tokenizers.html.call(self, eat, subvalue, true) ) { break; } if (gfm && tokenizers.list.call(self, eat, subvalue, true)) { break; } if ( !commonmark && ( tokenizers.lineHeading.call(self, eat, subvalue, true) || tokenizers.definition.call(self, eat, subvalue, true) || tokenizers.footnoteDefinition.call(self, eat, subvalue, true) ) ) { break; } index = value.indexOf(C_NEWLINE, index + 1); } subvalue = value.slice(0, index); if (trim(subvalue) === EMPTY) { eat(subvalue); return null; } /* istanbul ignore if - never used (yet) */ if (silent) { return true; } now = eat.now(); subvalue = trimTrailingLines(subvalue); return eat(subvalue)(self.renderInline(T_PARAGRAPH, subvalue, now)); } /** * Tokenise a text node. * * @example * tokenizeText(eat, 'foo'); * * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `text` node. */ function tokenizeText(eat, value, silent) { var self = this; var methods; var tokenizers; var index; var length; var subvalue; var position; var tokenizer; var name; var min; var now; /* istanbul ignore if - never used (yet) */ if (silent) { return true; } methods = self.inlineMethods; length = methods.length; tokenizers = self.inlineTokenizers; index = -1; min = value.length; while (++index < length) { name = methods[index]; if (name === 'inlineText' || !tokenizers[name]) { continue; } tokenizer = tokenizers[name].locator; if (!tokenizer) { eat.file.fail(ERR_MISSING_LOCATOR + C_TICK + name + C_TICK); continue; } position = tokenizer.call(self, value, 1); if (position !== -1 && position < min) { min = position; } } subvalue = value.slice(0, min); now = eat.now(); self.decode(subvalue, now, function (content, position, source) { eat(source || content)(self.renderRaw(T_TEXT, content)); }); } /** * Create a code-block node. * * @example * renderCodeBlock('foo()', 'js', now()); * * @param {string?} [value] - Code. * @param {string?} [language] - Optional language flag. * @param {Function} eat - Eater. * @return {Object} - `code` node. */ function renderCodeBlock(value, language) { return { 'type': T_CODE, 'lang': language || null, 'value': trimTrailingLines(value || EMPTY) }; } /** * Create a list-item using overly simple mechanics. * * @example * renderPedanticListItem('- _foo_', now()); * * @param {string} value - List-item. * @param {Object} position - List-item location. * @return {string} - Cleaned `value`. */ function renderPedanticListItem(value, position) { var self = this; var indent = self.indent(position.line); /** * A simple replacer which removed all matches, * and adds their length to `offset`. * * @param {string} $0 - Indentation to subtract. * @return {string} - An empty string. */ function replacer($0) { indent($0.length); return EMPTY; } /* * Remove the list-item’s bullet. */ value = value.replace(EXPRESSION_PEDANTIC_BULLET, replacer); /* * The initial line was also matched by the below, so * we reset the `line`. */ indent = self.indent(position.line); return value.replace(EXPRESSION_INITIAL_INDENT, replacer); } /** * Create a list-item using sane mechanics. * * @example * renderNormalListItem('- _foo_', now()); * * @param {string} value - List-item. * @param {Object} position - List-item location. * @return {string} - Cleaned `value`. */ function renderNormalListItem(value, position) { var self = this; var indent = self.indent(position.line); var max; var bullet; var rest; var lines; var trimmedLines; var index; var length; /* * Remove the list-item’s bullet. */ value = value.replace(EXPRESSION_BULLET, function ($0, $1, $2, $3, $4) { bullet = $1 + $2 + $3; rest = $4; /* * Make sure that the first nine numbered list items * can indent with an extra space. That is, when * the bullet did not receive an extra final space. */ if (Number($2) < 10 && bullet.length % 2 === 1) { $2 = C_SPACE + $2; } max = $1 + repeat(C_SPACE, $2.length) + $3; return max + rest; }); lines = value.split(C_NEWLINE); trimmedLines = removeIndentation( value, getIndent(max).indent ).split(C_NEWLINE); /* * We replaced the initial bullet with something * else above, which was used to trick * `removeIndentation` into removing some more * characters when possible. However, that could * result in the initial line to be stripped more * than it should be. */ trimmedLines[0] = rest; indent(bullet.length); index = 0; length = lines.length; while (++index < length) { indent(lines[index].length - trimmedLines[index].length); } return trimmedLines.join(C_NEWLINE); } /** * Create a list-item node. * * @example * renderListItem('- _foo_', now()); * * @param {Object} value - List-item. * @param {Object} position - List-item location. * @return {Object} - `listItem` node. */ function renderListItem(value, position) { var self = this; var checked = null; var node; var task; var indent; value = LIST_ITEM_MAP[self.options.pedantic].apply(self, arguments); if (self.options.gfm) { task = value.match(EXPRESSION_TASK_ITEM); if (task) { indent = task[0].length; checked = task[1].toLowerCase() === C_X_LOWER; self.indent(position.line)(indent); value = value.slice(indent); } } node = { 'type': T_LIST_ITEM, 'loose': EXPRESSION_LOOSE_LIST_ITEM.test(value) || value.charAt(value.length - 1) === C_NEWLINE }; if (self.options.gfm) { node.checked = checked; } node.children = self.tokenizeBlock(value, position); return node; } /** * Create a footnote-definition node. * * @example * renderFootnoteDefinition('1', '_foo_', now()); * * @param {string} identifier - Unique reference. * @param {string} value - Contents * @param {Object} position - Definition location. * @return {Object} - `footnoteDefinition` node. */ function renderFootnoteDefinition(identifier, value, position) { var self = this; var exitBlockquote = self.enterBlockquote(); var node; node = { 'type': T_FOOTNOTE_DEFINITION, 'identifier': identifier, 'children': self.tokenizeBlock(value, position) }; exitBlockquote(); return node; } /** * Create a heading node. * * @example * renderHeading('_foo_', 1, now()); * * @param {string} value - Content. * @param {number} depth - Heading depth. * @param {Object} position - Heading content location. * @return {Object} - `heading` node */ function renderHeading(value, depth, position) { return { 'type': T_HEADING, 'depth': depth, 'children': this.tokenizeInline(value, position) }; } /** * Create a blockquote node. * * @example * renderBlockquote('_foo_', eat); * * @param {string} value - Content. * @param {Object} now - Position. * @return {Object} - `blockquote` node. */ function renderBlockquote(value, now) { var self = this; var exitBlockquote = self.enterBlockquote(); var node = { 'type': T_BLOCKQUOTE, 'children': self.tokenizeBlock(value, now) }; exitBlockquote(); return node; } /** * Create a void node. * * @example * renderVoid('horizontalRule'); * * @param {string} type - Node type. * @return {Object} - Node of type `type`. */ function renderVoid(type) { return { 'type': type }; } /** * Create a parent. * * @example * renderParent('paragraph', '_foo_'); * * @param {string} type - Node type. * @param {Array.} children - Child nodes. * @return {Object} - Node of type `type`. */ function renderParent(type, children) { return { 'type': type, 'children': children }; } /** * Create a raw node. * * @example * renderRaw('inlineCode', 'foo()'); * * @param {string} type - Node type. * @param {string} value - Contents. * @return {Object} - Node of type `type`. */ function renderRaw(type, value) { return { 'type': type, 'value': value }; } /** * Create a link node. * * @example * renderLink(true, 'example.com', 'example', 'Example Domain', now(), eat); * renderLink(false, 'fav.ico', 'example', 'Example Domain', now(), eat); * * @param {boolean} isLink - Whether linking to a document * or an image. * @param {string} href - URI reference. * @param {string} text - Content. * @param {string?} title - Title. * @param {Object} position - Location of link. * @return {Object} - `link` or `image` node. */ function renderLink(isLink, href, text, title, position) { var self = this; var exitLink = self.enterLink(); var node; node = { 'type': isLink ? T_LINK : T_IMAGE, 'title': title || null }; if (isLink) { node.href = href; node.children = self.tokenizeInline(text, position); } else { node.src = href; node.alt = text ? self.decode.raw(self.descape(text), position) : null; } exitLink(); return node; } /** * Create a footnote node. * * @example * renderFootnote('_foo_', now()); * * @param {string} value - Contents. * @param {Object} position - Location of footnote. * @return {Object} - `footnote` node. */ function renderFootnote(value, position) { return this.renderInline(T_FOOTNOTE, value, position); } /** * Add a node with inline content. * * @example * renderInline('strong', '_foo_', now()); * * @param {string} type - Node type. * @param {string} value - Contents. * @param {Object} position - Location of node. * @return {Object} - Node of type `type`. */ function renderInline(type, value, position) { return this.renderParent(type, this.tokenizeInline(value, position)); } /** * Add a node with block content. * * @example * renderBlock('blockquote', 'Foo.', now()); * * @param {string} type - Node type. * @param {string} value - Contents. * @param {Object} position - Location of node. * @return {Object} - Node of type `type`. */ function renderBlock(type, value, position) { return this.renderParent(type, this.tokenizeBlock(value, position)); } /** * Find a possible escape sequence. * * @example * locateEscape('foo \- bar'); // 4 * * @param {string} value - Value to search. * @param {number} fromIndex - Index to start searching at. * @return {number} - Location of possible escape sequence. */ function locateEscape(value, fromIndex) { return value.indexOf(C_BACKSLASH, fromIndex); } /** * Tokenise an escape sequence. * * @example * tokenizeEscape(eat, '\\a'); * * @property {Function} locator - Escape locator. * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `text` or `break` node. */ function tokenizeEscape(eat, value, silent) { var self = this; var character; if (value.charAt(0) === C_BACKSLASH) { character = value.charAt(1); if (self.escape.indexOf(character) !== -1) { /* istanbul ignore if - never used (yet) */ if (silent) { return true; } return eat(C_BACKSLASH + character)( character === C_NEWLINE ? self.renderVoid(T_BREAK) : self.renderRaw(T_TEXT, character) ); } } } tokenizeEscape.locator = locateEscape; /** * Find a possible auto-link. * * @example * locateAutoLink('foo '); * * @property {boolean} notInLink * @property {Function} locator - Auto-link locator. * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `link` node. */ function tokenizeAutoLink(eat, value, silent) { var self; var subvalue; var length; var index; var queue; var character; var hasAtCharacter; var link; var now; var content; var tokenize; var node; if (value.charAt(0) !== C_LT) { return; } self = this; subvalue = EMPTY; length = value.length; index = 0; queue = EMPTY; hasAtCharacter = false; link = EMPTY; index++; subvalue = C_LT; while (index < length) { character = value.charAt(index); if ( character === C_SPACE || character === C_GT || character === C_AT_SIGN || (character === C_COLON && value.charAt(index + 1) === C_SLASH) ) { break; } queue += character; index++; } if (!queue) { return; } link += queue; queue = EMPTY; character = value.charAt(index); link += character; index++; if (character === C_AT_SIGN) { hasAtCharacter = true; } else { if ( character !== C_COLON || value.charAt(index + 1) !== C_SLASH ) { return; } link += C_SLASH; index++; } while (index < length) { character = value.charAt(index); if (character === C_SPACE || character === C_GT) { break; } queue += character; index++; } character = value.charAt(index); if (!queue || character !== C_GT) { return; } /* istanbul ignore if - never used (yet) */ if (silent) { return true; } link += queue; content = link; subvalue += link + character; now = eat.now(); now.column++; if (hasAtCharacter) { if ( link.substr(0, MAILTO_PROTOCOL.length).toLowerCase() !== MAILTO_PROTOCOL ) { link = MAILTO_PROTOCOL + link; } else { content = content.substr(MAILTO_PROTOCOL.length); now.column += MAILTO_PROTOCOL.length; } } /* * Temporarily remove support for escapes in autolinks. */ tokenize = self.inlineTokenizers.escape; self.inlineTokenizers.escape = null; node = eat(subvalue)( self.renderLink(true, decode(link), content, null, now, eat) ); self.inlineTokenizers.escape = tokenize; return node; } tokenizeAutoLink.notInLink = true; tokenizeAutoLink.locator = locateAutoLink; /** * Find a possible URL. * * @example * locateURL('foo http://bar'); // 4 * * @param {string} value - Value to search. * @param {number} fromIndex - Index to start searching at. * @return {number} - Location of possible URL. */ function locateURL(value, fromIndex) { var index = -1; var min = -1; var position; if (!this.options.gfm) { return -1; } while (++index < PROTOCOLS_LENGTH) { position = value.indexOf(PROTOCOLS[index], fromIndex); if (position !== -1 && (position < min || min === -1)) { min = position; } } return min; } /** * Tokenise a URL in text. * * @example * tokenizeURL(eat, 'http://foo.bar'); * * @property {boolean} notInLink * @property {Function} locator - URL locator. * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `link` node. */ function tokenizeURL(eat, value, silent) { var self = this; var subvalue; var content; var character; var index; var position; var protocol; var match; var length; var queue; var parenCount; var nextCharacter; var now; if (!self.options.gfm) { return; } subvalue = EMPTY; index = -1; length = PROTOCOLS_LENGTH; while (++index < length) { protocol = PROTOCOLS[index]; match = value.slice(0, protocol.length); if (match.toLowerCase() === protocol) { subvalue = match; break; } } if (!subvalue) { return; } index = subvalue.length; length = value.length; queue = EMPTY; parenCount = 0; while (index < length) { character = value.charAt(index); if (isWhiteSpace(character) || character === C_LT) { break; } if ( character === C_DOT || character === C_COMMA || character === C_COLON || character === C_SEMI_COLON || character === C_DOUBLE_QUOTE || character === C_SINGLE_QUOTE || character === C_PAREN_CLOSE || character === C_BRACKET_CLOSE ) { nextCharacter = value.charAt(index + 1); if ( !nextCharacter || isWhiteSpace(nextCharacter) ) { break; } } if ( character === C_PAREN_OPEN || character === C_BRACKET_OPEN ) { parenCount++; } if ( character === C_PAREN_CLOSE || character === C_BRACKET_CLOSE ) { parenCount--; if (parenCount < 0) { break; } } queue += character; index++; } if (!queue) { return; } subvalue += queue; content = subvalue; if (protocol === MAILTO_PROTOCOL) { position = queue.indexOf(C_AT_SIGN); if (position === -1 || position === length - 1) { return; } content = content.substr(MAILTO_PROTOCOL.length); } /* istanbul ignore if - never used (yet) */ if (silent) { return true; } now = eat.now(); return eat(subvalue)( self.renderLink(true, decode(subvalue), content, null, now, eat) ); } tokenizeURL.notInLink = true; tokenizeURL.locator = locateURL; /** * Find a possible tag. * * @example * locateTag('foo '); * * @property {Function} locator - Tag locator. * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `html` node. */ function tokenizeTag(eat, value, silent) { var self = this; var subvalue = eatHTMLComment(value, self.options) || eatHTMLCDATA(value) || eatHTMLProcessingInstruction(value) || eatHTMLDeclaration(value) || eatHTMLClosingTag(value) || eatHTMLOpeningTag(value); if (!subvalue) { return; } /* istanbul ignore if - never used (yet) */ if (silent) { return true; } if (!self.inLink && EXPRESSION_HTML_LINK_OPEN.test(subvalue)) { self.inLink = true; } else if (self.inLink && EXPRESSION_HTML_LINK_CLOSE.test(subvalue)) { self.inLink = false; } return eat(subvalue)(self.renderRaw(T_HTML, subvalue)); } tokenizeTag.locator = locateTag; /** * Find a possible link. * * @example * locateLink('foo ![bar'); // 4 * * @param {string} value - Value to search. * @param {number} fromIndex - Index to start searching at. * @return {number} - Location of possible link. */ function locateLink(value, fromIndex) { var link = value.indexOf(C_BRACKET_OPEN, fromIndex); var image = value.indexOf(C_EXCLAMATION_MARK + C_BRACKET_OPEN, fromIndex); if (image === -1) { return link; } /* * Link can never be `-1` if an image is found, so we don’t need to * check for that :) */ return link < image ? link : image; } /** * Tokenise a link. * * @example * tokenizeLink(eat, '![foo](fav.ico "Favicon")); * * @property {Function} locator - Link locator. * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `link` or `image` node. */ function tokenizeLink(eat, value, silent) { var self = this; var subvalue = EMPTY; var index = 0; var character = value.charAt(0); var beforeURL; var beforeTitle; var whiteSpaceQueue; var commonmark; var openCount; var hasMarker; var markers; var isImage; var content; var marker; var length; var title; var depth; var queue; var url; var now; /* * Detect whether this is an image. */ if (character === C_EXCLAMATION_MARK) { isImage = true; subvalue = character; character = value.charAt(++index); } /* * Eat the opening. */ if (character !== C_BRACKET_OPEN) { return; } /* * Exit when this is a link and we’re already inside * a link. */ if (!isImage && self.inLink) { return; } subvalue += character; queue = EMPTY; index++; /* * Eat the content. */ commonmark = self.options.commonmark; length = value.length; now = eat.now(); depth = 0; now.column += index; while (index < length) { character = value.charAt(index); if (character === C_BRACKET_OPEN) { depth++; } else if (character === C_BRACKET_CLOSE) { /* * Allow a single closing bracket when not in * commonmark-mode. */ if (!commonmark && !depth) { if (value.charAt(index + 1) === C_PAREN_OPEN) { break; } depth++; } if (depth === 0) { break; } depth--; } queue += character; index++; } /* * Eat the content closing. */ if ( value.charAt(index) !== C_BRACKET_CLOSE || value.charAt(++index) !== C_PAREN_OPEN ) { return; } subvalue += queue + C_BRACKET_CLOSE + C_PAREN_OPEN; index++; content = queue; /* * Eat white-space. */ while (index < length) { character = value.charAt(index); if (!isWhiteSpace(character)) { break; } subvalue += character; index++; } /* * Eat the URL. */ character = value.charAt(index); markers = commonmark ? COMMONMARK_LINK_TITLE_MARKERS : LINK_TITLE_MARKERS; openCount = 0; queue = EMPTY; beforeURL = subvalue; if (character === C_LT) { index++; beforeURL += C_LT; while (index < length) { character = value.charAt(index); if (character === C_GT) { break; } if (commonmark && character === C_NEWLINE) { return; } queue += character; index++; } if (value.charAt(index) !== C_GT) { return; } subvalue += C_LT + queue + C_GT; url = queue; index++; } else { character = null; whiteSpaceQueue = EMPTY; while (index < length) { character = value.charAt(index); if (whiteSpaceQueue && has.call(markers, character)) { break; } if (isWhiteSpace(character)) { if (commonmark) { break; } whiteSpaceQueue += character; } else { if (character === C_PAREN_OPEN) { depth++; openCount++; } else if (character === C_PAREN_CLOSE) { if (depth === 0) { break; } depth--; } queue += whiteSpaceQueue; whiteSpaceQueue = EMPTY; if (character === C_BACKSLASH) { queue += C_BACKSLASH; character = value.charAt(++index); } queue += character; } index++; } queue = queue; subvalue += queue; url = queue; index = subvalue.length; } /* * Eat white-space. */ queue = EMPTY; while (index < length) { character = value.charAt(index); if (!isWhiteSpace(character)) { break; } queue += character; index++; } character = value.charAt(index); subvalue += queue; /* * Eat the title. */ if (queue && has.call(markers, character)) { index++; subvalue += character; queue = EMPTY; marker = markers[character]; beforeTitle = subvalue; /* * In commonmark-mode, things are pretty easy: the * marker cannot occur inside the title. * * Non-commonmark does, however, support nested * delimiters. */ if (commonmark) { while (index < length) { character = value.charAt(index); if (character === marker) { break; } if (character === C_BACKSLASH) { queue += C_BACKSLASH; character = value.charAt(++index); } index++; queue += character; } character = value.charAt(index); if (character !== marker) { return; } title = queue; subvalue += queue + character; index++; while (index < length) { character = value.charAt(index); if (!isWhiteSpace(character)) { break; } subvalue += character; index++; } } else { whiteSpaceQueue = EMPTY; while (index < length) { character = value.charAt(index); if (character === marker) { if (hasMarker) { queue += marker + whiteSpaceQueue; whiteSpaceQueue = EMPTY; } hasMarker = true; } else if (!hasMarker) { queue += character; } else if (character === C_PAREN_CLOSE) { subvalue += queue + marker + whiteSpaceQueue; title = queue; break; } else if (isWhiteSpace(character)) { whiteSpaceQueue += character; } else { queue += marker + whiteSpaceQueue + character; whiteSpaceQueue = EMPTY; hasMarker = false; } index++; } } } if (value.charAt(index) !== C_PAREN_CLOSE) { return; } /* istanbul ignore if - never used (yet) */ if (silent) { return true; } subvalue += C_PAREN_CLOSE; url = self.decode.raw(self.descape(url), eat(beforeURL).test().end); if (title) { beforeTitle = eat(beforeTitle).test().end; title = self.decode.raw(self.descape(title), beforeTitle); } return eat(subvalue)( self.renderLink(!isImage, url, content, title, now, eat) ); } tokenizeLink.locator = locateLink; /** * Tokenise a reference link, image, or footnote; * shortcut reference link, or footnote. * * @example * tokenizeReference(eat, '[foo]'); * tokenizeReference(eat, '[foo][]'); * tokenizeReference(eat, '[foo][bar]'); * * @property {Function} locator - Reference locator. * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - Reference node. */ function tokenizeReference(eat, value, silent) { var self = this; var character = value.charAt(0); var index = 0; var length = value.length; var subvalue = EMPTY; var intro = EMPTY; var type = T_LINK; var referenceType = REFERENCE_TYPE_SHORTCUT; var text; var identifier; var now; var node; var exitLink; var queue; var bracketed; var depth; /* * Check whether we’re eating an image. */ if (character === C_EXCLAMATION_MARK) { type = T_IMAGE; intro = character; character = value.charAt(++index); } if (character !== C_BRACKET_OPEN) { return; } index++; intro += character; queue = EMPTY; /* * Check whether we’re eating a footnote. */ if ( self.options.footnotes && type === T_LINK && value.charAt(index) === C_CARET ) { intro += C_CARET; index++; type = T_FOOTNOTE; } /* * Eat the text. */ depth = 0; while (index < length) { character = value.charAt(index); if (character === C_BRACKET_OPEN) { bracketed = true; depth++; } else if (character === C_BRACKET_CLOSE) { if (!depth) { break; } depth--; } if (character === C_BACKSLASH) { queue += C_BACKSLASH; character = value.charAt(++index); } queue += character; index++; } subvalue = text = queue; character = value.charAt(index); if (character !== C_BRACKET_CLOSE) { return; } index++; subvalue += character; queue = EMPTY; while (index < length) { character = value.charAt(index); if (!isWhiteSpace(character)) { break; } queue += character; index++; } character = value.charAt(index); if (character !== C_BRACKET_OPEN) { if (!text) { return; } identifier = text; } else { identifier = EMPTY; queue += character; index++; while (index < length) { character = value.charAt(index); if ( character === C_BRACKET_OPEN || character === C_BRACKET_CLOSE ) { break; } if (character === C_BACKSLASH) { identifier += C_BACKSLASH; character = value.charAt(++index); } identifier += character; index++; } character = value.charAt(index); if (character === C_BRACKET_CLOSE) { queue += identifier + character; index++; referenceType = identifier ? REFERENCE_TYPE_FULL : REFERENCE_TYPE_COLLAPSED; } else { identifier = EMPTY; } subvalue += queue; queue = EMPTY; } /* * Brackets cannot be inside the identifier. */ if (referenceType !== REFERENCE_TYPE_FULL && bracketed) { return; } /* * Inline footnotes cannot have an identifier. */ if (type === T_FOOTNOTE && referenceType !== REFERENCE_TYPE_SHORTCUT) { type = T_LINK; intro = C_BRACKET_OPEN + C_CARET; text = C_CARET + text; } subvalue = intro + subvalue; if (type === T_LINK && self.inLink) { return null; } /* istanbul ignore if - never used (yet) */ if (silent) { return true; } if (type === T_FOOTNOTE && text.indexOf(C_SPACE) !== -1) { return eat(subvalue)(self.renderFootnote(text, eat.now())); } now = eat.now(); now.column += intro.length; identifier = referenceType === REFERENCE_TYPE_FULL ? identifier : text; node = { 'type': type + 'Reference', 'identifier': normalize(identifier) }; if (type === T_LINK || type === T_IMAGE) { node.referenceType = referenceType; } if (type === T_LINK) { exitLink = self.enterLink(); node.children = self.tokenizeInline(text, now); exitLink(); } else if (type === T_IMAGE) { node.alt = self.decode.raw(self.descape(text), now) || null; } return eat(subvalue)(node); } tokenizeReference.locator = locateLink; /** * Find a possible strong emphasis. * * @example * locateStrong('foo **bar'); // 4 * * @param {string} value - Value to search. * @param {number} fromIndex - Index to start searching at. * @return {number} - Location of possible strong emphasis. */ function locateStrong(value, fromIndex) { var asterisk = value.indexOf(C_ASTERISK + C_ASTERISK, fromIndex); var underscore = value.indexOf(C_UNDERSCORE + C_UNDERSCORE, fromIndex); if (underscore === -1) { return asterisk; } if (asterisk === -1) { return underscore; } return underscore < asterisk ? underscore : asterisk; } /** * Tokenise strong emphasis. * * @example * tokenizeStrong(eat, '**foo**'); * tokenizeStrong(eat, '__foo__'); * * @property {Function} locator - Strong emphasis locator. * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `strong` node. */ function tokenizeStrong(eat, value, silent) { var self = this; var index = 0; var character = value.charAt(index); var now; var pedantic; var marker; var queue; var subvalue; var length; var prev; if ( EMPHASIS_MARKERS[character] !== true || value.charAt(++index) !== character ) { return; } pedantic = self.options.pedantic; marker = character; subvalue = marker + marker; length = value.length; index++; queue = character = EMPTY; if (pedantic && isWhiteSpace(value.charAt(index))) { return; } while (index < length) { prev = character; character = value.charAt(index); if ( character === marker && value.charAt(index + 1) === marker && (!pedantic || !isWhiteSpace(prev)) ) { character = value.charAt(index + 2); if (character !== marker) { if (!trim(queue)) { return; } /* istanbul ignore if - never used (yet) */ if (silent) { return true; } now = eat.now(); now.column += 2; return eat(subvalue + queue + subvalue)( self.renderInline(T_STRONG, queue, now) ); } } if (!pedantic && character === C_BACKSLASH) { queue += character; character = value.charAt(++index); } queue += character; index++; } } tokenizeStrong.locator = locateStrong; /** * Find possible slight emphasis. * * @example * locateEmphasis('foo *bar'); // 4 * * @param {string} value - Value to search. * @param {number} fromIndex - Index to start searching at. * @return {number} - Location of possible slight emphasis. */ function locateEmphasis(value, fromIndex) { var asterisk = value.indexOf(C_ASTERISK, fromIndex); var underscore = value.indexOf(C_UNDERSCORE, fromIndex); if (underscore === -1) { return asterisk; } if (asterisk === -1) { return underscore; } return underscore < asterisk ? underscore : asterisk; } /** * Tokenise slight emphasis. * * @example * tokenizeEmphasis(eat, '*foo*'); * tokenizeEmphasis(eat, '_foo_'); * * @property {Function} locator - Slight emphasis locator. * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `emphasis` node. */ function tokenizeEmphasis(eat, value, silent) { var self = this; var index = 0; var character = value.charAt(index); var now; var pedantic; var marker; var queue; var subvalue; var length; var prev; if (EMPHASIS_MARKERS[character] !== true) { return; } pedantic = self.options.pedantic; subvalue = marker = character; length = value.length; index++; queue = character = EMPTY; if (pedantic && isWhiteSpace(value.charAt(index))) { return; } while (index < length) { prev = character; character = value.charAt(index); if ( character === marker && (!pedantic || !isWhiteSpace(prev)) ) { character = value.charAt(++index); if (character !== marker) { if (!trim(queue) || prev === marker) { return; } if ( pedantic || marker !== C_UNDERSCORE || !isWordCharacter(character) ) { /* istanbul ignore if - never used (yet) */ if (silent) { return true; } now = eat.now(); now.column++; return eat(subvalue + queue + marker)( self.renderInline(T_EMPHASIS, queue, now) ); } } queue += marker; } if (!pedantic && character === C_BACKSLASH) { queue += character; character = value.charAt(++index); } queue += character; index++; } } tokenizeEmphasis.locator = locateEmphasis; /** * Find a possible deletion. * * @example * locateDeletion('foo ~~bar'); // 4 * * @param {string} value - Value to search. * @param {number} fromIndex - Index to start searching at. * @return {number} - Location of possible deletion. */ function locateDeletion(value, fromIndex) { return value.indexOf(C_TILDE + C_TILDE, fromIndex); } /** * Tokenise a deletion. * * @example * tokenizeDeletion(eat, '~~foo~~'); * * @property {Function} locator - Deletion locator. * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `delete` node. */ function tokenizeDeletion(eat, value, silent) { var self = this; var character = EMPTY; var previous = EMPTY; var preceding = EMPTY; var subvalue = EMPTY; var index; var length; var now; if ( !self.options.gfm || value.charAt(0) !== C_TILDE || value.charAt(1) !== C_TILDE || isWhiteSpace(value.charAt(2)) ) { return; } index = 1; length = value.length; now = eat.now(); now.column += 2; while (++index < length) { character = value.charAt(index); if ( character === C_TILDE && previous === C_TILDE && (!preceding || !isWhiteSpace(preceding)) ) { /* istanbul ignore if - never used (yet) */ if (silent) { return true; } return eat(C_TILDE + C_TILDE + subvalue + C_TILDE + C_TILDE)( self.renderInline(T_DELETE, subvalue, now) ); } subvalue += previous; preceding = previous; previous = character; } } tokenizeDeletion.locator = locateDeletion; /** * Find possible inline code. * * @example * locateInlineCode('foo `bar'); // 4 * * @param {string} value - Value to search. * @param {number} fromIndex - Index to start searching at. * @return {number} - Location of possible inline code. */ function locateInlineCode(value, fromIndex) { return value.indexOf(C_TICK, fromIndex); } /** * Tokenise inline code. * * @example * tokenizeInlineCode(eat, '`foo()`'); * * @property {Function} locator - Inline code locator. * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `inlineCode` node. */ function tokenizeInlineCode(eat, value, silent) { var self = this; var length = value.length; var index = 0; var queue = EMPTY; var tickQueue = EMPTY; var contentQueue; var whiteSpaceQueue; var count; var openingCount; var subvalue; var character; var found; var next; while (index < length) { if (value.charAt(index) !== C_TICK) { break; } queue += C_TICK; index++; } if (!queue) { return; } subvalue = queue; openingCount = index; queue = EMPTY; next = value.charAt(index); count = 0; while (index < length) { character = next; next = value.charAt(index + 1); if (character === C_TICK) { count++; tickQueue += character; } else { count = 0; queue += character; } if (count && next !== C_TICK) { if (count === openingCount) { subvalue += queue + tickQueue; found = true; break; } queue += tickQueue; tickQueue = EMPTY; } index++; } if (!found) { if (openingCount % 2 !== 0) { return; } queue = EMPTY; } /* istanbul ignore if - never used (yet) */ if (silent) { return true; } contentQueue = whiteSpaceQueue = EMPTY; length = queue.length; index = -1; while (++index < length) { character = queue.charAt(index); if (isWhiteSpace(character)) { whiteSpaceQueue += character; continue; } if (whiteSpaceQueue) { if (contentQueue) { contentQueue += whiteSpaceQueue; } whiteSpaceQueue = EMPTY; } contentQueue += character; } return eat(subvalue)(self.renderRaw(T_INLINE_CODE, contentQueue)); } tokenizeInlineCode.locator = locateInlineCode; /** * Find a possible break. * * @example * locateBreak('foo \nbar'); // 3 * * @param {string} value - Value to search. * @param {number} fromIndex - Index to start searching at. * @return {number} - Location of possible break. */ function locateBreak(value, fromIndex) { var index = value.indexOf(C_NEWLINE, fromIndex); while (index > fromIndex) { if (value.charAt(index - 1) !== C_SPACE) { break; } index--; } return index; } /** * Tokenise a break. * * @example * tokenizeBreak(eat, ' \n'); * * @property {Function} locator - Break locator. * @param {function(string)} eat - Eater. * @param {string} value - Rest of content. * @param {boolean?} [silent] - Whether this is a dry run. * @return {Node?|boolean} - `break` node. */ function tokenizeBreak(eat, value, silent) { var self = this; var breaks = self.options.breaks; var length = value.length; var index = -1; var queue = EMPTY; var character; while (++index < length) { character = value.charAt(index); if (character === C_NEWLINE) { if (!breaks && index < MIN_BREAK_LENGTH) { return; } /* istanbul ignore if - never used (yet) */ if (silent) { return true; } queue += character; return eat(queue)(self.renderVoid(T_BREAK)); } if (character !== C_SPACE) { return; } queue += character; } } tokenizeBreak.locator = locateBreak; /** * Construct a new parser. * * @example * var parser = new Parser(new VFile('Foo')); * * @constructor * @class {Parser} * @param {VFile} file - File to parse. * @param {Object?} [options] - Passed to * `Parser#setOptions()`. */ function Parser(file, options, processor) { var self = this; self.file = file; self.inLink = false; self.atTop = true; self.atStart = true; self.inBlockquote = false; self.data = processor.data; self.descape = descapeFactory(self, 'escape'); self.decode = decodeFactory(self); self.options = extend({}, self.options); self.setOptions(options); } /** * Set options. Does not overwrite previously set * options. * * @example * var parser = new Parser(); * parser.setOptions({gfm: true}); * * @this {Parser} * @throws {Error} - When an option is invalid. * @param {Object?} [options] - Parse settings. * @return {Parser} - `self`. */ Parser.prototype.setOptions = function (options) { var self = this; var escape = self.data.escape; var current = self.options; var key; if (options === null || options === undefined) { options = {}; } else if (typeof options === 'object') { options = extend({}, options); } else { raise(options, 'options'); } for (key in defaultOptions) { validate.boolean(options, key, current[key]); } self.options = options; if (options.commonmark) { self.escape = escape.commonmark; } else if (options.gfm) { self.escape = escape.gfm; } else { self.escape = escape.default; } return self; }; /* * Expose `defaults`. */ Parser.prototype.options = defaultOptions; /** * Factory to track indentation for each line corresponding * to the given `start` and the number of invocations. * * @param {number} start - Starting line. * @return {function(offset)} - Indenter. */ Parser.prototype.indent = function (start) { var self = this; var line = start; /** * Intender which increments the global offset, * starting at the bound line, and further incrementing * each line for each invocation. * * @example * indenter(2); * * @param {number} offset - Number to increment the * offset. */ function indenter(offset) { self.offset[line] = (self.offset[line] || 0) + offset; line++; } return indenter; }; /** * Get found offsets starting at `start`. * * @param {number} start - Starting line. * @return {Array.} - Offsets starting at `start`. */ Parser.prototype.getIndent = function (start) { var offset = this.offset; var result = []; while (++start) { if (!(start in offset)) { break; } result.push((offset[start] || 0) + 1); } return result; }; /** * Parse the bound file. * * @example * new Parser(new File('_Foo_.')).parse(); * * @this {Parser} * @return {Object} - `root` node. */ Parser.prototype.parse = function () { var self = this; var value = clean(String(self.file)); var node; /* * Add an `offset` matrix, used to keep track of * syntax and white space indentation per line. */ self.offset = {}; node = self.renderBlock(T_ROOT, value); if (self.options.position) { node.position = { 'start': { 'line': 1, 'column': 1 } }; node.position.end = self.eof || node.position.start; } return node; }; /* * Enter and exit helpers. */ Parser.prototype.enterLink = stateToggler('inLink', false); Parser.prototype.exitTop = stateToggler('atTop', true); Parser.prototype.exitStart = stateToggler('atStart', true); Parser.prototype.enterBlockquote = stateToggler('inBlockquote', false); /* * Expose helpers */ Parser.prototype.renderRaw = renderRaw; Parser.prototype.renderVoid = renderVoid; Parser.prototype.renderParent = renderParent; Parser.prototype.renderInline = renderInline; Parser.prototype.renderBlock = renderBlock; Parser.prototype.renderLink = renderLink; Parser.prototype.renderCodeBlock = renderCodeBlock; Parser.prototype.renderBlockquote = renderBlockquote; Parser.prototype.renderListItem = renderListItem; Parser.prototype.renderFootnoteDefinition = renderFootnoteDefinition; Parser.prototype.renderHeading = renderHeading; Parser.prototype.renderFootnote = renderFootnote; /** * Construct a tokenizer. This creates both * `tokenizeInline` and `tokenizeBlock`. * * @example * Parser.prototype.tokenizeInline = tokenizeFactory('inline'); * * @param {string} type - Name of parser, used to find * its expressions (`%sMethods`) and tokenizers * (`%Tokenizers`). * @return {Function} - Tokenizer. */ function tokenizeFactory(type) { /** * Tokenizer for a bound `type` * * @example * parser = new Parser(); * parser.tokenizeInline('_foo_'); * * @param {string} value - Content. * @param {Object?} [location] - Offset at which `value` * starts. * @return {Array.} - Nodes. */ function tokenize(value, location) { var self = this; var offset = self.offset; var tokens = []; var methods = self[type + 'Methods']; var tokenizers = self[type + 'Tokenizers']; var line = location ? location.line : 1; var column = location ? location.column : 1; var patchPosition = self.options.position; var add; var index; var length; var method; var name; var matched; var valueLength; var eater; /* * Trim white space only lines. */ if (!value) { return tokens; } /** * Update line and column based on `value`. * * @example * updatePosition('foo'); * * @param {string} subvalue - Subvalue to eat. */ function updatePosition(subvalue) { var lastIndex = -1; var index = subvalue.indexOf(C_NEWLINE); while (index !== -1) { line++; lastIndex = index; index = subvalue.indexOf(C_NEWLINE, index + 1); } if (lastIndex === -1) { column = column + subvalue.length; } else { column = subvalue.length - lastIndex; } if (line in offset) { if (lastIndex !== -1) { column += offset[line]; } else if (column <= offset[line]) { column = offset[line] + 1; } } } /** * Get offset. Called before the first character is * eaten to retrieve the range's offsets. * * @return {Function} - `done`, to be called when * the last character is eaten. */ function getOffset() { var indentation = []; var pos = line + 1; /** * Done. Called when the last character is * eaten to retrieve the range’s offsets. * * @return {Array.} - Offset. */ function done() { var last = line + 1; while (pos < last) { indentation.push((offset[pos] || 0) + 1); pos++; } return indentation; } return done; } /** * Get the current position. * * @example * position = now(); // {line: 1, column: 1} * * @return {Object} - Current Position. */ function now() { return { 'line': line, 'column': column }; } /** * Store position information for a node. * * @example * start = now(); * updatePosition('foo'); * location = new Position(start); * // {start: {line: 1, column: 1}, end: {line: 1, column: 3}} * * @param {Object} start - Starting position. */ function Position(start) { this.start = start; this.end = now(); } /** * Throw when a value is incorrectly eaten. * This shouldn’t happen but will throw on new, * incorrect rules. * * @example * // When the current value is set to `foo bar`. * validateEat('foo'); * eat('foo'); * * validateEat('bar'); * // throws, because the space is not eaten. * * @param {string} subvalue - Value to be eaten. * @throws {Error} - When `subvalue` cannot be eaten. */ function validateEat(subvalue) { /* istanbul ignore if */ if (value.substring(0, subvalue.length) !== subvalue) { self.file.fail(ERR_INCORRECTLY_EATEN, now()); } } /** * Mark position and patch `node.position`. * * @example * var update = position(); * updatePosition('foo'); * update({}); * // { * // position: { * // start: {line: 1, column: 1} * // end: {line: 1, column: 3} * // } * // } * * @returns {Function} - Updater. */ function position() { var before = now(); /** * Add the position to a node. * * @example * update({type: 'text', value: 'foo'}); * * @param {Node} node - Node to attach position * on. * @param {Array} [indent] - Indentation for * `node`. * @return {Node} - `node`. */ function update(node, indent) { var prev = node.position; var start = prev ? prev.start : before; var combined = []; var n = prev && prev.end.line; var l = before.line; node.position = new Position(start); /* * If there was already a `position`, this * node was merged. Fixing `start` wasn’t * hard, but the indent is different. * Especially because some information, the * indent between `n` and `l` wasn’t * tracked. Luckily, that space is * (should be?) empty, so we can safely * check for it now. */ if (prev && indent && prev.indent) { combined = prev.indent; if (n < l) { while (++n < l) { combined.push((offset[n] || 0) + 1); } combined.push(before.column); } indent = combined.concat(indent); } node.position.indent = indent || []; return node; } return update; } /** * Add `node` to `parent`s children or to `tokens`. * Performs merges where possible. * * @example * add({}); * * add({}, {children: []}); * * @param {Object} node - Node to add. * @param {Object} [parent] - Parent to insert into. * @return {Object} - Added or merged into node. */ add = function (node, parent) { var prev; var children; if (!parent) { children = tokens; } else { children = parent.children; } prev = children[children.length - 1]; if ( prev && node.type === prev.type && node.type in MERGEABLE_NODES && mergeable(prev) && mergeable(node) ) { node = MERGEABLE_NODES[node.type].call( self, prev, node ); } if (node !== prev) { children.push(node); } if (self.atStart && tokens.length) { self.exitStart(); } return node; }; /** * Remove `subvalue` from `value`. * Expects `subvalue` to be at the start from * `value`, and applies no validation. * * @example * eat('foo')({type: 'text', value: 'foo'}); * * @param {string} subvalue - Removed from `value`, * and passed to `updatePosition`. * @return {Function} - Wrapper around `add`, which * also adds `position` to node. */ function eat(subvalue) { var indent = getOffset(); var pos = position(); var current = now(); validateEat(subvalue); /** * Add the given arguments, add `position` to * the returned node, and return the node. * * @param {Object} node - Node to add. * @param {Object} [parent] - Node to insert into. * @return {Node} - Added node. */ function apply(node, parent) { return pos(add(pos(node), parent), indent); } /** * Functions just like apply, but resets the * content: the line and column are reversed, * and the eaten value is re-added. * * This is useful for nodes with a single * type of content, such as lists and tables. * * See `apply` above for what parameters are * expected. * * @return {Node} - Added node. */ function reset() { var node = apply.apply(null, arguments); line = current.line; column = current.column; value = subvalue + value; return node; } /** * Test the position, after eating, and reverse * to a not-eaten state. * * @return {Position} - Position after eating `subvalue`. */ function test() { var result = pos({}); line = current.line; column = current.column; value = subvalue + value; return result.position; } apply.reset = reset; apply.test = reset.test = test; value = value.substring(subvalue.length); updatePosition(subvalue); indent = indent(); return apply; } /** * Same as `eat` above, but will not add positional * information to nodes. * * @example * noEat('foo')({type: 'text', value: 'foo'}); * * @param {string} subvalue - Removed from `value`. * @return {Function} - Wrapper around `add`. */ function noEat(subvalue) { validateEat(subvalue); /** * Add the given arguments, and return the * node. * * @return {Node} - Added node. */ function apply() { return add.apply(null, arguments); } /** * Functions just like apply, but resets the * content: the eaten value is re-added. * * @return {Node} - Added node. */ function reset() { var node = apply.apply(null, arguments); value = subvalue + value; return node; } /** * Test the position, which in this mode is an * empty object. * * @return {Object} - Empty position object. */ function test() { value = subvalue + value; return {}; } apply.reset = reset; apply.test = reset.test = test; value = value.substring(subvalue.length); return apply; } /* * Expose the eater, depending on if `position`s * should be patched on nodes. */ eater = patchPosition ? eat : noEat; /* * Expose `now` on `eater`. */ eater.now = now; /* * Expose `file` on `eater`. */ eater.file = self.file; /* * Sync initial offset. */ updatePosition(EMPTY); /* * Iterate over `value`, and iterate over all * tokenizers. When one eats something, re-iterate * with the remaining value. If no tokenizer eats, * something failed (should not happen) and an * exception is thrown. */ while (value) { index = -1; length = methods.length; matched = false; while (++index < length) { name = methods[index]; method = tokenizers[name]; if ( method && (!method.onlyAtStart || self.atStart) && (!method.onlyAtTop || self.atTop) && (!method.notInBlockquote || !self.inBlockquote) && (!method.notInLink || !self.inLink) ) { valueLength = value.length; method.apply(self, [eater, value]); matched = valueLength !== value.length; if (matched) { break; } } } /* istanbul ignore if */ if (!matched) { self.file.fail(ERR_INFINITE_LOOP, eater.now()); /* * Errors are not thrown on `File#fail` * when `quiet: true`. */ break; } } self.eof = now(); return tokens; } return tokenize; } /* * Expose tokenizers for block-level nodes. */ Parser.prototype.blockTokenizers = { 'yamlFrontMatter': tokenizeYAMLFrontMatter, 'newline': tokenizeNewline, 'code': tokenizeCode, 'fences': tokenizeFences, 'heading': tokenizeHeading, 'lineHeading': tokenizeLineHeading, 'horizontalRule': tokenizeHorizontalRule, 'blockquote': tokenizeBlockquote, 'list': tokenizeList, 'html': tokenizeHTML, 'definition': tokenizeDefinition, 'footnoteDefinition': tokenizeFootnoteDefinition, 'table': tokenizeTable, 'paragraph': tokenizeParagraph }; /* * Expose order in which to parse block-level nodes. */ Parser.prototype.blockMethods = [ 'yamlFrontMatter', 'newline', 'code', 'fences', 'blockquote', 'heading', 'horizontalRule', 'list', 'lineHeading', 'html', 'footnoteDefinition', 'definition', 'looseTable', 'table', 'paragraph' ]; /** * Block tokenizer. * * @example * var parser = new Parser(); * parser.tokenizeBlock('> foo.'); * * @param {string} value - Content. * @return {Array.} - Nodes. */ Parser.prototype.tokenizeBlock = tokenizeFactory(BLOCK); /* * Expose tokenizers for inline-level nodes. */ Parser.prototype.inlineTokenizers = { 'escape': tokenizeEscape, 'autoLink': tokenizeAutoLink, 'url': tokenizeURL, 'tag': tokenizeTag, 'link': tokenizeLink, 'reference': tokenizeReference, 'strong': tokenizeStrong, 'emphasis': tokenizeEmphasis, 'deletion': tokenizeDeletion, 'inlineCode': tokenizeInlineCode, 'break': tokenizeBreak, 'inlineText': tokenizeText }; /* * Expose order in which to parse inline-level nodes. */ Parser.prototype.inlineMethods = [ 'escape', 'autoLink', 'url', 'tag', 'link', 'reference', 'shortcutReference', 'strong', 'emphasis', 'deletion', 'inlineCode', 'break', 'inlineText' ]; /** * Inline tokenizer. * * @example * var parser = new Parser(); * parser.tokenizeInline('_foo_'); * * @param {string} value - Content. * @return {Array.} - Nodes. */ Parser.prototype.tokenizeInline = tokenizeFactory(INLINE); /* * Expose `tokenizeFactory` so dependencies could create * their own tokenizers. */ Parser.prototype.tokenizeFactory = tokenizeFactory; /* * Expose `parse` on `module.exports`. */ module.exports = Parser; },{"./block-elements.json":416,"./defaults.js":417,"./utilities.js":421,"extend.js":147,"parse-entities":289,"repeat-string":422,"trim":622,"trim-trailing-lines":621}],420:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015-2016 Titus Wormer * @license MIT * @module remark:stringify * @version 3.2.2 * @fileoverview Compile an abstract syntax tree into * a markdown document. */ 'use strict'; /* eslint-env commonjs */ /* * Dependencies. */ var decode = require('parse-entities'); var encode = require('stringify-entities'); var table = require('markdown-table'); var repeat = require('repeat-string'); var extend = require('extend.js'); var ccount = require('ccount'); var longestStreak = require('longest-streak'); var utilities = require('./utilities.js'); var defaultOptions = require('./defaults.js').stringify; /* * Methods. */ var raise = utilities.raise; var validate = utilities.validate; var stateToggler = utilities.stateToggler; var mergeable = utilities.mergeable; var MERGEABLE_NODES = utilities.MERGEABLE_NODES; /* * Constants. */ var INDENT = 4; var MINIMUM_CODE_FENCE_LENGTH = 3; var YAML_FENCE_LENGTH = 3; var MINIMUM_RULE_LENGTH = 3; var MAILTO = 'mailto:'; var ERROR_LIST_ITEM_INDENT = 'Cannot indent code properly. See ' + 'http://git.io/mdast-lii'; /* * Expressions. */ var EXPRESSIONS_WHITE_SPACE = /\s/; /* * Naive fence expression. */ var FENCE = /([`~])\1{2}/; /* * Expression for a protocol. * * @see http://en.wikipedia.org/wiki/URI_scheme#Generic_syntax */ var PROTOCOL = /^[a-z][a-z+.-]+:\/?/i; /* * Punctuation characters. */ var PUNCTUATION = /[-!"#$%&'()*+,.\/:;<=>?@\[\\\]^`{|}~_]/; /* * Characters. */ var ANGLE_BRACKET_CLOSE = '>'; var ANGLE_BRACKET_OPEN = '<'; var ASTERISK = '*'; var BACKSLASH = '\\'; var CARET = '^'; var COLON = ':'; var SEMICOLON = ';'; var DASH = '-'; var DOT = '.'; var EMPTY = ''; var EQUALS = '='; var EXCLAMATION_MARK = '!'; var HASH = '#'; var AMPERSAND = '&'; var LINE = '\n'; var CARRIAGE = '\r'; var FORM_FEED = '\f'; var PARENTHESIS_OPEN = '('; var PARENTHESIS_CLOSE = ')'; var PIPE = '|'; var PLUS = '+'; var QUOTE_DOUBLE = '"'; var QUOTE_SINGLE = '\''; var SPACE = ' '; var TAB = '\t'; var VERTICAL_TAB = '\u000B'; var SQUARE_BRACKET_OPEN = '['; var SQUARE_BRACKET_CLOSE = ']'; var TICK = '`'; var TILDE = '~'; var UNDERSCORE = '_'; /* * Entities. */ var ENTITY_AMPERSAND = AMPERSAND + 'amp' + SEMICOLON; var ENTITY_ANGLE_BRACKET_OPEN = AMPERSAND + 'lt' + SEMICOLON; var ENTITY_COLON = AMPERSAND + '#x3A' + SEMICOLON; /* * Character combinations. */ var BREAK = LINE + LINE; var GAP = BREAK + LINE; var DOUBLE_TILDE = TILDE + TILDE; /* * Allowed entity options. */ var ENTITY_OPTIONS = {}; ENTITY_OPTIONS.true = true; ENTITY_OPTIONS.false = true; ENTITY_OPTIONS.numbers = true; ENTITY_OPTIONS.escape = true; /* * Allowed list-bullet characters. */ var LIST_BULLETS = {}; LIST_BULLETS[ASTERISK] = true; LIST_BULLETS[DASH] = true; LIST_BULLETS[PLUS] = true; /* * Allowed horizontal-rule bullet characters. */ var HORIZONTAL_RULE_BULLETS = {}; HORIZONTAL_RULE_BULLETS[ASTERISK] = true; HORIZONTAL_RULE_BULLETS[DASH] = true; HORIZONTAL_RULE_BULLETS[UNDERSCORE] = true; /* * Allowed emphasis characters. */ var EMPHASIS_MARKERS = {}; EMPHASIS_MARKERS[UNDERSCORE] = true; EMPHASIS_MARKERS[ASTERISK] = true; /* * Allowed fence markers. */ var FENCE_MARKERS = {}; FENCE_MARKERS[TICK] = true; FENCE_MARKERS[TILDE] = true; /* * Which method to use based on `list.ordered`. */ var ORDERED_MAP = {}; ORDERED_MAP.true = 'visitOrderedItems'; ORDERED_MAP.false = 'visitUnorderedItems'; /* * Allowed list-item-indent's. */ var LIST_ITEM_INDENTS = {}; var LIST_ITEM_TAB = 'tab'; var LIST_ITEM_ONE = '1'; var LIST_ITEM_MIXED = 'mixed'; LIST_ITEM_INDENTS[LIST_ITEM_ONE] = true; LIST_ITEM_INDENTS[LIST_ITEM_TAB] = true; LIST_ITEM_INDENTS[LIST_ITEM_MIXED] = true; /* * Which checkbox to use. */ var CHECKBOX_MAP = {}; CHECKBOX_MAP.null = EMPTY; CHECKBOX_MAP.undefined = EMPTY; CHECKBOX_MAP.true = SQUARE_BRACKET_OPEN + 'x' + SQUARE_BRACKET_CLOSE + SPACE; CHECKBOX_MAP.false = SQUARE_BRACKET_OPEN + SPACE + SQUARE_BRACKET_CLOSE + SPACE; /** * Encode noop. * Simply returns the given value. * * @example * var encode = encodeNoop(); * encode('AT&T') // 'AT&T' * * @param {string} value - Content. * @return {string} - Content, without any modifications. */ function encodeNoop(value) { return value; } /** * Factory to encode HTML entities. * Creates a no-operation function when `type` is * `'false'`, a function which encodes using named * references when `type` is `'true'`, and a function * which encodes using numbered references when `type` is * `'numbers'`. * * @example * encodeFactory('false')('AT&T') // 'AT&T' * encodeFactory('true')('AT&T') // 'AT&T' * encodeFactory('numbers')('AT&T') // 'ATT&T' * * @param {string} type - Either `'true'`, `'false'`, or * `'numbers'`. * @return {function(string): string} - Function which * takes a value and returns its encoded version. */ function encodeFactory(type) { var options = {}; if (type === 'false') { return encodeNoop; } if (type === 'true') { options.useNamedReferences = true; } if (type === 'escape') { options.escapeOnly = options.useNamedReferences = true; } /** * Encode HTML entities using `he` using bound options. * * @see https://github.com/mathiasbynens/he#strict * * @example * // When `type` is `'true'`. * encode('AT&T'); // 'AT&T' * * // When `type` is `'numbers'`. * encode('AT&T'); // 'ATT&T' * * @param {string} value - Content. * @param {Object} [node] - Node which is compiled. * @return {string} - Encoded content. * @throws {Error} - When `file.quiet` is not `true`. * However, by default `he` does not throw on * parse errors, but when * `he.encode.options.strict: true`, they occur on * invalid HTML. */ function encoder(value) { return encode(value, options); } return encoder; } /** * Returns the length of HTML entity that is a prefix of * the given string (excluding the ampersand), 0 if it * does not start with an entity. * * @example * entityPrefixLength('©cat') // 4 * entityPrefixLength('&foo & &bar') // 0 * * @param {string} value - Input string. * @return {number} - Length of an entity. */ function entityPrefixLength(value) { var prefix; /* istanbul ignore if - Currently also tested for at * implemention, but we keep it here because that’s * proper. */ if (value.charAt(0) !== AMPERSAND) { return 0; } prefix = value.split(AMPERSAND, 2).join(AMPERSAND); return prefix.length - decode(prefix).length; } /** * Checks if a string starts with HTML entity. * * @example * startsWithEntity('©cat') // true * startsWithEntity('&foo & &bar') // false * * @param {string} value - Value to check. * @return {number} - Whether `value` starts an entity. */ function startsWithEntity(value) { return entityPrefixLength(value) > 0; } /** * Check if `character` is a valid alignment row character. * * @example * isAlignmentRowCharacter(':') // true * isAlignmentRowCharacter('=') // false * * @param {string} character - Character to check. * @return {boolean} - Whether `character` is a valid * alignment row character. */ function isAlignmentRowCharacter(character) { return character === COLON || character === DASH || character === SPACE || character === PIPE; } /** * Check if `index` in `value` is inside an alignment row. * * @example * isInAlignmentRow(':--:', 2) // true * isInAlignmentRow(':--:\n:-*-:', 9) // false * * @param {string} value - Value to check. * @param {number} index - Position in `value` to check. * @return {boolean} - Whether `index` in `value` is in * an alignment row. */ function isInAlignmentRow(value, index) { var length = value.length; var start = index; var character; while (++index < length) { character = value.charAt(index); if (character === LINE) { break; } if (!isAlignmentRowCharacter(character)) { return false; } } index = start; while (--index > -1) { character = value.charAt(index); if (character === LINE) { break; } if (!isAlignmentRowCharacter(character)) { return false; } } return true; } /** * Factory to escape characters. * * @example * var escape = escapeFactory({ commonmark: true }); * escape('x*x', { type: 'text', value: 'x*x' }) // 'x\\*x' * * @param {Object} options - Compiler options. * @return {function(value, node, parent): string} - Function which * takes a value and a node and (optionally) its parent and returns * its escaped value. */ function escapeFactory(options) { /** * Escape punctuation characters in a node's value. * * @param {string} value - Value to escape. * @param {Object} node - Node in which `value` exists. * @param {Object} [parent] - Parent of `node`. * @return {string} - Escaped `value`. */ return function escape(value, node, parent) { var self = this; var gfm = options.gfm; var commonmark = options.commonmark; var siblings = parent && parent.children; var index = siblings && siblings.indexOf(node); var prev = siblings && siblings[index - 1]; var next = siblings && siblings[index + 1]; var length = value.length; var position = -1; var queue = []; var escaped = queue; var afterNewLine; var character; if (prev) { afterNewLine = prev.type === 'text' && /\n\s*$/.test(prev.value); } else if (parent) { afterNewLine = parent.type === 'paragraph'; } while (++position < length) { character = value.charAt(position); if ( character === BACKSLASH || character === TICK || character === ASTERISK || character === SQUARE_BRACKET_OPEN || character === UNDERSCORE || (self.inLink && character === SQUARE_BRACKET_CLOSE) || ( gfm && character === PIPE && ( self.inTable || isInAlignmentRow(value, position) ) ) ) { afterNewLine = false; queue.push(BACKSLASH); } else if (character === ANGLE_BRACKET_OPEN) { afterNewLine = false; if (commonmark) { queue.push(BACKSLASH); } else { queue.push(ENTITY_ANGLE_BRACKET_OPEN); continue; } } else if ( gfm && !self.inLink && character === COLON && ( queue.slice(-6).join(EMPTY) === 'mailto' || queue.slice(-5).join(EMPTY) === 'https' || queue.slice(-4).join(EMPTY) === 'http' ) ) { afterNewLine = false; if (commonmark) { queue.push(BACKSLASH); } else { queue.push(ENTITY_COLON); continue; } /* istanbul ignore if - Impossible to test with * the current set-up. We need tests which try * to force markdown content into the tree. */ } else if ( character === AMPERSAND && startsWithEntity(value.slice(position)) ) { afterNewLine = false; if (commonmark) { queue.push(BACKSLASH); } else { queue.push(ENTITY_AMPERSAND); continue; } } else if ( gfm && character === TILDE && value.charAt(position + 1) === TILDE ) { queue.push(BACKSLASH, TILDE); afterNewLine = false; position += 1; } else if (character === LINE) { afterNewLine = true; } else if (afterNewLine) { if ( character === ANGLE_BRACKET_CLOSE || character === HASH || LIST_BULLETS[character] ) { queue.push(BACKSLASH); afterNewLine = false; } else if ( character !== SPACE && character !== TAB && character !== CARRIAGE && character !== VERTICAL_TAB && character !== FORM_FEED ) { afterNewLine = false; } } queue.push(character); } /* * Multi-node versions. */ if (siblings && node.type === 'text') { /* * Check for an opening parentheses after a * link-reference (which can be joined by * white-space). */ if ( prev && prev.referenceType === 'shortcut' ) { position = -1; length = escaped.length; while (++position < length) { character = escaped[position]; if (character === SPACE || character === TAB) { continue; } if (character === PARENTHESIS_OPEN) { escaped[position] = BACKSLASH + character; } if (character === COLON) { if (commonmark) { escaped[position] = BACKSLASH + character; } else { escaped[position] = ENTITY_COLON; } } break; } } /* * Ensure non-auto-links are not seen as links. * This pattern needs to check the preceding * nodes too. */ if ( gfm && !self.inLink && prev && prev.type === 'text' && value.charAt(0) === COLON ) { queue = prev.value.slice(-6); if ( queue === 'mailto' || queue.slice(-5) === 'https' || queue.slice(-4) === 'http' ) { if (commonmark) { escaped.unshift(BACKSLASH); } else { escaped.splice(0, 1, ENTITY_COLON); } } } /* * Escape ampersand if it would otherwise * start an entity. */ if ( next && next.type === 'text' && value.slice(-1) === AMPERSAND && startsWithEntity(AMPERSAND + next.value) ) { if (commonmark) { escaped.splice(escaped.length - 1, 0, BACKSLASH); } else { escaped.push('amp', SEMICOLON); } } /* * Escape double tildes in GFM. */ if ( gfm && next && next.type === 'text' && value.slice(-1) === TILDE && next.value.charAt(0) === TILDE ) { escaped.splice(escaped.length - 1, 0, BACKSLASH); } } return escaped.join(EMPTY); }; } /** * Wrap `url` in angle brackets when needed, or when * forced. * * In links, images, and definitions, the URL part needs * to be enclosed when it: * * - has a length of `0`; * - contains white-space; * - has more or less opening than closing parentheses. * * @example * encloseURI('foo bar') // '' * encloseURI('foo(bar(baz)') // '' * encloseURI('') // '<>' * encloseURI('example.com') // 'example.com' * encloseURI('example.com', true) // '' * * @param {string} uri - URI to enclose. * @param {boolean?} [always] - Force enclosing. * @return {boolean} - Properly enclosed `uri`. */ function encloseURI(uri, always) { if ( always || !uri.length || EXPRESSIONS_WHITE_SPACE.test(uri) || ccount(uri, PARENTHESIS_OPEN) !== ccount(uri, PARENTHESIS_CLOSE) ) { return ANGLE_BRACKET_OPEN + uri + ANGLE_BRACKET_CLOSE; } return uri; } /** * There is currently no way to support nested delimiters * across Markdown.pl, CommonMark, and GitHub (RedCarpet). * The following code supports Markdown.pl and GitHub. * CommonMark is not supported when mixing double- and * single quotes inside a title. * * @see https://github.com/vmg/redcarpet/issues/473 * @see https://github.com/jgm/CommonMark/issues/308 * * @example * encloseTitle('foo') // '"foo"' * encloseTitle('foo \'bar\' baz') // '"foo \'bar\' baz"' * encloseTitle('foo "bar" baz') // '\'foo "bar" baz\'' * encloseTitle('foo "bar" \'baz\'') // '"foo "bar" \'baz\'"' * * @param {string} title - Content. * @return {string} - Properly enclosed title. */ function encloseTitle(title) { var delimiter = QUOTE_DOUBLE; if (title.indexOf(delimiter) !== -1) { delimiter = QUOTE_SINGLE; } return delimiter + title + delimiter; } /** * Pad `value` with `level * INDENT` spaces. Respects * lines. Ignores empty lines. * * @example * pad('foo', 1) // ' foo' * * @param {string} value - Content. * @param {number} level - Indentation level. * @return {string} - Padded `value`. */ function pad(value, level) { var index; var padding; value = value.split(LINE); index = value.length; padding = repeat(SPACE, level * INDENT); while (index--) { if (value[index].length !== 0) { value[index] = padding + value[index]; } } return value.join(LINE); } /** * Construct a new compiler. * * @example * var compiler = new Compiler(new File('> foo.')); * * @constructor * @class {Compiler} * @param {File} file - Virtual file. * @param {Object?} [options] - Passed to * `Compiler#setOptions()`. */ function Compiler(file, options) { var self = this; self.file = file; self.options = extend({}, self.options); self.setOptions(options); } /* * Cache prototype. */ var compilerPrototype = Compiler.prototype; /* * Expose defaults. */ compilerPrototype.options = defaultOptions; /* * Map of applicable enum's. */ var maps = { 'entities': ENTITY_OPTIONS, 'bullet': LIST_BULLETS, 'rule': HORIZONTAL_RULE_BULLETS, 'listItemIndent': LIST_ITEM_INDENTS, 'emphasis': EMPHASIS_MARKERS, 'strong': EMPHASIS_MARKERS, 'fence': FENCE_MARKERS }; /** * Set options. Does not overwrite previously set * options. * * @example * var compiler = new Compiler(); * compiler.setOptions({bullet: '*'}); * * @this {Compiler} * @throws {Error} - When an option is invalid. * @param {Object?} [options] - Stringify settings. * @return {Compiler} - `self`. */ compilerPrototype.setOptions = function (options) { var self = this; var current = self.options; var ruleRepetition; var key; if (options === null || options === undefined) { options = {}; } else if (typeof options === 'object') { options = extend({}, options); } else { raise(options, 'options'); } for (key in defaultOptions) { validate[typeof current[key]]( options, key, current[key], maps[key] ); } ruleRepetition = options.ruleRepetition; if (ruleRepetition && ruleRepetition < MINIMUM_RULE_LENGTH) { raise(ruleRepetition, 'options.ruleRepetition'); } self.encode = encodeFactory(String(options.entities)); self.escape = escapeFactory(options); self.options = options; return self; }; /* * Enter and exit helpers. */ compilerPrototype.enterLink = stateToggler('inLink', false); compilerPrototype.enterTable = stateToggler('inTable', false); /** * Shortcut and collapsed link references need no escaping * and encoding during the processing of child nodes (it * must be implied from identifier). * * This toggler turns encoding and escaping off for shortcut * and collapsed references. * * Implies `enterLink`. * * @param {Compiler} compiler - Compiler instance. * @param {LinkReference} node - LinkReference node. * @return {Function} - Exit state. */ compilerPrototype.enterLinkReference = function (compiler, node) { var encode = compiler.encode; var escape = compiler.escape; var exitLink = compiler.enterLink(); if ( node.referenceType === 'shortcut' || node.referenceType === 'collapsed' ) { compiler.encode = compiler.escape = encodeNoop; return function () { compiler.encode = encode; compiler.escape = escape; exitLink(); }; } else { return exitLink; } }; /** * Visit a node. * * @example * var compiler = new Compiler(); * * compiler.visit({ * type: 'strong', * children: [{ * type: 'text', * value: 'Foo' * }] * }); * // '**Foo**' * * @param {Object} node - Node. * @param {Object?} [parent] - `node`s parent. * @return {string} - Compiled `node`. */ compilerPrototype.visit = function (node, parent) { var self = this; /* * Fail on unknown nodes. */ if (typeof self[node.type] !== 'function') { self.file.fail( 'Missing compiler for node of type `' + node.type + '`: `' + node + '`', node ); } return self[node.type](node, parent); }; /** * Visit all children of `parent`. * * @example * var compiler = new Compiler(); * * compiler.all({ * type: 'strong', * children: [{ * type: 'text', * value: 'Foo' * }, * { * type: 'text', * value: 'Bar' * }] * }); * // ['Foo', 'Bar'] * * @param {Object} parent - Parent node of children. * @return {Array.} - List of compiled children. */ compilerPrototype.all = function (parent) { var self = this; var children = parent.children; var values = []; var index = 0; var length = children.length; var node = children[0]; var next; if (length === 0) { return values; } while (++index < length) { next = children[index]; if ( node.type === next.type && node.type in MERGEABLE_NODES && mergeable(node) && mergeable(next) ) { node = MERGEABLE_NODES[node.type].call(self, node, next); } else { values.push(self.visit(node, parent)); node = next; } } values.push(self.visit(node, parent)); return values; }; /** * Visit ordered list items. * * Starts the list with * `node.start` and increments each following list item * bullet by one: * * 2. foo * 3. bar * * In `incrementListMarker: false` mode, does not increment * each marker and stays on `node.start`: * * 1. foo * 1. bar * * Adds an extra line after an item if it has * `loose: true`. * * @example * var compiler = new Compiler(); * * compiler.visitOrderedItems({ * type: 'list', * ordered: true, * children: [{ * type: 'listItem', * children: [{ * type: 'text', * value: 'bar' * }] * }] * }); * // '1. bar' * * @param {Object} node - `list` node with * `ordered: true`. * @return {string} - Markdown list. */ compilerPrototype.visitOrderedItems = function (node) { var self = this; var increment = self.options.incrementListMarker; var values = []; var start = node.start; var children = node.children; var length = children.length; var index = -1; var bullet; while (++index < length) { bullet = (increment ? start + index : start) + DOT; values[index] = self.listItem(children[index], node, index, bullet); } return values.join(LINE); }; /** * Visit unordered list items. * * Uses `options.bullet` as each item's bullet. * * Adds an extra line after an item if it has * `loose: true`. * * @example * var compiler = new Compiler(); * * compiler.visitUnorderedItems({ * type: 'list', * ordered: false, * children: [{ * type: 'listItem', * children: [{ * type: 'text', * value: 'bar' * }] * }] * }); * // '- bar' * * @param {Object} node - `list` node with * `ordered: false`. * @return {string} - Markdown list. */ compilerPrototype.visitUnorderedItems = function (node) { var self = this; var values = []; var children = node.children; var length = children.length; var index = -1; var bullet = self.options.bullet; while (++index < length) { values[index] = self.listItem(children[index], node, index, bullet); } return values.join(LINE); }; /** * Stringify a block node with block children (e.g., `root` * or `blockquote`). * * Knows about code following a list, or adjacent lists * with similar bullets, and places an extra newline * between them. * * @example * var compiler = new Compiler(); * * compiler.block({ * type: 'root', * children: [{ * type: 'paragraph', * children: [{ * type: 'text', * value: 'bar' * }] * }] * }); * // 'bar' * * @param {Object} node - `root` node. * @return {string} - Markdown block content. */ compilerPrototype.block = function (node) { var self = this; var values = []; var children = node.children; var length = children.length; var index = -1; var child; var prev; while (++index < length) { child = children[index]; if (prev) { /* * Duplicate nodes, such as a list * directly following another list, * often need multiple new lines. * * Additionally, code blocks following a list * might easily be mistaken for a paragraph * in the list itself. */ if (child.type === prev.type && prev.type === 'list') { values.push(prev.ordered === child.ordered ? GAP : BREAK); } else if ( prev.type === 'list' && child.type === 'code' && !child.lang ) { values.push(GAP); } else { values.push(BREAK); } } values.push(self.visit(child, node)); prev = child; } return values.join(EMPTY); }; /** * Stringify a root. * * Adds a final newline to ensure valid POSIX files. * * @example * var compiler = new Compiler(); * * compiler.root({ * type: 'root', * children: [{ * type: 'paragraph', * children: [{ * type: 'text', * value: 'bar' * }] * }] * }); * // 'bar' * * @param {Object} node - `root` node. * @return {string} - Markdown document. */ compilerPrototype.root = function (node) { return this.block(node) + LINE; }; /** * Stringify a heading. * * In `setext: true` mode and when `depth` is smaller than * three, creates a setext header: * * Foo * === * * Otherwise, an ATX header is generated: * * ### Foo * * In `closeAtx: true` mode, the header is closed with * hashes: * * ### Foo ### * * @example * var compiler = new Compiler(); * * compiler.heading({ * type: 'heading', * depth: 2, * children: [{ * type: 'strong', * children: [{ * type: 'text', * value: 'bar' * }] * }] * }); * // '## **bar**' * * @param {Object} node - `heading` node. * @return {string} - Markdown heading. */ compilerPrototype.heading = function (node) { var self = this; var setext = self.options.setext; var closeAtx = self.options.closeAtx; var depth = node.depth; var content = self.all(node).join(EMPTY); var prefix; if (setext && depth < 3) { return content + LINE + repeat(depth === 1 ? EQUALS : DASH, content.length); } prefix = repeat(HASH, node.depth); content = prefix + SPACE + content; if (closeAtx) { content += SPACE + prefix; } return content; }; /** * Stringify text. * * Supports named entities in `settings.encode: true` mode: * * AT&T * * Supports numbered entities in `settings.encode: numbers` * mode: * * AT&T * * @example * var compiler = new Compiler(); * * compiler.text({ * type: 'text', * value: 'foo' * }); * // 'foo' * * @param {Object} node - `text` node. * @param {Object} parent - Parent of `node`. * @return {string} - Raw markdown text. */ compilerPrototype.text = function (node, parent) { return this.encode(this.escape(node.value, node, parent), node); }; /** * Stringify a paragraph. * * @example * var compiler = new Compiler(); * * compiler.paragraph({ * type: 'paragraph', * children: [{ * type: 'strong', * children: [{ * type: 'text', * value: 'bar' * }] * }] * }); * // '**bar**' * * @param {Object} node - `paragraph` node. * @return {string} - Markdown paragraph. */ compilerPrototype.paragraph = function (node) { return this.all(node).join(EMPTY); }; /** * Stringify a block quote. * * @example * var compiler = new Compiler(); * * compiler.paragraph({ * type: 'blockquote', * children: [{ * type: 'paragraph', * children: [{ * type: 'strong', * children: [{ * type: 'text', * value: 'bar' * }] * }] * }] * }); * // '> **bar**' * * @param {Object} node - `blockquote` node. * @return {string} - Markdown block quote. */ compilerPrototype.blockquote = function (node) { var values = this.block(node).split(LINE); var result = []; var length = values.length; var index = -1; var value; while (++index < length) { value = values[index]; result[index] = (value ? SPACE : EMPTY) + value; } return ANGLE_BRACKET_CLOSE + result.join(LINE + ANGLE_BRACKET_CLOSE); }; /** * Stringify a list. See `Compiler#visitOrderedList()` and * `Compiler#visitUnorderedList()` for internal working. * * @example * var compiler = new Compiler(); * * compiler.visitUnorderedItems({ * type: 'list', * ordered: false, * children: [{ * type: 'listItem', * children: [{ * type: 'text', * value: 'bar' * }] * }] * }); * // '- bar' * * @param {Object} node - `list` node. * @return {string} - Markdown list. */ compilerPrototype.list = function (node) { return this[ORDERED_MAP[node.ordered]](node); }; /** * Stringify a list item. * * Prefixes the content with a checked checkbox when * `checked: true`: * * [x] foo * * Prefixes the content with an unchecked checkbox when * `checked: false`: * * [ ] foo * * @example * var compiler = new Compiler(); * * compiler.listItem({ * type: 'listItem', * checked: true, * children: [{ * type: 'text', * value: 'bar' * }] * }, { * type: 'list', * ordered: false, * children: [{ * type: 'listItem', * checked: true, * children: [{ * type: 'text', * value: 'bar' * }] * }] * }, 0, '*'); * '- [x] bar' * * @param {Object} node - `listItem` node. * @param {Object} parent - `list` node. * @param {number} position - Index of `node` in `parent`. * @param {string} bullet - Bullet to use. This, and the * `listItemIndent` setting define the used indent. * @return {string} - Markdown list item. */ compilerPrototype.listItem = function (node, parent, position, bullet) { var self = this; var style = self.options.listItemIndent; var children = node.children; var values = []; var index = -1; var length = children.length; var loose = node.loose; var value; var indent; var spacing; while (++index < length) { values[index] = self.visit(children[index], node); } value = CHECKBOX_MAP[node.checked] + values.join(loose ? BREAK : LINE); if ( style === LIST_ITEM_ONE || (style === LIST_ITEM_MIXED && value.indexOf(LINE) === -1) ) { indent = bullet.length + 1; spacing = SPACE; } else { indent = Math.ceil((bullet.length + 1) / INDENT) * INDENT; spacing = repeat(SPACE, indent - bullet.length); } value = bullet + spacing + pad(value, indent / INDENT).slice(indent); if (loose && parent.children.length - 1 !== position) { value += LINE; } return value; }; /** * Stringify inline code. * * Knows about internal ticks (`\``), and ensures one more * tick is used to enclose the inline code: * * ```foo ``bar`` baz``` * * Even knows about inital and final ticks: * * `` `foo `` * `` foo` `` * * @example * var compiler = new Compiler(); * * compiler.inlineCode({ * type: 'inlineCode', * value: 'foo(); `bar`; baz()' * }); * // '``foo(); `bar`; baz()``' * * @param {Object} node - `inlineCode` node. * @return {string} - Markdown inline code. */ compilerPrototype.inlineCode = function (node) { var value = node.value; var ticks = repeat(TICK, longestStreak(value, TICK) + 1); var start = ticks; var end = ticks; if (value.charAt(0) === TICK) { start += SPACE; } if (value.charAt(value.length - 1) === TICK) { end = SPACE + end; } return start + node.value + end; }; /** * Stringify YAML front matter. * * @example * var compiler = new Compiler(); * * compiler.yaml({ * type: 'yaml', * value: 'foo: bar' * }); * // '---\nfoo: bar\n---' * * @param {Object} node - `yaml` node. * @return {string} - Markdown YAML document. */ compilerPrototype.yaml = function (node) { var delimiter = repeat(DASH, YAML_FENCE_LENGTH); var value = node.value ? LINE + node.value : EMPTY; return delimiter + value + LINE + delimiter; }; /** * Stringify a code block. * * Creates indented code when: * * - No language tag exists; * - Not in `fences: true` mode; * - A non-empty value exists. * * Otherwise, GFM fenced code is created: * * ```js * foo(); * ``` * * When in ``fence: `~` `` mode, uses tildes as fences: * * ~~~js * foo(); * ~~~ * * Knows about internal fences (Note: GitHub/Kramdown does * not support this): * * ````javascript * ```markdown * foo * ``` * ```` * * Supports named entities in the language flag with * `settings.encode` mode. * * @example * var compiler = new Compiler(); * * compiler.code({ * type: 'code', * lang: 'js', * value: 'fooo();' * }); * // '```js\nfooo();\n```' * * @param {Object} node - `code` node. * @param {Object} parent - Parent of `node`. * @return {string} - Markdown code block. */ compilerPrototype.code = function (node, parent) { var self = this; var value = node.value; var options = self.options; var marker = options.fence; var language = self.encode(node.lang || EMPTY, node); var fence; /* * Without (needed) fences. */ if (!language && !options.fences && value) { /* * Throw when pedantic, in a list item which * isn’t compiled using a tab. */ if ( parent && parent.type === 'listItem' && options.listItemIndent !== LIST_ITEM_TAB && options.pedantic ) { self.file.fail(ERROR_LIST_ITEM_INDENT, node.position); } return pad(value, 1); } fence = longestStreak(value, marker) + 1; /* * Fix GFM / RedCarpet bug, where fence-like characters * inside fenced code can exit a code-block. * Yes, even when the outer fence uses different * characters, or is longer. * Thus, we can only pad the code to make it work. */ if (FENCE.test(value)) { value = pad(value, 1); } fence = repeat(marker, Math.max(fence, MINIMUM_CODE_FENCE_LENGTH)); return fence + language + LINE + value + LINE + fence; }; /** * Stringify HTML. * * @example * var compiler = new Compiler(); * * compiler.html({ * type: 'html', * value: '
    bar
    ' * }); * // '
    bar
    ' * * @param {Object} node - `html` node. * @return {string} - Markdown HTML. */ compilerPrototype.html = function (node) { return node.value; }; /** * Stringify a horizontal rule. * * The character used is configurable by `rule`: (`'_'`) * * ___ * * The number of repititions is defined through * `ruleRepetition`: (`6`) * * ****** * * Whether spaces delimit each character, is configured * through `ruleSpaces`: (`true`) * * * * * * * @example * var compiler = new Compiler(); * * compiler.horizontalRule({ * type: 'horizontalRule' * }); * // '***' * * @return {string} - Markdown rule. */ compilerPrototype.horizontalRule = function () { var options = this.options; var rule = repeat(options.rule, options.ruleRepetition); if (options.ruleSpaces) { rule = rule.split(EMPTY).join(SPACE); } return rule; }; /** * Stringify a strong. * * The marker used is configurable by `strong`, which * defaults to an asterisk (`'*'`) but also accepts an * underscore (`'_'`): * * _foo_ * * @example * var compiler = new Compiler(); * * compiler.strong({ * type: 'strong', * children: [{ * type: 'text', * value: 'Foo' * }] * }); * // '**Foo**' * * @param {Object} node - `strong` node. * @return {string} - Markdown strong-emphasised text. */ compilerPrototype.strong = function (node) { var marker = this.options.strong; marker = marker + marker; return marker + this.all(node).join(EMPTY) + marker; }; /** * Stringify an emphasis. * * The marker used is configurable by `emphasis`, which * defaults to an underscore (`'_'`) but also accepts an * asterisk (`'*'`): * * *foo* * * @example * var compiler = new Compiler(); * * compiler.emphasis({ * type: 'emphasis', * children: [{ * type: 'text', * value: 'Foo' * }] * }); * // '_Foo_' * * @param {Object} node - `emphasis` node. * @return {string} - Markdown emphasised text. */ compilerPrototype.emphasis = function (node) { var marker = this.options.emphasis; return marker + this.all(node).join(EMPTY) + marker; }; /** * Stringify a hard break. * * In Commonmark mode, trailing backslash form is used in order * to preserve trailing whitespace that the line may end with, * and also for better visibility. * * @example * var compiler = new Compiler(); * * compiler.break({ * type: 'break' * }); * // ' \n' * * @return {string} - Hard markdown break. */ compilerPrototype.break = function () { return this.options.commonmark ? BACKSLASH + LINE : SPACE + SPACE + LINE; }; /** * Stringify a delete. * * @example * var compiler = new Compiler(); * * compiler.delete({ * type: 'delete', * children: [{ * type: 'text', * value: 'Foo' * }] * }); * // '~~Foo~~' * * @param {Object} node - `delete` node. * @return {string} - Markdown strike-through. */ compilerPrototype.delete = function (node) { return DOUBLE_TILDE + this.all(node).join(EMPTY) + DOUBLE_TILDE; }; /** * Stringify a link. * * When no title exists, the compiled `children` equal * `href`, and `href` starts with a protocol, an auto * link is created: * * * * Otherwise, is smart about enclosing `href` (see * `encloseURI()`) and `title` (see `encloseTitle()`). * * [foo]( 'An "example" e-mail') * * Supports named entities in the `href` and `title` when * in `settings.encode` mode. * * @example * var compiler = new Compiler(); * * compiler.link({ * type: 'link', * href: 'http://example.com', * title: 'Example Domain', * children: [{ * type: 'text', * value: 'Foo' * }] * }); * // '[Foo](http://example.com "Example Domain")' * * @param {Object} node - `link` node. * @return {string} - Markdown link. */ compilerPrototype.link = function (node) { var self = this; var url = self.encode(node.href, node); var exit = self.enterLink(); var escapedURL = self.encode(self.escape(node.href, node)); var value = self.all(node).join(EMPTY); exit(); if ( node.title === null && PROTOCOL.test(url) && (escapedURL === value || escapedURL === MAILTO + value) ) { /* * Backslash escapes do not work in autolinks, * so we do not escape. */ return encloseURI(self.encode(node.href), true); } url = encloseURI(url); if (node.title) { url += SPACE + encloseTitle(self.encode(self.escape( node.title, node ), node)); } value = SQUARE_BRACKET_OPEN + value + SQUARE_BRACKET_CLOSE; value += PARENTHESIS_OPEN + url + PARENTHESIS_CLOSE; return value; }; /** * Stringify a link label. * * Because link references are easily, mistakingly, * created (for example, `[foo]`), reference nodes have * an extra property depicting how it looked in the * original document, so stringification can cause minimal * changes. * * @example * label({ * type: 'referenceImage', * referenceType: 'full', * identifier: 'foo' * }); * // '[foo]' * * label({ * type: 'referenceImage', * referenceType: 'collapsed', * identifier: 'foo' * }); * // '[]' * * label({ * type: 'referenceImage', * referenceType: 'shortcut', * identifier: 'foo' * }); * // '' * * @param {Object} node - `linkReference` or * `imageReference` node. * @return {string} - Markdown label reference. */ function label(node) { var value = EMPTY; var type = node.referenceType; if (type === 'full') { value = node.identifier; } if (type !== 'shortcut') { value = SQUARE_BRACKET_OPEN + value + SQUARE_BRACKET_CLOSE; } return value; } /** * For shortcut and collapsed reference links, the contents * is also an identifier, so we need to restore the original * encoding and escaping that were present in the source * string. * * This function takes the unescaped & unencoded value from * shortcut's child nodes and the identifier and encodes * the former according to the latter. * * @example * copyIdentifierEncoding('a*b', 'a\\*b*c') * // 'a\\*b*c' * * @param {string} value - Unescaped and unencoded stringified * link value. * @param {string} identifier - Link identifier. * @return {string} - Encoded link value. */ function copyIdentifierEncoding(value, identifier) { var index = 0; var position = 0; var length = value.length; var count = identifier.length; var result = []; var start; while (index < length) { /* * Take next non-punctuation characters from `value`. */ start = index; while ( index < length && !PUNCTUATION.test(value.charAt(index)) ) { index += 1; } result.push(value.slice(start, index)); /* * Advance `position` to the next punctuation character. */ while ( position < count && !PUNCTUATION.test(identifier.charAt(position)) ) { position += 1; } /* * Take next punctuation characters from `identifier`. */ start = position; while ( position < count && PUNCTUATION.test(identifier.charAt(position)) ) { if (identifier.charAt(position) === AMPERSAND) { position += entityPrefixLength(identifier.slice(position)); } position += 1; } result.push(identifier.slice(start, position)); /* * Advance `index` to the next non-punctuation character. */ while (index < length && PUNCTUATION.test(value.charAt(index))) { index += 1; } } return result.join(EMPTY); } /** * Stringify a link reference. * * See `label()` on how reference labels are created. * * @example * var compiler = new Compiler(); * * compiler.linkReference({ * type: 'linkReference', * referenceType: 'collapsed', * identifier: 'foo', * children: [{ * type: 'text', * value: 'Foo' * }] * }); * // '[Foo][]' * * @param {Object} node - `linkReference` node. * @return {string} - Markdown link reference. */ compilerPrototype.linkReference = function (node) { var self = this; var exitLinkReference = self.enterLinkReference(self, node); var value = self.all(node).join(EMPTY); exitLinkReference(); if ( node.referenceType === 'shortcut' || node.referenceType === 'collapsed' ) { value = copyIdentifierEncoding(value, node.identifier); } return SQUARE_BRACKET_OPEN + value + SQUARE_BRACKET_CLOSE + label(node); }; /** * Stringify an image reference. * * See `label()` on how reference labels are created. * * Supports named entities in the `alt` when * in `settings.encode` mode. * * @example * var compiler = new Compiler(); * * compiler.imageReference({ * type: 'imageReference', * referenceType: 'full', * identifier: 'foo', * alt: 'Foo' * }); * // '![Foo][foo]' * * @param {Object} node - `imageReference` node. * @return {string} - Markdown image reference. */ compilerPrototype.imageReference = function (node) { var alt = this.encode(node.alt, node) || EMPTY; return EXCLAMATION_MARK + SQUARE_BRACKET_OPEN + alt + SQUARE_BRACKET_CLOSE + label(node); }; /** * Stringify a footnote reference. * * @example * var compiler = new Compiler(); * * compiler.footnoteReference({ * type: 'footnoteReference', * identifier: 'foo' * }); * // '[^foo]' * * @param {Object} node - `footnoteReference` node. * @return {string} - Markdown footnote reference. */ compilerPrototype.footnoteReference = function (node) { return SQUARE_BRACKET_OPEN + CARET + node.identifier + SQUARE_BRACKET_CLOSE; }; /** * Stringify an link- or image definition. * * Is smart about enclosing `href` (see `encloseURI()`) and * `title` (see `encloseTitle()`). * * [foo]: 'An "example" e-mail' * * @example * var compiler = new Compiler(); * * compiler.definition({ * type: 'definition', * link: 'http://example.com', * title: 'Example Domain', * identifier: 'foo' * }); * // '[foo]: http://example.com "Example Domain"' * * @param {Object} node - `definition` node. * @return {string} - Markdown link- or image definition. */ compilerPrototype.definition = function (node) { var value = SQUARE_BRACKET_OPEN + node.identifier + SQUARE_BRACKET_CLOSE; var url = encloseURI(node.link); if (node.title) { url += SPACE + encloseTitle(node.title); } return value + COLON + SPACE + url; }; /** * Stringify an image. * * Is smart about enclosing `href` (see `encloseURI()`) and * `title` (see `encloseTitle()`). * * ![foo]( 'My "favourite" icon') * * Supports named entities in `src`, `alt`, and `title` * when in `settings.encode` mode. * * @example * var compiler = new Compiler(); * * compiler.image({ * type: 'image', * href: 'http://example.png/favicon.png', * title: 'Example Icon', * alt: 'Foo' * }); * // '![Foo](http://example.png/favicon.png "Example Icon")' * * @param {Object} node - `image` node. * @return {string} - Markdown image. */ compilerPrototype.image = function (node) { var url = encloseURI(this.encode(node.src, node)); var value; if (node.title) { url += SPACE + encloseTitle(this.encode(node.title, node)); } value = EXCLAMATION_MARK + SQUARE_BRACKET_OPEN + this.encode(node.alt || EMPTY, node) + SQUARE_BRACKET_CLOSE; value += PARENTHESIS_OPEN + url + PARENTHESIS_CLOSE; return value; }; /** * Stringify a footnote. * * @example * var compiler = new Compiler(); * * compiler.footnote({ * type: 'footnote', * children: [{ * type: 'text', * value: 'Foo' * }] * }); * // '[^Foo]' * * @param {Object} node - `footnote` node. * @return {string} - Markdown footnote. */ compilerPrototype.footnote = function (node) { return SQUARE_BRACKET_OPEN + CARET + this.all(node).join(EMPTY) + SQUARE_BRACKET_CLOSE; }; /** * Stringify a footnote definition. * * @example * var compiler = new Compiler(); * * compiler.footnoteDefinition({ * type: 'footnoteDefinition', * identifier: 'foo', * children: [{ * type: 'paragraph', * children: [{ * type: 'text', * value: 'bar' * }] * }] * }); * // '[^foo]: bar' * * @param {Object} node - `footnoteDefinition` node. * @return {string} - Markdown footnote definition. */ compilerPrototype.footnoteDefinition = function (node) { var id = node.identifier.toLowerCase(); return SQUARE_BRACKET_OPEN + CARET + id + SQUARE_BRACKET_CLOSE + COLON + SPACE + this.all(node).join(BREAK + repeat(SPACE, INDENT)); }; /** * Stringify table. * * Creates a fenced table by default, but not in * `looseTable: true` mode: * * Foo | Bar * :-: | --- * Baz | Qux * * NOTE: Be careful with `looseTable: true` mode, as a * loose table inside an indented code block on GitHub * renders as an actual table! * * Creates a spaces table by default, but not in * `spacedTable: false`: * * |Foo|Bar| * |:-:|---| * |Baz|Qux| * * @example * var compiler = new Compiler(); * * compiler.table({ * type: 'table', * align: ['center', null], * children: [ * { * type: 'tableHeader', * children: [ * { * type: 'tableCell' * children: [{ * type: 'text' * value: 'Foo' * }] * }, * { * type: 'tableCell' * children: [{ * type: 'text' * value: 'Bar' * }] * } * ] * }, * { * type: 'tableRow', * children: [ * { * type: 'tableCell' * children: [{ * type: 'text' * value: 'Baz' * }] * }, * { * type: 'tableCell' * children: [{ * type: 'text' * value: 'Qux' * }] * } * ] * } * ] * }); * // '| Foo | Bar |\n| :-: | --- |\n| Baz | Qux |' * * @param {Object} node - `table` node. * @return {string} - Markdown table. */ compilerPrototype.table = function (node) { var self = this; var loose = self.options.looseTable; var spaced = self.options.spacedTable; var rows = node.children; var index = rows.length; var exit = self.enterTable(); var result = []; var start; while (index--) { result[index] = self.all(rows[index]); } exit(); start = loose ? EMPTY : spaced ? PIPE + SPACE : PIPE; return table(result, { 'align': node.align, 'start': start, 'end': start.split(EMPTY).reverse().join(EMPTY), 'delimiter': spaced ? SPACE + PIPE + SPACE : PIPE }); }; /** * Stringify a table cell. * * @example * var compiler = new Compiler(); * * compiler.tableCell({ * type: 'tableCell', * children: [{ * type: 'text' * value: 'Qux' * }] * }); * // 'Qux' * * @param {Object} node - `tableCell` node. * @return {string} - Markdown table cell. */ compilerPrototype.tableCell = function (node) { return this.all(node).join(EMPTY); }; /** * Stringify the bound file. * * @example * var file = new VFile('__Foo__'); * * file.namespace('mdast').tree = { * type: 'strong', * children: [{ * type: 'text', * value: 'Foo' * }] * }); * * new Compiler(file).compile(); * // '**Foo**' * * @this {Compiler} * @return {string} - Markdown document. */ compilerPrototype.compile = function () { return this.visit(this.file.namespace('mdast').tree); }; /* * Expose `stringify` on `module.exports`. */ module.exports = Compiler; },{"./defaults.js":417,"./utilities.js":421,"ccount":69,"extend.js":147,"longest-streak":224,"markdown-table":240,"parse-entities":289,"repeat-string":422,"stringify-entities":617}],421:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015-2016 Titus Wormer * @license MIT * @module remark:utilities * @version 3.2.2 * @fileoverview Collection of tiny helpers useful for * both parsing and compiling markdown. */ 'use strict'; /* eslint-env commonjs */ /* * Dependencies. */ var collapseWhiteSpace = require('collapse-white-space'); /* * Expressions. */ var EXPRESSION_LINE_BREAKS = /\r\n|\r/g; var EXPRESSION_SYMBOL_FOR_NEW_LINE = /\u2424/g; var EXPRESSION_BOM = /^\ufeff/; /** * Throw an exception with in its `message` `value` * and `name`. * * @param {*} value - Invalid value. * @param {string} name - Setting name. */ function raise(value, name) { throw new Error( 'Invalid value `' + value + '` ' + 'for setting `' + name + '`' ); } /** * Validate a value to be boolean. Defaults to `def`. * Raises an exception with `context[name]` when not * a boolean. * * @example * validateBoolean({foo: null}, 'foo', true) // true * validateBoolean({foo: false}, 'foo', true) // false * validateBoolean({foo: 'bar'}, 'foo', true) // Throws * * @throws {Error} - When a setting is neither omitted nor * a boolean. * @param {Object} context - Settings. * @param {string} name - Setting name. * @param {boolean} def - Default value. */ function validateBoolean(context, name, def) { var value = context[name]; if (value === null || value === undefined) { value = def; } if (typeof value !== 'boolean') { raise(value, 'options.' + name); } context[name] = value; } /** * Validate a value to be boolean. Defaults to `def`. * Raises an exception with `context[name]` when not * a boolean. * * @example * validateNumber({foo: null}, 'foo', 1) // 1 * validateNumber({foo: 2}, 'foo', 1) // 2 * validateNumber({foo: 'bar'}, 'foo', 1) // Throws * * @throws {Error} - When a setting is neither omitted nor * a number. * @param {Object} context - Settings. * @param {string} name - Setting name. * @param {number} def - Default value. */ function validateNumber(context, name, def) { var value = context[name]; if (value === null || value === undefined) { value = def; } if (typeof value !== 'number' || value !== value) { raise(value, 'options.' + name); } context[name] = value; } /** * Validate a value to be in `map`. Defaults to `def`. * Raises an exception with `context[name]` when not * not in `map`. * * @example * var map = {bar: true, baz: true}; * validateString({foo: null}, 'foo', 'bar', map) // 'bar' * validateString({foo: 'baz'}, 'foo', 'bar', map) // 'baz' * validateString({foo: true}, 'foo', 'bar', map) // Throws * * @throws {Error} - When a setting is neither omitted nor * in `map`. * @param {Object} context - Settings. * @param {string} name - Setting name. * @param {string} def - Default value. * @param {Object} map - Enum. */ function validateString(context, name, def, map) { var value = context[name]; if (value === null || value === undefined) { value = def; } if (!(value in map)) { raise(value, 'options.' + name); } context[name] = value; } /** * Clean a string in preperation of parsing. * * @example * clean('\ufefffoo'); // 'foo' * clean('foo\r\nbar'); // 'foo\nbar' * clean('foo\u2424bar'); // 'foo\nbar' * * @param {string} value - Content to clean. * @return {string} - Cleaned content. */ function clean(value) { return String(value) .replace(EXPRESSION_BOM, '') .replace(EXPRESSION_LINE_BREAKS, '\n') .replace(EXPRESSION_SYMBOL_FOR_NEW_LINE, '\n'); } /** * Normalize an identifier. Collapses multiple white space * characters into a single space, and removes casing. * * @example * normalizeIdentifier('FOO\t bar'); // 'foo bar' * * @param {string} value - Content to normalize. * @return {string} - Normalized content. */ function normalizeIdentifier(value) { return collapseWhiteSpace(value).toLowerCase(); } /** * Construct a state `toggler`: a function which inverses * `property` in context based on its current value. * The by `toggler` returned function restores that value. * * @example * var context = {}; * var key = 'foo'; * var val = true; * context[key] = val; * context.enter = stateToggler(key, val); * context[key]; // true * var exit = context.enter(); * context[key]; // false * var nested = context.enter(); * context[key]; // false * nested(); * context[key]; // false * exit(); * context[key]; // true * * @param {string} key - Property to toggle. * @param {boolean} state - It's default state. * @return {function(): function()} - Enter. */ function stateToggler(key, state) { /** * Construct a toggler for the bound `key`. * * @return {Function} - Exit state. */ function enter() { var self = this; var current = self[key]; self[key] = !state; /** * State canceler, cancels the state, if allowed. */ function exit() { self[key] = current; } return exit; } return enter; } /* * Define nodes of a type which can be merged. */ var MERGEABLE_NODES = {}; /** * Check whether a node is mergeable with adjacent nodes. * * @param {Object} node - Node to check. * @return {boolean} - Whether `node` is mergable. */ function mergeable(node) { var start; var end; if (node.type !== 'text' || !node.position) { return true; } start = node.position.start; end = node.position.end; /* * Only merge nodes which occupy the same size as their * `value`. */ return start.line !== end.line || end.column - start.column === node.value.length; } /** * Merge two text nodes: `node` into `prev`. * * @param {Object} prev - Preceding sibling. * @param {Object} node - Following sibling. * @return {Object} - `prev`. */ MERGEABLE_NODES.text = function (prev, node) { prev.value += node.value; return prev; }; /** * Merge two blockquotes: `node` into `prev`, unless in * CommonMark mode. * * @param {Object} prev - Preceding sibling. * @param {Object} node - Following sibling. * @return {Object} - `prev`, or `node` in CommonMark mode. */ MERGEABLE_NODES.blockquote = function (prev, node) { if (this.options.commonmark) { return node; } prev.children = prev.children.concat(node.children); return prev; }; /* * Expose `validate`. */ exports.validate = { 'boolean': validateBoolean, 'string': validateString, 'number': validateNumber }; /* * Expose. */ exports.normalizeIdentifier = normalizeIdentifier; exports.clean = clean; exports.raise = raise; exports.stateToggler = stateToggler; exports.mergeable = mergeable; exports.MERGEABLE_NODES = MERGEABLE_NODES; },{"collapse-white-space":84}],422:[function(require,module,exports){ /*! * repeat-string * * Copyright (c) 2014-2015, Jon Schlinkert. * Licensed under the MIT License. */ 'use strict'; /** * Results cache */ var res = ''; var cache; /** * Expose `repeat` */ module.exports = repeat; /** * Repeat the given `string` the specified `number` * of times. * * **Example:** * * ```js * var repeat = require('repeat-string'); * repeat('A', 5); * //=> AAAAA * ``` * * @param {String} `string` The string to repeat * @param {Number} `number` The number of times to repeat the string * @return {String} Repeated string * @api public */ function repeat(str, num) { if (typeof str !== 'string') { throw new TypeError('repeat-string expects a string.'); } // cover common, quick use cases if (num === 1) return str; if (num === 2) return str + str; var max = str.length * num; if (cache !== str || typeof cache === 'undefined') { cache = str; res = ''; } while (max > res.length && num > 0) { if (num & 1) { res += str; } num >>= 1; if (!num) break; str += str; } return res.substr(0, max); } },{}],423:[function(require,module,exports){ (function (process){ module.exports = rimraf rimraf.sync = rimrafSync var assert = require("assert") var path = require("path") var fs = require("fs") var glob = require("glob") var globOpts = { nosort: true, nocomment: true, nonegate: true, silent: true } // for EMFILE handling var timeout = 0 var isWindows = (process.platform === "win32") function defaults (options) { var methods = [ 'unlink', 'chmod', 'stat', 'lstat', 'rmdir', 'readdir' ] methods.forEach(function(m) { options[m] = options[m] || fs[m] m = m + 'Sync' options[m] = options[m] || fs[m] }) options.maxBusyTries = options.maxBusyTries || 3 options.emfileWait = options.emfileWait || 1000 options.disableGlob = options.disableGlob || false } function rimraf (p, options, cb) { if (typeof options === 'function') { cb = options options = {} } assert(p, 'rimraf: missing path') assert.equal(typeof p, 'string', 'rimraf: path should be a string') assert(options, 'rimraf: missing options') assert.equal(typeof options, 'object', 'rimraf: options should be object') assert.equal(typeof cb, 'function', 'rimraf: callback function required') defaults(options) var busyTries = 0 var errState = null var n = 0 if (options.disableGlob || !glob.hasMagic(p)) return afterGlob(null, [p]) fs.lstat(p, function (er, stat) { if (!er) return afterGlob(null, [p]) glob(p, globOpts, afterGlob) }) function next (er) { errState = errState || er if (--n === 0) cb(errState) } function afterGlob (er, results) { if (er) return cb(er) n = results.length if (n === 0) return cb() results.forEach(function (p) { rimraf_(p, options, function CB (er) { if (er) { if (isWindows && (er.code === "EBUSY" || er.code === "ENOTEMPTY" || er.code === "EPERM") && busyTries < options.maxBusyTries) { busyTries ++ var time = busyTries * 100 // try again, with the same exact callback as this one. return setTimeout(function () { rimraf_(p, options, CB) }, time) } // this one won't happen if graceful-fs is used. if (er.code === "EMFILE" && timeout < options.emfileWait) { return setTimeout(function () { rimraf_(p, options, CB) }, timeout ++) } // already gone if (er.code === "ENOENT") er = null } timeout = 0 next(er) }) }) } } // Two possible strategies. // 1. Assume it's a file. unlink it, then do the dir stuff on EPERM or EISDIR // 2. Assume it's a directory. readdir, then do the file stuff on ENOTDIR // // Both result in an extra syscall when you guess wrong. However, there // are likely far more normal files in the world than directories. This // is based on the assumption that a the average number of files per // directory is >= 1. // // If anyone ever complains about this, then I guess the strategy could // be made configurable somehow. But until then, YAGNI. function rimraf_ (p, options, cb) { assert(p) assert(options) assert(typeof cb === 'function') // sunos lets the root user unlink directories, which is... weird. // so we have to lstat here and make sure it's not a dir. options.lstat(p, function (er, st) { if (er && er.code === "ENOENT") return cb(null) if (st && st.isDirectory()) return rmdir(p, options, er, cb) options.unlink(p, function (er) { if (er) { if (er.code === "ENOENT") return cb(null) if (er.code === "EPERM") return (isWindows) ? fixWinEPERM(p, options, er, cb) : rmdir(p, options, er, cb) if (er.code === "EISDIR") return rmdir(p, options, er, cb) } return cb(er) }) }) } function fixWinEPERM (p, options, er, cb) { assert(p) assert(options) assert(typeof cb === 'function') if (er) assert(er instanceof Error) options.chmod(p, 666, function (er2) { if (er2) cb(er2.code === "ENOENT" ? null : er) else options.stat(p, function(er3, stats) { if (er3) cb(er3.code === "ENOENT" ? null : er) else if (stats.isDirectory()) rmdir(p, options, er, cb) else options.unlink(p, cb) }) }) } function fixWinEPERMSync (p, options, er) { assert(p) assert(options) if (er) assert(er instanceof Error) try { options.chmodSync(p, 666) } catch (er2) { if (er2.code === "ENOENT") return else throw er } try { var stats = options.statSync(p) } catch (er3) { if (er3.code === "ENOENT") return else throw er } if (stats.isDirectory()) rmdirSync(p, options, er) else options.unlinkSync(p) } function rmdir (p, options, originalEr, cb) { assert(p) assert(options) if (originalEr) assert(originalEr instanceof Error) assert(typeof cb === 'function') // try to rmdir first, and only readdir on ENOTEMPTY or EEXIST (SunOS) // if we guessed wrong, and it's not a directory, then // raise the original error. options.rmdir(p, function (er) { if (er && (er.code === "ENOTEMPTY" || er.code === "EEXIST" || er.code === "EPERM")) rmkids(p, options, cb) else if (er && er.code === "ENOTDIR") cb(originalEr) else cb(er) }) } function rmkids(p, options, cb) { assert(p) assert(options) assert(typeof cb === 'function') options.readdir(p, function (er, files) { if (er) return cb(er) var n = files.length if (n === 0) return options.rmdir(p, cb) var errState files.forEach(function (f) { rimraf(path.join(p, f), options, function (er) { if (errState) return if (er) return cb(errState = er) if (--n === 0) options.rmdir(p, cb) }) }) }) } // this looks simpler, and is strictly *faster*, but will // tie up the JavaScript thread and fail on excessively // deep directory trees. function rimrafSync (p, options) { options = options || {} defaults(options) assert(p, 'rimraf: missing path') assert.equal(typeof p, 'string', 'rimraf: path should be a string') assert(options, 'rimraf: missing options') assert.equal(typeof options, 'object', 'rimraf: options should be object') var results if (options.disableGlob || !glob.hasMagic(p)) { results = [p] } else { try { fs.lstatSync(p) results = [p] } catch (er) { results = glob.sync(p, globOpts) } } if (!results.length) return for (var i = 0; i < results.length; i++) { var p = results[i] try { var st = options.lstatSync(p) } catch (er) { if (er.code === "ENOENT") return } try { // sunos lets the root user unlink directories, which is... weird. if (st && st.isDirectory()) rmdirSync(p, options, null) else options.unlinkSync(p) } catch (er) { if (er.code === "ENOENT") return if (er.code === "EPERM") return isWindows ? fixWinEPERMSync(p, options, er) : rmdirSync(p, options, er) if (er.code !== "EISDIR") throw er rmdirSync(p, options, er) } } } function rmdirSync (p, options, originalEr) { assert(p) assert(options) if (originalEr) assert(originalEr instanceof Error) try { options.rmdirSync(p) } catch (er) { if (er.code === "ENOENT") return if (er.code === "ENOTDIR") throw originalEr if (er.code === "ENOTEMPTY" || er.code === "EEXIST" || er.code === "EPERM") rmkidsSync(p, options) } } function rmkidsSync (p, options) { assert(p) assert(options) options.readdirSync(p).forEach(function (f) { rimrafSync(path.join(p, f), options) }) options.rmdirSync(p, options) } }).call(this,require('_process')) },{"_process":295,"assert":15,"fs":58,"glob":151,"path":290}],424:[function(require,module,exports){ (function (Buffer){ /* CryptoJS v3.1.2 code.google.com/p/crypto-js (c) 2009-2013 by Jeff Mott. All rights reserved. code.google.com/p/crypto-js/wiki/License */ /** @preserve (c) 2012 by Cédric Mesnil. All rights reserved. Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: - Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. - Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ // constants table var zl = [ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8, 3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12, 1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2, 4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13 ] var zr = [ 5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12, 6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2, 15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13, 8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14, 12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11 ] var sl = [ 11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8, 7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12, 11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5, 11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12, 9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6 ] var sr = [ 8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6, 9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11, 9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5, 15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8, 8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11 ] var hl = [0x00000000, 0x5A827999, 0x6ED9EBA1, 0x8F1BBCDC, 0xA953FD4E] var hr = [0x50A28BE6, 0x5C4DD124, 0x6D703EF3, 0x7A6D76E9, 0x00000000] function bytesToWords (bytes) { var words = [] for (var i = 0, b = 0; i < bytes.length; i++, b += 8) { words[b >>> 5] |= bytes[i] << (24 - b % 32) } return words } function wordsToBytes (words) { var bytes = [] for (var b = 0; b < words.length * 32; b += 8) { bytes.push((words[b >>> 5] >>> (24 - b % 32)) & 0xFF) } return bytes } function processBlock (H, M, offset) { // swap endian for (var i = 0; i < 16; i++) { var offset_i = offset + i var M_offset_i = M[offset_i] // Swap M[offset_i] = ( (((M_offset_i << 8) | (M_offset_i >>> 24)) & 0x00ff00ff) | (((M_offset_i << 24) | (M_offset_i >>> 8)) & 0xff00ff00) ) } // Working variables var al, bl, cl, dl, el var ar, br, cr, dr, er ar = al = H[0] br = bl = H[1] cr = cl = H[2] dr = dl = H[3] er = el = H[4] // computation var t for (i = 0; i < 80; i += 1) { t = (al + M[offset + zl[i]]) | 0 if (i < 16) { t += f1(bl, cl, dl) + hl[0] } else if (i < 32) { t += f2(bl, cl, dl) + hl[1] } else if (i < 48) { t += f3(bl, cl, dl) + hl[2] } else if (i < 64) { t += f4(bl, cl, dl) + hl[3] } else {// if (i<80) { t += f5(bl, cl, dl) + hl[4] } t = t | 0 t = rotl(t, sl[i]) t = (t + el) | 0 al = el el = dl dl = rotl(cl, 10) cl = bl bl = t t = (ar + M[offset + zr[i]]) | 0 if (i < 16) { t += f5(br, cr, dr) + hr[0] } else if (i < 32) { t += f4(br, cr, dr) + hr[1] } else if (i < 48) { t += f3(br, cr, dr) + hr[2] } else if (i < 64) { t += f2(br, cr, dr) + hr[3] } else {// if (i<80) { t += f1(br, cr, dr) + hr[4] } t = t | 0 t = rotl(t, sr[i]) t = (t + er) | 0 ar = er er = dr dr = rotl(cr, 10) cr = br br = t } // intermediate hash value t = (H[1] + cl + dr) | 0 H[1] = (H[2] + dl + er) | 0 H[2] = (H[3] + el + ar) | 0 H[3] = (H[4] + al + br) | 0 H[4] = (H[0] + bl + cr) | 0 H[0] = t } function f1 (x, y, z) { return ((x) ^ (y) ^ (z)) } function f2 (x, y, z) { return (((x) & (y)) | ((~x) & (z))) } function f3 (x, y, z) { return (((x) | (~(y))) ^ (z)) } function f4 (x, y, z) { return (((x) & (z)) | ((y) & (~(z)))) } function f5 (x, y, z) { return ((x) ^ ((y) | (~(z)))) } function rotl (x, n) { return (x << n) | (x >>> (32 - n)) } function ripemd160 (message) { var H = [0x67452301, 0xEFCDAB89, 0x98BADCFE, 0x10325476, 0xC3D2E1F0] if (typeof message === 'string') { message = new Buffer(message, 'utf8') } var m = bytesToWords(message) var nBitsLeft = message.length * 8 var nBitsTotal = message.length * 8 // Add padding m[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32) m[(((nBitsLeft + 64) >>> 9) << 4) + 14] = ( (((nBitsTotal << 8) | (nBitsTotal >>> 24)) & 0x00ff00ff) | (((nBitsTotal << 24) | (nBitsTotal >>> 8)) & 0xff00ff00) ) for (var i = 0; i < m.length; i += 16) { processBlock(H, m, i) } // swap endian for (i = 0; i < 5; i++) { // shortcut var H_i = H[i] // Swap H[i] = (((H_i << 8) | (H_i >>> 24)) & 0x00ff00ff) | (((H_i << 24) | (H_i >>> 8)) & 0xff00ff00) } var digestbytes = wordsToBytes(H) return new Buffer(digestbytes) } module.exports = ripemd160 }).call(this,require("buffer").Buffer) },{"buffer":61}],425:[function(require,module,exports){ (function (Buffer){ var SecretStack = require('secret-stack') var create = require('secure-scuttlebutt/create') var ssbKeys = require('ssb-keys') var path = require('path') var osenv = require('osenv') var mkdirp = require('mkdirp') var rimraf = require('rimraf') var mdm = require('mdmanifest') var cmdAliases = require('./lib/cli-cmd-aliases') var valid = require('./lib/validators') var apidocs = require('./lib/apidocs.js') function isString(s) { return 'string' === typeof s } // create SecretStack definition var manifest = mdm.manifest(apidocs._) manifest.usage = 'sync' var SSB = { manifest: manifest, permissions: { master: {allow: null, deny: null}, anonymous: {allow: ['createHistoryStream'], deny: null} }, init: function (api, opts) { // .temp: use a /tmp data directory // (useful for testing) if(opts.temp) { var name = isString(opts.temp) ? opts.temp : ''+Date.now() opts.path = path.join(osenv.tmpdir(), name) rimraf.sync(opts.path) } // load/create secure scuttlebutt data directory var dbPath = path.join(opts.path, 'db') mkdirp.sync(dbPath) if(!opts.keys) opts.keys = ssbKeys.generate('ed25519', opts.seed && new Buffer(opts.seed, 'base64')) if(!opts.path) throw new Error('opts.path *must* be provided, or use opts.temp=name to create a test instance') // main interface var ssb = create(path.join(opts.path, 'db'), null, opts.keys) var feed = ssb.createFeed(opts.keys) var _close = api.close var close = function (cb) { // override to close the SSB database ssb.close(function (err) { if (err) throw err _close(cb) }) } return { id : feed.id, keys : opts.keys, usage : valid.sync(usage, 'string?|boolean?'), close : valid.async(close), publish : valid.async(feed.add, 'string|msgContent'), add : valid.async(ssb.add, 'msg'), get : valid.async(ssb.get, 'msgId'), pre : ssb.pre, post : ssb.post, getPublicKey : ssb.getPublicKey, latest : ssb.latest, getLatest : valid.async(ssb.getLatest, 'feedId'), latestSequence : valid.async(ssb.latestSequence, 'feedId'), createFeed : ssb.createFeed, whoami : function () { return { id: feed.id } }, relatedMessages : valid.async(ssb.relatedMessages, 'relatedMessagesOpts'), query : ssb.query, createFeedStream : valid.source(ssb.createFeedStream, 'readStreamOpts?'), createHistoryStream : valid.source(ssb.createHistoryStream, ['createHistoryStreamOpts'], ['feedId', 'number?', 'boolean?']), createLogStream : valid.source(ssb.createLogStream, 'readStreamOpts?'), createUserStream : valid.source(ssb.createUserStream, 'createUserStreamOpts'), links : valid.source(ssb.links, 'linksOpts'), sublevel : ssb.sublevel, messagesByType : valid.source(ssb.messagesByType, 'string|messagesByTypeOpts'), createWriteStream : ssb.createWriteStream, // createLatestLookupStream : ssb.createLatestLookupStream, } } } // live help RPC method function usage (cmd) { var path = (cmd||'').split('.') if ((path[0] && apidocs[path[0]]) || (cmd && apidocs[cmd])) { // return usage for the plugin cmd = path.slice(1).join('.') return mdm.usage(apidocs[path[0]], cmd, { prefix: path[0] }) } if (!cmd) { // return usage for all docs return Object.keys(apidocs).map(function (name) { if (name == '_') return mdm.usage(apidocs[name], null, { nameWidth: 20 }) var text = mdm.usage(apidocs[name], null, { prefix: name, nameWidth: 20 }) return text.slice(text.indexOf('Commands:') + 10) // skip past the toplevel summary, straight to the cmd list }).join('\n\n') } // toplevel cmd usage cmd = cmdAliases[cmd] || cmd return mdm.usage(apidocs._, cmd) } module.exports = SecretStack({ appKey: require('./lib/ssb-cap') }) .use(SSB) }).call(this,require("buffer").Buffer) },{"./lib/apidocs.js":426,"./lib/cli-cmd-aliases":427,"./lib/ssb-cap":428,"./lib/validators":430,"buffer":61,"mdmanifest":241,"mkdirp":248,"osenv":282,"path":290,"rimraf":423,"secret-stack":463,"secure-scuttlebutt/create":472,"ssb-keys":530}],426:[function(require,module,exports){ (function (__dirname){ var fs = require('fs') var path = require('path') module.exports = { _: fs.readFileSync(path.join(__dirname, '../api.md'), 'utf-8'), blobs: fs.readFileSync(path.join(__dirname, '../plugins/blobs.md'), 'utf-8'), block: fs.readFileSync(path.join(__dirname, '../plugins/block.md'), 'utf-8'), friends: fs.readFileSync(path.join(__dirname, '../plugins/friends.md'), 'utf-8'), gossip: fs.readFileSync(path.join(__dirname, '../plugins/gossip.md'), 'utf-8'), invite: fs.readFileSync(path.join(__dirname, '../plugins/invite.md'), 'utf-8'), plugins: fs.readFileSync(path.join(__dirname, '../plugins/plugins.md'), 'utf-8'), 'private': fs.readFileSync(path.join(__dirname, '../plugins/private.md'), 'utf-8'), replicate: fs.readFileSync(path.join(__dirname, '../plugins/replicate.md'), 'utf-8') } }).call(this,"/node_modules/scuttlebot/lib") },{"fs":58,"path":290}],427:[function(require,module,exports){ module.exports = { feed: 'createFeedStream', history: 'createHistoryStream', hist: 'createHistoryStream', public: 'getPublicKey', pub: 'getPublicKey', log: 'createLogStream', logt: 'messagesByType', conf: 'config' } },{}],428:[function(require,module,exports){ (function (Buffer){ //this is the key for accessing the ssb protocol. //this will be updated whenever breaking changes are made. //(see secret-handshake paper for a full explaination) module.exports = new Buffer('1KHLiKZvAvjbY1ziZEHMXawbCEIM6qwjCDm3VYRan/s=', 'base64') //there is nothing special about this value. //I generated it in the node repl with: // // > crypto.randomBytes(32).toString('base64') // //and copied it here. }).call(this,require("buffer").Buffer) },{"buffer":61}],429:[function(require,module,exports){ var ref = require('ssb-ref') function isObject(o) { return o && 'object' === typeof o } var DEFAULT_PORT = 8008 var isArray = Array.isArray var isInteger = Number.isInteger function isString (s) { return 'string' === typeof s } var find = exports.find = function find(ary, test) { for(var i in ary) if(test(ary[i], i, ary)) return ary[i] } var clone = exports.clone = function clone (obj, mapper) { function map(v, k) { return isObject(v) ? clone(v, mapper) : mapper(v, k) } if(isArray(obj)) return obj.map(map) else if(isObject(obj)) { var o = {} for(var k in obj) o[k] = map(obj[k], k) return o } else return map(obj) } var mergeKeys = exports.mergeKeys = function (a, b, iter) { var o = {} for(var k in a) { if(!isUndefined(a[k])) o[k] = iter(v[k], b[k], k) } for(var k in b) { if(isUndefined(a[a])) o[k] = iter(undefined, b[k], k) } return o } exports.merge = function (a, b) { //merge a and b objects if(isArray(a) != isArray(b)) throw new Error('cannot merge array with non-array') if(isObject(a) != isObject(b)) throw new Error('cannot merge object with non-object') a = clone(a) var keys if(isObject(b)) { for(var k in b) a[k] = b } } exports.stringifyAddress = function (e) { if(isString(e)) return e return [e.host, e.port || DEFAULT_PORT, e.key].join(':') } exports.parseAddress = function (e) { if(isString(e)) { var parts = e.split(':') var id = parts.pop(), port = parts.pop(), host = parts.join(':') var e = { host: host, port: +(port || DEFAULT_PORT), key: id } return e } return e } exports.isAddress = function (addr) { return ( ref.isFeedId(addr.key || addr.link) && isInteger(addr.port) && typeof addr.host === 'string' && !!addr.host ) } exports.toAddress = function (e) { e = exports.parseAddress(e) e.port = e.port || DEFAULT_PORT e.host = e.host || 'localhost' return e } },{"ssb-ref":573}],430:[function(require,module,exports){ var valid = require('muxrpc-validation') var zerr = require('zerr') var ref = require('ssb-ref') // errors var MissingAttr = zerr('Usage', 'Param % must have a .% of type "%"') var AttrType = zerr('Usage', '.% of param % must be of type "%"') function isFilter (v) { return (v == '@' || v == '%' || v == '&') } module.exports = valid({ msgId: function (v) { if (!ref.isMsg(v)) return 'type' }, feedId: function (v) { if (!ref.isFeed(v)) return 'type' }, blobId: function (v) { if (!ref.isBlob(v)) return 'type' }, msgContent: function (v, n) { var err = this.get('object')(v, n) if (err) return err if (!v.type || typeof v.type != 'string') return MissingAttr(n, 'type', 'string') }, msg: function (v, n) { var err = this.get('object')(v, n) if (err) return err // .content var err = this.get('object')(v.content, n) if (err) return MissingAttr(n, 'content', 'object') // .content.type if (!v.content.type || typeof v.content.type != 'string') return MissingAttr(n, 'content.type', 'string') // .author if (!ref.isFeed(v.author)) return MissingAttr(n, 'author', 'feedId') // .sequence if (typeof v.sequence != 'number') return MissingAttr(n, 'sequence', 'number') // .previous if (v.sequence > 1 && !ref.isMsg(v.previous)) return MissingAttr(n, 'previous', 'msgId') else if(v.sequence == 1 && v.previous != null) return MissingAttr(n, 'previous', 'null') // .timestamp if (typeof v.timestamp != 'number') return MissingAttr(n, 'timestamp', 'number') // .hash if (v.hash != 'sha256') return zerr('Usage', 'Param % must have .hash set to "sha256"')(n) // .signature if (typeof v.signature != 'string') return MissingAttr(n, 'signature', 'string') }, readStreamOpts: function (v, n) { var err = this.get('object')(v, n) if (err) return err // .live if (v.live && typeof v.live != 'boolean' && typeof v.live != 'number') return AttrType(n, 'live', 'boolean') // .reverse if (v.reverse && typeof v.reverse != 'boolean' && typeof v.reverse != 'number') return AttrType(n, 'reverse', 'boolean') // .keys if (v.keys && typeof v.keys != 'boolean' && typeof v.keys != 'number') return AttrType(n, 'keys', 'boolean') // .values if (v.values && typeof v.values != 'boolean' && typeof v.values != 'number') return AttrType(n, 'values', 'boolean') // .limit if (v.limit && typeof v.limit != 'number') return AttrType(n, 'limit', 'number') // .fillCache if (v.fillCache && typeof v.fillCache != 'boolean' && typeof v.fillCache != 'number') return AttrType(n, 'fillCache', 'boolean') }, createHistoryStreamOpts: function (v, n) { // .id if (!ref.isFeed(v.id)) return MissingAttr(n, 'id', 'feedId') // .seq if (v.seq && typeof v.seq != 'number') return AttrType(n, 'seq', 'number') // .live if (v.live && typeof v.live != 'boolean' && typeof v.live != 'number') return AttrType(n, 'live', 'boolean') }, createUserStreamOpts: function (v, n) { var err = this.get('readStreamOpts')(v, n) if (err) return err // .id if (!ref.isFeed(v.id)) return MissingAttr(n, 'id', 'feedId') }, messagesByTypeOpts: function (v, n) { var err = this.get('readStreamOpts')(v, n) if (err) return err // .type if (typeof v.type != 'string') return MissingAttr(n, 'type', 'string') }, linksOpts: function (v, n) { var err = this.get('object')(v, n) if (err) return err // .source if (v.source && !ref.isLink(v.source) && !isFilter(v.source)) return AttrType(n, 'source', 'id|filter') // .dest if (v.dest && !ref.isLink(v.dest) && !isFilter(v.dest)) return AttrType(n, 'dest', 'id|filter') // .rel if (v.rel && typeof v.rel != 'string') return AttrType(n, 'rel', 'string') // .live if (v.live && typeof v.live != 'boolean' && typeof v.live != 'number') return AttrType(n, 'live', 'boolean') // .reverse if (v.reverse && typeof v.reverse != 'boolean' && typeof v.reverse != 'number') return AttrType(n, 'reverse', 'boolean') // .keys if (v.keys && typeof v.keys != 'boolean' && typeof v.keys != 'number') return AttrType(n, 'keys', 'boolean') // .values if (v.values && typeof v.values != 'boolean' && typeof v.values != 'number') return AttrType(n, 'values', 'boolean') }, relatedMessagesOpts: function (v, n) { var err = this.get('object')(v, n) if (err) return err // .id if (!ref.isMsg(v.id)) return MissingAttr(n, 'id', 'msgId') // .rel if (v.rel && typeof v.rel != 'string') return AttrType(n, 'rel', 'string') // .count if (v.count && typeof v.count != 'boolean' && typeof v.count != 'number') return AttrType(n, 'count', 'boolean') // .parent if (v.parent && typeof v.parent != 'boolean' && typeof v.parent != 'number') return AttrType(n, 'parent', 'boolean') }, isBlockedOpts: function (v, n) { var err = this.get('object')(v, n) if (err) return err // .source if (v.source && !ref.isFeed(v.source)) return AttrType(n, 'source', 'feedId') // .dest if (v.dest && !ref.isFeed(v.dest)) return AttrType(n, 'dest', 'feedId') }, createFriendStreamOpts: function (v, n) { var err = this.get('object')(v, n) if (err) return err // .start if (v.start && !ref.isFeed(v.start)) return AttrType(n, 'start', 'feedId') // .graph if (v.graph && typeof v.graph != 'string') return AttrType(n, 'graph', 'string') // .dunbar if (v.dunbar && typeof v.dunbar != 'number') return AttrType(n, 'dunbar', 'number') // .hops if (v.hops && typeof v.hops != 'number') return AttrType(n, 'hops', 'number') } }) },{"muxrpc-validation":259,"ssb-ref":573,"zerr":643}],431:[function(require,module,exports){ arguments[4][232][0].apply(exports,arguments) },{"./pull":432,"./sinks":433,"./sources":434,"./throughs":435,"dup":232}],432:[function(require,module,exports){ arguments[4][233][0].apply(exports,arguments) },{"dup":233}],433:[function(require,module,exports){ arguments[4][234][0].apply(exports,arguments) },{"dup":234}],434:[function(require,module,exports){ arguments[4][235][0].apply(exports,arguments) },{"dup":235}],435:[function(require,module,exports){ arguments[4][236][0].apply(exports,arguments) },{"./sinks":433,"./sources":434,"dup":236}],436:[function(require,module,exports){ var ref = require('ssb-ref') function isObject (o) { return o && 'object' === typeof o } function isBool (o) { return 'boolean' === typeof o } function isString (s) { return 'string' === typeof s } function traverse (obj, each) { for (var k in obj) { if (!obj[k]) continue if (Array.isArray(obj[k])) { obj[k].forEach(function (v) { each(v, k) }) } else each(obj[k], k) } } exports.indexLinks = function (message, opts, each) { if (typeof opts == 'function') { each = opts opts = null } if (typeof opts == 'string') opts = { rel: opts } if (!opts) opts = {} var msg = opts.msg var feed = opts.feed var blob = opts.blob var any = !(msg || feed || blob) traverse(message, function (obj, rel) { if (opts.rel && rel !== opts.rel) return var r = (typeof obj == 'string') ? obj : obj.link if (any) { if (!ref.isLink(r)) return } else { if (msg) { if (isBool(msg) && ref.type(r) != 'msg') return if (!isBool(msg) && r != msg) return } if (feed) { if (isBool(feed) && ref.type(r) != 'feed') return if (!isBool(feed) && r != feed) return } if (blob) { if (isBool(blob) && ref.type(r) != 'blob') return if (!isBool(blob) && r != blob) return } } each((typeof obj == 'string') ? { link: obj } : obj, rel) }) } exports.link = exports.asLink = function (obj, type) { if (!obj) return null if (isString(obj)) obj = { link: obj } return isLink(obj, type) ? obj : null } exports.links = exports.asLinks = function (obj, type) { if (!obj) return [] var arr = Array.isArray(obj) ? obj : [obj] return arr .filter(function (l) { return isLink(l, type) }) .map(function (o) { return (typeof o == 'string') ? { link: o } : o }) } var isLink = exports.isLink = function (obj, type) { if (!obj) return false var r = (isString(obj)) ? obj : obj.link return (type) ? (ref.type(r) == type) : ref.isLink(r) } },{"ssb-ref":573}],437:[function(require,module,exports){ 'use strict' var Blobs = require('multiblob') var path = require('path') var pull = require('pull-stream') var isBlob = require('ssb-ref').isBlobId var Quota = require('./quota') var Notify = require('pull-notify') var mdm = require('mdmanifest') var valid = require('../../lib/validators') var apidoc = require('../../lib/apidocs').blobs var Replicate = require('./replication') // blobs plugin // methods to read/write the blobstore // and automated blob-fetching from the network function isFunction (f) { return 'function' === typeof f } function desigil (hash) { return isBlob(hash) ? hash.substring(1) : hash } function resigil (hash) { return isBlob(hash) ? hash : '&'+hash } function isString (s) { return 'string' === typeof s } module.exports = { name: 'blobs', version: '0.0.0', manifest: mdm.manifest(apidoc), permissions: { anonymous: {allow: ['has', 'get', 'changes']}, }, init: function (sbot, opts) { var notify = Notify() var config = opts var blobs = sbot._blobs = Blobs({ dir: path.join(config.path, 'blobs'), hash: 'sha256' }) var userQuotas = {} // map of { feedId => quotaUsage }, for rate-limiting var drain = Quota(sbot, blobs, userQuotas) var wantList = Replicate(sbot, config, notify, userQuotas) return { get: valid.source(function (hash) { return blobs.get(desigil(hash)) }, 'blobId'), has: valid.async(function (hash, cb) { //emit blobs:has event when this api is called remotely. //needed to make tests pass. should probably remove this. if(this.id) sbot.emit('blobs:has', hash) blobs.has(desigil(hash), cb) }, 'blobId|array'), size: valid.async(function (hash, cb) { //sbot.emit('blobs:size', hash) blobs.size(desigil(hash), cb) }, 'blobId|array'), add: valid.sink(function (hash, cb) { // cb once blob is successfully added. // sink cbs are not exposed over rpc // so this is only available when using this api if(isFunction(hash)) cb = hash, hash = null return blobs.add(desigil(hash), function (err, hash) { if(!err) { hash = resigil(hash) sbot.emit('blobs:got', hash) notify(hash) //wait until quotas have been calculated //befor returning (tests will fail without this) if(cb) drain(function () { cb(null, hash) }) } else { if(cb) cb(err, hash) else console.error(err.stack) } }) }, 'string?'), rm: valid.async(function (hash, cb) { return blobs.rm(desigil(hash), cb) }, 'string'), ls: function (opts) { return pull(blobs.ls(opts), pull.map(function (e) { if(e.sync) return e if(isString(e)) return resigil(e) e.id = resigil(e.id) return e })) }, // request to retrieve a blob, // calls back when that file is available. // - `opts.nowait`: call cb immediately if not found (dont register for callback) want: valid.async(function (hash, opts, cb) { if (isFunction(opts)) { cb = opts opts = null } var id = this.id if(!isBlob(hash)) return cb(new Error('not a hash:' + hash)) sbot.emit('blobs:wants', hash) blobs.has(desigil(hash), function (_, has) { if (has) return cb(null, true) // update queue wantList.want(hash, id, cb) }) }, 'blobId', 'object?'), changes: function () { return notify.listen() }, quota: valid.sync(function (id) { return wantList.quota(id) }, 'feedId'), // get current want list wants: function () { return wantList.jobs } } } } },{"../../lib/apidocs":426,"../../lib/validators":430,"./quota":439,"./replication":440,"mdmanifest":241,"multiblob":250,"path":290,"pull-notify":354,"pull-stream":431,"ssb-ref":573}],438:[function(require,module,exports){ // Queue // returns a function which... // - only acts if not already acting // - automatically requeues if the task is not yet done // - `delay`: ms, amount of time to wait before calling again // - `n`: number, amount of simultaneous calls allowed // - `label`: string, name of the task (for logging) // - `fun`: function(cb(done?)), calls cb(true) when done, cb(false) when needs to requeue function isFunction (f) { return 'function' === typeof f } function Work(avgWait, n, label, fun) { n = 1 var doing = 0, timeout var timers = [] function clear (timer) { var i = timers.indexOf(timer) clearTimeout(timer[i]) times.splice(i, 1) } function delay (job, d) { var i var timer = setTimeout(function () { timers.splice(timers.indexOf(timer), 1); job() }, d) timer.unref() timers.push(timer) return timer } function job () { // abort if already doing too many if(doing >= n) return doing++ // run the behavior fun(function (done) { doing-- if(done) { // we're done, dont requeue return } // requeue after a delay var wait = ~~(avgWait/2 + avgWait*Math.random()) delay(job, wait) }) } job.abort = function () { timers.forEach(clear) } return job } function find (jobs, test) { for(var k in jobs) if(test(jobs[k])) return k return -1 } function max (jobs, test) { var M = -Infinity, i = -1 for(var k in jobs) { var m = test(jobs[k], k, jobs) if(m > M) { M = m i = k } } return k } module.exports = function (work) { var jobs = [] var queue = { push: function (job) { jobs.push(job) }, pull: function (id) { var test = isFunction(id) ? id : function (e) { return e.id === id } if(!this.length()) return if(!id) return jobs.shift() else { var index = find(jobs, test) if(~index) return jobs.splice(index, 1)[0] } }, each: function (iter) { jobs.forEach(iter) }, length: function () { return jobs.length }, toJSON: function () { return jobs.slice() } } Work(100, 2, null, function (done) { if(!queue.length()) return done() work(queue, done) }) () return queue } },{}],439:[function(require,module,exports){ var pull = require('pull-stream') var paramap = require('pull-paramap') module.exports = function (sbot, blobs, userQuotas, cb) { var listeners = [] //recalculate the quota, with live updates. // share a file size between the feeds that link to it. // At the time we download it. // More feeds might link to it later, and these // won't be included in the calculation. // but it's simplest to do it this way. // this is only in memory, so it will be recalculated // when sbot is restarted. var total = 0 var start = Date.now() var inflight = 0 pull( blobs.ls({long: true, live: true}), paramap(function (data, cb) { if(data.sync) return cb(null, data) var acc = {}, count = 0 total += data.size inflight ++ pull( sbot.links({dest: '&'+data.id}), pull.drain(function (link) { if(!acc[link.source]) { acc[link.source] = true count ++ } return acc }, function (err) { inflight -- if(err) return cb(err) var size = data.size for(var k in acc) userQuotas[k] = (userQuotas[k] || 0) + size/count if(inflight === 0) while (listeners.length) listeners.shift()() cb(null, data) }) ) }), pull.drain() ) return function (listener) { if(!inflight) listener() else listeners.push(listener) } } },{"pull-paramap":363,"pull-stream":431}],440:[function(require,module,exports){ var pull = require('pull-stream') var Queue = require('./queue') function each (obj, iter) { for(var k in obj) iter(obj[k], k, obj) } function first (obj, test) { var v for (var k in obj) if(v = test(obj[k], k, obj)) return v } function union (a, b) { b = toArray(b) a = toArray(a) if(!a.length) return b if(a.length < b.length) { var t = b; b = a; a = t } b.forEach(function (e) { if(!~a.indexOf(e)) a.push(e) }) return a } function toArray (s) { return s != null ? (Array.isArray(s) ? s : [s]) : [] } function isFunction (f) { return 'function' === typeof f } var MB = 1024*1024 //default replication limits. var defaults = {limit: [-1, 100*MB, 20*MB], minLimit: 5*MB} module.exports = function (sbot, opts, notify, userQuotas) { var jobs = {}, hasQueue, getQueue var conf = opts.blobs || defaults, wl //keep track of who is over quota so that it doesn't get logged again and again. var over = {} // calculate quotas for each feed. // start with size of each blob // divided between the feeds that mention it. // getting a use for each feed. function createJob(id, owner, cb) { toArray(owner).forEach(function (e) { if(e[0] !== '@') throw new Error('not a owner:'+e) }) if(jobs[id]) { jobs[id].owner = union(jobs[id].owner, owner || []) jobs[id].cbs.push(cb) return } hasQueue.push(jobs[id] = { id: id, has: {}, owner: toArray(owner), cbs: cb ? [cb] : [], done: false }) } function finishJob(job) { if(!job) return delete jobs[job.id] while(job.cbs && job.cbs.length) { var cb = job.cbs.shift() if(isFunction(cb)) cb(null, true) } } //if want is called and then it's locally added, //handle that by calling back want. pull(notify.listen(), pull.drain(function (hash) { finishJob(hasQueue.pull(hash) || getQueue.pull(hash)) })) function hasPeers () { return Object.keys(sbot.peers).length !== 0 } function hops (id) { var p = sbot.friends.path({ source: sbot.id, dest: id, hops: conf.limit.length }) return p ? p.length - 1 : -1 } function limitFor(id) { if(opts.party) return -1 var h = hops(id) if(hops === -1) return conf.minLimit return conf.limit[h] || conf.minLimit } function filter (job) { //set config.blobs.party = true //to disable all quotas. if(conf.party) return true return job.owner.every(function (id) { var l = limitFor(id) if(l < 0) return true else if ((userQuotas[id] || 0) < l) return true else if(!over[id]) { over[id] = userQuotas[id] console.log('Over Quota:', id, wl.quota(id)) } }) } hasQueue = Queue(function (_, done) { //check if there is a something in the has queue. //filter out cases where work is impossible... //(empty queue, or no peers) if(!hasPeers()) return done() var job = hasQueue.pull(filter) if(!job || job.done) return done() var n = 0, found = false each(sbot.peers, function (peers, id) { if(('undefined' !== typeof job.has[id]) || !peers[0]) return n++ peers[0].blobs.has(job.id, function (err, has) { found = found || (job.has[id] = has) if(--n) return next() }) }) if(!n) return hasQueue.push(job), done() function next () { (found ? getQueue : hasQueue).push(job) done() } }) getQueue = Queue(function (_, done) { if(!hasPeers()) return done() //check if this file is over quota. var job = getQueue.pull(filter) if(!job) return done() //this covers weird edgecase where a blob is added //while something is looking for it. covered in //test/blobs2.js if(job.done) { delete jobs[job.id] return done() } var remote = first(job.has, function (has, id) { if (has) return getPeer(id) }) if(!remote) { hasQueue.push(job); return done() } pull( remote.blobs.get(job.id), //only accept blobs that have the correct size. sbot.blobs.add(job.id, function (err) { if(!err) { finishJob(job) return done() //success } // remove the remote, it may be misbehaving delete job.has[remote.id] // put it back on the get or has queue if(Object.keys(job.has).length) getQueue.push(job) else hasQueue.push(job) done() }) ) }) function getPeer(id) { return sbot.peers[id] && sbot.peers[id][0] } // monitor the feed for new links to blobs pull( sbot.links({dest: '&', live: true}), pull.drain(function (data) { // do we have the referenced blob yet? sbot.blobs.has(data.dest, function (_, has) { if(!has) createJob(data.dest, data.source) }) }) ) //handle weird edge case where something is added locally //but we are already looking for it because we saw a link. sbot.on('blobs:got', function (hash) { if(jobs[hash]) jobs[hash].done = true }) sbot.on('rpc:connect', function (rpc) { for(id in jobs) if(false === jobs[id].has[rpc.id]) delete jobs[id].has[rpc.id] }) return wl = { has: hasQueue, get: getQueue, want: function (id, owner, cb) { createJob(id, owner || sbot.id, cb) }, quota: function (id) { var l = limitFor(id), q = userQuotas[id] || 0 return { limit: l, usage: q, hops: hops(id), percent: ((q/l)*100).toPrecision(4)+'%' } } } } },{"./queue":438,"pull-stream":431}],441:[function(require,module,exports){ var pull = require('pull-stream') var valid = require('../lib/validators') exports.name = 'block' exports.version = '1.0.0' exports.manifest = { isBlocked : 'sync', } exports.init = function (sbot) { //TODO: move other blocking code in here, // i think we'll need a hook system for this. //if a currently connected peer is blocked, disconnect them immediately. pull( sbot.friends.createFriendStream({graph: 'flag', live: true}), pull.drain(function (blocked) { if(sbot.peers[blocked]) { sbot.peers[blocked].forEach(function (b) { b.close(true, function () {}) }) } }) ) function isBlocked (_opts) { var opts if('string' === typeof _opts) opts = { source: sbot.id, dest: _opts, graph:'flag' } else opts = { source: _opts.source, dest: _opts.dest, graph: 'flag' } return sbot.friends.get(opts) } sbot.createHistoryStream.hook(function (fn, args) { var opts = args[0], id = this.id if(opts.id !== this.id && isBlocked({source: opts.id, dest: this.id})) return fn({id: null, sequence: 0}) else return pull( fn.apply(this, args), //break off this feed if they suddenly block //the recipient. pull.take(function (msg) { //handle when createHistoryStream is called with keys: true if(!msg.content && msg.value.content) msg = msg.value if(msg.content.type !== 'contact') return true return !( msg.content.flagged && msg.content.contact === id ) }) ) }) sbot.auth.hook(function (fn, args) { if(isBlocked(args[0])) args[1](new Error('client is blocked')) else return fn.apply(this, args) }) return {isBlocked: valid.sync(isBlocked, 'feedId|isBlockedOpts') } } },{"../lib/validators":430,"pull-stream":431}],442:[function(require,module,exports){ var Graphmitter = require('graphmitter') var pull = require('pull-stream') var mlib = require('ssb-msgs') var memview = require('level-memview') var pushable = require('pull-pushable') var mdm = require('mdmanifest') var valid = require('../lib/validators') var apidoc = require('../lib/apidocs').friends // friends plugin // methods to analyze the social graph // maintains a 'follow' and 'flag' graph function isFunction (f) { return 'function' === typeof f } function isString (s) { return 'string' === typeof s } exports.name = 'friends' exports.version = '1.0.0' exports.manifest = mdm.manifest(apidoc) exports.init = function (sbot, config) { var graphs = { follow: new Graphmitter(), flag: new Graphmitter() } // view processor var syncCbs = [] function awaitSync (cb) { if (syncCbs) syncCbs.push(cb) else cb() } // read/watch the log for changes to the social graph pull(sbot.createLogStream({ live: true }), pull.drain(function (msg) { if (msg.sync) { syncCbs.forEach(function (cb) { cb() }) syncCbs = null return } var c = msg.value.content if (c.type == 'contact') { mlib.asLinks(c.contact).forEach(function (link) { if ('following' in c) { if (c.following) graphs.follow.edge(msg.value.author, link.link, true) else graphs.follow.del(msg.value.author, link.link) } if ('flagged' in c) { if (c.flagged) graphs.flag.edge(msg.value.author, link.link, c.flagged) else graphs.flag.del(msg.value.author, link.link) } }) } })) return { get: valid.sync(function (opts) { var g = graphs[opts.graph || 'follow'] if(!g) throw new Error('opts.graph must be provided') return g.get(opts.source, opts.dest) }, 'object?'), all: valid.async(function (graph, cb) { if (typeof graph == 'function') { cb = graph graph = null } if (!graph) graph = 'follow' awaitSync(function () { cb(null, graphs[graph] ? graphs[graph].toJSON() : null) }) }, 'string?'), path: valid.sync(function (opts) { if(isString(opts)) opts = {source: sbot.id, dest: opts} return graphs.follow.path(opts) }, 'string|object'), createFriendStream: valid.source(function (opts) { opts = opts || {} var live = opts.live === true var meta = opts.meta === true var start = opts.start || sbot.id var graph = graphs[opts.graph || 'follow'] if(!graph) return pull.error(new Error('unknown graph:' + opts.graph)) var cancel, ps = pushable(function () { cancel && cancel() }) function push (to, hops) { return ps.push(meta ? {id: to, hops: hops} : to) } //by default, also emit your own key. if(opts.self !== false) push(start, 0) var conf = config.friends || {} cancel = graph.traverse({ start: start, hops: opts.hops || conf.hops || 3, max: opts.dunbar || conf.dunbar || 150, each: function (_, to, hops) { if(to !== start) push(to, hops) } }) if(!live) { cancel(); ps.end() } return ps }, 'createFriendStreamOpts?'), hops: valid.async(function (start, graph, opts, cb) { if (typeof opts == 'function') { // (start|opts, graph, cb) cb = opts opts = null } else if (typeof graph == 'function') { // (start|opts, cb) cb = graph opts = graph = null } opts = opts || {} if(isString(start)) { // (start, ...) // first arg is id string opts.start = start } else if (start && typeof start == 'object') { // (opts, ...) // first arg is opts for (var k in start) opts[k] = start[k] } var conf = config.friends || {} opts.start = opts.start || sbot.id opts.dunbar = opts.dunbar || conf.dunbar || 150 opts.hops = opts.hops || conf.hops || 3 var g = graphs[graph || 'follow'] if (!g) return cb(new Error('Invalid graph type: '+graph)) awaitSync(function () { cb(null, g.traverse(opts)) }) }, ['feedId', 'string?', 'object?'], ['createFriendStreamOpts']) } } },{"../lib/apidocs":426,"../lib/validators":430,"graphmitter":154,"level-memview":178,"mdmanifest":241,"pull-pushable":370,"pull-stream":431,"ssb-msgs":436}],443:[function(require,module,exports){ 'use strict' var pull = require('pull-stream') var Notify = require('pull-notify') var toAddress = require('../../lib/util').toAddress var mdm = require('mdmanifest') var valid = require('../../lib/validators') var apidoc = require('../../lib/apidocs').gossip var u = require('../../lib/util') var ping = require('pull-ping') var Stats = require('statistics') var isArray = Array.isArray var Schedule = require('./schedule') var Init = require('./init') function isFunction (f) { return 'function' === typeof f } /* Peers : [{ key: id, host: ip, port: int, //to be backwards compatible with patchwork... announcers: {length: int} source: 'pub'|'manual'|'local' }] */ module.exports = { name: 'gossip', version: '1.0.0', manifest: mdm.manifest(apidoc), permissions: { anonymous: {allow: ['ping']} }, init: function (server, config) { var notify = Notify() var conf = config.gossip || {} var home = u.toAddress(server.getAddress()) //Known Peers var peers = [] function getPeer(id) { return u.find(peers, function (e) { return e && e.key === id }) } var timer_ping = 5*6e4 var gossip = { peers: function () { return peers }, get: function (addr) { addr = u.toAddress(addr) return u.find(peers, function (a) { return ( addr.port === a.port && addr.host === a.host && addr.key === a.key ) }) }, connect: valid.async(function (addr, cb) { addr = u.toAddress(addr) if (!addr || typeof addr != 'object') return cb(new Error('first param must be an address')) if(!addr.key) return cb(new Error('address must have ed25519 key')) // add peer to the table, incase it isn't already. gossip.add(addr, 'manual') var p = gossip.get(addr) if(!p) return cb() p.stateChange = Date.now() p.state = 'connecting' server.connect(p, function (err, rpc) { if (err) { p.state = undefined p.failure = (p.failure || 0) + 1 p.stateChange = Date.now() notify({ type: 'connect-failure', peer: p }) server.emit('log:info', ['SBOT', p.host+':'+p.port+p.key, 'connection failed', err.message || err]) p.duration.value(0) return (cb && cb(err)) } else { p.state = 'connected' p.failure = 0 } cb && cb(null, rpc) }) }, 'string|object'), disconnect: valid.async(function (addr, cb) { var peer = this.get(addr) peer.state = 'disconnecting' peer.stateChange = Date.now() if(!peer || !peer.disconnect) cb && cb() else peer.disconnect(true, function (err) { peer.stateChange = Date.now() }) }, 'string|object'), changes: function () { return notify.listen() }, //add an address to the peer table. add: valid.sync(function (addr, source) { addr = u.toAddress(addr) if(!u.isAddress(addr)) throw new Error('not a valid address:' + JSON.stringify(addr)) // check that this is a valid address, and not pointing at self. if(addr.key === home.key) return if(addr.host === home.host && addr.port === home.port) return var f = gossip.get(addr) if(!f) { // new peer addr.source = source addr.announcers = 1 addr.duration = Stats() peers.push(addr) notify({ type: 'discover', peer: addr, source: source || 'manual' }) return addr } //don't count local over and over else if(f.source != 'local') f.announcers ++ return f }, 'string|object', 'string?'), ping: function (opts) { var timeout = config.timers && config.timers.ping || 5*60e3 //between 10 seconds and 30 minutes, default 5 min timeout = Math.max(10e3, Math.min(timeout, 30*60e3)) return ping({timeout: timeout}) } } Schedule (gossip, config, server) Init (gossip, config, server) //get current state server.on('rpc:connect', function (rpc, isClient) { var peer = getPeer(rpc.id) //don't track clients that connect, but arn't considered peers. //maybe we should though? if(!peer) return console.log('+connected', u.stringifyAddress(peer)) //means that we have created this connection, not received it. peer.client = !!isClient peer.state = 'connected' peer.stateChange = Date.now() peer.disconnect = function (err, cb) { if(isFunction(err)) cb = err, err = null rpc.close(err, cb) } if(isClient) { //default ping is 5 minutes... var pp = ping({serve: true, timeout: timer_ping}, function (_) {}) peer.ping = {rtt: pp.rtt, skew: pp.skew} pull( pp, rpc.gossip.ping({timeout: timer_ping}, function (err) { if(err.name === 'TypeError') peer.ping.fail = true }), pp ) } rpc.on('closed', function () { console.log('-disconnected', u.stringifyAddress(peer)) //track whether we have successfully connected. //or how many failures there have been. var since = peer.stateChange peer.stateChange = Date.now() if(peer.state === 'connected') //may be "disconnecting" peer.duration.value(peer.stateChange - since) peer.state = undefined notify({ type: 'disconnect', peer: peer }) server.emit('log:info', ['SBOT', rpc.id, 'disconnect']) }) notify({ type: 'connect', peer: peer }) }) return gossip } } },{"../../lib/apidocs":426,"../../lib/util":429,"../../lib/validators":430,"./init":444,"./schedule":445,"mdmanifest":241,"pull-notify":354,"pull-ping":364,"pull-stream":431,"statistics":575}],444:[function(require,module,exports){ var isArray = Array.isArray var pull = require('pull-stream') module.exports = function (gossip, config, server) { // populate peertable with configured seeds (mainly used in testing) var seeds = config.seeds ;(isArray(seeds) ? seeds : [seeds]).filter(Boolean) .forEach(function (addr) { gossip.add(addr, 'seed') }) // populate peertable with pub announcements on the feed pull( server.messagesByType({ type: 'pub', live: true, keys: false }), pull.drain(function (msg) { if(!msg.content.address) return gossip.add(msg.content.address, 'pub') }) ) // populate peertable with announcements on the LAN multicast server.on('local', function (_peer) { gossip.add(_peer, 'local') }) } },{"pull-stream":431}],445:[function(require,module,exports){ var nonPrivate = require('non-private-ip') var ip = require('ip') var onWakeup = require('on-wakeup') var Stats = require('statistics') var os = require('os') var pull = require('pull-stream') var u = require('../../lib/util') function rand(array) { return array[~~(Math.random()*array.length)] } function not (fn) { return function (e) { return !fn(e) } } function and () { var args = [].slice.call(arguments) return function (value) { return args.every(function (fn) { return fn.call(null, value) }) } } //min delay (delay since last disconnect of most recent peer in unconnected set) //unconnected filter delay peer < min delay function delay (failures, factor, max) { return Math.min(Math.pow(2, failures)*factor, max || Infinity) } function maxStateChange (M, e) { return Math.max(M, e.stateChange || 0) } function peerNext(peer, opts) { return (peer.stateChange|0) + delay(peer.failure|0, opts.factor, opts.max) } //detect if not connected to wifi or other network //(i.e. if there is only localhost) function isOffline () { var lo = Object.keys(os.networkInterfaces()) return lo.length === 1 && lo[0] === 'lo' } var isOnline = not(isOffline) function isLocal (e) { return ip.isPrivate(e.host) } function isUnattempted (e) { return !e.stateChange } //select peers which have never been successfully connected to yet, //but have been tried. function isInactive (e) { return e.stateChange && e.duration.mean == 0 } function isLongterm (e) { return e.ping && e.ping.rtt.mean > 0 } //peers which we can connect to, but are not upgraded. //select peers which we can connect to, but are not upgraded to LT. //assume any peer is legacy, until we know otherwise... function isLegacy (peer) { return peer.duration.mean > 0 && !exports.isLongterm(peer) } function isConnect (e) { return 'connected' === e.state || 'connecting' === e.state } //sort oldest to newest then take first n function earliest(peers, n) { return peers.sort(function (a, b) { return a.stateChange - b.stateChange }).slice(0, Math.max(n, 0)) } function select(peers, ts, filter, opts) { if(opts.disable) return [] //opts: { quota, groupMin, min, factor, max } var type = peers.filter(filter) var unconnect = type.filter(not(isConnect)) var count = Math.max(opts.quota - type.filter(isConnect).length, 0) var min = unconnect.reduce(maxStateChange, 0) + opts.groupMin if(ts < min) return [] return earliest(unconnect.filter(function (peer) { return peerNext(peer, opts) < ts }), count) } var schedule = exports = module.exports = function (gossip, config, server) { var min = 60e3, hour = 60*60e3 function conf(name, def) { if(!config.gossip) return def var value = config.gossip[name] return (value === undefined || value === '') ? def : value } function connect (peers, ts, name, filter, opts) { var connected = peers.filter(isConnect).filter(filter) .filter(function (peer) { return peer.stateChange + 10e3 < ts }) if(connected.length > opts.quota) { return earliest(connected, connected.length - opts.quota) .forEach(function (peer) { console.log('Disconnect', name, u.stringifyAddress(peer)) gossip.disconnect(peer) }) } select(peers, ts, and(filter, isOnline), opts) .forEach(function (peer) { console.log('Connect', name, u.stringifyAddress(peer)) gossip.connect(peer) }) } function connections () { var ts = Date.now() var peers = gossip.peers() connect(peers, ts, 'attempt', exports.isUnattempted, { min: 0, quota: 10, factor: 0, max: 0, groupMin: 0, disable: !conf('global', true) }) //quota, groupMin, min, factor, max connect(peers, ts, 'retry', exports.isInactive, { min: 0, quota: 3, factor: 5*60e3, max: 3*60*60e3, groupMin: 5*50e3 }) connect(peers, ts, 'legacy', exports.isLegacy, { quota: 3, factor: 5*min, max: 3*hour, groupMin: 5*min, disable: !conf('global', true) }) connect(peers, ts, 'longterm', exports.isLongterm, { quota: 3, factor: 10e3, max: 10*min, groupMin: 5e3, disable: !conf('global', true) }) connect(peers, ts, 'local', exports.isLocal, { quota: 3, factor: 2e3, max: 10*min, groupMin: 1e3, disable: !conf('local', true) }) } pull( gossip.changes(), pull.drain(function (ev) { if(ev.type == 'disconnect') connections() }) ) setInterval(function () { connections() }, 2e3).unref() connections() } exports.isUnattempted = isUnattempted exports.isInactive = isInactive exports.isLongterm = isLongterm exports.isLegacy = isLegacy exports.isLocal = isLocal exports.isConnectedOrConnecting = isConnect exports.select = select },{"../../lib/util":429,"ip":169,"non-private-ip":272,"on-wakeup":277,"os":279,"pull-stream":431,"statistics":575}],446:[function(require,module,exports){ var crypto = require('crypto') var ssbKeys = require('ssb-keys') var toAddress = require('../lib/util').toAddress var cont = require('cont') var explain = require('explain-error') var ip = require('ip') var mdm = require('mdmanifest') var valid = require('../lib/validators') var apidoc = require('../lib/apidocs').invite // invite plugin // adds methods for producing invite-codes, // which peers can use to command your server to follow them. function isFunction (f) { return 'function' === typeof f } function isString (s) { return 'string' === typeof s } module.exports = { name: 'invite', version: '1.0.0', manifest: mdm.manifest(apidoc), permissions: { master: {allow: ['create']}, //temp: {allow: ['use']} }, init: function (server, config) { var codes = {} var codesDB = server.sublevel('codes') var createClient = this.createClient //add an auth hook. server.auth.hook(function (fn, args) { var pubkey = args[0], cb = args[1] // run normal authentication fn(pubkey, function (err, auth) { if(err || auth) return cb(err, auth) // if no rights were already defined for this pubkey // check if the pubkey is one of our invite codes codesDB.get(pubkey, function (_, code) { return cb(null, code && code.permissions) }) }) }) return { create: valid.async(function (n, cb) { var addr = server.getAddress() var host = toAddress(addr).host if(!config.allowPrivate && (ip.isPrivate(host) || 'localhost' === host)) return cb(new Error('Server has no public ip address, ' + 'cannot create useable invitation')) //this stuff is SECURITY CRITICAL //so it should be moved into the main app. //there should be something that restricts what //permissions the plugin can create also: //it should be able to diminish it's own permissions. // generate a key-seed and its key var seed = crypto.randomBytes(32) var keyCap = ssbKeys.generate('ed25519', seed) // store metadata under the generated pubkey var owner = server.id codesDB.put(keyCap.id, { id: keyCap.id, total: +n, used: 0, permissions: {allow: ['invite.use'], deny: null} }, function (err) { // emit the invite code: our server address, plus the key-seed if(err) cb(err) else cb(null, addr + '~' + seed.toString('base64')) }) }, 'number'), use: valid.async(function (req, cb) { var rpc = this // fetch the code codesDB.get(rpc.id, function(err, invite) { if(err) return cb(err) // check if we're already following them server.friends.all('follow', function(err, follows) { if (follows && follows[server.id] && follows[server.id][req.feed]) return cb(new Error('already following')) // although we already know the current feed // it's included so that request cannot be replayed. if(!req.feed) return cb(new Error('feed to follow is missing')) if(invite.used >= invite.total) return cb(new Error('invite has expired')) invite.used ++ //never allow this to be used again if(invite.used >= invite.total) invite.permissions = {allow: [], deny: null} //TODO //okay so there is a small race condition here //if people use a code massively in parallel //then it may not be counted correctly... //this is not a big enough deal to fix though. //-dominic // update code metadata codesDB.put(rpc.id, invite, function (err) { server.emit('log:info', ['invite', rpc.id, 'use', req]) // follow the user server.publish({ type: 'contact', contact: req.feed, following: true, autofollow: true }, cb) }) }) }) }, 'object'), accept: valid.async(function (invite, cb) { // remove surrounding quotes, if found if (invite.charAt(0) === '"' && invite.charAt(invite.length - 1) === '"') invite = invite.slice(1, -1) // connect to the address in the invite code // using a keypair generated from the key-seed in the invite code var parts = invite.split('~') var addr = toAddress(parts[0]) createClient({ seed: parts[1] }) (addr, function (err, rpc) { if(err) return cb(explain(err, 'could not connect to server')) // command the peer to follow me rpc.invite.use({ feed: server.id }, function (err, msg) { if(err) return cb(explain(err, 'invite not accepted')) // follow and announce the pub cont.para([ server.publish({ type: 'contact', following: true, autofollow: true, contact: addr.link || addr.key }), server.publish({ type: 'pub', address: addr, }) ])(function (err, results) { rpc.close() cb(err, results) }) }) }) }, 'string') } } } },{"../lib/apidocs":426,"../lib/util":429,"../lib/validators":430,"cont":86,"crypto":110,"explain-error":146,"ip":169,"mdmanifest":241,"ssb-keys":530}],447:[function(require,module,exports){ var broadcast = require('broadcast-stream') // local plugin // broadcasts the address:port:pubkey triple of the sbot server // on the LAN, using multicast UDP function isFunction (f) { return 'function' === typeof f } module.exports = { name: 'local', version: '2.0.0', init: function (sbot, config) { var local = broadcast(config.port) local.on('data', function (buf) { if(buf.loopback) return var data = buf.toString() sbot.gossip.add(data, 'local') }) setInterval(function () { // broadcast self // TODO: sign beacons, so that receipient can be confidant // that is really your id. // (which means they can update their peer table) // Oh if this includes your local address, // then it becomes unforgeable. local.write(sbot.getAddress()) }, 1000) } } },{"broadcast-stream":31}],448:[function(require,module,exports){ (function (process){ var color = require('bash-color') // logging plugin // subscribes to 'log:*' events // and emits using lovely colors var LOG_LEVELS = [ 'error', 'warning', 'notice', 'info' ] var DEFAULT_LEVEL = LOG_LEVELS.indexOf('notice') function indent (o) { return o.split('\n').map(function (e) { return ' ' + e }).join('\n') } function isString(s) { return 'string' === s } function formatter(id, level) { var b = id.substring(0, 4) return function (ary) { var plug = ary[0].substring(0, 4).toUpperCase() var id = ary[1] var verb = ary[2] var data = ary.length > 4 ? ary.slice(3) : ary[3] var _data = (isString(data) ? data : JSON.stringify(data)) || '' var pre = [plug, id, color.cyan(verb)].join(' ') var length = (5 + pre.length + 1 + _data.length) var lines = isString(data) && data.split('\n').length > 1 var c = process.stdout.columns if((process.stdout.columns > length) && !lines) console.log([level, b, pre, _data].join(' ')) else { console.log([level, b, pre].join(' ')) if(lines) console.log(indent(data)) else if(data && data.stack) console.log(indent(data.stack)) else if(data) { console.log(indent(JSON.stringify(data, null, 2))) } } } } module.exports = function logging (server, conf) { var level = conf.logging && conf.logging.level && LOG_LEVELS.indexOf(conf.logging.level) || DEFAULT_LEVEL if (level === -1) { console.log('Warning, logging.level configured to an invalid value:', conf.logging.level) console.log('Should be one of:', LOG_LEVELS.join(', ')) level = DEFAULT_LEVEL } console.log('Log level:', LOG_LEVELS[level]) var id = server.id if (level >= LOG_LEVELS.indexOf('info')) server.on('log:info', formatter(id, color.green('info'))) if (level >= LOG_LEVELS.indexOf('notice')) server.on('log:notice', formatter(id, color.blue('note'))) if (level >= LOG_LEVELS.indexOf('warning')) server.on('log:warning', formatter(id, color.yellow('warn'))) if (level >= LOG_LEVELS.indexOf('error')) server.on('log:error', formatter(id, color.red('err!'))) } module.exports.init = module.exports }).call(this,require('_process')) },{"_process":295,"bash-color":19}],449:[function(require,module,exports){ // master plugin // allows you to define "master" IDs in the config // which are given the full rights of the local main ID module.exports = function (api, opts) { var masters = [api.id].concat(opts.master).filter(Boolean) api.auth.hook(function (fn, args) { var id = args[0] var cb = args[1] cb(null, ~masters.indexOf(id) ? {allow: null, deny: null} : null) }) } },{}],450:[function(require,module,exports){ var ssbKeys = require('ssb-keys') var explain = require('explain-error') var mdm = require('mdmanifest') var valid = require('../lib/validators') var apidoc = require('../lib/apidocs').private module.exports = { name: 'private', version: '0.0.0', manifest: mdm.manifest(apidoc), permissions: { anonymous: {}, }, init: function (sbot, opts) { return { publish: valid.async(function (data, recps, cb) { var ciphertext try { ciphertext = ssbKeys.box(data, recps) } catch (e) { return cb(explain(e, 'failed to encrypt')) } sbot.publish(ciphertext, cb) }, 'string|object', 'array'), unbox: valid.sync(function (ciphertext) { var data try { data = ssbKeys.unbox(ciphertext, sbot.keys.private) } catch (e) { throw explain(e, 'failed to decrypt') } return data }, 'string') } } } },{"../lib/apidocs":426,"../lib/validators":430,"explain-error":146,"mdmanifest":241,"ssb-keys":530}],451:[function(require,module,exports){ var pull = require('pull-stream') var para = require('pull-paramap') var Notify = require('pull-notify') var many = require('pull-many') var cat = require('pull-cat') var Abort = require('pull-abortable') var Debounce = require('observ-debounce') var Observ = require('observ') var mdm = require('mdmanifest') var apidoc = require('../lib/apidocs').replicate var DAY = 1000*60*60*24 var LIMIT = [-1, -1, 100] // default rate-limits, by hops out var notify = Notify() function last (a) { return a[a.length - 1] } // main log-replication behavior function replicate(sbot, config, rpc, cb) { // rate limiter: // calculate how many messages we're willing to receive for a user // - works by number of "hops" away from the local user, in the follow graph function calcLimit (upto) { var limit = config.replication && config.replication.limit if(!Array.isArray(limit)) limit = LIMIT var hopLimit = (upto.hops < limit.length) ? limit[upto.hops] : last(limit) if(hopLimit <=0) return hopLimit return ( !upto.ts ? hopLimit : Math.ceil((Date.now() - upto.ts)/DAY * hopLimit) ) } // TODO // is `initial` and `to_recv` the same thing? do we need both? // -prf var aborter = Abort() var sources = many() var to_send = {} // { feedId => their latest seq } map for feeds requested by the peer var to_recv = {} // { feedId => our latest seq } map for feeds we request var initial = {} // { feedId => initial seq } map for feeds request, remembers what seq each feed was initially at var replicated = {} // { feedId => final seq } map for feeds request, tracks the final seq for each received feed var debounce = Debounce(100) // track progress, and emit update events periodically debounce(function () { // HACK // This uses the information produced by normal replication // to get a rough approximation for a progress-bar. // When the peer requests feeds, they'll tell us what sequence they have for each feed. // We track that in `to_send`. // We also track the sequence we have, for the feeds we're requesting, in `to_recv`. // If it so happens they have a higher sequence for a feed than we do, then // `to_send` will be higher than `to_recv`. // This means they have to request a feed for us to track that feed's progress, which is // often the case, but not always. // Works for now. // -prf (but code by dominic, blame him) var total = 0, progress = 0, feeds = 0 for(var id in to_recv) { var feed_to_send = to_send[id] || 0 var feed_to_recv = to_recv[id] || 0 var feed_replicated = replicated[id] || 0 if(to_send[id] != null && to_recv[id] != null) { feeds++ if(feed_to_send > feed_to_recv) { total += (feed_to_send - feed_to_recv) progress += (feed_replicated - feed_to_recv) } } } // emit progress event notify({ type: 'progress', peerid: rpc.id, total: total, progress: progress, feeds: feeds, sync: !!(feeds && (progress >= total)) }) }) rpc.on('call:createHistoryStream', function (opts) { // track what sequence the peer has for each feed to_send[opts.id] = (opts.sequence || opts.seq) - 1 debounce.set() }) // compatibility function for old implementations of `latestSequence` function toSeq (s) { return 'number' === typeof s ? s : s.sequence } // collect the IDs of feeds we want to request var opts = config.replication || {} opts.hops = opts.hops || 3 opts.dunbar = opts.dunbar || 150 opts.live = true opts.meta = true var userSources = [sbot.friends.createFriendStream(opts)] if (sbot.gossip) { // if we have the gossip plugin active, then include new local peers // so that you can put a name to someone on your local network. userSources.unshift(pull.values( sbot.gossip.peers() .filter(function (e) { return e.source === 'local' }) .map(function (e) { return {id: e.key, hops: 6} }) )) } // create read-streams for the desired feeds pull( cat(userSources), aborter, // filter out duplicates, and also keep track of what we expect to receive pull.filter(function (s) { var id = 'string' === typeof s ? s : s.id if(to_recv[id] == null) { to_recv[id] = 0; return true } }), // lookup the latest sequence from each user para(function (data, cb) { if(data.sync) return cb(null, data) var id = data.id || data sbot.latestSequence(id, function (err, seq) { cb(null, { id: id, sequence: err ? 0 : toSeq(seq), ts: err ? null : seq.ts, hops: data.hops }) }) }, 32), pull.drain(function (upto) { to_recv[upto.id] = upto.sequence initial[upto.id] = replicated[upto.id] = upto.sequence var limit = config.party ? null : calcLimit(upto) sources.add( pull( // TODO // how do `limit` and `live` interact, here? // what if only the first 100 messages, of 200, were requested? // would you start getting live updates, starting at sequence 201? // -prf rpc.createHistoryStream({ id: upto.id, seq: upto.sequence + 1, limit: limit, live: true, keys: false }), pull.through(function () { if(limit === null || limit--) return //REPLICATIOAN BACK PRESSURE rpc.close(true) // TODO // do we want to close the entire RPC connection when the limit is hit? // the limit is per feed ... it should just close the feed's history stream // -prf }) ) ) debounce.set() }, function (err) { if(err) sbot.emit('log:error', ['replication', rep.id, 'error', err]) sources.cap() }) ) // create the read -> write stream pull( sources, pull.through(function (msg) { // track progress replicated[msg.author] = Math.max( replicated[msg.author]||0, msg.sequence ) debounce.set() }), sbot.createWriteStream(function (err) { aborter.abort() debounce.immediate() // done! cb(err, replicated, initial) }) ) } module.exports = { name: 'replicate', version: '1.0.0', manifest: mdm.manifest(apidoc), replicate: replicate, init: function (sbot, config) { sbot.createHistoryStream.hook(function (fn, args) { if(this._emit) this._emit('call:createHistoryStream', args[0]) return fn.apply(this, args) }) // watch for new connections and replicate on creation sbot.on('rpc:connect', function(rpc) { // this is the cli client, just ignore. if(rpc.id === sbot.id) return sbot.emit('log:info', ['replicate', rpc.id, 'start']) sbot.emit('replicate:start', rpc) replicate(sbot, config, rpc, function (err, final, initial) { if(err) { sbot.emit('replicate:fail', err) sbot.emit('log:warning', ['replicate', rpc.id, 'error', err]) } else { var progress = {} // subtract `initial` from `final` so `progress` represents a delta for (var author in final) progress[author] = final[author] - (initial[author] || 0) var progressSummary = summarizeProgress(progress) if (progressSummary) sbot.emit('log:notice', ['replicate', rpc.id, 'success', progressSummary]) sbot.emit('replicate:finish', final) } }) }) return { changes: function () { return notify.listen() } } } } function summarizeProgress (progress) { // count the number of feeds updated, and the number of new messages var updatedFeeds = 0, newMessages = 0 for (var author in progress) { if (progress[author] > 0) { updatedFeeds++ newMessages += progress[author] } } // no message if no updates if (updatedFeeds === 0) return false return 'Feeds updated: '+updatedFeeds+', New messages: '+newMessages } },{"../lib/apidocs":426,"mdmanifest":241,"observ":276,"observ-debounce":275,"pull-abortable":303,"pull-cat":305,"pull-many":353,"pull-notify":354,"pull-paramap":363,"pull-stream":431}],452:[function(require,module,exports){ var pull = require('pull-stream') var Handshake = require('pull-handshake') var State = require('./state') var challenge_length = 64 var client_auth_length = 16+32+64 var server_auth_length = 16+64 var mac_length = 16 //client is Alice //create the client stream with the public key you expect to connect to. exports.client = exports.createClientStream = function (alice, app_key, timeout) { return function (bob_pub, cb) { var state = new State(app_key, alice, bob_pub) var stream = Handshake({timeout: timeout}, cb) var shake = stream.handshake delete stream.handshake function abort(err, reason) { if(err && err !== true) shake.abort(err, cb) else shake.abort(new Error(reason), cb) } shake.write(state.createChallenge()) shake.read(challenge_length, function (err, msg) { if(err) return abort(err, 'challenge not accepted') //create the challenge first, because we need to generate a local key if(!state.verifyChallenge(msg)) return abort(null, 'wrong protocol (version?)') shake.write(state.createClientAuth()) shake.read(server_auth_length, function (err, boxed_sig) { if(err) return abort(err, 'hello not accepted') if(!state.verifyServerAccept(boxed_sig)) return abort(null, 'server not authenticated') cb(null, shake.rest(), state.cleanSecrets()) }) }) return stream } } //server is Bob. exports.server = exports.createServerStream = function (bob, authorize, app_key, timeout) { return function (cb) { var state = new State(app_key, bob) var stream = Handshake({timeout: timeout}, cb) var shake = stream.handshake delete stream.handshake function abort (err, reason) { if(err && err !== true) shake.abort(err, cb) else shake.abort(new Error(reason), cb) } shake.read(challenge_length, function (err, challenge) { if(err) return abort(err, 'expected challenge') if(!state.verifyChallenge(challenge)) return shake.abort(new Error('wrong protocol/version')) shake.write(state.createChallenge()) shake.read(client_auth_length, function (err, hello) { if(err) return abort(err, 'expected hello') if(!state.verifyClientAuth(hello)) { //we know who the client was, but chose not to answer: if(state.remote.public) return abort(null, 'unauthenticated client:' + state.remote.public.toString('hex'), cb) //client dialed wrong number... (we don't know who they where) else return abort(null, 'wrong number') } //check if the user wants to speak to alice. authorize(state.remote.public, function (err, auth) { if(auth == null && !err) err = new Error('client unauthorized') if(!auth) return abort(err, 'client authentication rejected') state.auth = auth shake.write(state.createServerAccept()) cb(null, shake.rest(), state.cleanSecrets()) }) }) }) return stream } } },{"./state":461,"pull-handshake":329,"pull-stream":455}],453:[function(require,module,exports){ (function (Buffer){ var handshake = require('./handshake') var secure = require('./secure') exports.client = exports.createClient = function (alice, app_key, timeout) { var create = handshake.client(alice, app_key, timeout) return function (bob, cb) { if(!Buffer.isBuffer(bob) || bob.length != 32) throw new Error('createClient *must* be passed a public key') return create(bob, secure(cb)) } } exports.server = exports.createServer = function (bob, authorize, app_key, timeout) { var create = handshake.server(bob, authorize, app_key, timeout) return function (cb) { return create(secure(cb)) } } }).call(this,{"isBuffer":require("../is-buffer/index.js")}) },{"../is-buffer/index.js":170,"./handshake":452,"./secure":460}],454:[function(require,module,exports){ (function (Buffer){ var sodium = require('chloride') var net = require('net') var toPull = require('stream-to-pull-stream') var shs = require('./') var isBuffer = Buffer.isBuffer var pull = require('pull-stream') var Defer = require('pull-defer/duplex') function assertOpts (opts) { if(!(opts && 'object' === typeof opts)) throw new Error('opts *must* be provided') } function assertKeys (opts) { if(!( opts.keys && isBuffer(opts.keys.publicKey) && isBuffer(opts.keys.secretKey) )) throw new Error('opts.keys = ed25519 key pair *must* be provided.') } function assertAppKey (opts) { if(!isBuffer(opts.appKey)) throw new Error('appKey must be provided') } function assertAddr (addr) { if(!isBuffer(addr.key)) throw new Error('opts.key *must* be an ed25519 public key') if(!Number.isInteger(+addr.port)) throw new Error('opts.port *must* be provided') if(!('string' === typeof addr.host || null == addr.host)) throw new Error('opts.host must be string or null') } module.exports = function createNode (opts) { var keys = isBuffer(opts.seed) ? sodium.crypto_sign_seed_keypair(opts.seed) : opts.keys assertOpts(opts); assertKeys({keys: keys}); assertAppKey(opts) var create = shs.createClient(keys, opts.appKey, opts.timeout) return { publicKey: keys.publicKey, createServer: function (onConnect) { if('function' !== typeof opts.authenticate) throw new Error('function opts.authenticate(pub, cb)' + '*must* be provided in order to receive connections') var createServerStream = shs.createServer(keys, opts.authenticate, opts.appKey, opts.timeout) var server return server = net.createServer(function (stream) { stream = toPull.duplex(stream) pull( stream, createServerStream(function (err, stream) { if(err) return server.emit('unauthenticated', err) onConnect(stream) }), stream ) }) }, connect: function (addr, cb) { assertAddr(addr) var stream = toPull.duplex(net.connect(addr.port, addr.host)) if(cb) { pull( stream, create(addr.key, cb), stream ) } else { var defer = Defer() pull( stream, create(addr.key, function (err, stream) { if(err) defer.resolve({ source: function (abort, cb) { cb(err) }, sink: function (read) { read(err, function (){}) } }) else defer.resolve(stream) }), stream ) return defer } } } } }).call(this,{"isBuffer":require("../is-buffer/index.js")}) },{"../is-buffer/index.js":170,"./":453,"chloride":80,"net":58,"pull-defer/duplex":307,"pull-stream":455,"stream-to-pull-stream":593}],455:[function(require,module,exports){ arguments[4][232][0].apply(exports,arguments) },{"./pull":456,"./sinks":457,"./sources":458,"./throughs":459,"dup":232}],456:[function(require,module,exports){ arguments[4][233][0].apply(exports,arguments) },{"dup":233}],457:[function(require,module,exports){ arguments[4][234][0].apply(exports,arguments) },{"dup":234}],458:[function(require,module,exports){ arguments[4][235][0].apply(exports,arguments) },{"dup":235}],459:[function(require,module,exports){ arguments[4][236][0].apply(exports,arguments) },{"./sinks":457,"./sources":458,"dup":236}],460:[function(require,module,exports){ (function (Buffer){ var sodium = require('chloride') var hash = sodium.crypto_hash_sha256 var pull = require('pull-stream') var boxes = require('pull-box-stream') var concat = Buffer.concat module.exports = function (cb) { return function (err, stream, state) { if(err) return cb(err) var en_key = hash(concat([state.secret, state.remote.public])) var de_key = hash(concat([state.secret, state.local.public])) var en_nonce = state.remote.app_mac.slice(0, 24) var de_nonce = state.local.app_mac.slice(0, 24) cb(null, { remote: state.remote.public, //on the server, attach any metadata gathered //during `authorize` call auth: state.auth, source: pull( stream.source, boxes.createUnboxStream(de_key, de_nonce) ), sink: pull( boxes.createBoxStream(en_key, en_nonce), stream.sink ) }) } } }).call(this,require("buffer").Buffer) },{"buffer":61,"chloride":80,"pull-box-stream":304,"pull-stream":455}],461:[function(require,module,exports){ (function (Buffer){ var sodium = require('chloride') var keypair = sodium.crypto_box_keypair var shared = sodium.crypto_scalarmult var hash = sodium.crypto_hash_sha256 var sign = sodium.crypto_sign_detached var verify = sodium.crypto_sign_verify_detached var auth = sodium.crypto_auth var verify_auth = sodium.crypto_auth_verify var curvify_pk = sodium.crypto_sign_ed25519_pk_to_curve25519 var curvify_sk = sodium.crypto_sign_ed25519_sk_to_curve25519 var box = sodium.crypto_secretbox_easy var unbox = sodium.crypto_secretbox_open_easy var concat = Buffer.concat var nonce = new Buffer(24); nonce.fill(0) var challenge_length = 64 var client_auth_length = 16+32+64 var server_auth_length = 16+64 var mac_length = 16 //this is a simple secure handshake, //the client public key is passed in plain text, module.exports = State function State (app_key, local, remote) { if(!(this instanceof State)) return new State(app_key, local, remote) this.app_key = app_key var kx = keypair() this.local = { kx_pk: kx.publicKey, kx_sk: kx.secretKey, public: local.publicKey, secret: local.secretKey } this.remote = { public: remote || null } } var proto = State.prototype proto.createChallenge = function createChallenge () { var state = this state.local.app_mac = auth(state.local.kx_pk, state.app_key) return concat([state.local.app_mac, state.local.kx_pk]) } proto.verifyChallenge = function verifyChallenge (challenge) { var state = this var mac = challenge.slice(0, 32) var remote_pk = challenge.slice(32, challenge.length) if(0 !== verify_auth(mac, remote_pk, state.app_key)) return null state.remote.kx_pk = remote_pk state.remote.app_mac = mac state.secret = shared(state.local.kx_sk, state.remote.kx_pk) state.shash = hash(state.secret) return true } proto.createClientAuth = function createClientAuth () { var state = this //now we have agreed on the secret. //this can be an encryption secret, //or a hmac secret. // shared(local.kx, remote.public) var a_bob = shared(state.local.kx_sk, curvify_pk(state.remote.public)) state.a_bob = a_bob state.secret2 = hash(concat([state.app_key, state.secret, a_bob])) var signed = concat([state.app_key, state.remote.public, state.shash]) var sig = sign(signed, state.local.secret) state.local.hello = Buffer.concat([sig, state.local.public]) return box(state.local.hello, nonce, state.secret2) } proto.verifyClientAuth = function verifyClientAuth (data) { var state = this var a_bob = shared(curvify_sk(state.local.secret), state.remote.kx_pk) state.a_bob = a_bob state.secret2 = hash(concat([state.app_key, state.secret, a_bob])) state.remote.hello = unbox(data, nonce, state.secret2) if(!state.remote.hello) return null var sig = state.remote.hello.slice(0, 64) var public = state.remote.hello.slice(64, client_auth_length) var signed = concat([state.app_key, state.local.public, state.shash]) if(!verify(sig, signed, public)) return null state.remote.public = public return true } proto.createServerAccept = function createServerAccept () { var state = this //shared key between my local ephemeral key + remote public var b_alice = shared(state.local.kx_sk, curvify_pk(state.remote.public)) state.b_alice = b_alice state.secret3 = hash(concat([state.app_key, state.secret, state.a_bob, state.b_alice])) var signed = concat([state.app_key, state.remote.hello, state.shash]) var okay = sign(signed, state.local.secret) return box(okay, nonce, state.secret3) } proto.verifyServerAccept = function verifyServerAccept (boxed_okay) { var state = this var b_alice = shared(curvify_sk(state.local.secret), state.remote.kx_pk) state.b_alice = b_alice // state.secret3 = hash(concat([state.secret2, b_alice])) state.secret3 = hash(concat([state.app_key, state.secret, state.a_bob, state.b_alice])) var sig = unbox(boxed_okay, nonce, state.secret3) if(!sig) return null var signed = concat([state.app_key, state.local.hello, state.shash]) if(!verify(sig, signed, state.remote.public)) return null return true } proto.cleanSecrets = function cleanSecrets () { var state = this // clean away all the secrets for forward security. // use a different secret hash(secret3) in the rest of the session, // and so that a sloppy application cannot compromise the handshake. delete state.local.secret state.shash.fill(0) state.secret.fill(0) state.a_bob.fill(0) state.b_alice.fill(0) state.secret = hash(state.secret3) state.secret2.fill(0) state.secret3.fill(0) state.local.kx_sk.fill(0) delete state.shash delete state.secret2 delete state.secret3 delete state.a_bob delete state.b_alice delete state.local.kx_sk return state } }).call(this,require("buffer").Buffer) },{"buffer":61,"chloride":80}],462:[function(require,module,exports){ (function (Buffer){ var EventEmitter = require('events') var u = require('./util') var Hookable = require('hoox') function isFunction (f) { return 'function' === typeof f } function merge (a, b, mapper) { for(var k in b) { if(b[k] && 'object' === typeof b[k] && !Buffer.isBuffer(b[k])) merge(a[k] = {}, b[k], mapper) else a[k] = mapper(b[k], k) } return a } module.exports = function (plugins) { function create (opts) { //change event emitter to something with more rigorous security? var api = new EventEmitter() create.plugins.forEach(function (plug) { var _api = plug.init.call({createClient: create.createClient}, api, opts) if(plug.name) { var o = {}; o[plug.name] = _api; _api = o } api = merge(api, _api, function (v, k) { if ('function' === typeof v) { v = Hookable(v) if (plug.manifest && plug.manifest[k] === 'sync') { u.hookOptionalCB(v) } } return v }) }) return api } create.plugins = [] create.manifest = {} create.permissions = {} create.use = function (plug) { if(isFunction(plug)) return create.plugins.push({init: plug}), create if(!plug.init) throw new Error('plugins *must* have "init" method') var name = plug.name if(plug.manifest) create.manifest = u.merge.manifest(create.manifest, plug.manifest, name) if(plug.permissions) create.permissions = u.merge.permissions(create.permissions, plug.permissions, name) create.plugins.push(plug) return create } ;[].concat(plugins).filter(Boolean).forEach(create.use) return create } }).call(this,{"isBuffer":require("../is-buffer/index.js")}) },{"../is-buffer/index.js":170,"./util":470,"events":144,"hoox":162}],463:[function(require,module,exports){ (function (Buffer){ var u = require('./util') var Api = require('./api') var Muxrpc = require('muxrpc') var pull = require('pull-stream') var createNode = require('secret-handshake/net') var nonPrivate = require('non-private-ip') var Inactive = require('pull-inactivity') function isFunction (f) { return 'function' === typeof f } function isString (s) { return 'string' === typeof s } function each(obj, iter) { if(Array.isArray(obj)) return obj.forEach(iter) for(var k in obj) iter(obj[k], k, obj) } function toBuffer(base64) { if(Buffer.isBuffer(base64)) return base64 var i = base64.indexOf('.') return new Buffer(~i ? base64.substring(0, i) : base64, 'base64') } function toSodiumKeys (keys) { if(!(isString(keys.public) && isString(keys.private))) return keys return { publicKey: toBuffer(keys.public), secretKey: toBuffer(keys.private) } } function coearseAddress (address) { if(isString(address)) address = u.parseAddress(address) if(isString(address.key)) return { host: address.host, port: address.port, key: new Buffer( address.key .substring(1, address.key.indexOf('.')), 'base64' ) } return address } //opts must have appKey module.exports = function (opts) { var appKey = opts.appKey var defaultTimeout = ( opts.defaultTimeout || 5e3 // 5 seconds. ) var timeout_handshake if(opts.timers && !isNaN(opts.timers.inactivity)) defaultTimeout = opts.timers.inactivity if(opts.timers && !isNaN(opts.timers.handshake)) timeout_handshake = opts.timers.handshake timeout_handshake = timeout_handshake || 5e3 opts.permissions = opts.permissions || {} var create = Api(opts.permissions ? [{ permissions: opts.permissions, init: function () {} }]: null) create.createClient = function (opts) { if(opts.keys) opts.keys = toSodiumKeys(opts.keys) if(opts.seed) opts.seed = toBuffer(opts.seed) // opts.appKey = toBuffer(opts.appKey || appKey) var snet = createNode({ keys: opts.keys && toSodiumKeys(opts.keys), seed: opts.seed && toBuffer(opts.seed), appKey: toBuffer(opts.appKey || appKey), timeout: opts.timeout || (opts.timers && opts.timers.handshake) || 5e3 }) return function (address, cb) { address = coearseAddress(address) snet.connect(address, function (err, stream) { if(err) return cb(err) var rpc = Muxrpc(opts.manifest || create.manifest, {})({}) pull(stream, rpc.createStream(), stream) cb(null, rpc) }) } } return create.use({ manifest: { auth: 'async', address: 'sync', manifest: 'sync', }, init: function (api, opts, permissions, manifest) { var snet = createNode({ keys: opts.keys && toSodiumKeys(opts.keys), seed: opts.seed, appKey: toBuffer(opts.appKey || appKey), //**************************************** timeout: timeout_handshake, authenticate: function (pub, cb) { var id = '@'+u.toId(pub) api.auth(id, function (err, auth) { if(err) cb(err) else cb(null, auth || create.permissions.anonymous) }) } }) //use configured port, or a random user port. var port = opts.port || 1024+(~~(Math.random()*(65536-1024))) var host = opts.host || nonPrivate.v4 || nonPrivate.private.v4 || '127.0.0.1' var peers = api.peers = {} var server = snet.createServer(setupRPC) server.listen(port) function setupRPC (stream, manf, isClient) { var rpc = Muxrpc(create.manifest, manf || create.manifest)(api, stream.auth) var timeout = opts.timeout == null ? defaultTimeout : opts.timeout var rpcStream = rpc.createStream() if(timeout > 0) rpcStream = Inactive(rpcStream, opts.timeout) pull(stream, rpcStream, stream) var id = rpc.id = '@'+u.toId(stream.remote) //keep track of current connections. if(!peers[id]) peers[id] = [] peers[id].push(rpc) rpc.once('closed', function () { peers[id].splice(peers[id].indexOf(rpc), 1) }) api.emit('rpc:connect', rpc, !!isClient) return rpc } return { //can be called remotely. publicKey: snet.publicKey, auth: function (pub, cb) { cb() }, address: function () { return this.getAddress() }, getAddress: function () { return [host, port, '@'+u.toId(snet.publicKey)].join(':') }, manifest: function () { return create.manifest }, getManifest: function () { return this.manifest() }, //cannot be called remote. connect: function (address, cb) { address = coearseAddress(address) address.appKey = opts.appKey || appKey snet.connect(address, function (err, stream) { return err ? cb(err) : cb(null, setupRPC(stream, null, true)) }) }, close: function (err, cb) { if(isFunction(err)) cb = err, err = null api.closed = true server.close(function (err) { api.emit('close', err) cb && cb(err) }) if(err) { each(peers, function (connections, id) { each(connections, function (rpc) { rpc.close(err) }) }) } } } } }) } }).call(this,require("buffer").Buffer) },{"./api":462,"./util":470,"buffer":61,"muxrpc":261,"non-private-ip":464,"pull-inactivity":337,"pull-stream":465,"secret-handshake/net":454}],464:[function(require,module,exports){ var os = require('os') var ip = require('ip') //pick the first reasonable looking host. //this should *just work* when running on a vps. var isPrivate = ip.isPrivate function isNonPrivate (e) { return !isPrivate(e) } var address = module.exports = function (inter, filter) { inter = inter || os.networkInterfaces() filter = filter || isNonPrivate for(var k in inter) { for(var i in inter[k]) { var e = inter[k][i] // find a reasonable looking address if(!e.internal && filter(e.address, e)) return e.address } } } function isV4 (e) { return e.family === 'IPv4' } function isV6 (e) { return e.family === 'IPv6' } var private = module.exports.private = function (inter) { return address(inter, isPrivate) } module.exports.v4 = address(null, function (addr, e) { return isV4(e) && isNonPrivate(addr) }) module.exports.v6 = address(null, function (addr, e) { return isV6(e) && isNonPrivate(addr) }) private.v4 = address(null, function (addr, e) { return isV4(e) && isPrivate(addr) }) private.v6 = address(null, function (addr, e) { return isV6(e) && isPrivate(addr) }) module.exports.all = { public: { v4: module.exports.v4, v6: module.exports.v6 }, private: { v4: private.v4, v6: private.v6 } } if(!module.parent) { console.log(module.exports.all) } },{"ip":169,"os":279}],465:[function(require,module,exports){ arguments[4][179][0].apply(exports,arguments) },{"./maybe":466,"./sinks":467,"./sources":468,"./throughs":469,"dup":179,"pull-core":306}],466:[function(require,module,exports){ arguments[4][180][0].apply(exports,arguments) },{"dup":180,"pull-core":306}],467:[function(require,module,exports){ arguments[4][181][0].apply(exports,arguments) },{"dup":181}],468:[function(require,module,exports){ arguments[4][384][0].apply(exports,arguments) },{"dup":384}],469:[function(require,module,exports){ (function (process){ var u = require('pull-core') var sources = require('./sources') var sinks = require('./sinks') var prop = u.prop var id = u.id var tester = u.tester var map = exports.map = function (read, map) { map = prop(map) || id return function (abort, cb) { read(abort, function (end, data) { try { data = !end ? map(data) : null } catch (err) { return read(err, function () { return cb(err) }) } cb(end, data) }) } } var asyncMap = exports.asyncMap = function (read, map) { if(!map) return read return function (end, cb) { if(end) return read(end, cb) //abort read(null, function (end, data) { if(end) return cb(end, data) map(data, cb) }) } } var paraMap = exports.paraMap = function (read, map, width) { if(!map) return read var ended = false, queue = [], _cb function drain () { if(!_cb) return var cb = _cb _cb = null if(queue.length) return cb(null, queue.shift()) else if(ended && !n) return cb(ended) _cb = cb } function pull () { read(null, function (end, data) { if(end) { ended = end return drain() } n++ map(data, function (err, data) { n-- queue.push(data) drain() }) if(n < width && !ended) pull() }) } var n = 0 return function (end, cb) { if(end) return read(end, cb) //abort //continue to read while there are less than 3 maps in flight _cb = cb if(queue.length || ended) pull(), drain() else pull() } return highWaterMark(asyncMap(read, map), width) } var filter = exports.filter = function (read, test) { //regexp test = tester(test) return function next (end, cb) { var sync, loop = true while(loop) { loop = false sync = true read(end, function (end, data) { if(!end && !test(data)) return sync ? loop = true : next(end, cb) cb(end, data) }) sync = false } } } var filterNot = exports.filterNot = function (read, test) { test = tester(test) return filter(read, function (e) { return !test(e) }) } var through = exports.through = function (read, op, onEnd) { var a = false function once (abort) { if(a || !onEnd) return a = true onEnd(abort === true ? null : abort) } return function (end, cb) { if(end) once(end) return read(end, function (end, data) { if(!end) op && op(data) else once(end) cb(end, data) }) } } var take = exports.take = function (read, test) { var ended = false if('number' === typeof test) { var n = test; test = function () { return n -- } } return function (end, cb) { if(ended) return cb(ended) if(ended = end) return read(ended, cb) read(null, function (end, data) { if(ended = ended || end) return cb(ended) if(!test(data)) { ended = true read(true, function (end, data) { cb(ended, data) }) } else cb(null, data) }) } } var unique = exports.unique = function (read, field, invert) { field = prop(field) || id var seen = {} return filter(read, function (data) { var key = field(data) if(seen[key]) return !!invert //false, by default else seen[key] = true return !invert //true by default }) } var nonUnique = exports.nonUnique = function (read, field) { return unique(read, field, true) } var group = exports.group = function (read, size) { var ended; size = size || 5 var queue = [] return function (end, cb) { //this means that the upstream is sending an error. if(end) return read(ended = end, cb) //this means that we read an end before. if(ended) return cb(ended) read(null, function next(end, data) { if(ended = ended || end) { if(!queue.length) return cb(ended) var _queue = queue; queue = [] return cb(null, _queue) } queue.push(data) if(queue.length < size) return read(null, next) var _queue = queue; queue = [] cb(null, _queue) }) } } var flatten = exports.flatten = function (read) { var _read return function (abort, cb) { if(_read) nextChunk() else nextStream() function nextChunk () { _read(null, function (end, data) { if(end) nextStream() else cb(null, data) }) } function nextStream () { read(null, function (end, stream) { if(end) return cb(end) if(Array.isArray(stream) || stream && 'object' === typeof stream) stream = sources.values(stream) else if('function' != typeof stream) throw new Error('expected stream of streams') _read = stream nextChunk() }) } } } var prepend = exports.prepend = function (read, head) { return function (abort, cb) { if(head !== null) { if(abort) return read(abort, cb) var _head = head head = null cb(null, _head) } else { read(abort, cb) } } } //var drainIf = exports.drainIf = function (op, done) { // sinks.drain( //} var _reduce = exports._reduce = function (read, reduce, initial) { return function (close, cb) { if(close) return read(close, cb) if(ended) return cb(ended) sinks.drain(function (item) { initial = reduce(initial, item) }, function (err, data) { ended = err || true if(!err) cb(null, initial) else cb(ended) }) (read) } } var nextTick = process.nextTick var highWaterMark = exports.highWaterMark = function (read, highWaterMark) { var buffer = [], waiting = [], ended, ending, reading = false highWaterMark = highWaterMark || 10 function readAhead () { while(waiting.length && (buffer.length || ended)) waiting.shift()(ended, ended ? null : buffer.shift()) if (!buffer.length && ending) ended = ending; } function next () { if(ended || ending || reading || buffer.length >= highWaterMark) return reading = true return read(ended || ending, function (end, data) { reading = false ending = ending || end if(data != null) buffer.push(data) next(); readAhead() }) } process.nextTick(next) return function (end, cb) { ended = ended || end waiting.push(cb) next(); readAhead() } } var flatMap = exports.flatMap = function (read, mapper) { mapper = mapper || id var queue = [], ended return function (abort, cb) { if(queue.length) return cb(null, queue.shift()) else if(ended) return cb(ended) read(abort, function next (end, data) { if(end) ended = end else { var add = mapper(data) while(add && add.length) queue.push(add.shift()) } if(queue.length) cb(null, queue.shift()) else if(ended) cb(ended) else read(null, next) }) } } }).call(this,require('_process')) },{"./sinks":467,"./sources":468,"_process":295,"pull-core":306}],470:[function(require,module,exports){ (function (Buffer){ var isArray = Array.isArray var merge = require('map-merge') function isObject (o) { return o && 'object' === typeof o } function isString (s) { return 'string' === typeof s } var clone = exports.clone = function clone (obj, mapper) { function map(v, k) { return isObject(v) ? clone(v, mapper) : mapper(v, k) } if(isArray(obj)) return obj.map(map) else if(isObject(obj)) { var o = {} for(var k in obj) o[k] = map(obj[k], k) return o } else return map(obj) } exports.parseAddress = function (e) { if(isString(e)) { var parts = e.split(':') var e = { host: parts[0], port: +parts[1], key: fromId(parts[2]) } return e } return e } var fromId = exports.fromId = function (id) { return new Buffer(id.substring(0, id.indexOf('.')), 'base64') } exports.toId = function (pub) { return Buffer.isBuffer(pub) ? pub.toString('base64')+'.ed25519' : pub } exports.merge = { permissions: function (perms, _perms, name) { return merge(perms, clone(_perms, function (v) { return name ? name + '.' + v : v }) ) }, manifest: function (manf, _manf, name) { if(name) { var o = {}; o[name] = _manf; _manf = o } return merge(manf, _manf) } } exports.hookOptionalCB = function (syncFn) { // syncFn is a function that's expected to return its result or throw an error // we're going to hook it so you can optionally pass a callback syncFn.hook(function(fn, args) { // if a function is given as the last argument, treat it as a callback var cb = args[args.length - 1] if (typeof cb == 'function') { var res args.pop() // remove cb from the arguments try { res = fn.apply(this, args) } catch (e) { return cb(e) } cb(null, res) } else { // no cb provided, regular usage return fn.apply(this, args) } }) } }).call(this,require("buffer").Buffer) },{"buffer":61,"map-merge":239}],471:[function(require,module,exports){ module.exports = { decode: function (string) { return JSON.parse(string) }, encode: function (obj) { return JSON.stringify(obj, null, 2) }, buffer: false } },{}],472:[function(require,module,exports){ var level = require('level') var sublevel = require('level-sublevel/bytewise') var opts = require('./defaults') var SSB = require('./') module.exports = function (path, opts, keys) { opts = opts || require('./defaults') return SSB( sublevel(level(path, { valueEncoding: opts.codec })), opts, keys) } },{"./":474,"./defaults":473,"level":199,"level-sublevel/bytewise":478}],473:[function(require,module,exports){ module.exports = require('ssb-keys') module.exports.codec = require('./codec') module.exports.keys = module.exports },{"./codec":471,"ssb-keys":530}],474:[function(require,module,exports){ 'use strict'; var contpara = require('cont').para var pull = require('pull-stream') var pl = require('pull-level') var paramap = require('pull-paramap') var timestamp = require('monotonic-timestamp') var assert = require('assert') var ltgt = require('ltgt') var mlib = require('ssb-msgs') var explain = require('explain-error') var pdotjson = require('./package.json') var createFeed = require('ssb-feed') var cat = require('pull-cat') var ssbref = require('ssb-ref') var ssbKeys = require('ssb-keys') var Validator = require('ssb-feed/validator') var isFeedId = ssbref.isFeedId var isMsgId = ssbref.isMsgId var isBlobId = ssbref.isBlobId //var u = require('./util') //53 bit integer var MAX_INT = 0x1fffffffffffff function isNumber (n) { return typeof n === 'number' } function isString (s) { return 'string' === typeof s } function isObject (o) { return o && 'object' === typeof o && !Array.isArray(o) } function all (stream) { return function (cb) { pull(stream, pull.collect(cb)) } } function compare(a, b) { return a < b ? -1 : a > b ? 1 : 0 } function getVMajor () { var version = require('./package.json').version return (version.split('.')[0])|0 } module.exports = function (db, opts, keys) { var sysDB = db.sublevel('sys') var logDB = db.sublevel('log') var feedDB = db.sublevel('fd') var clockDB = db.sublevel('clk') var lastDB = db.sublevel('lst') var indexDB = db.sublevel('idx') var appsDB = db.sublevel('app') function get (db, key) { return function (cb) { db.get(key, cb) } } db.opts = opts db.add = Validator(db) db.pre(function (op, add, _batch) { var msg = op.value var id = op.key // index by sequence number add({ key: [msg.author, msg.sequence], value: id, type: 'put', prefix: clockDB }) // index my timestamp, used to generate feed. add({ key: [msg.timestamp, msg.author], value: id, type: 'put', prefix: feedDB }) var localtime = op.timestamp = timestamp() // index the latest message from each author add({ key: msg.author, value: {sequence: msg.sequence, ts: localtime }, type: 'put', prefix: lastDB }) // index messages in the order _received_ // this will be used to pass to plugins which // must create their indexes asyncly. add({ key: localtime, value: id, type: 'put', prefix: logDB }) indexMsg(add, localtime, id, msg) }) function indexMsg (add, localtime, id, msg) { //DECRYPT the message, if possible //to enable indexing. If external apis //are not provided that may access indexes //then this will not leak information. //otherwise, we may need to figure something out. var content = (keys && isString(msg.content)) ? ssbKeys.unbox(msg.content, keys) : msg.content if(!content) return if(isString(content.type)) add({ key: ['type', content.type.toString().substring(0, 32), localtime], value: id, type: 'put', prefix: indexDB }) mlib.indexLinks(content, function (obj, rel) { add({ key: ['link', msg.author, rel, obj.link, msg.sequence, id], value: obj, type: 'put', prefix: indexDB }) add({ key: ['_link', obj.link, rel, msg.author, msg.sequence, id], value: obj, type: 'put', prefix: indexDB }) }) } db.createFeed = function (keys) { return createFeed(db, keys, opts) } db.needsRebuild = function (cb) { sysDB.get('vmajor', function (err, dbvmajor) { dbvmajor = (dbvmajor|0) || 0 cb(null, dbvmajor < getVMajor()) }) } db.rebuildIndex = function (cb) { // remove all entries from the index pull( pl.read(indexDB, { keys: true, values: false }), paramap(function (key, cb) { indexDB.del(key, cb) }), pull.drain(null, next) ) function next (err) { if (err) return cb(err) // replay the log pull( db.createLogStream({ keys: true, values: true }), pull.map(function (msg) { var ops = [] function add (item) { ops.push(item) } indexMsg(add, msg.timestamp, msg.key, msg.value) return ops }), pull.flatten(), pl.write(indexDB, next2) ) function next2 (err) { if (err) return cb(err) sysDB.put('vmajor', getVMajor(), cb) } } } // opts standardized to work like levelup api function stdopts (opts) { opts = opts || {} if (opts.keys !== false) opts.keys = true if (opts.values !== false) opts.values = true return opts } function msgFmt (keys, values, obj) { if (keys && values) return obj if (keys) return obj.key if (values) return obj.value return null // i guess? } //TODO: eventually, this should filter out authors you do not follow. db.createFeedStream = function (opts) { opts = stdopts(opts) ltgt.toLtgt(opts, opts, function (value) { return [value, LO] }, LO, HI) var _keys = opts.keys var _values = opts.values opts.keys = false opts.values = true return pull( pl.read(feedDB, opts), lookup(_keys, _values) ) } //latest was stored as author: seq //but for the purposes of replication back pressure //we need to know when we last replicated with someone. //instead store as: {sequence: seq, ts: localtime} //then, peers can request a max number of posts per feed. function toSeq (latest) { return isNumber(latest) ? latest : latest.sequence } db.latest = function (opts) { return pull( pl.read(lastDB, opts), pull.map(function (data) { var d = {id: data.key, sequence: toSeq(data.value), ts: data.value.ts } return d }) ) } function lookup(keys, values) { return paramap(function (key, cb) { if(key.sync) return cb(null, key) if(!values) return cb(null, key) db.get(key, function (err, msg) { if (err) cb(err) else cb(null, msgFmt(keys, values, { key: key, value: msg })) }) }) } db.createHistoryStream = function (id, seq, live) { var _keys = true, _values = true, limit if(!isFeedId(id)) { var opts = stdopts(id) id = opts.id seq = opts.sequence || opts.seq || 0 live = !!opts.live limit = opts.limit _keys = opts.keys !== false _values = opts.values !== false } return pull( pl.read(clockDB, { gte: [id, seq], lte: [id, MAX_INT], live: live, keys: false, sync: opts && opts.sync, limit: limit, onAbort: opts && opts.onAbort }), lookup(_keys, _values) ) } db.createUserStream = function (opts) { opts = stdopts(opts) ltgt.toLtgt(opts, opts, function (value) { return [opts.id, value] }, LO, HI) var _keys = opts.keys var _values = opts.values opts.keys = false opts.values = true return pull( pl.read(clockDB, opts), lookup(_keys, _values) ) } //writeStream - used in replication. db.createWriteStream = function (cb) { return pull( paramap(function (data, cb) { db.add(data, function (err, msg) { db.emit('invalid', err, msg) cb() }) }), pull.drain(null, cb) ) } db.createFeed = function (keys) { if(!keys) keys = opts.keys.generate() return createFeed(db, keys, opts) } db.latestSequence = function (id, cb) { lastDB.get(id, cb) } db.getLatest = function (id, cb) { lastDB.get(id, function (err, v) { if(err) return cb(err) clockDB.get([id, toSeq(v)], function (err, hash) { if(err) return cb(err) db.get(hash, function (err, msg) { cb(err, {key: hash, value: msg}) }) }) }) } db.createLogStream = function (opts) { opts = stdopts(opts) var live = opts.live || opts.tail; delete opts.live var keys = opts.keys; delete opts.keys var values = opts.values; delete opts.values var old = pull( pl.read(logDB, opts), paramap(function (data, cb) { if(data.sync) return cb(null, data) var key = data.value var seq = data.key db.get(key, function (err, value) { if (err) cb(err) else cb(null, msgFmt(keys, values, {key: key, value: value, timestamp: seq})) }) }) ) if(!live) return old return cat([old, pull.values([{sync: true}]), pl.live(db)]) } var HI = undefined, LO = null db.messagesByType = function (opts) { if(!opts) throw new Error('must provide {type: string} to messagesByType') if(isString(opts)) opts = {type: opts} opts = stdopts(opts) var _keys = opts.keys var _values = opts.values opts.values = true ltgt.toLtgt(opts, opts, function (value) { return ['type', opts.type, value] }, LO, HI) return pull( pl.read(indexDB, opts), paramap(function (data, cb) { var id = _keys ? data.value : data db.get(id, function (err, msg) { var ts = opts.keys ? data.key[2] : undefined cb(null, msgFmt(_keys, _values, {key: id, ts: ts, value: msg})) }) }), pull.filter() ) } function format(opts, op, key, value) { var meta = opts.meta !== false //default: true var keys = opts.keys !== false //default: true var vals = opts.values === true //default: false if(!meta&&!keys&&!vals) throw new Error('a stream without any values does not make sense') if(!meta) return ( keys && vals ? {key: op.key, value: value} : keys ? op.key : value ) else { if(vals) op.value = value if(!keys) delete op.key return op } } function type(t) { return {feed: '@', msg: '%', blob: '&'}[t] || t } db.links = function (opts) { if(!opts) throw new Error('opts *must* be provided') opts.meta = opts.meta !== false //default: true opts.keys = opts.keys !== false //default: true if(!opts.values&&!opts.meta&&!opts.keys) throw new Error('makes no sense to return stream without results' + 'set at least one of {keys, values, meta} to true') function tolink (v) { return (ssbref.isLink(v)) ? v : null } var src = type(opts.source), dst = type(opts.dest), rel = opts.rel var back = dst && !src var from = back ? dst : src, to = back ? src : dst function range(value, end, def) { return !value ? def : /^[@%&]$/.test(value) ? value + end : value } function lo(value) { return range(value, "!", LO) } function hi(value) { return range(value, "~", HI) } var index = back ? '_link' : 'link' var gte = [index, lo(from), rel || LO, lo(to), LO, LO] var lte = [index, hi(from), rel || HI, hi(to), HI, HI] function testLink (a, e) { //actual, expected return e ? e.length === 1 ? a[0]==e[0] : a===e : true } return pull( pl.read(indexDB, { gte: gte, lte: lte, live: opts.live, reverse: opts.reverse }), pull.map(function (op) { return { source: op.key[back?3:1], rel: op.key[2], dest: op.key[back?1:3], key: op.key[5] } }), // in case source and dest are known but not rel, // this will scan all links from the source // and filter out those to the dest. not efficient // but probably a rare query. pull.filter(function (data) { if(rel && rel !== data.rel) return false if(!testLink(data.dest, dst)) return false if(!testLink(data.source, src)) return false return true }), ! opts.values ? pull.map(function (op) { return format(opts, op, op.key, null) }) : paramap(function (op, cb) { db.get(op.key, function (err, msg) { if(err) return cb(err) cb(null, format(opts, op, op.key, msg)) }) }) ) } //get all messages that link to a given message. db.relatedMessages = function (opts, cb) { if(isString(opts)) opts = {key: opts} if(!opts) throw new Error('opts *must* be object') var key = opts.id || opts.key var n = 1 var msgs = {key: key, value: null} db.get(key, function (err, msg) { msgs.value = msg if (err && err.notFound) err = null // ignore not found done(err) }) related(msgs) function related (msg) { if (n<0) return n++ all(db.links({dest: msg.key, rel: opts.rel, keys: true, values:true, meta: false, type:'msg'})) (function (err, ary) { if(ary && ary.length) { ary.sort(function (a, b) { return compare(a.value.timestamp, b.value.timestamp) || compare(a.key, b.key) }) msg.related = ary ary.forEach(related) } done(err) }) } function count (msg) { if(!msg.related) return msg var c = 0 msg.related.forEach(function (_msg) { if(opts.parent) _msg.parent = msg.key c += 1 + (count(_msg).count || 0) }) if(opts.count) msg.count = c return msg } function done (err) { if(err && n > 0) { n = -1 return cb(err) } if(--n) return cb(null, count(msgs)) } } return db } },{"./package.json":505,"assert":15,"cont":86,"explain-error":146,"ltgt":226,"monotonic-timestamp":249,"pull-cat":305,"pull-level":487,"pull-paramap":363,"pull-stream":499,"ssb-feed":519,"ssb-feed/validator":521,"ssb-keys":530,"ssb-msgs":543,"ssb-ref":573}],475:[function(require,module,exports){ // require typewise first to extend with core typewise functionality require('typewise') // TODO: bytewise-binary encoding -- no hex parsing or toString hackery module.exports = require('bytewise-core') },{"bytewise-core":67,"typewise":627}],476:[function(require,module,exports){ // TODO: standard bytewise encoding constructor // TODO: enhance binary encoding with optional hex helpers module.exports = require('./binary') },{"./binary":475}],477:[function(require,module,exports){ // TODO: initialize and export a standard bytewise encoding, add hex and binary module.exports = require('./encoding/') },{"./encoding/":476}],478:[function(require,module,exports){ var nut = require('./nut') var shell = require('./shell') //the shell surrounds the nut var codec = require('levelup/lib/codec') var merge = require('xtend') var compare = require('typewiselite') var ReadStream = require('levelup/lib/read-stream') var precodec = require('./codec/bytewise') function id (e) { return e } module.exports = function (db, opts) { opts = merge(db.options, { keyEncoding: { encode: id, decode: id, buffer: true } }, opts) return shell ( nut ( db, precodec, codec, compare ), [], ReadStream, opts ) } },{"./codec/bytewise":479,"./nut":482,"./shell":485,"levelup/lib/codec":209,"levelup/lib/read-stream":212,"typewiselite":628,"xtend":504}],479:[function(require,module,exports){ var bytewise = require('bytewise') module.exports = { encode: bytewise.encode, decode: bytewise.decode, lowerBound: null, upperBound: undefined, buffer: true } },{"bytewise":477}],480:[function(require,module,exports){ var inRange = require('./range') module.exports = function (compare) { var hooks = [] return { add: function (range, hook) { var m = {range: range, hook: hook} hooks.push(m) //call this to remove return function () { var i = hooks.indexOf(m) if(~i) return hooks.splice(i, 1) } }, //remove all listeners within a range. //this will be used to close a sublevel. removeAll: function (range) { throw new Error('not implemented') }, trigger: function (key, args) { for(var i = 0; i < hooks.length; i++) { var test = hooks[i] if(inRange(test.range, key, compare)) test.hook.apply(this, args) } } } } },{"./range":484}],481:[function(require,module,exports){ (function (Buffer){ exports.compare = function (a, b) { if(Buffer.isBuffer(a)) { var l = Math.min(a.length, b.length) for(var i = 0; i < l; i++) { var cmp = a[i] - b[i] if(cmp) return cmp } return a.length - b.length } return a < b ? -1 : a > b ? 1 : 0 } function has(obj, key) { return Object.hasOwnProperty.call(obj, key) } // to be compatible with the current abstract-leveldown tests // nullish or empty strings. // I could use !!val but I want to permit numbers and booleans, // if possible. function isDef (val) { return val !== undefined && val !== '' } function has (range, name) { return Object.hasOwnProperty.call(range, name) } function hasKey(range, name) { return Object.hasOwnProperty.call(range, name) && name } var lowerBoundKey = exports.lowerBoundKey = function (range) { return ( hasKey(range, 'gt') || hasKey(range, 'gte') || hasKey(range, 'min') || (range.reverse ? hasKey(range, 'end') : hasKey(range, 'start')) || undefined ) } var lowerBound = exports.lowerBound = function (range) { var k = lowerBoundKey(range) return k && range[k] } exports.lowerBoundInclusive = function (range) { return has(range, 'gt') ? false : true } exports.upperBoundInclusive = function (range) { return has(range, 'lt') || !range.minEx ? false : true } var lowerBoundExclusive = exports.lowerBoundExclusive = function (range) { return has(range, 'gt') || range.minEx ? true : false } var upperBoundExclusive = exports.upperBoundExclusive = function (range) { return has(range, 'lt') ? true : false } var upperBoundKey = exports.upperBoundKey = function (range) { return ( hasKey(range, 'lt') || hasKey(range, 'lte') || hasKey(range, 'max') || (range.reverse ? hasKey(range, 'start') : hasKey(range, 'end')) || undefined ) } var upperBound = exports.upperBound = function (range) { var k = upperBoundKey(range) return k && range[k] } function id (e) { return e } exports.toLtgt = function (range, _range, map, lower, upper) { _range = _range || {} map = map || id var defaults = arguments.length > 3 var lb = exports.lowerBoundKey(range) var ub = exports.upperBoundKey(range) if(lb) { if(lb === 'gt') _range.gt = map(range.gt, false) else _range.gte = map(range[lb], false) } else if(defaults) _range.gte = map(lower, false) if(ub) { if(ub === 'lt') _range.lt = map(range.lt, true) else _range.lte = map(range[ub], true) } else if(defaults) _range.lte = map(upper, true) if(range.reverse != null) _range.reverse = !!range.reverse //if range was used mutably //(in level-sublevel it's part of an options object //that has more properties on it.) if(has(_range, 'max')) delete _range.max if(has(_range, 'min')) delete _range.min if(has(_range, 'start')) delete _range.start if(has(_range, 'end')) delete _range.end return _range } exports.contains = function (range, key, compare) { compare = compare || exports.compare var lb = lowerBound(range) if(isDef(lb)) { var cmp = compare(key, lb) if(cmp < 0 || (cmp === 0 && lowerBoundExclusive(range))) return false } var ub = upperBound(range) if(isDef(ub)) { var cmp = compare(key, ub) if(cmp > 0 || (cmp === 0) && upperBoundExclusive(range)) return false } return true } exports.filter = function (range, compare) { return function (key) { return exports.contains(range, key, compare) } } }).call(this,{"isBuffer":require("../../../../../is-buffer/index.js")}) },{"../../../../../is-buffer/index.js":170}],482:[function(require,module,exports){ var hooks = require('./hooks') var ltgt = require('ltgt') function isFunction (f) { return 'function' === typeof f } function getPrefix (db) { if(db == null) return db if(isFunction(db.prefix)) return db.prefix() return db } function has(obj, name) { return Object.hasOwnProperty.call(obj, name) } function clone (_obj) { var obj = {} for(var k in _obj) obj[k] = _obj[k] return obj } module.exports = function (db, precodec, codec, compare) { var prehooks = hooks(compare) var posthooks = hooks(compare) var waiting = [], ready = false function encodePrefix(prefix, key, opts1, opts2) { return precodec.encode([ prefix, codec.encodeKey(key, opts1, opts2 ) ]) } function decodePrefix(data) { return precodec.decode(data) } function addEncodings(op, prefix) { if(prefix && prefix.options) { op.keyEncoding = op.keyEncoding || prefix.options.keyEncoding op.valueEncoding = op.valueEncoding || prefix.options.valueEncoding } return op } function start () { ready = true while(waiting.length) waiting.shift()() } if(isFunction(db.isOpen)) { if(db.isOpen()) ready = true else db.open(start) } else { db.open(start) } return { apply: function (ops, opts, cb) { //apply prehooks here. for(var i = 0; i < ops.length; i++) { var op = ops[i] function add(op) { if(op === false) return delete ops[i] ops.push(op) } addEncodings(op, op.prefix) op.prefix = getPrefix(op.prefix) prehooks.trigger([op.prefix, op.key], [op, add, ops]) } opts = opts || {} if('object' !== typeof opts) throw new Error('opts must be object, was:'+ opts) if('function' === typeof opts) cb = opts, opts = {} if(ops.length) (db.db || db).batch( ops.map(function (op) { return { key: encodePrefix(op.prefix, op.key, opts, op), value: op.type !== 'del' ? codec.encodeValue( op.value, opts, op ) : undefined, type: op.type || (op.value === undefined ? 'del' : 'put') } }), opts, function (err) { if(err) return cb(err) ops.forEach(function (op) { posthooks.trigger([op.prefix, op.key], [op]) }) cb() } ) else cb() }, get: function (key, prefix, opts, cb) { opts.asBuffer = codec.isValueAsBuffer(opts) return (db.db || db).get( encodePrefix(prefix, key, opts), opts, function (err, value) { if(err) cb(err) else cb(null, codec.decodeValue(value, opts)) } ) }, pre: prehooks.add, post: posthooks.add, createDecoder: function (opts) { if(opts.keys !== false && opts.values !== false) return function (key, value) { return { key: codec.decodeKey(precodec.decode(key)[1], opts), value: codec.decodeValue(value, opts) } } if(opts.values !== false) return function (_, value) { return codec.decodeValue(value, opts) } if(opts.keys !== false) return function (key) { return codec.decodeKey(precodec.decode(key)[1], opts) } return function () {} }, isOpen: function isOpen() { if (db.db && isFunction(db.db.isOpen)) return db.db.isOpen() return db.isOpen() }, isClosed: function isClosed() { if (db.db && isFunction(db.db.isClosed)) return db.db.isClosed() return db.isClosed() }, close: function close (cb) { return db.close(cb) }, iterator: function (_opts, cb) { var opts = clone(_opts || {}) var prefix = _opts.prefix || [] function encodeKey(key) { return encodePrefix(prefix, key, opts, {}) } ltgt.toLtgt(_opts, opts, encodeKey, precodec.lowerBound, precodec.upperBound) // if these legacy values are in the options, remove them opts.prefix = null //************************************************ //hard coded defaults, for now... //TODO: pull defaults and encoding out of levelup. opts.keyAsBuffer = opts.valueAsBuffer = false //************************************************ //this is vital, otherwise limit: undefined will //create an empty stream. if ('number' !== typeof opts.limit) opts.limit = -1 opts.keyAsBuffer = precodec.buffer opts.valueAsBuffer = codec.isValueAsBuffer(opts) function wrapIterator (iterator) { return { next: function (cb) { return iterator.next(cb) }, end: function (cb) { iterator.end(cb) } } } if(ready) return wrapIterator((db.db || db).iterator(opts)) else waiting.push(function () { cb(null, wrapIterator((db.db || db).iterator(opts))) }) } } } },{"./hooks":480,"ltgt":481}],483:[function(require,module,exports){ module.exports={ "_args": [ [ "level-sublevel@^6.5.2", "/Users/joran/Documents/development/patchdeck/node_modules/secure-scuttlebutt" ] ], "_from": "level-sublevel@>=6.5.2 <7.0.0", "_id": "level-sublevel@6.5.4", "_inCache": true, "_installable": true, "_location": "/secure-scuttlebutt/level-sublevel", "_nodeVersion": "5.3.0", "_npmUser": { "email": "dominic.tarr@gmail.com", "name": "dominictarr" }, "_npmVersion": "3.3.12", "_phantomChildren": { "pull-core": "1.0.0" }, "_requested": { "name": "level-sublevel", "raw": "level-sublevel@^6.5.2", "rawSpec": "^6.5.2", "scope": null, "spec": ">=6.5.2 <7.0.0", "type": "range" }, "_requiredBy": [ "/secure-scuttlebutt" ], "_resolved": "https://registry.npmjs.org/level-sublevel/-/level-sublevel-6.5.4.tgz", "_shasum": "92e6534e7ac3fa35c8bdb121b8a8094a8d1c0826", "_shrinkwrap": null, "_spec": "level-sublevel@^6.5.2", "_where": "/Users/joran/Documents/development/patchdeck/node_modules/secure-scuttlebutt", "author": { "email": "dominic.tarr@gmail.com", "name": "Dominic Tarr", "url": "http://dominictarr.com" }, "bugs": { "url": "https://github.com/dominictarr/level-sublevel/issues" }, "dependencies": { "bytewise": "~1.1.0", "levelup": "~0.19.0", "ltgt": "~2.1.1", "pull-stream": "~2.21.0", "typewiselite": "~1.0.0", "xtend": "~4.0.0" }, "description": "partition levelup databases", "devDependencies": { "level": "^1.4.0", "level-test": "^2.0.1", "monotonic-timestamp": "0.0.8", "pull-level": "~1.1.1", "rimraf": "~2.1.4", "shasum": "0.0.2", "stream-to-pull-stream": "~1.2.0", "tape": "~2.14.0", "through": "~2.3.4" }, "directories": {}, "dist": { "shasum": "92e6534e7ac3fa35c8bdb121b8a8094a8d1c0826", "tarball": "http://registry.npmjs.org/level-sublevel/-/level-sublevel-6.5.4.tgz" }, "gitHead": "fa1b7121f9632b637e650cc1ec9b1723b60df864", "homepage": "https://github.com/dominictarr/level-sublevel", "license": "MIT", "maintainers": [ { "name": "dominictarr", "email": "dominic.tarr@gmail.com" } ], "name": "level-sublevel", "optionalDependencies": {}, "readme": "ERROR: No README data found!", "repository": { "type": "git", "url": "git://github.com/dominictarr/level-sublevel.git" }, "scripts": { "test": "set -e; for t in test/*.js; do node $t; done" }, "stability": "unstable", "testling": { "browsers": [ "android-browser/4.2..latest", "chrome/22..latest", "chrome/canary", "firefox/17..latest", "firefox/nightly", "ie/8..latest", "ipad/6.0..latest", "iphone/6.0..latest", "opera/12..latest", "opera/next", "safari/5.1..latest" ], "files": "test/*.js" }, "version": "6.5.4" } },{}],484:[function(require,module,exports){ (function (Buffer){ var ltgt = require('ltgt') //compare two array items function isArrayLike (a) { return Array.isArray(a) || Buffer.isBuffer(a) } function isPrimitive (a) { return 'string' === typeof a || 'number' === typeof a } function has(o, k) { return Object.hasOwnProperty.call(o, k) } function compare (a, b) { if(isArrayLike(a) && isArrayLike(b)) { var l = Math.min(a.length, b.length) for(var i = 0; i < l; i++) { var c = compare(a[i], b[i]) if(c) return c } return a.length - b.length } if(isPrimitive(a) && isPrimitive(b)) return a < b ? -1 : a > b ? 1 : 0 throw new Error('items not comparable:' + JSON.stringify(a) + ' ' + JSON.stringify(b)) } //this assumes that the prefix is of the form: // [Array, string] function prefix (a, b) { if(a.length > b.length) return false var l = a.length - 1 var lastA = a[l] var lastB = b[l] if(typeof lastA !== typeof lastB) return false if('string' == typeof lastA && 0 != lastB.indexOf(lastA)) return false //handle cas where there is no key prefix //(a hook on an entire sublevel) if(a.length == 1 && isArrayLike(lastA)) l ++ while(l--) { if(compare(a[l], b[l])) return false } return true } exports = module.exports = function (range, key, _compare) { _compare = _compare || compare //handle prefix specially, //check that everything up to the last item is equal //then check the last item starts with if(isArrayLike(range)) return prefix(range, key) return ltgt.contains(range, key, _compare) } function addPrefix(prefix, range) { var o = ltgt.toLtgt(range, null, function (key) { return [prefix, key] }) //if there where no ranges, then then just use a prefix. if(!has(o, 'gte') && !has(o, 'lte')) return [prefix] return o } exports.compare = compare exports.prefix = prefix exports.addPrefix = addPrefix }).call(this,{"isBuffer":require("../../../is-buffer/index.js")}) },{"../../../is-buffer/index.js":170,"ltgt":481}],485:[function(require,module,exports){ (function (process){ var EventEmitter = require('events').EventEmitter var addpre = require('./range').addPrefix var errors = require('levelup/lib/errors') function isFunction (f) { return 'function' === typeof f } function isString (s) { return 'string' === typeof s } function isObject (o) { return o && 'object' === typeof o } var version = require('./package.json').version var sublevel = module.exports = function (nut, prefix, createStream, options) { var emitter = new EventEmitter() emitter.sublevels = {} emitter.options = options emitter.version = version emitter.methods = {} prefix = prefix || [] function errback (err) { if (err) emitter.emit('error', err) } createStream = createStream || function (e) { return e } function mergeOpts(opts) { var o = {} if(options) for(var k in options) if(options[k] != undefined)o[k] = options[k] if(opts) for(var k in opts) if(opts[k] != undefined) o[k] = opts[k] return o } emitter.put = function (key, value, opts, cb) { if('function' === typeof opts) cb = opts, opts = {} if(!cb) cb = errback nut.apply([{ key: key, value: value, prefix: prefix.slice(), type: 'put' }], mergeOpts(opts), function (err) { if(!err) { emitter.emit('put', key, value); cb(null) } if(err) return cb(err) }) } emitter.prefix = function () { return prefix.slice() } emitter.del = function (key, opts, cb) { if('function' === typeof opts) cb = opts, opts = {} if(!cb) cb = errback nut.apply([{ key: key, prefix: prefix.slice(), type: 'del' }], mergeOpts(opts), function (err) { if(!err) { emitter.emit('del', key); cb(null) } if(err) return cb(err) }) } emitter.batch = function (ops, opts, cb) { if('function' === typeof opts) cb = opts, opts = {} if(!cb) cb = errback ops = ops.map(function (op) { return { key: op.key, value: op.value, prefix: op.prefix || prefix, keyEncoding: op.keyEncoding, // * valueEncoding: op.valueEncoding, // * (TODO: encodings on sublevel) type: op.type } }) nut.apply(ops, mergeOpts(opts), function (err) { if(!err) { emitter.emit('batch', ops); cb(null) } if(err) return cb(err) }) } emitter.get = function (key, opts, cb) { if('function' === typeof opts) cb = opts, opts = {} nut.get(key, prefix, mergeOpts(opts), function (err, value) { if(err) cb(new errors.NotFoundError('Key not found in database', err)) else cb(null, value) }) } emitter.clone = function(opts) { return sublevel(nut, prefix, createStream, mergeOpts(opts)) } emitter.sublevel = function (name, opts) { return emitter.sublevels[name] = emitter.sublevels[name] || sublevel(nut, prefix.concat(name), createStream, mergeOpts(opts)) } emitter.pre = function (key, hook) { if(isFunction(key)) return nut.pre([prefix], key) if(isString(key)) return nut.pre([prefix, key], hook) if(isObject(key)) return nut.pre(addpre(prefix, key), hook) throw new Error('not implemented yet') } emitter.post = function (key, hook) { if(isFunction(key)) return nut.post([prefix], key) if(isString(key)) return nut.post([prefix, key], hook) if(isObject(key)) return nut.post(addpre(prefix, key), hook) //TODO: handle ranges, needed for level-live-stream, etc. throw new Error('not implemented yet') } emitter.readStream = emitter.createReadStream = function (opts) { opts = mergeOpts(opts) opts.prefix = prefix var stream var it = nut.iterator(opts, function (err, it) { stream.setIterator(it) }) stream = createStream(opts, nut.createDecoder(opts)) if(it) stream.setIterator(it) return stream } emitter.valueStream = emitter.createValueStream = function (opts) { opts = opts || {} opts.values = true opts.keys = false return emitter.createReadStream(opts) } emitter.keyStream = emitter.createKeyStream = function (opts) { opts = opts || {} opts.values = false opts.keys = true return emitter.createReadStream(opts) } emitter.close = function (cb) { //TODO: deregister all hooks cb = cb || function () {} if (!prefix.length) nut.close(cb) else process.nextTick(cb) } emitter.isOpen = nut.isOpen emitter.isClosed = nut.isClosed return emitter } }).call(this,require('_process')) },{"./package.json":483,"./range":484,"_process":295,"events":144,"levelup/lib/errors":211}],486:[function(require,module,exports){ arguments[4][345][0].apply(exports,arguments) },{"dup":345}],487:[function(require,module,exports){ var pull = require('pull-stream') var toPull = require('stream-to-pull-stream') var pushable = require('pull-pushable') var cat = require('pull-cat') var pw = require('pull-window') var post = require('level-post') function read(db, opts) { return toPull.read1(db.createReadStream(opts)) } var live = exports.live = function (db, opts) { opts = opts || {} var l = pushable(function (err) { if(opts.onAbort) opts.onAbort(err) cleanup() }) var cleanup = post(db, opts, function (ch) { if(opts.keys === false) l.push(ch.value) else if(opts.values === false) l.push(ch.key) else l.push(ch) }) return l } exports.read = exports.readStream = exports.createReadStream = function (db, opts) { opts = opts || {} if(!(opts.tail || opts.live)) return read(db, opts) //optionally notify when we switch from reading history to realtime var sync = opts.onSync && function (abort, cb) { opts.onSync(abort); cb(abort || true) } if(opts.onSync === true || opts.sync === true) sync = pull.values([{sync: true}]) return cat([read(db, opts), sync, live(db, opts)]) } exports.write = exports.writeStream = exports.createWriteStream = function (db, opts, done) { if('function' === typeof opts) done = opts, opts = null opts = opts || {} return pull( pull.map(function (e) { if(e.type) return e return { key : e.key, value : e.value, type : e.value == null ? 'del' : 'put' } }), pw.recent(opts.windowSize, opts.windowTime), pull.asyncMap(function (batch, cb) { db.batch(batch, cb) }), pull.drain(null, done) ) } },{"level-post":198,"pull-cat":305,"pull-pushable":493,"pull-stream":488,"pull-window":390,"stream-to-pull-stream":593}],488:[function(require,module,exports){ arguments[4][232][0].apply(exports,arguments) },{"./pull":489,"./sinks":490,"./sources":491,"./throughs":492,"dup":232}],489:[function(require,module,exports){ arguments[4][233][0].apply(exports,arguments) },{"dup":233}],490:[function(require,module,exports){ arguments[4][234][0].apply(exports,arguments) },{"dup":234}],491:[function(require,module,exports){ arguments[4][235][0].apply(exports,arguments) },{"dup":235}],492:[function(require,module,exports){ arguments[4][236][0].apply(exports,arguments) },{"./sinks":490,"./sources":491,"dup":236}],493:[function(require,module,exports){ arguments[4][346][0].apply(exports,arguments) },{"dup":346,"pull-stream":494}],494:[function(require,module,exports){ arguments[4][347][0].apply(exports,arguments) },{"./maybe":495,"./sinks":496,"./sources":497,"./throughs":498,"dup":347,"pull-core":486}],495:[function(require,module,exports){ arguments[4][348][0].apply(exports,arguments) },{"dup":348,"pull-core":486}],496:[function(require,module,exports){ arguments[4][349][0].apply(exports,arguments) },{"dup":349}],497:[function(require,module,exports){ arguments[4][350][0].apply(exports,arguments) },{"dup":350}],498:[function(require,module,exports){ (function (process){ var u = require('pull-core') var sources = require('./sources') var sinks = require('./sinks') var prop = u.prop var id = u.id var tester = u.tester var map = exports.map = function (read, map) { map = prop(map) || id return function (end, cb) { read(end, function (end, data) { var data = !end ? map(data) : null cb(end, data) }) } } var asyncMap = exports.asyncMap = function (read, map) { if(!map) return read return function (end, cb) { if(end) return read(end, cb) //abort read(null, function (end, data) { if(end) return cb(end, data) map(data, cb) }) } } var paraMap = exports.paraMap = function (read, map, width) { if(!map) return read var ended = false, queue = [], _cb function drain () { if(!_cb) return var cb = _cb _cb = null if(queue.length) return cb(null, queue.shift()) else if(ended && !n) return cb(ended) _cb = cb } function pull () { read(null, function (end, data) { if(end) { ended = end return drain() } n++ map(data, function (err, data) { n-- queue.push(data) drain() }) if(n < width && !ended) pull() }) } var n = 0 return function (end, cb) { if(end) return read(end, cb) //abort //continue to read while there are less than 3 maps in flight _cb = cb if(queue.length || ended) pull(), drain() else pull() } return highWaterMark(asyncMap(read, map), width) } var filter = exports.filter = function (read, test) { //regexp test = tester(test) return function next (end, cb) { read(end, function (end, data) { if(!end && !test(data)) return next(end, cb) cb(end, data) }) } } var filterNot = exports.filterNot = function (read, test) { test = tester(test) return filter(read, function (e) { return !test(e) }) } var through = exports.through = function (read, op, onEnd) { var a = false function once (abort) { if(a || !onEnd) return a = true onEnd(abort === true ? null : abort) } return function (end, cb) { if(end) once(end) return read(end, function (end, data) { if(!end) op && op(data) else once(end) cb(end, data) }) } } var take = exports.take = function (read, test) { var ended = false if('number' === typeof test) { var n = test; test = function () { return n -- } } return function (end, cb) { if(ended) return cb(ended) if(ended = end) return read(ended, cb) read(null, function (end, data) { if(ended = ended || end) return cb(ended) if(!test(data)) { ended = true read(true, function (end, data) { cb(ended, data) }) } else cb(null, data) }) } } var unique = exports.unique = function (read, field, invert) { field = prop(field) || id var seen = {} return filter(read, function (data) { var key = field(data) if(seen[key]) return !!invert //false, by default else seen[key] = true return !invert //true by default }) } var nonUnique = exports.nonUnique = function (read, field) { return unique(read, field, true) } var group = exports.group = function (read, size) { var ended; size = size || 5 var queue = [] return function (end, cb) { //this means that the upstream is sending an error. if(end) return read(ended = end, cb) //this means that we read an end before. if(ended) return cb(ended) read(null, function next(end, data) { if(ended = ended || end) { if(!queue.length) return cb(ended) var _queue = queue; queue = [] return cb(null, _queue) } queue.push(data) if(queue.length < size) return read(null, next) var _queue = queue; queue = [] cb(null, _queue) }) } } var flatten = exports.flatten = function (read) { var _read return function (abort, cb) { if(_read) nextChunk() else nextStream() function nextChunk () { _read(null, function (end, data) { if(end) nextStream() else cb(null, data) }) } function nextStream () { read(null, function (end, stream) { if(end) return cb(end) if(Array.isArray(stream)) stream = sources.values(stream) else if('function' != typeof stream) throw new Error('expected stream of streams') _read = stream nextChunk() }) } } } var prepend = exports.prepend = function (read, head) { return function (abort, cb) { if(head !== null) { if(abort) return read(abort, cb) var _head = head head = null cb(null, _head) } else { read(abort, cb) } } } //var drainIf = exports.drainIf = function (op, done) { // sinks.drain( //} var _reduce = exports._reduce = function (read, reduce, initial) { return function (close, cb) { if(close) return read(close, cb) if(ended) return cb(ended) sinks.drain(function (item) { initial = reduce(initial, item) }, function (err, data) { ended = err || true if(!err) cb(null, initial) else cb(ended) }) (read) } } var nextTick = process.nextTick var highWaterMark = exports.highWaterMark = function (read, highWaterMark) { var buffer = [], waiting = [], ended, reading = false highWaterMark = highWaterMark || 10 function readAhead () { while(waiting.length && (buffer.length || ended)) waiting.shift()(ended, ended ? null : buffer.shift()) } function next () { if(ended || reading || buffer.length >= highWaterMark) return reading = true return read(ended, function (end, data) { reading = false ended = ended || end if(data != null) buffer.push(data) next(); readAhead() }) } nextTick(next) return function (end, cb) { ended = ended || end waiting.push(cb) next(); readAhead() } } }).call(this,require('_process')) },{"./sinks":496,"./sources":497,"_process":295,"pull-core":486}],499:[function(require,module,exports){ arguments[4][179][0].apply(exports,arguments) },{"./maybe":500,"./sinks":501,"./sources":502,"./throughs":503,"dup":179,"pull-core":486}],500:[function(require,module,exports){ arguments[4][180][0].apply(exports,arguments) },{"dup":180,"pull-core":486}],501:[function(require,module,exports){ arguments[4][181][0].apply(exports,arguments) },{"dup":181}],502:[function(require,module,exports){ var keys = exports.keys = function (object) { return values(Object.keys(object)) } var once = exports.once = function (value) { return function (abort, cb) { if(abort) return cb(abort) if(value != null) { var _value = value; value = null cb(null, _value) } else cb(true) } } var values = exports.values = exports.readArray = function (array) { if(!Array.isArray(array)) array = Object.keys(array).map(function (k) { return array[k] }) var i = 0 return function (end, cb) { if(end) return cb && cb(end) cb(i >= array.length || null, array[i++]) } } var count = exports.count = function (max) { var i = 0; max = max || Infinity return function (end, cb) { if(end) return cb && cb(end) if(i > max) return cb(true) cb(null, i++) } } var infinite = exports.infinite = function (generate) { generate = generate || Math.random return function (end, cb) { if(end) return cb && cb(end) return cb(null, generate()) } } var defer = exports.defer = function () { var _read, cbs = [], _end var read = function (end, cb) { if(!_read) { _end = end cbs.push(cb) } else _read(end, cb) } read.resolve = function (read) { if(_read) throw new Error('already resolved') _read = read if(!_read) throw new Error('no read cannot resolve!' + _read) while(cbs.length) _read(_end, cbs.shift()) } read.abort = function(err) { read.resolve(function (_, cb) { cb(err || true) }) } return read } var empty = exports.empty = function () { return function (abort, cb) { cb(true) } } var depthFirst = exports.depthFirst = function (start, createStream) { var reads = [] reads.unshift(once(start)) return function next (end, cb) { if(!reads.length) return cb(true) reads[0](end, function (end, data) { if(end) { //if this stream has ended, go to the next queue reads.shift() return next(null, cb) } reads.unshift(createStream(data)) cb(end, data) }) } } //width first is just like depth first, //but push each new stream onto the end of the queue var widthFirst = exports.widthFirst = function (start, createStream) { var reads = [] reads.push(once(start)) return function next (end, cb) { if(!reads.length) return cb(true) reads[0](end, function (end, data) { if(end) { reads.shift() return next(null, cb) } reads.push(createStream(data)) cb(end, data) }) } } //this came out different to the first (strm) //attempt at leafFirst, but it's still a valid //topological sort. var leafFirst = exports.leafFirst = function (start, createStream) { var reads = [] var output = [] reads.push(once(start)) return function next (end, cb) { reads[0](end, function (end, data) { if(end) { reads.shift() if(!output.length) return cb(true) return cb(null, output.shift()) } reads.unshift(createStream(data)) output.unshift(data) next(null, cb) }) } } },{}],503:[function(require,module,exports){ (function (process){ var u = require('pull-core') var sources = require('./sources') var sinks = require('./sinks') var prop = u.prop var id = u.id var tester = u.tester var map = exports.map = function (read, map) { map = prop(map) || id return function (abort, cb) { read(abort, function (end, data) { try { data = !end ? map(data) : null } catch (err) { return read(err, function () { return cb(err) }) } cb(end, data) }) } } var asyncMap = exports.asyncMap = function (read, map) { if(!map) return read return function (end, cb) { if(end) return read(end, cb) //abort read(null, function (end, data) { if(end) return cb(end, data) map(data, cb) }) } } var paraMap = exports.paraMap = function (read, map, width) { if(!map) return read var ended = false, queue = [], _cb function drain () { if(!_cb) return var cb = _cb _cb = null if(queue.length) return cb(null, queue.shift()) else if(ended && !n) return cb(ended) _cb = cb } function pull () { read(null, function (end, data) { if(end) { ended = end return drain() } n++ map(data, function (err, data) { n-- queue.push(data) drain() }) if(n < width && !ended) pull() }) } var n = 0 return function (end, cb) { if(end) return read(end, cb) //abort //continue to read while there are less than 3 maps in flight _cb = cb if(queue.length || ended) pull(), drain() else pull() } return highWaterMark(asyncMap(read, map), width) } var filter = exports.filter = function (read, test) { //regexp test = tester(test) return function next (end, cb) { var sync, loop = true while(loop) { loop = false sync = true read(end, function (end, data) { if(!end && !test(data)) return sync ? loop = true : next(end, cb) cb(end, data) }) sync = false } } } var filterNot = exports.filterNot = function (read, test) { test = tester(test) return filter(read, function (e) { return !test(e) }) } var through = exports.through = function (read, op, onEnd) { var a = false function once (abort) { if(a || !onEnd) return a = true onEnd(abort === true ? null : abort) } return function (end, cb) { if(end) once(end) return read(end, function (end, data) { if(!end) op && op(data) else once(end) cb(end, data) }) } } var take = exports.take = function (read, test) { var ended = false if('number' === typeof test) { var n = test; test = function () { return n -- } } return function (end, cb) { if(ended) return cb(ended) if(ended = end) return read(ended, cb) read(null, function (end, data) { if(ended = ended || end) return cb(ended) if(!test(data)) { ended = true read(true, function (end, data) { cb(ended, data) }) } else cb(null, data) }) } } var unique = exports.unique = function (read, field, invert) { field = prop(field) || id var seen = {} return filter(read, function (data) { var key = field(data) if(seen[key]) return !!invert //false, by default else seen[key] = true return !invert //true by default }) } var nonUnique = exports.nonUnique = function (read, field) { return unique(read, field, true) } var group = exports.group = function (read, size) { var ended; size = size || 5 var queue = [] return function (end, cb) { //this means that the upstream is sending an error. if(end) return read(ended = end, cb) //this means that we read an end before. if(ended) return cb(ended) read(null, function next(end, data) { if(ended = ended || end) { if(!queue.length) return cb(ended) var _queue = queue; queue = [] return cb(null, _queue) } queue.push(data) if(queue.length < size) return read(null, next) var _queue = queue; queue = [] cb(null, _queue) }) } } var flatten = exports.flatten = function (read) { var _read return function (abort, cb) { if(_read) nextChunk() else nextStream() function nextChunk () { _read(null, function (end, data) { if(end) nextStream() else cb(null, data) }) } function nextStream () { read(null, function (end, stream) { if(end) return cb(end) if(Array.isArray(stream)) stream = sources.values(stream) else if('function' != typeof stream) throw new Error('expected stream of streams') _read = stream nextChunk() }) } } } var prepend = exports.prepend = function (read, head) { return function (abort, cb) { if(head !== null) { if(abort) return read(abort, cb) var _head = head head = null cb(null, _head) } else { read(abort, cb) } } } //var drainIf = exports.drainIf = function (op, done) { // sinks.drain( //} var _reduce = exports._reduce = function (read, reduce, initial) { return function (close, cb) { if(close) return read(close, cb) if(ended) return cb(ended) sinks.drain(function (item) { initial = reduce(initial, item) }, function (err, data) { ended = err || true if(!err) cb(null, initial) else cb(ended) }) (read) } } var nextTick = process.nextTick var highWaterMark = exports.highWaterMark = function (read, highWaterMark) { var buffer = [], waiting = [], ended, ending, reading = false highWaterMark = highWaterMark || 10 function readAhead () { while(waiting.length && (buffer.length || ended)) waiting.shift()(ended, ended ? null : buffer.shift()) if (!buffer.length && ending) ended = ending; } function next () { if(ended || ending || reading || buffer.length >= highWaterMark) return reading = true return read(ended || ending, function (end, data) { reading = false ending = ending || end if(data != null) buffer.push(data) next(); readAhead() }) } process.nextTick(next) return function (end, cb) { ended = ended || end waiting.push(cb) next(); readAhead() } } var flatMap = exports.flatMap = function (read, mapper) { mapper = mapper || id var queue = [], ended return function (abort, cb) { if(queue.length) return cb(null, queue.shift()) else if(ended) return cb(ended) read(abort, function next (end, data) { if(end) ended = end else { var add = mapper(data) while(add && add.length) queue.push(add.shift()) } if(queue.length) cb(null, queue.shift()) else if(ended) cb(ended) else read(null, next) }) } } }).call(this,require('_process')) },{"./sinks":501,"./sources":502,"_process":295,"pull-core":486}],504:[function(require,module,exports){ arguments[4][177][0].apply(exports,arguments) },{"dup":177}],505:[function(require,module,exports){ module.exports={ "_args": [ [ "secure-scuttlebutt@git+https://github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d", "/Users/joran/Documents/development/patchdeck/node_modules/scuttlebot" ] ], "_from": "git+https://github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d", "_id": "secure-scuttlebutt@15.0.5", "_inCache": true, "_installable": true, "_location": "/secure-scuttlebutt", "_phantomChildren": { "bytewise-core": "1.2.3", "level-post": "1.0.4", "levelup": "0.19.1", "pull-cat": "1.1.9", "pull-window": "2.1.3", "stream-to-pull-stream": "1.6.8", "typewise": "1.0.3", "typewiselite": "1.0.0" }, "_requested": { "hosted": { "directUrl": "https://raw.githubusercontent.com/ssbc/secure-scuttlebutt/b8de480bd262a69c357e80681dd60cf60c17681d/package.json", "gitUrl": "git://github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d", "httpsUrl": "git+https://github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d", "shortcut": "github:ssbc/secure-scuttlebutt#b8de480bd262a69c357e80681dd60cf60c17681d", "ssh": "git@github.com:ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d", "sshUrl": "git+ssh://git@github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d", "type": "github" }, "name": "secure-scuttlebutt", "raw": "secure-scuttlebutt@git+https://github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d", "rawSpec": "git+https://github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d", "scope": null, "spec": "git+https://github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d", "type": "hosted" }, "_requiredBy": [ "/scuttlebot" ], "_resolved": "git+https://github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d", "_shasum": "4c2fa68fd5ebd8d9ee0d4b27279cb9c156ed7868", "_shrinkwrap": null, "_spec": "secure-scuttlebutt@git+https://github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d", "_where": "/Users/joran/Documents/development/patchdeck/node_modules/scuttlebot", "author": { "email": "dominic.tarr@gmail.com", "name": "Dominic Tarr", "url": "http://dominictarr.com" }, "bugs": { "url": "https://github.com/ssbc/secure-scuttlebutt/issues" }, "dependencies": { "cont": "~1.0.0", "deep-equal": "~0.2.1", "explain-error": "~1.0.1", "level": "^1.3.0", "level-sublevel": "^6.5.2", "ltgt": "~2.0.0", "monotonic-timestamp": "~0.0.8", "pull-cat": "~1.1.5", "pull-level": "~1.4.0", "pull-paramap": "~1.1.3", "pull-stream": "~2.24.1", "ssb-feed": "^2.0.0", "ssb-keys": "^5.0.0", "ssb-msgs": "^5.0.0", "ssb-ref": "^2.0.0" }, "description": "a secure, replicatable database", "devDependencies": { "deep-equal": "^0.2.1", "hexpp": "~1.1.3", "level-test": "^2.0.1", "multicb": "~0.0.2", "pull-abortable": "~4.1.0", "pull-randomly-split": "~1.0.4", "rimraf": "~2.2.8", "tape": "^4.2.2", "typewiselite": "~1.0.0" }, "gitHead": "b8de480bd262a69c357e80681dd60cf60c17681d", "homepage": "https://github.com/ssbc/secure-scuttlebutt", "license": "MIT", "name": "secure-scuttlebutt", "optionalDependencies": {}, "readme": "# secure-scuttlebutt\n\nA database of unforgable append-only feeds, optimized for efficient replication for peer to peer protocols.\n\n## What does it do?\n\nSecure-scuttlebutt provides tools for dealing with unforgeable append-only message \nfeeds. You can create a feed, post messages to that feed, verify a feed created by\nsomeone else, stream messages to and from feeds, and more (see [API](#API)).\n\n\"Unforgeable\" means that only the owner of a feed can modify that feed, as\nenforced by digital signing (see [Security properties](#security-properties)).\nThis property makes secure-scuttlebutt useful for peer-to-peer applications.\nSecure-scuttlebutt also makes it easy to encrypt messages.\n\n## Example\n\nIn this example, we create a feed, post a signed message to it, then create a stream \nthat reads from the feed.\n\n``` js\n/**\n * create a secure scuttlebutt instance and add a message to it.\n */\n\nvar pull = require('pull-stream')\n\n// paths:\nvar pathToDB = '/tmp/ssb1/'\nvar pathToSecret = '/tmp/ssb1-secret'\n\n// ways to create keys:\nvar keys = require('ssb-keys').generate()\nvar keys = require('ssb-keys').loadSync(pathToSecret)\nvar keys = require('ssb-keys').createSync(pathToSecret)\nvar keys = require('ssb-keys').loadOrCreateSync(pathToSecret)\n\n// create the db instance.\n// - uses leveldb.\n// - can only open one instance at a time.\n\nvar ssb = require('secure-scuttlebutt/create')(pathToDB)\n\n// create a feed.\n// - this represents a write access / user.\n// - you must pass in keys.\n// (see options section)\n\nvar feed = ssb.createFeed(keys)\n\n// publish a message.\n// - feed.add appends a message to your key's chain.\n// - the `type` attribute is required.\n\nfeed.add({ type: 'post', text: 'My First Post!' }, function (err, msg, hash) {\n // the message as it appears in the database:\n console.log(msg)\n\n // and its hash:\n console.log(hash)\n})\n\n// stream all messages for all keypairs.\npull(\n ssb.createFeedStream(),\n pull.collect(function (err, ary) {\n console.log(ary)\n })\n)\n\n// stream all messages for a particular keypair.\npull(\n ssb.createHistoryStream(feed.id),\n pull.collect(function (err, ary) {\n console.log(ary)\n })\n)\n```\n\n## Concepts\n\nBuilding upon secure-scuttlebutt requires understanding a few concepts\nthat it uses to ensure the unforgeability of message feeds.\n\n### Identities\n\nAn identity is simply a public/private key pair.\n\nEven though there is no worldwide store of identities, it's infeasible\nfor anyone to forge your identity. Identities are binary strings, so not\nparticularly human-readable.\n\n### Feeds\n\nA feed is an append-only sequence of messages. Each feed is associated\n1:1 with an identity. The feed is identified by its public key. This\nworks because public keys are unique.\n\nSince feeds are append-only, replication is simple: request all messages\nin the feed that are newer than the latest message you know about.\n\nNote that append-only really means append-only: you cannot delete an\nexisting message. If you want to enable entities to be deleted or \nmodified in your data model, that can be implemented in a layer on top \nof secure-scuttlebutt using \n[delta encoding](https://en.wikipedia.org/wiki/Delta_encoding). \n\n### Messages\n\nEach message contains:\n\n- A message object. This is the thing that the end user cares about. If\n there is no encryption, this is a `{}` object. If there is encryption,\n this is an encrypted string.\n- A content-hash of the previous message. This prevents somebody with\n the private key from changing the feed history after publishing, as a\n newly-created message wouldn't match the \"prev-hash\" of later messages\n which were already replicated.\n- The signing public key.\n- A signature. This prevents malicious parties from writing fake \n messages to a stream.\n- A sequence number. This prevents a malicious party from making a copy\n of the feed that omits or reorders messages.\n \nSince each message contains a reference to the previous message, a feed \nmust be replicated in order, starting with the first message. This is\nthe only way that the feed can be verified. A feed can be *viewed* in\nany order after it's been replicated.\n\n### Object ids\n\nThe text inside a message can refer to three types of secure-scuttlebutt\nentities: messages, feeds, and blobs (i.e. attachments). Messages and \nblobs are referred to by their hashes, but a feed is referred to by its\nsigning public key. Thus, a message within a feed can refer to another\nfeed, or to a particular point _within_ a feed.\n\nObject ids begin with a sigil `@` `%` and `&` for a `feedId`, `msgId`\nand `blobId` respectively.\n\nNote that secure-scuttlebutt does not include facilities for retrieving\na blob given the hash.\n\n### Replication\n\nIt is possible to easily replicate data between two SecureScuttlebutts.\nFirst, they exchange maps of their newest data. Then, each one downloads\nall data newer than its newest data.\n\n[Scuttlebot](https://github.com/ssbc/scuttlebot) is a tool that\nmakes it easy to replicate multiple SecureScuttlebutts using a\ndecentralized network.\n\n### Security properties\nSecure-scuttlebutt maintains useful security properties even when it is\nconnected to a malicious secure-scuttlebutt database. This makes it ideal\nas a store for peer-to-peer applications.\n\nImagine that we want to read from a feed for which we know the identity,\nbut we're connected to a malicious secure-scuttlebutt instance. As\nlong as the malicious database does not have the private key:\n\n- The malicious database cannot create a new feed with the same identifier\n- The malicious database cannot write new fake messages to the feed\n- The malicious database cannot reorder the messages in the feed\n- The malicious database cannot send us a new copy of the feed that omits\n messages from the middle\n- The malicious database *can* refuse to send us the feed, or only send\n us the first *N* messages in the feed\n- Messages may optionally be encrypted. See `test/end-to-end.js`.\n\n\n## API\n\n### ssb = require('secure-scuttlebutt/create')(path)\n\nCreate a secure-scuttlebutt database at the given path,\nreturns an instance.\n\n### require('secure-scuttlebutt')(db, opts)\n\nPass in a [levelup](https://github.com/rvagg/node-levelup) instance\n(it must have [sublevel](https://github.com/dominictarr/level-sublevel) installed),\nand an options object. The options object provides the crypto\nand encoding functions, that are not directly tied into how\nsecure-scuttlebutt works.\n\nThe following methods all apply to a `SecureScuttlebutt` instance\n\n### SecureScuttlebutt#createFeed (keys?)\n\nCreate a Feed object. A feed is a chain of messages signed\nby a single key (the identity of the feed).\nThis handles the state needed to append valid messages to a feed.\nIf keys are not provided, then a new key pair will be generated.\n\nThe following methods apply to the Feed type.\n\n#### Feed#add (message, cb)\n\nAdds a message of a given type to a feed.\nThis is the recommended way to append messages.\nmessage is a javascript object. It must be a `{}` object with a `type`\nproperty that is a string between 3 and 32 chars long.\n\n#### Feed#id\n\nthe id of the feed (which is the feed's public key)\n\n#### Feed#keys\n\nthe key pair for this feed.\n\n### SecureScuttlebutt#needsRebuild(cb)\n\nChecks the version stored in the database against the code version and\ncalls back true/false accordingly. This keeps the database in sync with\nmajor breaking changes to secure-scuttlebutt when they occur.\n\nShould be run at startup. If true, you should call `rebuildIndex` before\nusing the database.\n\n```js\nssb.needsRebuild(function (err, b) {\n if (b)\n ssb.rebuildIndex(next)\n})\n```\n\n### SecureScuttlebutt#rebuildIndex(cb)\n\nRebuilds the indexes by replaying history. See `needsRebuild`.\n\n### SecureScuttlebutt#createFeedStream (opts) -> PullSource\n\nCreate a [pull-stream](https://github.com/dominictarr/pull-stream)\nof all the feeds in the database, ordered by timestamps.\nAll [pull-level](https://github.com/dominictarr/pull-level) options\nare allowed (start, end, reverse, tail)\n\n### SecureScuttlebutt#createLogStream({gt: ts, tail: boolean}) -> PullSource\n\ncreate a stream of the messages that have been written to this instance\nin the order they arrived. This is mainly intended for building views.\nThe objects in this stream will be of the form:\n\n``` js\n{\n key: Hash, value: Message, timestamp: timestamp\n}\n```\n`timestamp` is generated by\n[monotonic-timestamp](https://github.com/dominictarr/monotonic-timestamp)\n\n### SecureScuttlebutt#createHistoryStream ({id: feedId, seq: int?, live: bool?}) -> PullSource\n\nCreate a stream of the history of `id`. If `seq > 0`, then\nonly stream messages with sequence numbers greater than `seq`.\nif `live` is true, the stream will be a\n[live mode](https://github.com/dominictarr/pull-level#example---reading)\n\n### SecureScuttlebutt#messagesByType ({type: string, live: bool?}) -> PullSource\n\nretrive messages with a given type. All messages must have a type,\nso this is a good way to select messages that an application might use.\nReturns a source pull-stream. This function takes all the options from [pull-level#read](https://github.com/dominictarr/pull-level#example---reading)\n(gt, lt, gte, lte, limit, reverse, live)\n\n\n### SecureScuttlebutt#links ({source: feedId?, dest: feedId|msgId|blobId?, rel: string?, meta: true?, keys: true?, values: false?, live:false?, reverse: false?}) -> PullSource\n\nGet a stream of links from a feed to a blob/msg/feed id.\n\nThe objects in this stream will be of the form:\n\n```\n{ source: feedId, rel: String, dest: Id, key: MsgId, value: Object? }\n```\n\n - `source` (string, optional): feed id..\n - `dest` (string, optional): An id or filter, specifying where the link should point to.\n To filter, just use the sigil of the type you want: `@` for feeds, `%` for messages, and `&` for blobs.\n - `rel` (string, optional): Filters the links by the relation string.\n\nIf `opts.values` is set (default: false) `value` will be the message the link occurs in.\nIf `opts.keys` is set (default: true) `key` will be the message id.\nIf `opts.meta` is unset (default: true) `source, hash, rel` will be left off.\n\n> Note: if `source`, and `dest` is provided, but not `rel`, ssb will\n> have to scan all the links from source, and then filter by dest.\n> your query will be more efficient if you also provide `rel`.\n\n\n### SecureScuttlebutt#relatedMessages ({id: msgId, rel: string?, count: false?, parent: false?}, cb)\n\nRetrieve the tree of messages related to `id`.\nThis is ideal for collecting things like threaded replies.\nIf `rel` is provided, only messages that link to the message with the given type are included.\nThe output is a recursive structure like this:\n\n``` js\n{\n key: ,\n value: ,\n related: [\n ,...\n ],\n //number of messages below this point. (when opts.count = true)\n count: ,\n //the message this message links to. this will not appear on the bottom level.\n //(when opts.parent = true)\n parent: \n}\n```\n\nIf `count` option is true, then each message will contain a `count`\nit's descendant messages. If `parent` is true then each level will have \n`parent`, the `id/key` of it's parent message.\n\n## Stability\n\nStable: Expect patches, possible features additions.\n\n## License\n\nMIT\n\n", "readmeFilename": "README.md", "repository": { "type": "git", "url": "git://github.com/ssbc/secure-scuttlebutt.git" }, "scripts": { "prepublish": "npm ls && npm test", "test": "set -e; for t in test/*.js; do node $t; done" }, "testling": { "browsers": [ "chrome/22..latest", "chrome/canary", "firefox/17..latest", "firefox/nightly", "ie/8..latest", "ipad/6.0..latest", "iphone/6.0..latest", "opera/12..latest", "opera/next", "safari/5.1..latest" ], "files": "test/defaults.js" }, "version": "15.0.5" } },{}],506:[function(require,module,exports){ (function (Buffer){ // prototype class for hash functions function Hash (blockSize, finalSize) { this._block = new Buffer(blockSize) this._finalSize = finalSize this._blockSize = blockSize this._len = 0 this._s = 0 } Hash.prototype.update = function (data, enc) { if (typeof data === 'string') { enc = enc || 'utf8' data = new Buffer(data, enc) } var l = this._len += data.length var s = this._s || 0 var f = 0 var buffer = this._block while (s < l) { var t = Math.min(data.length, f + this._blockSize - (s % this._blockSize)) var ch = (t - f) for (var i = 0; i < ch; i++) { buffer[(s % this._blockSize) + i] = data[i + f] } s += ch f += ch if ((s % this._blockSize) === 0) { this._update(buffer) } } this._s = s return this } Hash.prototype.digest = function (enc) { // Suppose the length of the message M, in bits, is l var l = this._len * 8 // Append the bit 1 to the end of the message this._block[this._len % this._blockSize] = 0x80 // and then k zero bits, where k is the smallest non-negative solution to the equation (l + 1 + k) === finalSize mod blockSize this._block.fill(0, this._len % this._blockSize + 1) if (l % (this._blockSize * 8) >= this._finalSize * 8) { this._update(this._block) this._block.fill(0) } // to this append the block which is equal to the number l written in binary // TODO: handle case where l is > Math.pow(2, 29) this._block.writeInt32BE(l, this._blockSize - 4) var hash = this._update(this._block) || this._hash() return enc ? hash.toString(enc) : hash } Hash.prototype._update = function () { throw new Error('_update must be implemented by subclass') } module.exports = Hash }).call(this,require("buffer").Buffer) },{"buffer":61}],507:[function(require,module,exports){ var exports = module.exports = function SHA (algorithm) { algorithm = algorithm.toLowerCase() var Algorithm = exports[algorithm] if (!Algorithm) throw new Error(algorithm + ' is not supported (we accept pull requests)') return new Algorithm() } exports.sha = require('./sha') exports.sha1 = require('./sha1') exports.sha224 = require('./sha224') exports.sha256 = require('./sha256') exports.sha384 = require('./sha384') exports.sha512 = require('./sha512') },{"./sha":508,"./sha1":509,"./sha224":510,"./sha256":511,"./sha384":512,"./sha512":513}],508:[function(require,module,exports){ (function (Buffer){ /* * A JavaScript implementation of the Secure Hash Algorithm, SHA-0, as defined * in FIPS PUB 180-1 * This source code is derived from sha1.js of the same repository. * The difference between SHA-0 and SHA-1 is just a bitwise rotate left * operation was added. */ var inherits = require('inherits') var Hash = require('./hash') var K = [ 0x5a827999, 0x6ed9eba1, 0x8f1bbcdc | 0, 0xca62c1d6 | 0 ] var W = new Array(80) function Sha () { this.init() this._w = W Hash.call(this, 64, 56) } inherits(Sha, Hash) Sha.prototype.init = function () { this._a = 0x67452301 this._b = 0xefcdab89 this._c = 0x98badcfe this._d = 0x10325476 this._e = 0xc3d2e1f0 return this } function rotl5 (num) { return (num << 5) | (num >>> 27) } function rotl30 (num) { return (num << 30) | (num >>> 2) } function ft (s, b, c, d) { if (s === 0) return (b & c) | ((~b) & d) if (s === 2) return (b & c) | (b & d) | (c & d) return b ^ c ^ d } Sha.prototype._update = function (M) { var W = this._w var a = this._a | 0 var b = this._b | 0 var c = this._c | 0 var d = this._d | 0 var e = this._e | 0 for (var i = 0; i < 16; ++i) W[i] = M.readInt32BE(i * 4) for (; i < 80; ++i) W[i] = W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16] for (var j = 0; j < 80; ++j) { var s = ~~(j / 20) var t = (rotl5(a) + ft(s, b, c, d) + e + W[j] + K[s]) | 0 e = d d = c c = rotl30(b) b = a a = t } this._a = (a + this._a) | 0 this._b = (b + this._b) | 0 this._c = (c + this._c) | 0 this._d = (d + this._d) | 0 this._e = (e + this._e) | 0 } Sha.prototype._hash = function () { var H = new Buffer(20) H.writeInt32BE(this._a | 0, 0) H.writeInt32BE(this._b | 0, 4) H.writeInt32BE(this._c | 0, 8) H.writeInt32BE(this._d | 0, 12) H.writeInt32BE(this._e | 0, 16) return H } module.exports = Sha }).call(this,require("buffer").Buffer) },{"./hash":506,"buffer":61,"inherits":167}],509:[function(require,module,exports){ (function (Buffer){ /* * A JavaScript implementation of the Secure Hash Algorithm, SHA-1, as defined * in FIPS PUB 180-1 * Version 2.1a Copyright Paul Johnston 2000 - 2002. * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet * Distributed under the BSD License * See http://pajhome.org.uk/crypt/md5 for details. */ var inherits = require('inherits') var Hash = require('./hash') var K = [ 0x5a827999, 0x6ed9eba1, 0x8f1bbcdc | 0, 0xca62c1d6 | 0 ] var W = new Array(80) function Sha1 () { this.init() this._w = W Hash.call(this, 64, 56) } inherits(Sha1, Hash) Sha1.prototype.init = function () { this._a = 0x67452301 this._b = 0xefcdab89 this._c = 0x98badcfe this._d = 0x10325476 this._e = 0xc3d2e1f0 return this } function rotl1 (num) { return (num << 1) | (num >>> 31) } function rotl5 (num) { return (num << 5) | (num >>> 27) } function rotl30 (num) { return (num << 30) | (num >>> 2) } function ft (s, b, c, d) { if (s === 0) return (b & c) | ((~b) & d) if (s === 2) return (b & c) | (b & d) | (c & d) return b ^ c ^ d } Sha1.prototype._update = function (M) { var W = this._w var a = this._a | 0 var b = this._b | 0 var c = this._c | 0 var d = this._d | 0 var e = this._e | 0 for (var i = 0; i < 16; ++i) W[i] = M.readInt32BE(i * 4) for (; i < 80; ++i) W[i] = rotl1(W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16]) for (var j = 0; j < 80; ++j) { var s = ~~(j / 20) var t = (rotl5(a) + ft(s, b, c, d) + e + W[j] + K[s]) | 0 e = d d = c c = rotl30(b) b = a a = t } this._a = (a + this._a) | 0 this._b = (b + this._b) | 0 this._c = (c + this._c) | 0 this._d = (d + this._d) | 0 this._e = (e + this._e) | 0 } Sha1.prototype._hash = function () { var H = new Buffer(20) H.writeInt32BE(this._a | 0, 0) H.writeInt32BE(this._b | 0, 4) H.writeInt32BE(this._c | 0, 8) H.writeInt32BE(this._d | 0, 12) H.writeInt32BE(this._e | 0, 16) return H } module.exports = Sha1 }).call(this,require("buffer").Buffer) },{"./hash":506,"buffer":61,"inherits":167}],510:[function(require,module,exports){ (function (Buffer){ /** * A JavaScript implementation of the Secure Hash Algorithm, SHA-256, as defined * in FIPS 180-2 * Version 2.2-beta Copyright Angel Marin, Paul Johnston 2000 - 2009. * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet * */ var inherits = require('inherits') var Sha256 = require('./sha256') var Hash = require('./hash') var W = new Array(64) function Sha224 () { this.init() this._w = W // new Array(64) Hash.call(this, 64, 56) } inherits(Sha224, Sha256) Sha224.prototype.init = function () { this._a = 0xc1059ed8 this._b = 0x367cd507 this._c = 0x3070dd17 this._d = 0xf70e5939 this._e = 0xffc00b31 this._f = 0x68581511 this._g = 0x64f98fa7 this._h = 0xbefa4fa4 return this } Sha224.prototype._hash = function () { var H = new Buffer(28) H.writeInt32BE(this._a, 0) H.writeInt32BE(this._b, 4) H.writeInt32BE(this._c, 8) H.writeInt32BE(this._d, 12) H.writeInt32BE(this._e, 16) H.writeInt32BE(this._f, 20) H.writeInt32BE(this._g, 24) return H } module.exports = Sha224 }).call(this,require("buffer").Buffer) },{"./hash":506,"./sha256":511,"buffer":61,"inherits":167}],511:[function(require,module,exports){ (function (Buffer){ /** * A JavaScript implementation of the Secure Hash Algorithm, SHA-256, as defined * in FIPS 180-2 * Version 2.2-beta Copyright Angel Marin, Paul Johnston 2000 - 2009. * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet * */ var inherits = require('inherits') var Hash = require('./hash') var K = [ 0x428A2F98, 0x71374491, 0xB5C0FBCF, 0xE9B5DBA5, 0x3956C25B, 0x59F111F1, 0x923F82A4, 0xAB1C5ED5, 0xD807AA98, 0x12835B01, 0x243185BE, 0x550C7DC3, 0x72BE5D74, 0x80DEB1FE, 0x9BDC06A7, 0xC19BF174, 0xE49B69C1, 0xEFBE4786, 0x0FC19DC6, 0x240CA1CC, 0x2DE92C6F, 0x4A7484AA, 0x5CB0A9DC, 0x76F988DA, 0x983E5152, 0xA831C66D, 0xB00327C8, 0xBF597FC7, 0xC6E00BF3, 0xD5A79147, 0x06CA6351, 0x14292967, 0x27B70A85, 0x2E1B2138, 0x4D2C6DFC, 0x53380D13, 0x650A7354, 0x766A0ABB, 0x81C2C92E, 0x92722C85, 0xA2BFE8A1, 0xA81A664B, 0xC24B8B70, 0xC76C51A3, 0xD192E819, 0xD6990624, 0xF40E3585, 0x106AA070, 0x19A4C116, 0x1E376C08, 0x2748774C, 0x34B0BCB5, 0x391C0CB3, 0x4ED8AA4A, 0x5B9CCA4F, 0x682E6FF3, 0x748F82EE, 0x78A5636F, 0x84C87814, 0x8CC70208, 0x90BEFFFA, 0xA4506CEB, 0xBEF9A3F7, 0xC67178F2 ] var W = new Array(64) function Sha256 () { this.init() this._w = W // new Array(64) Hash.call(this, 64, 56) } inherits(Sha256, Hash) Sha256.prototype.init = function () { this._a = 0x6a09e667 this._b = 0xbb67ae85 this._c = 0x3c6ef372 this._d = 0xa54ff53a this._e = 0x510e527f this._f = 0x9b05688c this._g = 0x1f83d9ab this._h = 0x5be0cd19 return this } function ch (x, y, z) { return z ^ (x & (y ^ z)) } function maj (x, y, z) { return (x & y) | (z & (x | y)) } function sigma0 (x) { return (x >>> 2 | x << 30) ^ (x >>> 13 | x << 19) ^ (x >>> 22 | x << 10) } function sigma1 (x) { return (x >>> 6 | x << 26) ^ (x >>> 11 | x << 21) ^ (x >>> 25 | x << 7) } function gamma0 (x) { return (x >>> 7 | x << 25) ^ (x >>> 18 | x << 14) ^ (x >>> 3) } function gamma1 (x) { return (x >>> 17 | x << 15) ^ (x >>> 19 | x << 13) ^ (x >>> 10) } Sha256.prototype._update = function (M) { var W = this._w var a = this._a | 0 var b = this._b | 0 var c = this._c | 0 var d = this._d | 0 var e = this._e | 0 var f = this._f | 0 var g = this._g | 0 var h = this._h | 0 for (var i = 0; i < 16; ++i) W[i] = M.readInt32BE(i * 4) for (; i < 64; ++i) W[i] = (gamma1(W[i - 2]) + W[i - 7] + gamma0(W[i - 15]) + W[i - 16]) | 0 for (var j = 0; j < 64; ++j) { var T1 = (h + sigma1(e) + ch(e, f, g) + K[j] + W[j]) | 0 var T2 = (sigma0(a) + maj(a, b, c)) | 0 h = g g = f f = e e = (d + T1) | 0 d = c c = b b = a a = (T1 + T2) | 0 } this._a = (a + this._a) | 0 this._b = (b + this._b) | 0 this._c = (c + this._c) | 0 this._d = (d + this._d) | 0 this._e = (e + this._e) | 0 this._f = (f + this._f) | 0 this._g = (g + this._g) | 0 this._h = (h + this._h) | 0 } Sha256.prototype._hash = function () { var H = new Buffer(32) H.writeInt32BE(this._a, 0) H.writeInt32BE(this._b, 4) H.writeInt32BE(this._c, 8) H.writeInt32BE(this._d, 12) H.writeInt32BE(this._e, 16) H.writeInt32BE(this._f, 20) H.writeInt32BE(this._g, 24) H.writeInt32BE(this._h, 28) return H } module.exports = Sha256 }).call(this,require("buffer").Buffer) },{"./hash":506,"buffer":61,"inherits":167}],512:[function(require,module,exports){ (function (Buffer){ var inherits = require('inherits') var SHA512 = require('./sha512') var Hash = require('./hash') var W = new Array(160) function Sha384 () { this.init() this._w = W Hash.call(this, 128, 112) } inherits(Sha384, SHA512) Sha384.prototype.init = function () { this._ah = 0xcbbb9d5d this._bh = 0x629a292a this._ch = 0x9159015a this._dh = 0x152fecd8 this._eh = 0x67332667 this._fh = 0x8eb44a87 this._gh = 0xdb0c2e0d this._hh = 0x47b5481d this._al = 0xc1059ed8 this._bl = 0x367cd507 this._cl = 0x3070dd17 this._dl = 0xf70e5939 this._el = 0xffc00b31 this._fl = 0x68581511 this._gl = 0x64f98fa7 this._hl = 0xbefa4fa4 return this } Sha384.prototype._hash = function () { var H = new Buffer(48) function writeInt64BE (h, l, offset) { H.writeInt32BE(h, offset) H.writeInt32BE(l, offset + 4) } writeInt64BE(this._ah, this._al, 0) writeInt64BE(this._bh, this._bl, 8) writeInt64BE(this._ch, this._cl, 16) writeInt64BE(this._dh, this._dl, 24) writeInt64BE(this._eh, this._el, 32) writeInt64BE(this._fh, this._fl, 40) return H } module.exports = Sha384 }).call(this,require("buffer").Buffer) },{"./hash":506,"./sha512":513,"buffer":61,"inherits":167}],513:[function(require,module,exports){ (function (Buffer){ var inherits = require('inherits') var Hash = require('./hash') var K = [ 0x428a2f98, 0xd728ae22, 0x71374491, 0x23ef65cd, 0xb5c0fbcf, 0xec4d3b2f, 0xe9b5dba5, 0x8189dbbc, 0x3956c25b, 0xf348b538, 0x59f111f1, 0xb605d019, 0x923f82a4, 0xaf194f9b, 0xab1c5ed5, 0xda6d8118, 0xd807aa98, 0xa3030242, 0x12835b01, 0x45706fbe, 0x243185be, 0x4ee4b28c, 0x550c7dc3, 0xd5ffb4e2, 0x72be5d74, 0xf27b896f, 0x80deb1fe, 0x3b1696b1, 0x9bdc06a7, 0x25c71235, 0xc19bf174, 0xcf692694, 0xe49b69c1, 0x9ef14ad2, 0xefbe4786, 0x384f25e3, 0x0fc19dc6, 0x8b8cd5b5, 0x240ca1cc, 0x77ac9c65, 0x2de92c6f, 0x592b0275, 0x4a7484aa, 0x6ea6e483, 0x5cb0a9dc, 0xbd41fbd4, 0x76f988da, 0x831153b5, 0x983e5152, 0xee66dfab, 0xa831c66d, 0x2db43210, 0xb00327c8, 0x98fb213f, 0xbf597fc7, 0xbeef0ee4, 0xc6e00bf3, 0x3da88fc2, 0xd5a79147, 0x930aa725, 0x06ca6351, 0xe003826f, 0x14292967, 0x0a0e6e70, 0x27b70a85, 0x46d22ffc, 0x2e1b2138, 0x5c26c926, 0x4d2c6dfc, 0x5ac42aed, 0x53380d13, 0x9d95b3df, 0x650a7354, 0x8baf63de, 0x766a0abb, 0x3c77b2a8, 0x81c2c92e, 0x47edaee6, 0x92722c85, 0x1482353b, 0xa2bfe8a1, 0x4cf10364, 0xa81a664b, 0xbc423001, 0xc24b8b70, 0xd0f89791, 0xc76c51a3, 0x0654be30, 0xd192e819, 0xd6ef5218, 0xd6990624, 0x5565a910, 0xf40e3585, 0x5771202a, 0x106aa070, 0x32bbd1b8, 0x19a4c116, 0xb8d2d0c8, 0x1e376c08, 0x5141ab53, 0x2748774c, 0xdf8eeb99, 0x34b0bcb5, 0xe19b48a8, 0x391c0cb3, 0xc5c95a63, 0x4ed8aa4a, 0xe3418acb, 0x5b9cca4f, 0x7763e373, 0x682e6ff3, 0xd6b2b8a3, 0x748f82ee, 0x5defb2fc, 0x78a5636f, 0x43172f60, 0x84c87814, 0xa1f0ab72, 0x8cc70208, 0x1a6439ec, 0x90befffa, 0x23631e28, 0xa4506ceb, 0xde82bde9, 0xbef9a3f7, 0xb2c67915, 0xc67178f2, 0xe372532b, 0xca273ece, 0xea26619c, 0xd186b8c7, 0x21c0c207, 0xeada7dd6, 0xcde0eb1e, 0xf57d4f7f, 0xee6ed178, 0x06f067aa, 0x72176fba, 0x0a637dc5, 0xa2c898a6, 0x113f9804, 0xbef90dae, 0x1b710b35, 0x131c471b, 0x28db77f5, 0x23047d84, 0x32caab7b, 0x40c72493, 0x3c9ebe0a, 0x15c9bebc, 0x431d67c4, 0x9c100d4c, 0x4cc5d4be, 0xcb3e42b6, 0x597f299c, 0xfc657e2a, 0x5fcb6fab, 0x3ad6faec, 0x6c44198c, 0x4a475817 ] var W = new Array(160) function Sha512 () { this.init() this._w = W Hash.call(this, 128, 112) } inherits(Sha512, Hash) Sha512.prototype.init = function () { this._ah = 0x6a09e667 this._bh = 0xbb67ae85 this._ch = 0x3c6ef372 this._dh = 0xa54ff53a this._eh = 0x510e527f this._fh = 0x9b05688c this._gh = 0x1f83d9ab this._hh = 0x5be0cd19 this._al = 0xf3bcc908 this._bl = 0x84caa73b this._cl = 0xfe94f82b this._dl = 0x5f1d36f1 this._el = 0xade682d1 this._fl = 0x2b3e6c1f this._gl = 0xfb41bd6b this._hl = 0x137e2179 return this } function Ch (x, y, z) { return z ^ (x & (y ^ z)) } function maj (x, y, z) { return (x & y) | (z & (x | y)) } function sigma0 (x, xl) { return (x >>> 28 | xl << 4) ^ (xl >>> 2 | x << 30) ^ (xl >>> 7 | x << 25) } function sigma1 (x, xl) { return (x >>> 14 | xl << 18) ^ (x >>> 18 | xl << 14) ^ (xl >>> 9 | x << 23) } function Gamma0 (x, xl) { return (x >>> 1 | xl << 31) ^ (x >>> 8 | xl << 24) ^ (x >>> 7) } function Gamma0l (x, xl) { return (x >>> 1 | xl << 31) ^ (x >>> 8 | xl << 24) ^ (x >>> 7 | xl << 25) } function Gamma1 (x, xl) { return (x >>> 19 | xl << 13) ^ (xl >>> 29 | x << 3) ^ (x >>> 6) } function Gamma1l (x, xl) { return (x >>> 19 | xl << 13) ^ (xl >>> 29 | x << 3) ^ (x >>> 6 | xl << 26) } function getCarry (a, b) { return (a >>> 0) < (b >>> 0) ? 1 : 0 } Sha512.prototype._update = function (M) { var W = this._w var ah = this._ah | 0 var bh = this._bh | 0 var ch = this._ch | 0 var dh = this._dh | 0 var eh = this._eh | 0 var fh = this._fh | 0 var gh = this._gh | 0 var hh = this._hh | 0 var al = this._al | 0 var bl = this._bl | 0 var cl = this._cl | 0 var dl = this._dl | 0 var el = this._el | 0 var fl = this._fl | 0 var gl = this._gl | 0 var hl = this._hl | 0 for (var i = 0; i < 32; i += 2) { W[i] = M.readInt32BE(i * 4) W[i + 1] = M.readInt32BE(i * 4 + 4) } for (; i < 160; i += 2) { var xh = W[i - 15 * 2] var xl = W[i - 15 * 2 + 1] var gamma0 = Gamma0(xh, xl) var gamma0l = Gamma0l(xl, xh) xh = W[i - 2 * 2] xl = W[i - 2 * 2 + 1] var gamma1 = Gamma1(xh, xl) var gamma1l = Gamma1l(xl, xh) // W[i] = gamma0 + W[i - 7] + gamma1 + W[i - 16] var Wi7h = W[i - 7 * 2] var Wi7l = W[i - 7 * 2 + 1] var Wi16h = W[i - 16 * 2] var Wi16l = W[i - 16 * 2 + 1] var Wil = (gamma0l + Wi7l) | 0 var Wih = (gamma0 + Wi7h + getCarry(Wil, gamma0l)) | 0 Wil = (Wil + gamma1l) | 0 Wih = (Wih + gamma1 + getCarry(Wil, gamma1l)) | 0 Wil = (Wil + Wi16l) | 0 Wih = (Wih + Wi16h + getCarry(Wil, Wi16l)) | 0 W[i] = Wih W[i + 1] = Wil } for (var j = 0; j < 160; j += 2) { Wih = W[j] Wil = W[j + 1] var majh = maj(ah, bh, ch) var majl = maj(al, bl, cl) var sigma0h = sigma0(ah, al) var sigma0l = sigma0(al, ah) var sigma1h = sigma1(eh, el) var sigma1l = sigma1(el, eh) // t1 = h + sigma1 + ch + K[j] + W[j] var Kih = K[j] var Kil = K[j + 1] var chh = Ch(eh, fh, gh) var chl = Ch(el, fl, gl) var t1l = (hl + sigma1l) | 0 var t1h = (hh + sigma1h + getCarry(t1l, hl)) | 0 t1l = (t1l + chl) | 0 t1h = (t1h + chh + getCarry(t1l, chl)) | 0 t1l = (t1l + Kil) | 0 t1h = (t1h + Kih + getCarry(t1l, Kil)) | 0 t1l = (t1l + Wil) | 0 t1h = (t1h + Wih + getCarry(t1l, Wil)) | 0 // t2 = sigma0 + maj var t2l = (sigma0l + majl) | 0 var t2h = (sigma0h + majh + getCarry(t2l, sigma0l)) | 0 hh = gh hl = gl gh = fh gl = fl fh = eh fl = el el = (dl + t1l) | 0 eh = (dh + t1h + getCarry(el, dl)) | 0 dh = ch dl = cl ch = bh cl = bl bh = ah bl = al al = (t1l + t2l) | 0 ah = (t1h + t2h + getCarry(al, t1l)) | 0 } this._al = (this._al + al) | 0 this._bl = (this._bl + bl) | 0 this._cl = (this._cl + cl) | 0 this._dl = (this._dl + dl) | 0 this._el = (this._el + el) | 0 this._fl = (this._fl + fl) | 0 this._gl = (this._gl + gl) | 0 this._hl = (this._hl + hl) | 0 this._ah = (this._ah + ah + getCarry(this._al, al)) | 0 this._bh = (this._bh + bh + getCarry(this._bl, bl)) | 0 this._ch = (this._ch + ch + getCarry(this._cl, cl)) | 0 this._dh = (this._dh + dh + getCarry(this._dl, dl)) | 0 this._eh = (this._eh + eh + getCarry(this._el, el)) | 0 this._fh = (this._fh + fh + getCarry(this._fl, fl)) | 0 this._gh = (this._gh + gh + getCarry(this._gl, gl)) | 0 this._hh = (this._hh + hh + getCarry(this._hl, hl)) | 0 } Sha512.prototype._hash = function () { var H = new Buffer(64) function writeInt64BE (h, l, offset) { H.writeInt32BE(h, offset) H.writeInt32BE(l, offset + 4) } writeInt64BE(this._ah, this._al, 0) writeInt64BE(this._bh, this._bl, 8) writeInt64BE(this._ch, this._cl, 16) writeInt64BE(this._dh, this._dl, 24) writeInt64BE(this._eh, this._el, 32) writeInt64BE(this._fh, this._fl, 40) writeInt64BE(this._gh, this._gl, 48) writeInt64BE(this._hh, this._hl, 56) return H } module.exports = Sha512 }).call(this,require("buffer").Buffer) },{"./hash":506,"buffer":61,"inherits":167}],514:[function(require,module,exports){ (function (Buffer){ var sodium = require('libsodium-wrappers') function I(b) { return Buffer.isBuffer(b) ? new Uint8Array(b) : b } function B(b) { return (b instanceof Uint8Array) ? new Buffer(b) : b } function bufferize(fn) { if('function' !== typeof fn) throw new Error('not a function') return function () { var args = [].map.call(arguments, I) var r = B(fn.apply(this, args)) return r } } function keys (k) { return { publicKey: B(k.publicKey), secretKey: B(k.secretKey || k.privateKey) } } exports.crypto_sign_seed_keypair = function (seed) { return keys(sodium.crypto_sign_seed_keypair(I(seed))) } exports.crypto_sign_keypair = function () { return keys(sodium.crypto_sign_keypair()) } exports.crypto_box_keypair = function () { return keys(sodium.crypto_box_keypair()) } ;[ 'sign_verify_detached', 'sign_detached', 'sign', 'sign_open', 'sign_ed25519_pk_to_curve25519', 'sign_ed25519_sk_to_curve25519', 'scalarmult', 'secretbox_easy', 'secretbox_open_easy', 'box_easy', 'box_open_easy', 'auth', 'auth_verify', 'hash' ].forEach(function (name) { if(name === 'auth_verify') { //this is inconsistent with sign_verify!! var fn = bufferize(sodium.crypto_auth_verify) exports['crypto_'+name] = function (msg, tok, key) { return fn(msg, tok, key) ? 0 : 1 } } else exports['crypto_'+name] = bufferize(sodium['crypto_'+name]) }) var Sha256 = require('sha.js/sha256') exports.crypto_hash_sha256 = function (msg) { return new Sha256().update(msg).digest() } function nullIfThrew (fn) { return function () { try { return fn.apply(this, [].slice.call(arguments)) } catch (err) { return null } } } exports.crypto_secretbox_open_easy = nullIfThrew(exports.crypto_secretbox_open_easy) exports.crypto_box_open_easy = nullIfThrew(exports.crypto_box_open_easy) }).call(this,require("buffer").Buffer) },{"buffer":61,"libsodium-wrappers":222,"sha.js/sha256":511}],515:[function(require,module,exports){ //only exports browser api. use chloride module //to get automatic fallbacks! module.exports = require('./browser') },{"./browser":514}],516:[function(require,module,exports){ module.exports = function split (data, max) { if(max <= 0) throw new Error('cannot split into zero (or smaller) length buffers') if(data.length <= max) return [data] var out = [], len = 0 while(len < data.length) { out.push(data.slice(len, Math.min(len + max, data.length))) len += max } return out } },{}],517:[function(require,module,exports){ var path = require('path') var home = require('osenv').home var nonPrivate = require('non-private-ip') var merge = require('deep-extend') var RC = require('rc') var SEC = 1e3 var MIN = 60*SEC module.exports = function (name, override) { name = name || 'ssb' return RC(name || 'ssb', merge({ //just use an ipv4 address by default. //there have been some reports of seemingly non-private //ipv6 addresses being returned and not working. //https://github.com/ssbc/scuttlebot/pull/102 party: true, host: nonPrivate.v4 || '', port: 8008, timeout: 0, pub: true, local: true, friends: { dunbar: 150, hops: 3 }, gossip: { connections: 3 }, path: path.join(home(), '.' + name), timers: { connection: 0, reconnect: 5*SEC, ping: 5*MIN, handshake: 5*SEC }, path: path.join(home(), '.' + name), master: [], logging: { level: 'notice' }, party: true //disable quotas }, override || {})) } },{"deep-extend":111,"non-private-ip":518,"osenv":282,"path":290,"rc":404}],518:[function(require,module,exports){ arguments[4][464][0].apply(exports,arguments) },{"dup":464,"ip":169,"os":279}],519:[function(require,module,exports){ (function (Buffer){ var cont = require('cont') var util = require('./util') var ssbKeys = require('ssb-keys') function isFunction (f) { return 'function' === typeof f } function isObject (o) { return ( o && 'object' === typeof o && !Buffer.isBuffer(o) && !Array.isArray(o) ) } module.exports = function (ssb, keys) { if(!ssb.add) throw new Error('*must* install feeds on this ssb instance') function getPrev(next) { ssb.getLatest(keys.id, next) } function noop (err) { if (err) throw err } var queue = null var prev = null var writing = false var publish = cont(function (type, message, cb) { // argument variations if (isFunction(message)) { cb = message; message = type } // add(msgObj, cbFn) else if (isObject(message)) { message.type = type } // add(typeStr, mgObj, cbFn) else { message = { type: type, value: message } } // add(typeStr, msgStr, cbFn) var err = util.isInvalidContent(message) if(err) return cb(err) return ssb.add.queue(keys.id, function (key, value) { return util.create(keys, null, message, value, key) }, cb) return this }) return { id: keys.id, keys: keys, add: publish, publish: publish } } }).call(this,{"isBuffer":require("../is-buffer/index.js")}) },{"../is-buffer/index.js":170,"./util":520,"cont":86,"ssb-keys":530}],520:[function(require,module,exports){ (function (Buffer){ var ssbKeys = require('ssb-keys') var timestamp = require('monotonic-timestamp') var isRef = require('ssb-ref') var isHash = isRef.isHash var isFeedId = isRef.isFeedId var encode = exports.encode = function (obj) { return JSON.stringify(obj, null, 2) } function isString (s) { return 'string' === typeof s } function isInteger (n) { return ~~n === n } function isObject (o) { return o && 'object' === typeof o } function clone (obj) { var o = {} for(var k in obj) o[k] = obj[k]; return o } function isEncrypted (str) { return isString(str) && /^[0-9A-Za-z\/+]+={0,2}\.box/.test(str) } exports.BatchQueue = function BatchQueue (db) { var batch = [], writing = false function drain () { writing = true var _batch = batch batch = [] db.batch(_batch, function () { writing = false write.size = batch.length if(batch.length) drain() _batch.forEach(function (op) { op.cb(null, {key:op.key, value: op.value}) }) }) } function write (op) { batch.push(op) write.size = batch.length if(!writing) drain() } write.size = 0 return write } exports.create = function (keys, type, content, prev, prev_key) { //this noise is to handle things calling this with legacy api. if(isString(type) && (Buffer.isBuffer(content) || isString(content))) content = {type: type, value: content} if(isObject(content)) content.type = content.type || type //noise end prev_key = !prev_key && prev ? ('%'+ssbKeys.hash(encode(prev))) : prev_key || null return ssbKeys.signObj(keys, { previous: prev_key, author: keys.id, sequence: prev ? prev.sequence + 1 : 1, timestamp: timestamp(), hash: 'sha256', content: content, }) } var isInvalidContent = exports.isInvalidContent = function (content) { if(!isEncrypted(content)) { type = content.type if (!(isString(type) && type.length <= 52 && type.length >= 3)) { return new Error('type must be a string' + '3 <= type.length < 52, was:' + type ) } } return false } exports.isInvalidShape = function (msg) { if( !isObject(msg) || !isInteger(msg.sequence) || !isFeedId(msg.author) || !(isObject(msg.content) || isEncrypted(msg.content)) ) return new Error('message has invalid properties') //allow encrypted messages, where content is a base64 string. var asJson = encode(msg) if (asJson.length > 8192) // 8kb return new Error( 'encoded message must not be larger than 8192 bytes') return isInvalidContent(msg.content) } exports.isInvalid = function validateSync (pub, msg, previous) { // :TODO: is there a faster way to measure the size of this message? var key = previous.key var prev = previous.value if(prev) { if(msg.previous !== key) return new Error( 'expected previous: ' + key + 'but found:' + msg.previous ) if(msg.sequence !== prev.sequence + 1 || msg.timestamp <= prev.timestamp) return new Error('out of order') } else { if(!(msg.previous == null && msg.sequence === 1 && msg.timestamp > 0)) return new Error('expected initial message') } if(msg.author !== pub) { return new Error( 'expected different author:' + hash(pub.public || pub).toString('base64') + 'but found:' + msg.author.toString('base64') ) } if(!ssbKeys.verifyObj(pub, msg)) return new Error('signature was invalid') return false } }).call(this,{"isBuffer":require("../is-buffer/index.js")}) },{"../is-buffer/index.js":170,"monotonic-timestamp":249,"ssb-keys":530,"ssb-ref":573}],521:[function(require,module,exports){ 'use strict'; var hash = require('ssb-keys').hash // make a validation stream? // read the latest record in the database // check it against the incoming data, // and then read through function isString (s) { return 'string' === typeof s } function isInteger (n) { return ~~n === n } function isObject (o) { return o && 'object' === typeof o } var util = require('./util') var encode = util.encode module.exports = function (ssb) { var write = util.BatchQueue(ssb) function getLatest (id, cb) { ssb.getLatest(id, function (err, data) { if(err) return cb(null, {key: null, value: null, type: 'put', public: null, ready: true}) cb(null, { key: data.key, value: data.value, type: 'put', public: data.value && data.value.author, ready: true }) }) } var latest = {} function setLatest(id) { if(latest[id].ready) throw new Error('setLatest should only be called once') ssb.getLatest(id, function (err, data) { latest[id].ready = true if(data) { latest[id].key = data.key latest[id].value = data.value } validate(id) }) } function validate(id) { var feed = latest[id] if(!feed.queue.length) return if(!feed.ready) return while(feed.queue.length) { var op = feed.queue.shift() if('function' == typeof op.create) { op.value = op.create(feed.key, feed.value) op.key = '%'+hash(encode(op.value)) } var err = util.isInvalidShape(op.value) || util.isInvalid(id, op.value, feed) if(err) op.cb(err) else { feed.key = op.key feed.value = op.value feed.ts = Date.now() write(op) } } } function queue (id, job) { if(!latest[id]) { latest[id] = { key:null, value: null, ready: false, queue: [], ts: Date.now() } latest[id].queue.push(job) setLatest(id) } else latest[id].queue.push(job) validate(id) } function add (msg, cb) { var err = util.isInvalidShape(msg) if(err) return cb(err) queue(msg.author, { key: '%'+hash(encode(msg)), value: msg, cb: cb, create: null }) } add.queue = function (id, create, cb) { queue(id, { key: null, value: null, create: create, cb: cb }) } return add } },{"./util":520,"ssb-keys":530}],522:[function(require,module,exports){ var pull = require('pull-stream') var toPull = require('stream-to-pull-stream') var cat = require('pull-cat') var ident = require('pull-identify-filetype') var mime = require('mime-types') var URL = require('url') var fs = require('fs') var refs = require('ssb-ref') var Stack = require('stack') var ip = require('ip') exports = module.exports = function (sbot, config) { require('http').createServer(exports.BlobStack(sbot)).listen(7777) } function respond (res, status, message) { res.writeHead(status) res.end(message) } function respondSource (res, source, wrap) { if(wrap) { res.writeHead(200, {'Content-Type': 'text/html'}) pull( cat([ pull.once('') ]), toPull.sink(res) ) } else { pull( source, ident(function (type) { if (type) res.writeHead(200, {'Content-Type': mime.lookup(type)}) }), toPull.sink(res) ) } } var Localhost = exports.Localhost = function () { return function (req, res, next) { if (!ip.isLoopback(req.socket.remoteAddress)) return respond(res, 403, 'Remote access forbidden') next() } } var CSP = exports.CSP = function (origin) { return function (req, res, next) { res.setHeader('Content-Security-Policy', "default-src "+origin+" 'unsafe-inline' 'unsafe-eval' data:; "+ "object-src 'none'; "+ "frame-src 'none'; "+ "sandbox" ) next() } } var ServeBlobs = exports.ServeBlobs = function (sbot) { return function (req, res, next) { var parsed = URL.parse(req.url, true) var hash = parsed.pathname.slice(1) sbot.blobs.want(hash, function(err, has) { if (!has) return respond(res, 404, 'File not found') // optional name override if (parsed.query.name) res.setHeader('Content-Disposition', 'inline; filename='+encodeURIComponent(parsed.query.name)) // serve respondSource(res, sbot.blobs.get(hash), false) }) } } var ServeFiles = exports.ServeFiles = function () { return function (req, res, next) { var parsed = URL.parse(req.url, true) fs.stat(parsed.pathname, function (err, stat) { if(err) return respond(res, 404, 'File not found') if(!stat.isFile()) return respond(res, 403, 'May only load filess') respondSource( res, toPull.source(fs.createReadStream(parsed.pathname)), false ) }) } } exports.BlobStack = function (sbot, opts) { return Stack( Localhost(), CSP('http://localhost:7777'), ServeBlobs(sbot) ) } exports.FileStack = function (opts) { return Stack( Localhost(), CSP('http://localhost:7777'), ServeFiles() ) } },{"fs":58,"http":588,"ip":523,"mime-types":245,"pull-cat":305,"pull-identify-filetype":335,"pull-stream":524,"ssb-ref":573,"stack":574,"stream-to-pull-stream":593,"url":632}],523:[function(require,module,exports){ 'use strict'; var ip = exports; var Buffer = require('buffer').Buffer; var os = require('os'); ip.toBuffer = function(ip, buff, offset) { offset = ~~offset; var result; if (this.isV4Format(ip)) { result = buff || new Buffer(offset + 4); ip.split(/\./g).map(function(byte) { result[offset++] = parseInt(byte, 10) & 0xff; }); } else if (this.isV6Format(ip)) { var sections = ip.split(':', 8); var i; for (i = 0; i < sections.length; i++) { var isv4 = this.isV4Format(sections[i]); var v4Buffer; if (isv4) { v4Buffer = this.toBuffer(sections[i]); sections[i] = v4Buffer.slice(0, 2).toString('hex'); } if (v4Buffer && ++i < 8) { sections.splice(i, 0, v4Buffer.slice(2, 4).toString('hex')); } } if (sections[0] === '') { while (sections.length < 8) sections.unshift('0'); } else if (sections[sections.length - 1] === '') { while (sections.length < 8) sections.push('0'); } else if (sections.length < 8) { for (i = 0; i < sections.length && sections[i] !== ''; i++); var argv = [ i, 1 ]; for (i = 9 - sections.length; i > 0; i--) { argv.push('0'); } sections.splice.apply(sections, argv); } result = buff || new Buffer(offset + 16); for (i = 0; i < sections.length; i++) { var word = parseInt(sections[i], 16); result[offset++] = (word >> 8) & 0xff; result[offset++] = word & 0xff; } } if (!result) { throw Error('Invalid ip address: ' + ip); } return result; }; ip.toString = function(buff, offset, length) { offset = ~~offset; length = length || (buff.length - offset); var result = []; if (length === 4) { // IPv4 for (var i = 0; i < length; i++) { result.push(buff[offset + i]); } result = result.join('.'); } else if (length === 16) { // IPv6 for (var i = 0; i < length; i += 2) { result.push(buff.readUInt16BE(offset + i).toString(16)); } result = result.join(':'); result = result.replace(/(^|:)0(:0)*:0(:|$)/, '$1::$3'); result = result.replace(/:{3,4}/, '::'); } return result; }; var ipv4Regex = /^(\d{1,3}\.){3,3}\d{1,3}$/; var ipv6Regex = /^(::)?(((\d{1,3}\.){3}(\d{1,3}){1})?([0-9a-f]){0,4}:{0,2}){1,8}(::)?$/i; ip.isV4Format = function(ip) { return ipv4Regex.test(ip); }; ip.isV6Format = function(ip) { return ipv6Regex.test(ip); }; function _normalizeFamily(family) { return family ? family.toLowerCase() : 'ipv4'; } ip.fromPrefixLen = function(prefixlen, family) { if (prefixlen > 32) { family = 'ipv6'; } else { family = _normalizeFamily(family); } var len = 4; if (family === 'ipv6') { len = 16; } var buff = new Buffer(len); for (var i = 0, n = buff.length; i < n; ++i) { var bits = 8; if (prefixlen < 8) { bits = prefixlen; } prefixlen -= bits; buff[i] = ~(0xff >> bits); } return ip.toString(buff); }; ip.mask = function(addr, mask) { addr = ip.toBuffer(addr); mask = ip.toBuffer(mask); var result = new Buffer(Math.max(addr.length, mask.length)); // Same protocol - do bitwise and if (addr.length === mask.length) { for (var i = 0; i < addr.length; i++) { result[i] = addr[i] & mask[i]; } } else if (mask.length === 4) { // IPv6 address and IPv4 mask // (Mask low bits) for (var i = 0; i < mask.length; i++) { result[i] = addr[addr.length - 4 + i] & mask[i]; } } else { // IPv6 mask and IPv4 addr for (var i = 0; i < result.length - 6; i++) { result[i] = 0; } // ::ffff:ipv4 result[10] = 0xff; result[11] = 0xff; for (var i = 0; i < addr.length; i++) { result[i + 12] = addr[i] & mask[i + 12]; } } return ip.toString(result); }; ip.cidr = function(cidrString) { var cidrParts = cidrString.split('/'); var addr = cidrParts[0]; if (cidrParts.length !== 2) throw new Error('invalid CIDR subnet: ' + addr); var mask = ip.fromPrefixLen(parseInt(cidrParts[1], 10)); return ip.mask(addr, mask); }; ip.subnet = function(addr, mask) { var networkAddress = ip.toLong(ip.mask(addr, mask)); // Calculate the mask's length. var maskBuffer = ip.toBuffer(mask); var maskLength = 0; for (var i = 0; i < maskBuffer.length; i++) { if (maskBuffer[i] === 0xff) { maskLength += 8; } else { var octet = maskBuffer[i] & 0xff; while (octet) { octet = (octet << 1) & 0xff; maskLength++; } } } var numberOfAddresses = Math.pow(2, 32 - maskLength); return { networkAddress: ip.fromLong(networkAddress), firstAddress: numberOfAddresses <= 2 ? ip.fromLong(networkAddress) : ip.fromLong(networkAddress + 1), lastAddress: numberOfAddresses <= 2 ? ip.fromLong(networkAddress + numberOfAddresses - 1) : ip.fromLong(networkAddress + numberOfAddresses - 2), broadcastAddress: ip.fromLong(networkAddress + numberOfAddresses - 1), subnetMask: mask, subnetMaskLength: maskLength, numHosts: numberOfAddresses <= 2 ? numberOfAddresses : numberOfAddresses - 2, length: numberOfAddresses, contains: function(other) { return networkAddress === ip.toLong(ip.mask(other, mask)); } }; }; ip.cidrSubnet = function(cidrString) { var cidrParts = cidrString.split('/'); var addr = cidrParts[0]; if (cidrParts.length !== 2) throw new Error('invalid CIDR subnet: ' + addr); var mask = ip.fromPrefixLen(parseInt(cidrParts[1], 10)); return ip.subnet(addr, mask); }; ip.not = function(addr) { var buff = ip.toBuffer(addr); for (var i = 0; i < buff.length; i++) { buff[i] = 0xff ^ buff[i]; } return ip.toString(buff); }; ip.or = function(a, b) { a = ip.toBuffer(a); b = ip.toBuffer(b); // same protocol if (a.length === b.length) { for (var i = 0; i < a.length; ++i) { a[i] |= b[i]; } return ip.toString(a); // mixed protocols } else { var buff = a; var other = b; if (b.length > a.length) { buff = b; other = a; } var offset = buff.length - other.length; for (var i = offset; i < buff.length; ++i) { buff[i] |= other[i - offset]; } return ip.toString(buff); } }; ip.isEqual = function(a, b) { a = ip.toBuffer(a); b = ip.toBuffer(b); // Same protocol if (a.length === b.length) { for (var i = 0; i < a.length; i++) { if (a[i] !== b[i]) return false; } return true; } // Swap if (b.length === 4) { var t = b; b = a; a = t; } // a - IPv4, b - IPv6 for (var i = 0; i < 10; i++) { if (b[i] !== 0) return false; } var word = b.readUInt16BE(10); if (word !== 0 && word !== 0xffff) return false; for (var i = 0; i < 4; i++) { if (a[i] !== b[i + 12]) return false; } return true; }; ip.isPrivate = function(addr) { return /^(::f{4}:)?10\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/i .test(addr) || /^(::f{4}:)?192\.168\.([0-9]{1,3})\.([0-9]{1,3})$/i.test(addr) || /^(::f{4}:)?172\.(1[6-9]|2\d|30|31)\.([0-9]{1,3})\.([0-9]{1,3})$/i .test(addr) || /^(::f{4}:)?127\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/i.test(addr) || /^(::f{4}:)?169\.254\.([0-9]{1,3})\.([0-9]{1,3})$/i.test(addr) || /^f[cd][0-9a-f]{2}:/i.test(addr) || /^fe80:/i.test(addr) || /^::1$/.test(addr) || /^::$/.test(addr); }; ip.isPublic = function(addr) { return !ip.isPrivate(addr); }; ip.isLoopback = function(addr) { return /^(::f{4}:)?127\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})/ .test(addr) || /^fe80::1$/.test(addr) || /^::1$/.test(addr) || /^::$/.test(addr); }; ip.loopback = function(family) { // // Default to `ipv4` // family = _normalizeFamily(family); if (family !== 'ipv4' && family !== 'ipv6') { throw new Error('family must be ipv4 or ipv6'); } return family === 'ipv4' ? '127.0.0.1' : 'fe80::1'; }; // // ### function address (name, family) // #### @name {string|'public'|'private'} **Optional** Name or security // of the network interface. // #### @family {ipv4|ipv6} **Optional** IP family of the address (defaults // to ipv4). // // Returns the address for the network interface on the current system with // the specified `name`: // * String: First `family` address of the interface. // If not found see `undefined`. // * 'public': the first public ip address of family. // * 'private': the first private ip address of family. // * undefined: First address with `ipv4` or loopback address `127.0.0.1`. // ip.address = function(name, family) { var interfaces = os.networkInterfaces(); var all; // // Default to `ipv4` // family = _normalizeFamily(family); // // If a specific network interface has been named, // return the address. // if (name && name !== 'private' && name !== 'public') { var res = interfaces[name].filter(function(details) { var itemFamily = details.family.toLowerCase(); return itemFamily === family; }); if (res.length === 0) return undefined; return res[0].address; } var all = Object.keys(interfaces).map(function (nic) { // // Note: name will only be `public` or `private` // when this is called. // var addresses = interfaces[nic].filter(function (details) { details.family = details.family.toLowerCase(); if (details.family !== family || ip.isLoopback(details.address)) { return false; } else if (!name) { return true; } return name === 'public' ? !ip.isPrivate(details.address) : ip.isPrivate(details.address); }); return addresses.length ? addresses[0].address : undefined; }).filter(Boolean); return !all.length ? ip.loopback(family) : all[0]; }; ip.toLong = function(ip) { var ipl = 0; ip.split('.').forEach(function(octet) { ipl <<= 8; ipl += parseInt(octet); }); return(ipl >>> 0); }; ip.fromLong = function(ipl) { return ((ipl >>> 24) + '.' + (ipl >> 16 & 255) + '.' + (ipl >> 8 & 255) + '.' + (ipl & 255) ); }; },{"buffer":61,"os":279}],524:[function(require,module,exports){ arguments[4][232][0].apply(exports,arguments) },{"./pull":525,"./sinks":526,"./sources":527,"./throughs":528,"dup":232}],525:[function(require,module,exports){ arguments[4][233][0].apply(exports,arguments) },{"dup":233}],526:[function(require,module,exports){ arguments[4][234][0].apply(exports,arguments) },{"dup":234}],527:[function(require,module,exports){ arguments[4][235][0].apply(exports,arguments) },{"dup":235}],528:[function(require,module,exports){ arguments[4][236][0].apply(exports,arguments) },{"./sinks":526,"./sources":527,"dup":236}],529:[function(require,module,exports){ var ecc = require('eccjs') var crypto = require('crypto') var Blake2s = require('blake2s') var curve = ecc.curves.k256 function hash (message) { return new Blake2s().update(message).digest() } module.exports = { curves: ['k256'], generate: function (seed) { //we use eccjs.restore here, instead of eccjs.generate //because we trust node's random generator much more than //sjcl's (via crypto-browserify's polyfil this uses //webcrypto's random generator in the browser) var keys = ecc.restore(curve, seed || crypto.randomBytes(32)) return { curve: 'k256', public: keys.public, private: keys.private } }, sign: function (private, message) { return ecc.sign(curve, private, hash(message)) }, verify: function (public, sig, message) { return ecc.verify(curve, public, sig, hash(message)) }, restore: function (seed) { return ecc.restore(curve, seed) } } },{"blake2s":28,"crypto":110,"eccjs":124}],530:[function(require,module,exports){ (function (Buffer){ var fs = require('fs') var mkdirp = require('mkdirp') var path = require('path') var deepEqual = require('deep-equal') var crypto = require('crypto') var createHmac = require('hmac') var sodium = require('chloride') var ssbref = require('ssb-ref') var pb = require('private-box') var isBuffer = Buffer.isBuffer function isString (s) { return 'string' === typeof s } //UTILS function clone (obj) { var _obj = {} for(var k in obj) { if(Object.hasOwnProperty.call(obj, k)) _obj[k] = obj[k] } return _obj } function hash (data, enc) { data = ( 'string' === typeof data && enc == null ? new Buffer(data, 'binary') : new Buffer(data, enc) ) return crypto.createHash('sha256').update(data).digest('base64')+'.sha256' } var isLink = ssbref.isLink var isFeedId = ssbref.isFeedId exports.hash = hash function isObject (o) { return 'object' === typeof o } function isFunction (f) { return 'function' === typeof f } function isString(s) { return 'string' === typeof s } function hasSigil (s) { return /^(@|%|&)/.test(s) } function empty(v) { return !!v } function toBuffer(buf) { if(buf == null) return buf if(Buffer.isBuffer(buf)) throw new Error('already a buffer') var i = buf.indexOf('.') var start = (hasSigil(buf)) ? 1 : 0 return new Buffer(buf.substring(start, ~i ? i : buf.length), 'base64') } function toUint8(buf) { return new Uint8Array(toBuffer(buf)) } function getTag (string) { var i = string.indexOf('.') return string.substring(i+1) } exports.getTag = getTag function tag (key, tag) { if(!tag) throw new Error('no tag for:' + key.toString('base64')) return key.toString('base64')+'.' + tag.replace(/^\./, '') } function keysToJSON(keys, curve) { curve = (keys.curve || curve) var pub = tag(keys.public.toString('base64'), curve) return { curve: curve, public: pub, private: keys.private ? tag(keys.private.toString('base64'), curve) : undefined, id: '@'+(curve === 'ed25519' ? pub : hash(pub)) } } //(DE)SERIALIZE KEYS function constructKeys(keys, legacy) { if(!keys) throw new Error('*must* pass in keys') return [ '# this is your SECRET name.', '# this name gives you magical powers.', '# with it you can mark your messages so that your friends can verify', '# that they really did come from you.', '#', '# if any one learns this name, they can use it to destroy your identity', '# NEVER show this to anyone!!!', '', legacy ? keys.private : JSON.stringify(keys, null, 2), '', '# WARNING! It\'s vital that you DO NOT edit OR share your secret name', '# instead, share your public name', '# your public name: ' + keys.id ].join('\n') } function reconstructKeys(keyfile) { var private = keyfile .replace(/\s*\#[^\n]*/g, '') .split('\n').filter(empty).join('') //if the key is in JSON format, we are good. try { var keys = JSON.parse(private) if(!hasSigil(keys.id)) keys.id = '@' + keys.public return keys } catch (_) {} //else, reconstruct legacy curve... var curve = getTag(private) if(curve !== 'k256') throw new Error('expected legacy curve (k256) but found:' + curve) var ecc = require('./eccjs') return keysToJSON(ecc.restore(toBuffer(private)), 'k256') } var toNameFile = exports.toNameFile = function (namefile) { if(isObject(namefile)) return path.join(namefile.path, 'secret') return namefile } exports.load = function(namefile, cb) { namefile = toNameFile(namefile) fs.readFile(namefile, 'ascii', function(err, privateKeyStr) { if (err) return cb(err) try { cb(null, reconstructKeys(privateKeyStr)) } catch (e) { cb(err) } }) } exports.loadSync = function(namefile) { namefile = toNameFile(namefile) return reconstructKeys(fs.readFileSync(namefile, 'ascii')) } exports.create = function(namefile, curve, legacy, cb) { if(isFunction(legacy)) cb = legacy, legacy = null if(isFunction(curve)) cb = curve, curve = null namefile = toNameFile(namefile) var keys = exports.generate(curve) var keyfile = constructKeys(keys, legacy) mkdirp(path.dirname(namefile), function (err) { if(err) return cb(err) fs.writeFile(namefile, keyfile, function(err) { if (err) return cb(err) cb(null, keys) }) }) } exports.createSync = function(namefile, curve, legacy) { namefile = toNameFile(namefile) var keys = exports.generate(curve) var keyfile = constructKeys(keys, legacy) mkdirp.sync(path.dirname(namefile)) fs.writeFileSync(namefile, keyfile) return keys } exports.loadOrCreate = function (namefile, cb) { namefile = toNameFile(namefile) exports.load(namefile, function (err, keys) { if(!err) return cb(null, keys) exports.create(namefile, cb) }) } exports.loadOrCreateSync = function (namefile) { namefile = toNameFile(namefile) try { return exports.loadSync(namefile) } catch (err) { return exports.createSync(namefile) } } // DIGITAL SIGNATURES var curves = {} curves.ed25519 = require('./sodium') try { curves.k256 = require('./eccjs') } catch (_) {} function getCurve(keys) { var curve = keys.curve if(!keys.curve && isString(keys.public)) keys = keys.public if(!curve && isString(keys)) curve = getTag(keys) if(!curves[curve]) { throw new Error( 'unkown curve:' + curve + ' expected: '+Object.keys(curves) ) } return curve } //this should return a key pair: // {curve: curve, public: Buffer, private: Buffer} exports.generate = function (curve, seed) { curve = curve || 'ed25519' if(!curves[curve]) throw new Error('unknown curve:'+curve) return keysToJSON(curves[curve].generate(seed), curve) } //takes a public key and a hash and returns a signature. //(a signature must be a node buffer) exports.sign = function (keys, msg) { if(isString(msg)) msg = new Buffer(msg) if(!isBuffer(msg)) throw new Error('msg should be buffer') var curve = getCurve(keys) return curves[curve] .sign(toBuffer(keys.private || keys), msg) .toString('base64')+'.sig.'+curve } //takes a public key, signature, and a hash //and returns true if the signature was valid. exports.verify = function (keys, sig, msg) { if(isObject(sig)) throw new Error('signature should be base64 string, did you mean verifyObj(public, signed_obj)') return curves[getCurve(keys)].verify( toBuffer(keys.public || keys), toBuffer(sig), isBuffer(msg) ? msg : new Buffer(msg) ) } // OTHER CRYTPO FUNCTIONS exports.hmac = function (data, key) { return createHmac(createHash, 64, key) .update(data).digest('base64')+'.sha256.hmac' } exports.signObj = function (keys, obj) { var _obj = clone(obj) var b = new Buffer(JSON.stringify(_obj, null, 2)) _obj.signature = exports.sign(keys, b) return _obj } exports.verifyObj = function (keys, obj) { obj = clone(obj) var sig = obj.signature delete obj.signature var b = new Buffer(JSON.stringify(obj, null, 2)) return exports.verify(keys, sig, b) } exports.box = function (msg, recipients) { msg = new Buffer(JSON.stringify(msg)) recipients = recipients.map(function (keys) { var public = keys.public || keys return sodium.crypto_sign_ed25519_pk_to_curve25519(toBuffer(public)) }) //it's since the nonce is 24 bytes (a multiple of 3) //it's possible to concatenate the base64 strings //and still have a valid base64 string. return pb.multibox(msg, recipients).toString('base64')+'.box' } exports.unbox = function (boxed, keys) { boxed = toBuffer(boxed) var sk = sodium.crypto_sign_ed25519_sk_to_curve25519(toBuffer(keys.private || keys)) var msg = pb.multibox_open(boxed, sk) if(msg) return JSON.parse(''+msg) } }).call(this,require("buffer").Buffer) },{"./eccjs":529,"./sodium":534,"buffer":61,"chloride":80,"crypto":110,"deep-equal":531,"fs":58,"hmac":161,"mkdirp":248,"path":290,"private-box":293,"ssb-ref":573}],531:[function(require,module,exports){ var pSlice = Array.prototype.slice; var objectKeys = require('./lib/keys.js'); var isArguments = require('./lib/is_arguments.js'); var deepEqual = module.exports = function (actual, expected, opts) { if (!opts) opts = {}; // 7.1. All identical values are equivalent, as determined by ===. if (actual === expected) { return true; } else if (actual instanceof Date && expected instanceof Date) { return actual.getTime() === expected.getTime(); // 7.3. Other pairs that do not both pass typeof value == 'object', // equivalence is determined by ==. } else if (typeof actual != 'object' && typeof expected != 'object') { return opts.strict ? actual === expected : actual == expected; // 7.4. For all other Object pairs, including Array objects, equivalence is // determined by having the same number of owned properties (as verified // with Object.prototype.hasOwnProperty.call), the same set of keys // (although not necessarily the same order), equivalent values for every // corresponding key, and an identical 'prototype' property. Note: this // accounts for both named and indexed properties on Arrays. } else { return objEquiv(actual, expected, opts); } } function isUndefinedOrNull(value) { return value === null || value === undefined; } function isBuffer (x) { if (!x || typeof x !== 'object' || typeof x.length !== 'number') return false; if (typeof x.copy !== 'function' || typeof x.slice !== 'function') { return false; } if (x.length > 0 && typeof x[0] !== 'number') return false; return true; } function objEquiv(a, b, opts) { var i, key; if (isUndefinedOrNull(a) || isUndefinedOrNull(b)) return false; // an identical 'prototype' property. if (a.prototype !== b.prototype) return false; //~~~I've managed to break Object.keys through screwy arguments passing. // Converting to array solves the problem. if (isArguments(a)) { if (!isArguments(b)) { return false; } a = pSlice.call(a); b = pSlice.call(b); return deepEqual(a, b, opts); } if (isBuffer(a)) { if (!isBuffer(b)) { return false; } if (a.length !== b.length) return false; for (i = 0; i < a.length; i++) { if (a[i] !== b[i]) return false; } return true; } try { var ka = objectKeys(a), kb = objectKeys(b); } catch (e) {//happens when one is a string literal and the other isn't return false; } // having the same number of owned properties (keys incorporates // hasOwnProperty) if (ka.length != kb.length) return false; //the same set of keys (although not necessarily the same order), ka.sort(); kb.sort(); //~~~cheap key test for (i = ka.length - 1; i >= 0; i--) { if (ka[i] != kb[i]) return false; } //equivalent values for every corresponding key, and //~~~possibly expensive deep test for (i = ka.length - 1; i >= 0; i--) { key = ka[i]; if (!deepEqual(a[key], b[key], opts)) return false; } return typeof a === typeof b; } },{"./lib/is_arguments.js":532,"./lib/keys.js":533}],532:[function(require,module,exports){ var supportsArgumentsClass = (function(){ return Object.prototype.toString.call(arguments) })() == '[object Arguments]'; exports = module.exports = supportsArgumentsClass ? supported : unsupported; exports.supported = supported; function supported(object) { return Object.prototype.toString.call(object) == '[object Arguments]'; }; exports.unsupported = unsupported; function unsupported(object){ return object && typeof object == 'object' && typeof object.length == 'number' && Object.prototype.hasOwnProperty.call(object, 'callee') && !Object.prototype.propertyIsEnumerable.call(object, 'callee') || false; }; },{}],533:[function(require,module,exports){ exports = module.exports = typeof Object.keys === 'function' ? Object.keys : shim; exports.shim = shim; function shim (obj) { var keys = []; for (var key in obj) keys.push(key); return keys; } },{}],534:[function(require,module,exports){ var sodium = require('chloride') var crypto = require('crypto') module.exports = { curves: ['ed25519'], generate: function (seed) { var keys = sodium.crypto_sign_seed_keypair(seed || crypto.randomBytes(32)) return { curve: 'ed25519', public: keys.publicKey, //so that this works with either sodium //or libsodium-wrappers (in browser) private: keys.privateKey || keys.secretKey } }, sign: function (private, message) { return sodium.crypto_sign_detached(message, private) }, verify: function (public, sig, message) { return sodium.crypto_sign_verify_detached(sig, message, public) } } },{"chloride":80,"crypto":110}],535:[function(require,module,exports){ (function (process){ var pull = require('pull-stream') var Links = require('streamview-links') var path = require('path') var extractLinks = require('./links') //we could have up to six indexes for links, //but these are the three that we really need. //(queries are fast if the fields you already know //are left most, and the ranges are to the right of that. var indexes = [ { key: 'SRD', value: ['source', 'rel', 'dest', 'ts'] }, { key: 'DRS', value: ['dest', 'rel', 'source', 'ts'] }, { key: 'RDS', value: ['rel', 'dest', 'source', 'ts'] } ] exports.name = 'links2' exports.manifest = { read: 'source', dump: 'source' } exports.init = function (ssb, config) { var dir = path.join(config.path, 'links') var version = 5 //it's really nice to tweak a few things //and then change the version number, //restart the server and have it regenerate the indexes, //all consistent again. var links = Links(dir, indexes, extractLinks, version) links.init(function (err, since) { console.error('LOAD LINKS SINCE', err, since) pull( ssb.createLogStream({gt: since || 0, live: true, limit: -1}), pull.through(function (e) { process.stderr.write('.') }), links.write(function (err) { if(err) throw err }) ) }) return { dump: function () { return links.dump() }, read: function (opts) { if(opts && 'string' == typeof opts) try { opts = {query: JSON.parse(opts) } } catch (err) { return pull.error(err) } return links.read(opts) } } } }).call(this,require('_process')) },{"./links":536,"_process":295,"path":290,"pull-stream":537,"streamview-links":595}],536:[function(require,module,exports){ var msgs = require('ssb-msgs') module.exports = function (data, iter) { if(data.sync) return var content = data.value.content var source = data.value.author //TODO parse the links from markdown //and index those also. most of these are http links, //some ipfs. //it would be easy to tag another message, //and query that, once markdown links are ready //[#hashtag](msgId) would tag msg with #hashtag //TODO: what about a syntax for self-links? //interpret a lone hashtag in a message as a selflink, //and then that will work. msgs.indexLinks(data.value, function (ln, rel) { var dest = ln.link //take all the already existing links and put //the relavant aspects into the index, //as part of the rel, so that we don't need to lookup //the message to get them, and even better, //we can query by these attributes! enabling search. if(rel == 'vote') rel = ['vote', ln.value] else if(rel == 'flag') rel = ['flag', ln.reason] else if(rel == 'mentions') { if(ln.link[0] === '@') rel = ['mentions', '@'+(ln.name||'').toLowerCase()] else if(ln.link[0] == '&') { rel = ['mentions', ln.filename || ln.name, ln.size] } else { //TODO: check whether they included some text in the markdown link. rel = ['mentions'] } } else if(rel == 'about') { rel = ['about', content.name] } else if(rel == 'image') rel = ['image', ln.type, ln.size] else if(rel == 'contact') rel = ['contact', content.following, content.blocking] else rel = [rel] iter({ source: source, dest: dest, rel: rel, ts: data.timestamp }) }) } },{"ssb-msgs":542}],537:[function(require,module,exports){ arguments[4][232][0].apply(exports,arguments) },{"./pull":538,"./sinks":539,"./sources":540,"./throughs":541,"dup":232}],538:[function(require,module,exports){ arguments[4][233][0].apply(exports,arguments) },{"dup":233}],539:[function(require,module,exports){ arguments[4][234][0].apply(exports,arguments) },{"dup":234}],540:[function(require,module,exports){ arguments[4][235][0].apply(exports,arguments) },{"dup":235}],541:[function(require,module,exports){ arguments[4][236][0].apply(exports,arguments) },{"./sinks":539,"./sources":540,"dup":236}],542:[function(require,module,exports){ var ref = require('ssb-ref') function isObject (o) { return o && 'object' === typeof o } function isBool (o) { return 'boolean' === typeof o } function isString (s) { return 'string' === typeof s } function toArray (v, force) { if (Array.isArray(v)) return v // maybe it's an array-like object? (object with ordered numeric keys) var i=0, arr=[] if (isObject(v)) { while (v[i]) { arr[i] = v[i] i++ } if (Object.keys(arr).length > 0) return arr // it was! } // it wasnt... if (force) { // ...just put v in the arr arr.push(v) return arr } return v } // given any part of the message-obj hierarchy, pull out the content-object // - uses ducktyping to find the content function toMsgContent (obj) { if (!obj) return null if (obj.value && obj.value.content && obj.value.content.type) return obj.value.content if (obj.content && obj.content.type) return obj.content return obj } function traverse (obj, each) { for (var k in obj) { if (!obj[k]) continue var arr = toArray(obj[k], false) if (Array.isArray(arr)) { arr.forEach(function (v) { each(v, k) }) } else each(obj[k], k) } } // iterate links in the message exports.indexLinks = function (message, opts, each) { if (typeof opts == 'function') { each = opts opts = null } if (typeof opts == 'string') opts = { rel: opts } if (!opts) opts = {} var msg = opts.msg var feed = opts.feed var blob = opts.blob var any = !(msg || feed || blob) traverse(toMsgContent(message), function (obj, rel) { if (opts.rel && rel !== opts.rel) return var r = (typeof obj == 'string') ? obj : obj.link if (any) { if (!ref.isLink(r)) return } else { if (msg) { if (isBool(msg) && ref.type(r) != 'msg') return if (!isBool(msg) && r != msg) return } if (feed) { if (isBool(feed) && ref.type(r) != 'feed') return if (!isBool(feed) && r != feed) return } if (blob) { if (isBool(blob) && ref.type(r) != 'blob') return if (!isBool(blob) && r != blob) return } } each((typeof obj == 'string') ? { link: obj } : obj, rel) }) } // coerce to link object, optionally of a given type // null if coersion fails exports.link = exports.asLink = function (obj, type) { if (!obj) return null if (isString(obj)) obj = { link: obj } return isLink(obj, type) ? obj : null } // coerce to links array, optionally of a given type // filters out failed coersions exports.links = exports.asLinks = function (obj, type) { if (!obj) return [] var arr = toArray(obj, true) return arr .filter(function (l) { return isLink(l, type) }) .map(function (o) { return (typeof o == 'string') ? { link: o } : o }) } // detects whether the given string/object is a link // - `type` optional var isLink = exports.isLink = function (obj, type) { if (!obj) return false var r = (isString(obj)) ? obj : obj.link return (type) ? (ref.type(r) == type) : ref.isLink(r) } function indexLinksTo (msgA, msgB, each) { if (!msgA || !msgB || !msgB.key) return exports.indexLinks(msgA, function (l, rel) { if (l.link === msgB.key) each(l, rel) }) } // iterate `msgA` and find all links to `msgB`, returning an array of the link objects exports.linksTo = function (msgA, msgB) { var links = [] indexLinksTo(msgA, msgB, function (link, rel) { links.push(link) }) return links } // iterate `msgA` and find all links to `msgB`, returning an array of the link rels exports.relationsTo = function (msgA, msgB) { var rels = [] indexLinksTo(msgA, msgB, function (link, rel) { rels.push(rel) }) return rels } },{"ssb-ref":573}],543:[function(require,module,exports){ arguments[4][542][0].apply(exports,arguments) },{"dup":542,"ssb-ref":573}],544:[function(require,module,exports){ (function (process){ var pull = require('pull-stream') var path = require('path') var Links = require('streamview-links') var explain = require('explain-error') exports.name = 'query' exports.version = require('./package.json').version exports.manifest = { read: 'source', dump: 'source' } var indexes = [ {key: 'clk', value: [['value', 'author'], ['value', 'sequence'], 'timestamp'] }, {key: 'typ', value: [['value', 'content', 'type'], 'timestamp'] }, {key: 'hsh', value: ['key', 'timestamp']}, // {key: 'aty', value: [['value', 'author'], ['value', 'content', 'type'], 'ts']} ] //createHistoryStream( id, seq ) //[{$filter: {author: , sequence: {$gt: }}}, {$map: true}] //messagesByType (type) //[{$filter: {content: {type: }}}, {$map: true}] exports.init = function (ssb, config) { var dir = path.join(config.path, 'query') var version = 12 //it's really nice to tweak a few things //and then change the version number, //restart the server and have it regenerate the indexes, //all consistent again. function id (e, emit) { return emit(e) } var links = Links(dir, indexes, id, version) links.init(function (err, since) { pull( ssb.createLogStream({gt: since || 0, live: true, limit: -1}), pull.through(function () { process.stdout.write('x') }), links.write(function (err) { if(err) throw err }) ) }) return { dump: function () { return links.dump() }, read: function (opts) { if(opts && 'string' == typeof opts) try { opts = {query: JSON.parse(opts) } } catch (err) { return pull.error(err) } console.log('query', JSON.stringify(opts.query, null, 2)) return links.read(opts, function (ts, cb) { ssb.sublevel('log').get(ts, function (err, key) { if(err) return cb(explain(err, 'missing timestamp:'+ts)) ssb.get(key, function (err, value) { if(err) return cb(explain(err, 'missing key:'+key)) cb(null, {key: key, value: value, timestamp: ts}) }) }) }) } } } }).call(this,require('_process')) },{"./package.json":572,"_process":295,"explain-error":146,"path":290,"pull-stream":563,"streamview-links":568}],545:[function(require,module,exports){ arguments[4][475][0].apply(exports,arguments) },{"bytewise-core":67,"dup":475,"typewise":627}],546:[function(require,module,exports){ arguments[4][476][0].apply(exports,arguments) },{"./binary":545,"dup":476}],547:[function(require,module,exports){ arguments[4][477][0].apply(exports,arguments) },{"./encoding/":546,"dup":477}],548:[function(require,module,exports){ module.exports = { $count: function (a, b) { if(b === undefined) return (a||0) return (a||0)+1 }, $sum: function (a, b) { if(b === undefined) return (a||0) return (a||0)+(b||0) }, $max: function (a, b) { if(b === undefined) a if(a === undefined) return b return Math.max(a, b) }, $min: function (a, b) { if(b === undefined) a if(a === undefined) return b return Math.min(a, b) }, $collect: function (a, b) { if(!a) a = a || [] if(!Array.isArray(a)) a = [a] a.push(b) return a } } },{}],549:[function(require,module,exports){ arguments[4][228][0].apply(exports,arguments) },{"./util":554,"dup":228}],550:[function(require,module,exports){ var pull = require('pull-stream') var filter = require('./filter') var map = require('./map') var reduce = require('./reduce') var SinkThrough = require('pull-sink-through') function first (q) { for(var k in q) return k } function get (q) { var k = first(q) var s = k.substring(1) if(k[0] == '$' && exports[s]) return exports[s](q[k]) throw new Error('unknown function:'+ k) } function last (l) { return l[l.length - 1] } exports = module.exports = function (q, cb) { q = q.filter(Boolean) if(last(q).$reduce && cb) { return pull.apply(null, q.slice(0, q.length - 1).map(get) .concat(exports.reduce(last(q).$reduce, cb)) ) } else if(Array.isArray(q)) return pull.apply(null, q.map(get)) else return get(q) } exports.filter = function (q) { return pull.filter(filter(q)) } exports.map = function (q) { return pull(pull.map(map(q)),pull.filter()) } exports.reduce = function (q, cb) { if(cb) return pull.reduce(reduce(q), null, cb) return pull(SinkThrough(function (cb) { return pull.reduce(reduce(q), null, cb) }), pull.flatten()) } },{"./filter":549,"./map":552,"./reduce":553,"pull-sink-through":379,"pull-stream":563}],551:[function(require,module,exports){ arguments[4][230][0].apply(exports,arguments) },{"./util":554,"dup":230}],552:[function(require,module,exports){ var u = require('./util') var map = u.map function id (v, k) { return k ? v[k] : v } function isNull (n) { return n == null } function key(q) { return function (v) { if(isNull(v)) return undefined return v[q] } } function path (q) { return q.reduce(function (map1, map2) { return function (v) { return map2(map1(v)) } }) } function notEmpty (o) { for(var k in o) return o return undefined } function obj (q) { return function (v) { if(isNull(v)) return undefined return notEmpty(map(q, function (fn, k, o) { return fn(v, k) })) } } function make(q) { if(true === q) return id if(isNull(q)) return isNull if(u.isString(q) || u.isNumber(q)) return key(q) if(u.isArray(q)) return path(q.map(make)) if(u.isObject(q)) return obj(map(q, make)) throw new Error('no match - should never happen') } module.exports = make },{"./util":554}],553:[function(require,module,exports){ var u = require('./util') var Map = require('./map') var simple = require('./basic') var search = require('binary-search') var compare = require('typewiselite') function isFunction (f) { return 'function' === typeof f } function isSimple(query) { if(query.$reduce) return amake(query.$reduce) for(var k in simple) if(u.has(query, k)) return lookup(simple[k], query[k]) } //this should be a reduce and a map function lookup(reduce, path) { if(path === true) return reduce return function (a, b) { return reduce(a, u.get(b, path)) } } function multi(query) { if(u.isFunction(query)) return query return function (a, b) { return u.map(query, function traverse (reduce, k) { //some reduce functions may be maps (which take one arg) return reduce.length == 1 ? reduce(b) : reduce(a[k], b) }, a = a || {}) } } //rawpaths, reducedpaths, reduce function arrayGroup (_g, g, reduce) { //we can use a different lookup path on the right hand object //is always the "needle" //compare(haystay[j], needle) function _compare (hay, needle) { for(var i in _g) { var x = u.get(hay, _g[i]), y = needle[i] if(x !== y) return compare(x, y) // < y ? -1 : 1 } return 0 } return function (a, b) { if(a && !Array.isArray(a)) a = reduce([], a) var A = a = a || [] var i = search(A, g.map(function (fn) { return fn(b) }), _compare) if(i >= 0) A[i] = reduce(A[i], b) else A.splice(~i, 0, reduce(undefined, b)) return a } } function objectGroup (g, reduce) { if('string' === typeof g) g = [g] return function (a, b) { var A = a = a || {} u.each(g, function (k, i) { var last = (i == (g.length - 1)) var v = u.get(b, k) A[v] = last ? reduce(A[v], b) : A[v] || {} A = A[v] }) return a } } function make2 (query) { var r = isSimple(query) if(r) return r if(query.$group) return objectGroup(query.$group, multi(make2(query.$reduce))) if(query.$reduce) return make2(query.$reduce) if(u.isObject(query)) return u.map(query, make2) return Map(query) } function make (query) { var r = isSimple(query) if(r) return r else if(query.$group) return objectGroup(query.$group, gmake(query.$reduce)) else if(u.isObject(query) && !u.isArray(query)) { return multi(u.map(query, gmake)) } else return function (a, b) { return u.get(b, query) } } function amake (query) { var _query = make2(query) if(query.$group) return objectGroup(query.$group, make(query.$reduce)) var r = isSimple(query) if(r) return r //get the lookup paths, and the paths they will be saved to. //these will both be passed to arrayGroup. var paths = [] var _paths = u.paths(_query, function (value) { if(u.isFunction(value) && value.length === 1) { return paths.push(value), true } }) return paths.length ? arrayGroup(_paths, paths, make(query)) : make(query) } function gmake (query) { if(query.$group && !query.$reduce) throw new Error('expected $reduce') return query.$group ? objectGroup(query.$group, gmake(query.$reduce)) : make(query) } module.exports = amake },{"./basic":548,"./map":552,"./util":554,"binary-search":20,"typewiselite":628}],554:[function(require,module,exports){ 'use strict' function isString(s) { return 'string' === typeof s } function isNumber(n) { return !isNaN(+n) } function isBoolean (b) { return 'boolean' === typeof b } function isBasic (p) { return isString(p) || isNumber(p) || isBoolean(p) } function isFunction (f) { return 'function' === typeof f } var isArray = Array.isArray function isObject (o) { return o && 'object' === typeof o && !isArray(o) } function has(o, k) { return Object.hasOwnProperty.call(o, k) } function isExact (v) { if(isBasic(v)) return true if(isArray(v)) return v.every(isExact) return isObject(v) && has(v, '$eq') } function isLtgt (v) { return has(v, '$lt') || has(v, '$gt') || has(v, '$lte') || has(v, '$gte') } function isRange (v) { if(!isObject(v)) return false if(isString(v.$prefix)) return true if(isArray(v)) return find(v, isRange) return isLtgt(v) } function find (ary, test) { for(var i = 0; i < ary.length; i++) if(test(ary[i], i, ary)) return true return false } function lower (v) { if(isBasic(v)) return v if(isObject(v)) { if(isArray(v.$prefix)) return v.$prefix.concat(exports.HI) if(isString(v.$prefix)) return v.$prefix if(has(v, '$gt')) return v.$gt if(has(v, '$gte')) return v.$gte } if(isArray(v)) return v.map(lower) } function upper (v) { if(isBasic(v)) return v if(isObject(v)) { if(isArray(v.$prefix)) return v.$prefix.concat(exports.LO) if(isString(v.$prefix)) return v.$prefix+'\uffff' if(has(v, '$le')) return v.$lt if(has(v, '$lte')) return v.$lte } if(isArray(v)) return v.map(upper) } function get(obj, path) { if(isString(path)) return obj[path] if(isArray(path)) { for(var i = 0; i < path.length; i++) { if(obj == null) return undefined obj = obj[path[i]] } return obj } if(path === true) return obj return undefined } function map(obj, iter, o) { if(Array.isArray(obj)) return obj.map(iter) o = o || {} for(var k in obj) o[k] = iter(obj[k], k, obj) return o } function mapa(obj, iter) { if(Array.isArray(obj)) return obj.map(iter) var a = [] for(var k in obj) { var v = iter(obj[k], k, obj) if(v !== undefined) a.push(v) } return a } function each(obj, iter) { if(Array.isArray(obj)) return obj.forEach(iter) else if(isObject(obj)) for(var k in obj) iter(obj[k], k, obj) else iter(obj) } function project (value, map, isObj) { isObj = isObj || isObject if(!isObj(value)) return map(value) else { var o for(var k in value) { var v = project(value[k], map, isObj) if(v !== undefined) (o = o || {})[k] = v } return o } } //get all paths within an object //this can probably be optimized to create less arrays! function paths (object, test) { var p = [] if(test(object)) return [] for(var key in object) { var value = object[key] if(test(value)) p.push(key) else if(isObject(value)) p = p.concat(paths(value, test).map(function (path) { return [key].concat(path) })) } return p } exports.isString = isString exports.isNumber = isNumber exports.isBasic = isBasic exports.isArray = isArray exports.isObject = isObject exports.isRange = isRange exports.isExact = isExact exports.isLtgt = isLtgt exports.isFunction = isFunction exports.has = has exports.get = get exports.map = map exports.mapa = mapa exports.project = project exports.paths = paths exports.each = each exports.upper = upper exports.lower = lower exports.HI = undefined exports.LO = null },{}],555:[function(require,module,exports){ arguments[4][345][0].apply(exports,arguments) },{"dup":345}],556:[function(require,module,exports){ arguments[4][487][0].apply(exports,arguments) },{"dup":487,"level-post":198,"pull-cat":305,"pull-pushable":557,"pull-stream":563,"pull-window":390,"stream-to-pull-stream":593}],557:[function(require,module,exports){ arguments[4][346][0].apply(exports,arguments) },{"dup":346,"pull-stream":558}],558:[function(require,module,exports){ arguments[4][347][0].apply(exports,arguments) },{"./maybe":559,"./sinks":560,"./sources":561,"./throughs":562,"dup":347,"pull-core":555}],559:[function(require,module,exports){ arguments[4][348][0].apply(exports,arguments) },{"dup":348,"pull-core":555}],560:[function(require,module,exports){ arguments[4][349][0].apply(exports,arguments) },{"dup":349}],561:[function(require,module,exports){ arguments[4][350][0].apply(exports,arguments) },{"dup":350}],562:[function(require,module,exports){ (function (process){ var u = require('pull-core') var sources = require('./sources') var sinks = require('./sinks') var prop = u.prop var id = u.id var tester = u.tester var map = exports.map = function (read, map) { map = prop(map) || id return function (end, cb) { read(end, function (end, data) { var data = !end ? map(data) : null cb(end, data) }) } } var asyncMap = exports.asyncMap = function (read, map) { if(!map) return read return function (end, cb) { if(end) return read(end, cb) //abort read(null, function (end, data) { if(end) return cb(end, data) map(data, cb) }) } } var paraMap = exports.paraMap = function (read, map, width) { if(!map) return read var ended = false, queue = [], _cb function drain () { if(!_cb) return var cb = _cb _cb = null if(queue.length) return cb(null, queue.shift()) else if(ended && !n) return cb(ended) _cb = cb } function pull () { read(null, function (end, data) { if(end) { ended = end return drain() } n++ map(data, function (err, data) { n-- queue.push(data) drain() }) if(n < width && !ended) pull() }) } var n = 0 return function (end, cb) { if(end) return read(end, cb) //abort //continue to read while there are less than 3 maps in flight _cb = cb if(queue.length || ended) pull(), drain() else pull() } return highWaterMark(asyncMap(read, map), width) } var filter = exports.filter = function (read, test) { //regexp test = tester(test) return function next (end, cb) { read(end, function (end, data) { if(!end && !test(data)) return next(end, cb) cb(end, data) }) } } var filterNot = exports.filterNot = function (read, test) { test = tester(test) return filter(read, function (e) { return !test(e) }) } var through = exports.through = function (read, op, onEnd) { var a = false function once (abort) { if(a || !onEnd) return a = true onEnd(abort === true ? null : abort) } return function (end, cb) { if(end) once(end) return read(end, function (end, data) { if(!end) op && op(data) else once(end) cb(end, data) }) } } var take = exports.take = function (read, test) { var ended = false if('number' === typeof test) { var n = test; test = function () { return n -- } } return function (end, cb) { if(ended) return cb(ended) if(ended = end) return read(ended, cb) read(null, function (end, data) { if(ended = ended || end) return cb(ended) if(!test(data)) { ended = true read(true, function (end, data) { cb(ended, data) }) } else cb(null, data) }) } } var unique = exports.unique = function (read, field, invert) { field = prop(field) || id var seen = {} return filter(read, function (data) { var key = field(data) if(seen[key]) return !!invert //false, by default else seen[key] = true return !invert //true by default }) } var nonUnique = exports.nonUnique = function (read, field) { return unique(read, field, true) } var group = exports.group = function (read, size) { var ended; size = size || 5 var queue = [] return function (end, cb) { //this means that the upstream is sending an error. if(end) return read(ended = end, cb) //this means that we read an end before. if(ended) return cb(ended) read(null, function next(end, data) { if(ended = ended || end) { if(!queue.length) return cb(ended) var _queue = queue; queue = [] return cb(null, _queue) } queue.push(data) if(queue.length < size) return read(null, next) var _queue = queue; queue = [] cb(null, _queue) }) } } var flatten = exports.flatten = function (read) { var _read return function (abort, cb) { if(_read) nextChunk() else nextStream() function nextChunk () { _read(null, function (end, data) { if(end) nextStream() else cb(null, data) }) } function nextStream () { read(null, function (end, stream) { if(end) return cb(end) if(Array.isArray(stream)) stream = sources.values(stream) else if('function' != typeof stream) throw new Error('expected stream of streams') _read = stream nextChunk() }) } } } var prepend = exports.prepend = function (read, head) { return function (abort, cb) { if(head !== null) { if(abort) return read(abort, cb) var _head = head head = null cb(null, _head) } else { read(abort, cb) } } } //var drainIf = exports.drainIf = function (op, done) { // sinks.drain( //} var _reduce = exports._reduce = function (read, reduce, initial) { return function (close, cb) { if(close) return read(close, cb) if(ended) return cb(ended) sinks.drain(function (item) { initial = reduce(initial, item) }, function (err, data) { ended = err || true if(!err) cb(null, initial) else cb(ended) }) (read) } } var nextTick = process.nextTick var highWaterMark = exports.highWaterMark = function (read, highWaterMark) { var buffer = [], waiting = [], ended, reading = false highWaterMark = highWaterMark || 10 function readAhead () { while(waiting.length && (buffer.length || ended)) waiting.shift()(ended, ended ? null : buffer.shift()) } function next () { if(ended || reading || buffer.length >= highWaterMark) return reading = true return read(ended, function (end, data) { reading = false ended = ended || end if(data != null) buffer.push(data) next(); readAhead() }) } nextTick(next) return function (end, cb) { ended = ended || end waiting.push(cb) next(); readAhead() } } }).call(this,require('_process')) },{"./sinks":560,"./sources":561,"_process":295,"pull-core":555}],563:[function(require,module,exports){ arguments[4][232][0].apply(exports,arguments) },{"./pull":564,"./sinks":565,"./sources":566,"./throughs":567,"dup":232}],564:[function(require,module,exports){ arguments[4][233][0].apply(exports,arguments) },{"dup":233}],565:[function(require,module,exports){ arguments[4][234][0].apply(exports,arguments) },{"dup":234}],566:[function(require,module,exports){ arguments[4][235][0].apply(exports,arguments) },{"dup":235}],567:[function(require,module,exports){ arguments[4][236][0].apply(exports,arguments) },{"./sinks":565,"./sources":566,"dup":236}],568:[function(require,module,exports){ 'use strict' var level = require('level') var pull = require('pull-stream') var Write = require('pull-write') var pl = require('pull-level') var query = require('./query') var select = require('./select') var mfr = require('map-filter-reduce') var keys = require('map-filter-reduce/keys') var bytewise = require('bytewise') var paramap = require('pull-paramap') var explain = require('explain-error') var u = require('./util') var isArray = Array.isArray //sorted index. module.exports = function (path, indexes, links, version, codec) { codec = codec || require('bytewise') var db = level(path) if('string' !== typeof path) throw new Error('must provide path for leveldb instance') if(!Array.isArray(indexes)) throw new Error('must provide an array of indexes') if('number' !== typeof version) throw new Error('must provide version number') if(!links) links = function (data, emit) { emit(data) } //always write metada to the lowest key, //so the indexes do not interfeer //we don't want to encode this with the codec, //because then we can't change the codec safely //(prehaps the encoding of META is also some indexed value in another codec?) var META = '\x00' return { init: function (cb) { db.get(META, function (err, value) { console.log('RELOAD INDEX:', value) if(value) try { value = JSON.parse(value) } catch (err) { return cb(null, 0) } if(err) //first time this was run cb(null, 0) //if the view has changed, rebuild entire index. //else, read current version. else if(version && value.version !== version) { db.close(function () { level.destroy(path, function (err) { if(err) return cb(err) db = level(path) cb(null, 0) }) }) } else cb(null, value.since || 0) }) }, write: function (cb) { return pull( Write(function (batch, cb) { db.batch(batch, cb) }, function (batch, data) { if(data.sync) return batch if(!batch) batch = [{ key: META, value: {version: version, since: data.ts}, valueEncoding: 'json', type: 'put' }] function push(ary) { batch.push({key: codec.encode(ary), value: ' ', type: 'put'}) } links(data, function (link) { indexes.forEach(function (index) { var a = [index.key] for(var i = 0; i < index.value.length; i++) { var key = index.value[i] if(!u.has(key, link)) return a.push(u.get(key, link)) } push(a) }) }) var ts = data.ts || data.timestamp if(ts) batch[0].value.since = ts return batch }, 100, cb) ) }, close: function (cb) { db.close(cb) }, //get the raw indexes, for debugging. dump: function () { return pl.read(db, {keyEncoding: codec, gt: '\x00'}) }, //read all the messages out, via matching ranges. read: function (opts, get) { var lookup opts = opts || {} var _opts = {} var q, k if(isArray(opts.query)) { q = opts.query[0].$filter || {} k = keys(opts.query) } else if(opts.query) { q = opts.query } else q = {} var index = select(indexes, q) var _opts = query(index, q) console.log(_opts) _opts.values = false _opts.keys = true _opts.keyEncoding = codec _opts.reverse = !!opts.reverse _opts.live = !!opts.live _opts.limit = opts.limit || -1 // If a query uses a key not in the index // then we need to get that somehow. // if this is a key from the thing indexed, // it makes sense to look up that record. // how to do that might be different in a view. // just disable this for now. if(get) lookup = paramap(function (link, cb) { get(link.ts || link.timestamp, function (err, data) { if(err) return cb(explain(err, 'could not find matching timestamp for index:'+JSON.stringify(link))) link.key = data.key link.value = data.value cb(null, link) }) }) return pull( pl.read(db, _opts), //rehydrate the index to resemble the original object. pull.map(function (e) { var o = {} for(var i = 0; i < index.value.length; i++) u.set(index.value[i], e[i+1], o) return o }), lookup, isArray(opts.query) ? mfr(opts.query) : pull.through() ) } } } },{"./query":569,"./select":570,"./util":571,"bytewise":547,"explain-error":146,"level":199,"map-filter-reduce":550,"map-filter-reduce/keys":551,"pull-level":556,"pull-paramap":363,"pull-stream":563,"pull-write":393}],569:[function(require,module,exports){ var Q = require('map-filter-reduce/util') var select = require('./select') var get = require('./util').get function id (e) { return e } module.exports = function (index, query) { function bound (value, range, sentinel) { return ( value == null ? sentinel : Q.isRange(value) ? range(value) : value ) } function build (index, map) { var a = [index.key] for(var i = 0; i < index.value.length; i++) a.push(map(get(index.value[i], query))) return a } return { gte: build(index, function (value) { return bound(value, Q.lower, Q.LO) }), lte: build(index, function (value) { return bound(value, Q.upper, Q.HI) }) //reverse, limit, live? } } },{"./select":570,"./util":571,"map-filter-reduce/util":554}],570:[function(require,module,exports){ //of several indexes available, //select the one most suitable for a given query. // select the index that matches the most exact fields in the query // starting from the left, then moving on to range fields. var Q = require('map-filter-reduce/util') var u = require('./util') function max(array, compare) { return array.reduce(function (max, e) { return compare(e.value, max.value) > 0 ? e : max }, array[0]) } module.exports = function select (indexes, query) { function score (k) { var v = u.get(k, query) return u.has(k, query) ? ( Q.isExact(v) ? 3 : Q.isRange(v) ? 2 : 1 ) : 0 } function exact (k) { return u.has(k, query) && Q.isExact(u.get(k, query)) } function range (k) { return u.has(k, query) && Q.isRange(u.get(k, query)) } function compare(a, b) { var l = Math.min(a.length, b.length) for(var i = 0; i < l; i++) { var k = a[i], j = b[i] var v = score(k), x = score(j) if(v != x) return v - x // else, loop to next item. } return 0 } return max(indexes, compare) } },{"./util":571,"map-filter-reduce/util":554}],571:[function(require,module,exports){ exports.has = function has (key, obj) { if('string' === typeof key) return Object.hasOwnProperty.call(obj, key) for(var i in key) { if(Object.hasOwnProperty.call(obj, key[i])) obj = obj[key[i]] else return false } return true } exports.get = function get (key, obj) { if('string' === typeof key) return obj[key] for(var i in key) { obj = obj[key[i]] if(!obj) return obj } return obj } exports.set = function set(key, value, obj) { if('string' === typeof key) obj[key] = value else { for(var i = 0 ; i < key.length - 1; i++) { obj = (obj[key[i]] = obj[key[i]] || {}) } obj[key[key.length -1]] = value } } },{}],572:[function(require,module,exports){ module.exports={ "_args": [ [ "ssb-query@0.0.2", "/Users/joran/Documents/development/patchdeck" ] ], "_from": "ssb-query@0.0.2", "_id": "ssb-query@0.0.2", "_inCache": true, "_installable": true, "_location": "/ssb-query", "_nodeVersion": "5.6.0", "_npmOperationalInternal": { "host": "packages-16-east.internal.npmjs.com", "tmp": "tmp/ssb-query-0.0.2.tgz_1460607908133_0.18419223045930266" }, "_npmUser": { "email": "dominic.tarr@gmail.com", "name": "dominictarr" }, "_npmVersion": "3.6.0", "_phantomChildren": { "binary-search": "1.2.0", "bytewise-core": "1.2.3", "explain-error": "1.0.1", "level": "1.4.0", "level-post": "1.0.4", "pull-cat": "1.1.9", "pull-paramap": "1.1.4", "pull-sink-through": "0.0.0", "pull-window": "2.1.3", "pull-write": "1.0.2", "stream-to-pull-stream": "1.6.8", "typewise": "1.0.3", "typewiselite": "1.0.0" }, "_requested": { "name": "ssb-query", "raw": "ssb-query@0.0.2", "rawSpec": "0.0.2", "scope": null, "spec": "0.0.2", "type": "version" }, "_requiredBy": [ "/" ], "_resolved": "https://registry.npmjs.org/ssb-query/-/ssb-query-0.0.2.tgz", "_shasum": "9af20e734ffda21724873fad375d7d160e831eb3", "_shrinkwrap": null, "_spec": "ssb-query@0.0.2", "_where": "/Users/joran/Documents/development/patchdeck", "author": { "email": "dominic.tarr@gmail.com", "name": "Dominic Tarr", "url": "http://dominictarr.com" }, "bugs": { "url": "https://github.com/dominictarr/ssb-query/issues" }, "dependencies": { "explain-error": "^1.0.1", "streamview-links": "^2.0.0" }, "description": "", "devDependencies": {}, "directories": {}, "dist": { "shasum": "9af20e734ffda21724873fad375d7d160e831eb3", "tarball": "https://registry.npmjs.org/ssb-query/-/ssb-query-0.0.2.tgz" }, "gitHead": "901b36afd5fb25815ecf077e71a0a8825e847907", "homepage": "https://github.com/dominictarr/ssb-query", "license": "MIT", "maintainers": [ { "name": "dominictarr", "email": "dominic.tarr@gmail.com" } ], "name": "ssb-query", "optionalDependencies": {}, "readme": "ERROR: No README data found!", "repository": { "type": "git", "url": "git://github.com/dominictarr/ssb-query.git" }, "scripts": { "test": "set -e; for t in test/*.js; do node $t; done" }, "version": "0.0.2" } },{}],573:[function(require,module,exports){ var isDomain = require('is-valid-domain') var rx = require('ip-regex')({exact: true}) var isIP = rx.test.bind(rx) var isInteger = Number.isInteger function isString(s) { return 'string' === typeof s } var isLink = exports.isLink = function (data) { return isString(data) && /^(@|%|&)[A-Za-z0-9\/+]{43}=\.[\w\d]+$/.test(data) } var isFeedId = exports.isFeed = exports.isFeedId = function (data) { return isString(data) && /^@[A-Za-z0-9\/+]{43}=\.(?:sha256|ed25519)$/.test(data) } var isMsgId = exports.isMsg = exports.isMsgId = function (data) { return isString(data) && /^%[A-Za-z0-9\/+]{43}=\.sha256$/.test(data) } var isBlobId = exports.isBlob = exports.isBlobId = function (data) { return isString(data) && /^&[A-Za-z0-9\/+]{43}=\.sha256$/.test(data) } var isAddress = exports.isAddress = function (data) { if(!isString(data)) return false var parts = data.split(':') var id = parts.pop(), port = parts.pop(), addr = parts.join(':') return ( isFeedId(id) && isInteger(+port) && (isIP(addr) || isDomain(addr) || addr === 'localhost') ) } var isInvite = exports.isInvite = function (data) { if(!isString(data)) return false var parts = data.split('~') //console.log(parts, isAddress(parts[0]), /^[A-Za-z0-9\/+]{43}=$/.test(parts[1])) return parts.length == 2 && isAddress(parts[0]) && /^[A-Za-z0-9\/+]{43}=$/.test(parts[1]) } exports.type = function (id) { if(!isString(id)) return false var c = id.charAt(0) if (c == '@' && isFeedId(id)) return 'feed' else if (c == '%' && isMsgId(id)) return 'msg' else if (c == '&' && isBlobId(id)) return 'blob' else if(isAddress(id)) return 'address' else if(isInvite(id)) return 'invite' else return false } exports.extract = function (data) { if (!isString(data)) return false var _data = data try { _data = decodeURIComponent(data) } catch (e) {} // this may fail if it's not encoded, so don't worry if it does _data = _data.replace(/&/g, '&') var res = /([@%&][A-Za-z0-9\/+]{43}=\.[\w\d]+)/.exec(_data) return res && res[0] } },{"ip-regex":168,"is-valid-domain":171}],574:[function(require,module,exports){ module.exports = Stack; var Url = require('url'); function Stack(/*layers*/) { var error = Stack.errorHandler, handle = error; Array.prototype.slice.call(arguments).reverse().forEach(function (layer) { var child = handle; handle = function (req, res) { try { layer(req, res, function (err) { if (err) { return error(req, res, err); } child(req, res); }); } catch (err) { error(req, res, err); } }; }); return handle; } Stack.errorHandler = function error(req, res, err) { if (err) { console.error(err.stack); res.writeHead(500, {"Content-Type": "text/plain"}); res.end(err.stack + "\n"); return; } res.writeHead(404, {"Content-Type": "text/plain"}); res.end("Not Found\n"); }; function core(req, res, next) { next(); } // Build a composite stack made of several layers Stack.compose = function compose(/*layers*/) { // Don't bother composing singletons if (arguments.length == 1) { return arguments[0]; } var stack = core; Array.prototype.slice.call(arguments).reverse().forEach(function (layer) { var child = stack; stack = function (req, res, next) { try { layer(req, res, function (err) { if (err) { return next(err); } child(req, res, next); }); } catch (err) { next(err); } }; }); return stack; } // Mounts a substack app at a url subtree Stack.mount = function mount(mountpoint/*, stack*/) { var stack = Stack.compose.apply(null, Array.prototype.slice.call(arguments, 1)); if (mountpoint.substr(mountpoint.length - 1) == "/") { mountpoint = mountpoint.substr(0, mountpoint.length - 1); } var matchpoint = mountpoint + "/"; return function (req, res, next) { var url = req.url; var uri = req.uri; if (url.substr(0, matchpoint.length) !== matchpoint) { return next(); } // Modify the url if (!req.realUrl) { req.realUrl = url; } req.url = url.substr(mountpoint.length); if (req.uri) { req.uri = Url.parse(req.url); } stack(req, res, function (err) { req.url = url; req.uri = uri; next(err) }); }; }; },{"url":632}],575:[function(require,module,exports){ // // caluclate simple statistics // module.exports = Stats function Stats () { if (!(this instanceof Stats)) return new Stats() this.sum = 0 this.sqsum = 0 this.mean = 0 this.count = 0 this.max = null this.min = null } Stats.prototype = { value: function (val) { this.sum += val this.sqsum += val*val this.count ++ this.mean = this.sum / this.count this.max = this.max === null ? val : val > this.max ? val : this.max this.min = this.min === null ? val : val < this.min ? val : this.min return this }, get variance () { return this.sqsum / this.count - (this.mean * this.mean) }, get stdev() { return Math.sqrt(this.variance) }, toJSON: function () { return {mean: this.mean, count: this.count, stdev: this.stdev} } } },{}],576:[function(require,module,exports){ // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. module.exports = Stream; var EE = require('events').EventEmitter; var inherits = require('inherits'); inherits(Stream, EE); Stream.Readable = require('readable-stream/readable.js'); Stream.Writable = require('readable-stream/writable.js'); Stream.Duplex = require('readable-stream/duplex.js'); Stream.Transform = require('readable-stream/transform.js'); Stream.PassThrough = require('readable-stream/passthrough.js'); // Backwards-compat with node 0.4.x Stream.Stream = Stream; // old-style streams. Note that the pipe method (the only relevant // part of this class) is overridden in the Readable class. function Stream() { EE.call(this); } Stream.prototype.pipe = function(dest, options) { var source = this; function ondata(chunk) { if (dest.writable) { if (false === dest.write(chunk) && source.pause) { source.pause(); } } } source.on('data', ondata); function ondrain() { if (source.readable && source.resume) { source.resume(); } } dest.on('drain', ondrain); // If the 'end' option is not supplied, dest.end() will be called when // source gets the 'end' or 'close' events. Only dest.end() once. if (!dest._isStdio && (!options || options.end !== false)) { source.on('end', onend); source.on('close', onclose); } var didOnEnd = false; function onend() { if (didOnEnd) return; didOnEnd = true; dest.end(); } function onclose() { if (didOnEnd) return; didOnEnd = true; if (typeof dest.destroy === 'function') dest.destroy(); } // don't leave dangling pipes when there are errors. function onerror(er) { cleanup(); if (EE.listenerCount(this, 'error') === 0) { throw er; // Unhandled stream error in pipe. } } source.on('error', onerror); dest.on('error', onerror); // remove all the event listeners that were added. function cleanup() { source.removeListener('data', ondata); dest.removeListener('drain', ondrain); source.removeListener('end', onend); source.removeListener('close', onclose); source.removeListener('error', onerror); dest.removeListener('error', onerror); source.removeListener('end', cleanup); source.removeListener('close', cleanup); dest.removeListener('close', cleanup); } source.on('end', cleanup); source.on('close', cleanup); dest.on('close', cleanup); dest.emit('pipe', source); // Allow for unix-like usage: A.pipe(B).pipe(C) return dest; }; },{"events":144,"inherits":167,"readable-stream/duplex.js":578,"readable-stream/passthrough.js":584,"readable-stream/readable.js":585,"readable-stream/transform.js":586,"readable-stream/writable.js":587}],577:[function(require,module,exports){ arguments[4][23][0].apply(exports,arguments) },{"dup":23}],578:[function(require,module,exports){ arguments[4][24][0].apply(exports,arguments) },{"./lib/_stream_duplex.js":579,"dup":24}],579:[function(require,module,exports){ arguments[4][25][0].apply(exports,arguments) },{"./_stream_readable":581,"./_stream_writable":583,"core-util-is":104,"dup":25,"inherits":167,"process-nextick-args":294}],580:[function(require,module,exports){ // a passthrough stream. // basically just the most minimal sort of Transform stream. // Every written chunk gets output as-is. 'use strict'; module.exports = PassThrough; var Transform = require('./_stream_transform'); /**/ var util = require('core-util-is'); util.inherits = require('inherits'); /**/ util.inherits(PassThrough, Transform); function PassThrough(options) { if (!(this instanceof PassThrough)) return new PassThrough(options); Transform.call(this, options); } PassThrough.prototype._transform = function (chunk, encoding, cb) { cb(null, chunk); }; },{"./_stream_transform":582,"core-util-is":104,"inherits":167}],581:[function(require,module,exports){ (function (process){ 'use strict'; module.exports = Readable; /**/ var processNextTick = require('process-nextick-args'); /**/ /**/ var isArray = require('isarray'); /**/ /**/ var Buffer = require('buffer').Buffer; /**/ Readable.ReadableState = ReadableState; var EE = require('events'); /**/ var EElistenerCount = function (emitter, type) { return emitter.listeners(type).length; }; /**/ /**/ var Stream; (function () { try { Stream = require('st' + 'ream'); } catch (_) {} finally { if (!Stream) Stream = require('events').EventEmitter; } })(); /**/ var Buffer = require('buffer').Buffer; /**/ var util = require('core-util-is'); util.inherits = require('inherits'); /**/ /**/ var debugUtil = require('util'); var debug = undefined; if (debugUtil && debugUtil.debuglog) { debug = debugUtil.debuglog('stream'); } else { debug = function () {}; } /**/ var StringDecoder; util.inherits(Readable, Stream); var Duplex; function ReadableState(options, stream) { Duplex = Duplex || require('./_stream_duplex'); options = options || {}; // object stream flag. Used to make read(n) ignore n and to // make all the buffer merging and length checks go away this.objectMode = !!options.objectMode; if (stream instanceof Duplex) this.objectMode = this.objectMode || !!options.readableObjectMode; // the point at which it stops calling _read() to fill the buffer // Note: 0 is a valid value, means "don't call _read preemptively ever" var hwm = options.highWaterMark; var defaultHwm = this.objectMode ? 16 : 16 * 1024; this.highWaterMark = hwm || hwm === 0 ? hwm : defaultHwm; // cast to ints. this.highWaterMark = ~ ~this.highWaterMark; this.buffer = []; this.length = 0; this.pipes = null; this.pipesCount = 0; this.flowing = null; this.ended = false; this.endEmitted = false; this.reading = false; // a flag to be able to tell if the onwrite cb is called immediately, // or on a later tick. We set this to true at first, because any // actions that shouldn't happen until "later" should generally also // not happen before the first write call. this.sync = true; // whenever we return null, then we set a flag to say // that we're awaiting a 'readable' event emission. this.needReadable = false; this.emittedReadable = false; this.readableListening = false; this.resumeScheduled = false; // Crypto is kind of old and crusty. Historically, its default string // encoding is 'binary' so we have to make this configurable. // Everything else in the universe uses 'utf8', though. this.defaultEncoding = options.defaultEncoding || 'utf8'; // when piping, we only care about 'readable' events that happen // after read()ing all the bytes and not getting any pushback. this.ranOut = false; // the number of writers that are awaiting a drain event in .pipe()s this.awaitDrain = 0; // if true, a maybeReadMore has been scheduled this.readingMore = false; this.decoder = null; this.encoding = null; if (options.encoding) { if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder; this.decoder = new StringDecoder(options.encoding); this.encoding = options.encoding; } } var Duplex; function Readable(options) { Duplex = Duplex || require('./_stream_duplex'); if (!(this instanceof Readable)) return new Readable(options); this._readableState = new ReadableState(options, this); // legacy this.readable = true; if (options && typeof options.read === 'function') this._read = options.read; Stream.call(this); } // Manually shove something into the read() buffer. // This returns true if the highWaterMark has not been hit yet, // similar to how Writable.write() returns true if you should // write() some more. Readable.prototype.push = function (chunk, encoding) { var state = this._readableState; if (!state.objectMode && typeof chunk === 'string') { encoding = encoding || state.defaultEncoding; if (encoding !== state.encoding) { chunk = new Buffer(chunk, encoding); encoding = ''; } } return readableAddChunk(this, state, chunk, encoding, false); }; // Unshift should *always* be something directly out of read() Readable.prototype.unshift = function (chunk) { var state = this._readableState; return readableAddChunk(this, state, chunk, '', true); }; Readable.prototype.isPaused = function () { return this._readableState.flowing === false; }; function readableAddChunk(stream, state, chunk, encoding, addToFront) { var er = chunkInvalid(state, chunk); if (er) { stream.emit('error', er); } else if (chunk === null) { state.reading = false; onEofChunk(stream, state); } else if (state.objectMode || chunk && chunk.length > 0) { if (state.ended && !addToFront) { var e = new Error('stream.push() after EOF'); stream.emit('error', e); } else if (state.endEmitted && addToFront) { var e = new Error('stream.unshift() after end event'); stream.emit('error', e); } else { var skipAdd; if (state.decoder && !addToFront && !encoding) { chunk = state.decoder.write(chunk); skipAdd = !state.objectMode && chunk.length === 0; } if (!addToFront) state.reading = false; // Don't add to the buffer if we've decoded to an empty string chunk and // we're not in object mode if (!skipAdd) { // if we want the data now, just emit it. if (state.flowing && state.length === 0 && !state.sync) { stream.emit('data', chunk); stream.read(0); } else { // update the buffer info. state.length += state.objectMode ? 1 : chunk.length; if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk); if (state.needReadable) emitReadable(stream); } } maybeReadMore(stream, state); } } else if (!addToFront) { state.reading = false; } return needMoreData(state); } // if it's past the high water mark, we can push in some more. // Also, if we have no data yet, we can stand some // more bytes. This is to work around cases where hwm=0, // such as the repl. Also, if the push() triggered a // readable event, and the user called read(largeNumber) such that // needReadable was set, then we ought to push more, so that another // 'readable' event will be triggered. function needMoreData(state) { return !state.ended && (state.needReadable || state.length < state.highWaterMark || state.length === 0); } // backwards compatibility. Readable.prototype.setEncoding = function (enc) { if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder; this._readableState.decoder = new StringDecoder(enc); this._readableState.encoding = enc; return this; }; // Don't raise the hwm > 8MB var MAX_HWM = 0x800000; function computeNewHighWaterMark(n) { if (n >= MAX_HWM) { n = MAX_HWM; } else { // Get the next highest power of 2 n--; n |= n >>> 1; n |= n >>> 2; n |= n >>> 4; n |= n >>> 8; n |= n >>> 16; n++; } return n; } function howMuchToRead(n, state) { if (state.length === 0 && state.ended) return 0; if (state.objectMode) return n === 0 ? 0 : 1; if (n === null || isNaN(n)) { // only flow one buffer at a time if (state.flowing && state.buffer.length) return state.buffer[0].length;else return state.length; } if (n <= 0) return 0; // If we're asking for more than the target buffer level, // then raise the water mark. Bump up to the next highest // power of 2, to prevent increasing it excessively in tiny // amounts. if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n); // don't have that much. return null, unless we've ended. if (n > state.length) { if (!state.ended) { state.needReadable = true; return 0; } else { return state.length; } } return n; } // you can override either this method, or the async _read(n) below. Readable.prototype.read = function (n) { debug('read', n); var state = this._readableState; var nOrig = n; if (typeof n !== 'number' || n > 0) state.emittedReadable = false; // if we're doing read(0) to trigger a readable event, but we // already have a bunch of data in the buffer, then just trigger // the 'readable' event and move on. if (n === 0 && state.needReadable && (state.length >= state.highWaterMark || state.ended)) { debug('read: emitReadable', state.length, state.ended); if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this); return null; } n = howMuchToRead(n, state); // if we've ended, and we're now clear, then finish it up. if (n === 0 && state.ended) { if (state.length === 0) endReadable(this); return null; } // All the actual chunk generation logic needs to be // *below* the call to _read. The reason is that in certain // synthetic stream cases, such as passthrough streams, _read // may be a completely synchronous operation which may change // the state of the read buffer, providing enough data when // before there was *not* enough. // // So, the steps are: // 1. Figure out what the state of things will be after we do // a read from the buffer. // // 2. If that resulting state will trigger a _read, then call _read. // Note that this may be asynchronous, or synchronous. Yes, it is // deeply ugly to write APIs this way, but that still doesn't mean // that the Readable class should behave improperly, as streams are // designed to be sync/async agnostic. // Take note if the _read call is sync or async (ie, if the read call // has returned yet), so that we know whether or not it's safe to emit // 'readable' etc. // // 3. Actually pull the requested chunks out of the buffer and return. // if we need a readable event, then we need to do some reading. var doRead = state.needReadable; debug('need readable', doRead); // if we currently have less than the highWaterMark, then also read some if (state.length === 0 || state.length - n < state.highWaterMark) { doRead = true; debug('length less than watermark', doRead); } // however, if we've ended, then there's no point, and if we're already // reading, then it's unnecessary. if (state.ended || state.reading) { doRead = false; debug('reading or ended', doRead); } if (doRead) { debug('do read'); state.reading = true; state.sync = true; // if the length is currently zero, then we *need* a readable event. if (state.length === 0) state.needReadable = true; // call internal read method this._read(state.highWaterMark); state.sync = false; } // If _read pushed data synchronously, then `reading` will be false, // and we need to re-evaluate how much data we can return to the user. if (doRead && !state.reading) n = howMuchToRead(nOrig, state); var ret; if (n > 0) ret = fromList(n, state);else ret = null; if (ret === null) { state.needReadable = true; n = 0; } state.length -= n; // If we have nothing in the buffer, then we want to know // as soon as we *do* get something into the buffer. if (state.length === 0 && !state.ended) state.needReadable = true; // If we tried to read() past the EOF, then emit end on the next tick. if (nOrig !== n && state.ended && state.length === 0) endReadable(this); if (ret !== null) this.emit('data', ret); return ret; }; function chunkInvalid(state, chunk) { var er = null; if (!Buffer.isBuffer(chunk) && typeof chunk !== 'string' && chunk !== null && chunk !== undefined && !state.objectMode) { er = new TypeError('Invalid non-string/buffer chunk'); } return er; } function onEofChunk(stream, state) { if (state.ended) return; if (state.decoder) { var chunk = state.decoder.end(); if (chunk && chunk.length) { state.buffer.push(chunk); state.length += state.objectMode ? 1 : chunk.length; } } state.ended = true; // emit 'readable' now to make sure it gets picked up. emitReadable(stream); } // Don't emit readable right away in sync mode, because this can trigger // another read() call => stack overflow. This way, it might trigger // a nextTick recursion warning, but that's not so bad. function emitReadable(stream) { var state = stream._readableState; state.needReadable = false; if (!state.emittedReadable) { debug('emitReadable', state.flowing); state.emittedReadable = true; if (state.sync) processNextTick(emitReadable_, stream);else emitReadable_(stream); } } function emitReadable_(stream) { debug('emit readable'); stream.emit('readable'); flow(stream); } // at this point, the user has presumably seen the 'readable' event, // and called read() to consume some data. that may have triggered // in turn another _read(n) call, in which case reading = true if // it's in progress. // However, if we're not ended, or reading, and the length < hwm, // then go ahead and try to read some more preemptively. function maybeReadMore(stream, state) { if (!state.readingMore) { state.readingMore = true; processNextTick(maybeReadMore_, stream, state); } } function maybeReadMore_(stream, state) { var len = state.length; while (!state.reading && !state.flowing && !state.ended && state.length < state.highWaterMark) { debug('maybeReadMore read 0'); stream.read(0); if (len === state.length) // didn't get any data, stop spinning. break;else len = state.length; } state.readingMore = false; } // abstract method. to be overridden in specific implementation classes. // call cb(er, data) where data is <= n in length. // for virtual (non-string, non-buffer) streams, "length" is somewhat // arbitrary, and perhaps not very meaningful. Readable.prototype._read = function (n) { this.emit('error', new Error('not implemented')); }; Readable.prototype.pipe = function (dest, pipeOpts) { var src = this; var state = this._readableState; switch (state.pipesCount) { case 0: state.pipes = dest; break; case 1: state.pipes = [state.pipes, dest]; break; default: state.pipes.push(dest); break; } state.pipesCount += 1; debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts); var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr; var endFn = doEnd ? onend : cleanup; if (state.endEmitted) processNextTick(endFn);else src.once('end', endFn); dest.on('unpipe', onunpipe); function onunpipe(readable) { debug('onunpipe'); if (readable === src) { cleanup(); } } function onend() { debug('onend'); dest.end(); } // when the dest drains, it reduces the awaitDrain counter // on the source. This would be more elegant with a .once() // handler in flow(), but adding and removing repeatedly is // too slow. var ondrain = pipeOnDrain(src); dest.on('drain', ondrain); var cleanedUp = false; function cleanup() { debug('cleanup'); // cleanup event handlers once the pipe is broken dest.removeListener('close', onclose); dest.removeListener('finish', onfinish); dest.removeListener('drain', ondrain); dest.removeListener('error', onerror); dest.removeListener('unpipe', onunpipe); src.removeListener('end', onend); src.removeListener('end', cleanup); src.removeListener('data', ondata); cleanedUp = true; // if the reader is waiting for a drain event from this // specific writer, then it would cause it to never start // flowing again. // So, if this is awaiting a drain, then we just call it now. // If we don't know, then assume that we are waiting for one. if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain(); } src.on('data', ondata); function ondata(chunk) { debug('ondata'); var ret = dest.write(chunk); if (false === ret) { // If the user unpiped during `dest.write()`, it is possible // to get stuck in a permanently paused state if that write // also returned false. if (state.pipesCount === 1 && state.pipes[0] === dest && src.listenerCount('data') === 1 && !cleanedUp) { debug('false write response, pause', src._readableState.awaitDrain); src._readableState.awaitDrain++; } src.pause(); } } // if the dest has an error, then stop piping into it. // however, don't suppress the throwing behavior for this. function onerror(er) { debug('onerror', er); unpipe(); dest.removeListener('error', onerror); if (EElistenerCount(dest, 'error') === 0) dest.emit('error', er); } // This is a brutally ugly hack to make sure that our error handler // is attached before any userland ones. NEVER DO THIS. if (!dest._events || !dest._events.error) dest.on('error', onerror);else if (isArray(dest._events.error)) dest._events.error.unshift(onerror);else dest._events.error = [onerror, dest._events.error]; // Both close and finish should trigger unpipe, but only once. function onclose() { dest.removeListener('finish', onfinish); unpipe(); } dest.once('close', onclose); function onfinish() { debug('onfinish'); dest.removeListener('close', onclose); unpipe(); } dest.once('finish', onfinish); function unpipe() { debug('unpipe'); src.unpipe(dest); } // tell the dest that it's being piped to dest.emit('pipe', src); // start the flow if it hasn't been started already. if (!state.flowing) { debug('pipe resume'); src.resume(); } return dest; }; function pipeOnDrain(src) { return function () { var state = src._readableState; debug('pipeOnDrain', state.awaitDrain); if (state.awaitDrain) state.awaitDrain--; if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) { state.flowing = true; flow(src); } }; } Readable.prototype.unpipe = function (dest) { var state = this._readableState; // if we're not piping anywhere, then do nothing. if (state.pipesCount === 0) return this; // just one destination. most common case. if (state.pipesCount === 1) { // passed in one, but it's not the right one. if (dest && dest !== state.pipes) return this; if (!dest) dest = state.pipes; // got a match. state.pipes = null; state.pipesCount = 0; state.flowing = false; if (dest) dest.emit('unpipe', this); return this; } // slow case. multiple pipe destinations. if (!dest) { // remove all. var dests = state.pipes; var len = state.pipesCount; state.pipes = null; state.pipesCount = 0; state.flowing = false; for (var _i = 0; _i < len; _i++) { dests[_i].emit('unpipe', this); }return this; } // try to find the right one. var i = indexOf(state.pipes, dest); if (i === -1) return this; state.pipes.splice(i, 1); state.pipesCount -= 1; if (state.pipesCount === 1) state.pipes = state.pipes[0]; dest.emit('unpipe', this); return this; }; // set up data events if they are asked for // Ensure readable listeners eventually get something Readable.prototype.on = function (ev, fn) { var res = Stream.prototype.on.call(this, ev, fn); // If listening to data, and it has not explicitly been paused, // then call resume to start the flow of data on the next tick. if (ev === 'data' && false !== this._readableState.flowing) { this.resume(); } if (ev === 'readable' && !this._readableState.endEmitted) { var state = this._readableState; if (!state.readableListening) { state.readableListening = true; state.emittedReadable = false; state.needReadable = true; if (!state.reading) { processNextTick(nReadingNextTick, this); } else if (state.length) { emitReadable(this, state); } } } return res; }; Readable.prototype.addListener = Readable.prototype.on; function nReadingNextTick(self) { debug('readable nexttick read 0'); self.read(0); } // pause() and resume() are remnants of the legacy readable stream API // If the user uses them, then switch into old mode. Readable.prototype.resume = function () { var state = this._readableState; if (!state.flowing) { debug('resume'); state.flowing = true; resume(this, state); } return this; }; function resume(stream, state) { if (!state.resumeScheduled) { state.resumeScheduled = true; processNextTick(resume_, stream, state); } } function resume_(stream, state) { if (!state.reading) { debug('resume read 0'); stream.read(0); } state.resumeScheduled = false; stream.emit('resume'); flow(stream); if (state.flowing && !state.reading) stream.read(0); } Readable.prototype.pause = function () { debug('call pause flowing=%j', this._readableState.flowing); if (false !== this._readableState.flowing) { debug('pause'); this._readableState.flowing = false; this.emit('pause'); } return this; }; function flow(stream) { var state = stream._readableState; debug('flow', state.flowing); if (state.flowing) { do { var chunk = stream.read(); } while (null !== chunk && state.flowing); } } // wrap an old-style stream as the async data source. // This is *not* part of the readable stream interface. // It is an ugly unfortunate mess of history. Readable.prototype.wrap = function (stream) { var state = this._readableState; var paused = false; var self = this; stream.on('end', function () { debug('wrapped end'); if (state.decoder && !state.ended) { var chunk = state.decoder.end(); if (chunk && chunk.length) self.push(chunk); } self.push(null); }); stream.on('data', function (chunk) { debug('wrapped data'); if (state.decoder) chunk = state.decoder.write(chunk); // don't skip over falsy values in objectMode if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return; var ret = self.push(chunk); if (!ret) { paused = true; stream.pause(); } }); // proxy all the other methods. // important when wrapping filters and duplexes. for (var i in stream) { if (this[i] === undefined && typeof stream[i] === 'function') { this[i] = function (method) { return function () { return stream[method].apply(stream, arguments); }; }(i); } } // proxy certain important events. var events = ['error', 'close', 'destroy', 'pause', 'resume']; forEach(events, function (ev) { stream.on(ev, self.emit.bind(self, ev)); }); // when we try to consume some more bytes, simply unpause the // underlying stream. self._read = function (n) { debug('wrapped _read', n); if (paused) { paused = false; stream.resume(); } }; return self; }; // exposed for testing purposes only. Readable._fromList = fromList; // Pluck off n bytes from an array of buffers. // Length is the combined lengths of all the buffers in the list. function fromList(n, state) { var list = state.buffer; var length = state.length; var stringMode = !!state.decoder; var objectMode = !!state.objectMode; var ret; // nothing in the list, definitely empty. if (list.length === 0) return null; if (length === 0) ret = null;else if (objectMode) ret = list.shift();else if (!n || n >= length) { // read it all, truncate the array. if (stringMode) ret = list.join('');else if (list.length === 1) ret = list[0];else ret = Buffer.concat(list, length); list.length = 0; } else { // read just some of it. if (n < list[0].length) { // just take a part of the first list item. // slice is the same for buffers and strings. var buf = list[0]; ret = buf.slice(0, n); list[0] = buf.slice(n); } else if (n === list[0].length) { // first list is a perfect match ret = list.shift(); } else { // complex case. // we have enough to cover it, but it spans past the first buffer. if (stringMode) ret = '';else ret = new Buffer(n); var c = 0; for (var i = 0, l = list.length; i < l && c < n; i++) { var buf = list[0]; var cpy = Math.min(n - c, buf.length); if (stringMode) ret += buf.slice(0, cpy);else buf.copy(ret, c, 0, cpy); if (cpy < buf.length) list[0] = buf.slice(cpy);else list.shift(); c += cpy; } } } return ret; } function endReadable(stream) { var state = stream._readableState; // If we get here before consuming all the bytes, then that is a // bug in node. Should never happen. if (state.length > 0) throw new Error('endReadable called on non-empty stream'); if (!state.endEmitted) { state.ended = true; processNextTick(endReadableNT, state, stream); } } function endReadableNT(state, stream) { // Check that we didn't get one last unshift. if (!state.endEmitted && state.length === 0) { state.endEmitted = true; stream.readable = false; stream.emit('end'); } } function forEach(xs, f) { for (var i = 0, l = xs.length; i < l; i++) { f(xs[i], i); } } function indexOf(xs, x) { for (var i = 0, l = xs.length; i < l; i++) { if (xs[i] === x) return i; } return -1; } }).call(this,require('_process')) },{"./_stream_duplex":579,"_process":295,"buffer":61,"core-util-is":104,"events":144,"inherits":167,"isarray":577,"process-nextick-args":294,"string_decoder/":616,"util":33}],582:[function(require,module,exports){ // a transform stream is a readable/writable stream where you do // something with the data. Sometimes it's called a "filter", // but that's not a great name for it, since that implies a thing where // some bits pass through, and others are simply ignored. (That would // be a valid example of a transform, of course.) // // While the output is causally related to the input, it's not a // necessarily symmetric or synchronous transformation. For example, // a zlib stream might take multiple plain-text writes(), and then // emit a single compressed chunk some time in the future. // // Here's how this works: // // The Transform stream has all the aspects of the readable and writable // stream classes. When you write(chunk), that calls _write(chunk,cb) // internally, and returns false if there's a lot of pending writes // buffered up. When you call read(), that calls _read(n) until // there's enough pending readable data buffered up. // // In a transform stream, the written data is placed in a buffer. When // _read(n) is called, it transforms the queued up data, calling the // buffered _write cb's as it consumes chunks. If consuming a single // written chunk would result in multiple output chunks, then the first // outputted bit calls the readcb, and subsequent chunks just go into // the read buffer, and will cause it to emit 'readable' if necessary. // // This way, back-pressure is actually determined by the reading side, // since _read has to be called to start processing a new chunk. However, // a pathological inflate type of transform can cause excessive buffering // here. For example, imagine a stream where every byte of input is // interpreted as an integer from 0-255, and then results in that many // bytes of output. Writing the 4 bytes {ff,ff,ff,ff} would result in // 1kb of data being output. In this case, you could write a very small // amount of input, and end up with a very large amount of output. In // such a pathological inflating mechanism, there'd be no way to tell // the system to stop doing the transform. A single 4MB write could // cause the system to run out of memory. // // However, even in such a pathological case, only a single written chunk // would be consumed, and then the rest would wait (un-transformed) until // the results of the previous transformed chunk were consumed. 'use strict'; module.exports = Transform; var Duplex = require('./_stream_duplex'); /**/ var util = require('core-util-is'); util.inherits = require('inherits'); /**/ util.inherits(Transform, Duplex); function TransformState(stream) { this.afterTransform = function (er, data) { return afterTransform(stream, er, data); }; this.needTransform = false; this.transforming = false; this.writecb = null; this.writechunk = null; this.writeencoding = null; } function afterTransform(stream, er, data) { var ts = stream._transformState; ts.transforming = false; var cb = ts.writecb; if (!cb) return stream.emit('error', new Error('no writecb in Transform class')); ts.writechunk = null; ts.writecb = null; if (data !== null && data !== undefined) stream.push(data); cb(er); var rs = stream._readableState; rs.reading = false; if (rs.needReadable || rs.length < rs.highWaterMark) { stream._read(rs.highWaterMark); } } function Transform(options) { if (!(this instanceof Transform)) return new Transform(options); Duplex.call(this, options); this._transformState = new TransformState(this); // when the writable side finishes, then flush out anything remaining. var stream = this; // start out asking for a readable event once data is transformed. this._readableState.needReadable = true; // we have implemented the _read method, and done the other things // that Readable wants before the first _read call, so unset the // sync guard flag. this._readableState.sync = false; if (options) { if (typeof options.transform === 'function') this._transform = options.transform; if (typeof options.flush === 'function') this._flush = options.flush; } this.once('prefinish', function () { if (typeof this._flush === 'function') this._flush(function (er) { done(stream, er); });else done(stream); }); } Transform.prototype.push = function (chunk, encoding) { this._transformState.needTransform = false; return Duplex.prototype.push.call(this, chunk, encoding); }; // This is the part where you do stuff! // override this function in implementation classes. // 'chunk' is an input chunk. // // Call `push(newChunk)` to pass along transformed output // to the readable side. You may call 'push' zero or more times. // // Call `cb(err)` when you are done with this chunk. If you pass // an error, then that'll put the hurt on the whole operation. If you // never call cb(), then you'll never get another chunk. Transform.prototype._transform = function (chunk, encoding, cb) { throw new Error('not implemented'); }; Transform.prototype._write = function (chunk, encoding, cb) { var ts = this._transformState; ts.writecb = cb; ts.writechunk = chunk; ts.writeencoding = encoding; if (!ts.transforming) { var rs = this._readableState; if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark); } }; // Doesn't matter what the args are here. // _transform does all the work. // That we got here means that the readable side wants more data. Transform.prototype._read = function (n) { var ts = this._transformState; if (ts.writechunk !== null && ts.writecb && !ts.transforming) { ts.transforming = true; this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform); } else { // mark that we need a transform, so that any data that comes in // will get processed, now that we've asked for it. ts.needTransform = true; } }; function done(stream, er) { if (er) return stream.emit('error', er); // if there's nothing in the write buffer, then that means // that nothing more will ever be provided var ws = stream._writableState; var ts = stream._transformState; if (ws.length) throw new Error('calling transform done when ws.length != 0'); if (ts.transforming) throw new Error('calling transform done when still transforming'); return stream.push(null); } },{"./_stream_duplex":579,"core-util-is":104,"inherits":167}],583:[function(require,module,exports){ // A bit simpler than readable streams. // Implement an async ._write(chunk, encoding, cb), and it'll handle all // the drain event emission and buffering. 'use strict'; module.exports = Writable; /**/ var processNextTick = require('process-nextick-args'); /**/ /**/ var asyncWrite = !true ? setImmediate : processNextTick; /**/ /**/ var Buffer = require('buffer').Buffer; /**/ Writable.WritableState = WritableState; /**/ var util = require('core-util-is'); util.inherits = require('inherits'); /**/ /**/ var internalUtil = { deprecate: require('util-deprecate') }; /**/ /**/ var Stream; (function () { try { Stream = require('st' + 'ream'); } catch (_) {} finally { if (!Stream) Stream = require('events').EventEmitter; } })(); /**/ var Buffer = require('buffer').Buffer; util.inherits(Writable, Stream); function nop() {} function WriteReq(chunk, encoding, cb) { this.chunk = chunk; this.encoding = encoding; this.callback = cb; this.next = null; } var Duplex; function WritableState(options, stream) { Duplex = Duplex || require('./_stream_duplex'); options = options || {}; // object stream flag to indicate whether or not this stream // contains buffers or objects. this.objectMode = !!options.objectMode; if (stream instanceof Duplex) this.objectMode = this.objectMode || !!options.writableObjectMode; // the point at which write() starts returning false // Note: 0 is a valid value, means that we always return false if // the entire buffer is not flushed immediately on write() var hwm = options.highWaterMark; var defaultHwm = this.objectMode ? 16 : 16 * 1024; this.highWaterMark = hwm || hwm === 0 ? hwm : defaultHwm; // cast to ints. this.highWaterMark = ~ ~this.highWaterMark; this.needDrain = false; // at the start of calling end() this.ending = false; // when end() has been called, and returned this.ended = false; // when 'finish' is emitted this.finished = false; // should we decode strings into buffers before passing to _write? // this is here so that some node-core streams can optimize string // handling at a lower level. var noDecode = options.decodeStrings === false; this.decodeStrings = !noDecode; // Crypto is kind of old and crusty. Historically, its default string // encoding is 'binary' so we have to make this configurable. // Everything else in the universe uses 'utf8', though. this.defaultEncoding = options.defaultEncoding || 'utf8'; // not an actual buffer we keep track of, but a measurement // of how much we're waiting to get pushed to some underlying // socket or file. this.length = 0; // a flag to see when we're in the middle of a write. this.writing = false; // when true all writes will be buffered until .uncork() call this.corked = 0; // a flag to be able to tell if the onwrite cb is called immediately, // or on a later tick. We set this to true at first, because any // actions that shouldn't happen until "later" should generally also // not happen before the first write call. this.sync = true; // a flag to know if we're processing previously buffered items, which // may call the _write() callback in the same tick, so that we don't // end up in an overlapped onwrite situation. this.bufferProcessing = false; // the callback that's passed to _write(chunk,cb) this.onwrite = function (er) { onwrite(stream, er); }; // the callback that the user supplies to write(chunk,encoding,cb) this.writecb = null; // the amount that is being written when _write is called. this.writelen = 0; this.bufferedRequest = null; this.lastBufferedRequest = null; // number of pending user-supplied write callbacks // this must be 0 before 'finish' can be emitted this.pendingcb = 0; // emit prefinish if the only thing we're waiting for is _write cbs // This is relevant for synchronous Transform streams this.prefinished = false; // True if the error was already emitted and should not be thrown again this.errorEmitted = false; // count buffered requests this.bufferedRequestCount = 0; // create the two objects needed to store the corked requests // they are not a linked list, as no new elements are inserted in there this.corkedRequestsFree = new CorkedRequest(this); this.corkedRequestsFree.next = new CorkedRequest(this); } WritableState.prototype.getBuffer = function writableStateGetBuffer() { var current = this.bufferedRequest; var out = []; while (current) { out.push(current); current = current.next; } return out; }; (function () { try { Object.defineProperty(WritableState.prototype, 'buffer', { get: internalUtil.deprecate(function () { return this.getBuffer(); }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.') }); } catch (_) {} })(); var Duplex; function Writable(options) { Duplex = Duplex || require('./_stream_duplex'); // Writable ctor is applied to Duplexes, though they're not // instanceof Writable, they're instanceof Readable. if (!(this instanceof Writable) && !(this instanceof Duplex)) return new Writable(options); this._writableState = new WritableState(options, this); // legacy. this.writable = true; if (options) { if (typeof options.write === 'function') this._write = options.write; if (typeof options.writev === 'function') this._writev = options.writev; } Stream.call(this); } // Otherwise people can pipe Writable streams, which is just wrong. Writable.prototype.pipe = function () { this.emit('error', new Error('Cannot pipe. Not readable.')); }; function writeAfterEnd(stream, cb) { var er = new Error('write after end'); // TODO: defer error events consistently everywhere, not just the cb stream.emit('error', er); processNextTick(cb, er); } // If we get something that is not a buffer, string, null, or undefined, // and we're not in objectMode, then that's an error. // Otherwise stream chunks are all considered to be of length=1, and the // watermarks determine how many objects to keep in the buffer, rather than // how many bytes or characters. function validChunk(stream, state, chunk, cb) { var valid = true; if (!Buffer.isBuffer(chunk) && typeof chunk !== 'string' && chunk !== null && chunk !== undefined && !state.objectMode) { var er = new TypeError('Invalid non-string/buffer chunk'); stream.emit('error', er); processNextTick(cb, er); valid = false; } return valid; } Writable.prototype.write = function (chunk, encoding, cb) { var state = this._writableState; var ret = false; if (typeof encoding === 'function') { cb = encoding; encoding = null; } if (Buffer.isBuffer(chunk)) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding; if (typeof cb !== 'function') cb = nop; if (state.ended) writeAfterEnd(this, cb);else if (validChunk(this, state, chunk, cb)) { state.pendingcb++; ret = writeOrBuffer(this, state, chunk, encoding, cb); } return ret; }; Writable.prototype.cork = function () { var state = this._writableState; state.corked++; }; Writable.prototype.uncork = function () { var state = this._writableState; if (state.corked) { state.corked--; if (!state.writing && !state.corked && !state.finished && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state); } }; Writable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) { // node::ParseEncoding() requires lower case. if (typeof encoding === 'string') encoding = encoding.toLowerCase(); if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new TypeError('Unknown encoding: ' + encoding); this._writableState.defaultEncoding = encoding; }; function decodeChunk(state, chunk, encoding) { if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') { chunk = new Buffer(chunk, encoding); } return chunk; } // if we're already writing something, then just put this // in the queue, and wait our turn. Otherwise, call _write // If we return false, then we need a drain event, so set that flag. function writeOrBuffer(stream, state, chunk, encoding, cb) { chunk = decodeChunk(state, chunk, encoding); if (Buffer.isBuffer(chunk)) encoding = 'buffer'; var len = state.objectMode ? 1 : chunk.length; state.length += len; var ret = state.length < state.highWaterMark; // we must ensure that previous needDrain will not be reset to false. if (!ret) state.needDrain = true; if (state.writing || state.corked) { var last = state.lastBufferedRequest; state.lastBufferedRequest = new WriteReq(chunk, encoding, cb); if (last) { last.next = state.lastBufferedRequest; } else { state.bufferedRequest = state.lastBufferedRequest; } state.bufferedRequestCount += 1; } else { doWrite(stream, state, false, len, chunk, encoding, cb); } return ret; } function doWrite(stream, state, writev, len, chunk, encoding, cb) { state.writelen = len; state.writecb = cb; state.writing = true; state.sync = true; if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite); state.sync = false; } function onwriteError(stream, state, sync, er, cb) { --state.pendingcb; if (sync) processNextTick(cb, er);else cb(er); stream._writableState.errorEmitted = true; stream.emit('error', er); } function onwriteStateUpdate(state) { state.writing = false; state.writecb = null; state.length -= state.writelen; state.writelen = 0; } function onwrite(stream, er) { var state = stream._writableState; var sync = state.sync; var cb = state.writecb; onwriteStateUpdate(state); if (er) onwriteError(stream, state, sync, er, cb);else { // Check if we're actually ready to finish, but don't emit yet var finished = needFinish(state); if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) { clearBuffer(stream, state); } if (sync) { /**/ asyncWrite(afterWrite, stream, state, finished, cb); /**/ } else { afterWrite(stream, state, finished, cb); } } } function afterWrite(stream, state, finished, cb) { if (!finished) onwriteDrain(stream, state); state.pendingcb--; cb(); finishMaybe(stream, state); } // Must force callback to be called on nextTick, so that we don't // emit 'drain' before the write() consumer gets the 'false' return // value, and has a chance to attach a 'drain' listener. function onwriteDrain(stream, state) { if (state.length === 0 && state.needDrain) { state.needDrain = false; stream.emit('drain'); } } // if there's something in the buffer waiting, then process it function clearBuffer(stream, state) { state.bufferProcessing = true; var entry = state.bufferedRequest; if (stream._writev && entry && entry.next) { // Fast case, write everything using _writev() var l = state.bufferedRequestCount; var buffer = new Array(l); var holder = state.corkedRequestsFree; holder.entry = entry; var count = 0; while (entry) { buffer[count] = entry; entry = entry.next; count += 1; } doWrite(stream, state, true, state.length, buffer, '', holder.finish); // doWrite is always async, defer these to save a bit of time // as the hot path ends with doWrite state.pendingcb++; state.lastBufferedRequest = null; state.corkedRequestsFree = holder.next; holder.next = null; } else { // Slow case, write chunks one-by-one while (entry) { var chunk = entry.chunk; var encoding = entry.encoding; var cb = entry.callback; var len = state.objectMode ? 1 : chunk.length; doWrite(stream, state, false, len, chunk, encoding, cb); entry = entry.next; // if we didn't call the onwrite immediately, then // it means that we need to wait until it does. // also, that means that the chunk and cb are currently // being processed, so move the buffer counter past them. if (state.writing) { break; } } if (entry === null) state.lastBufferedRequest = null; } state.bufferedRequestCount = 0; state.bufferedRequest = entry; state.bufferProcessing = false; } Writable.prototype._write = function (chunk, encoding, cb) { cb(new Error('not implemented')); }; Writable.prototype._writev = null; Writable.prototype.end = function (chunk, encoding, cb) { var state = this._writableState; if (typeof chunk === 'function') { cb = chunk; chunk = null; encoding = null; } else if (typeof encoding === 'function') { cb = encoding; encoding = null; } if (chunk !== null && chunk !== undefined) this.write(chunk, encoding); // .end() fully uncorks if (state.corked) { state.corked = 1; this.uncork(); } // ignore unnecessary end() calls. if (!state.ending && !state.finished) endWritable(this, state, cb); }; function needFinish(state) { return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing; } function prefinish(stream, state) { if (!state.prefinished) { state.prefinished = true; stream.emit('prefinish'); } } function finishMaybe(stream, state) { var need = needFinish(state); if (need) { if (state.pendingcb === 0) { prefinish(stream, state); state.finished = true; stream.emit('finish'); } else { prefinish(stream, state); } } return need; } function endWritable(stream, state, cb) { state.ending = true; finishMaybe(stream, state); if (cb) { if (state.finished) processNextTick(cb);else stream.once('finish', cb); } state.ended = true; stream.writable = false; } // It seems a linked list but it is not // there will be only 2 of these for each stream function CorkedRequest(state) { var _this = this; this.next = null; this.entry = null; this.finish = function (err) { var entry = _this.entry; _this.entry = null; while (entry) { var cb = entry.callback; state.pendingcb--; cb(err); entry = entry.next; } if (state.corkedRequestsFree) { state.corkedRequestsFree.next = _this; } else { state.corkedRequestsFree = _this; } }; } },{"./_stream_duplex":579,"buffer":61,"core-util-is":104,"events":144,"inherits":167,"process-nextick-args":294,"util-deprecate":634}],584:[function(require,module,exports){ module.exports = require("./lib/_stream_passthrough.js") },{"./lib/_stream_passthrough.js":580}],585:[function(require,module,exports){ var Stream = (function (){ try { return require('st' + 'ream'); // hack to fix a circular dependency issue when used with browserify } catch(_){} }()); exports = module.exports = require('./lib/_stream_readable.js'); exports.Stream = Stream || exports; exports.Readable = exports; exports.Writable = require('./lib/_stream_writable.js'); exports.Duplex = require('./lib/_stream_duplex.js'); exports.Transform = require('./lib/_stream_transform.js'); exports.PassThrough = require('./lib/_stream_passthrough.js'); // inline-process-browser and unreachable-branch-transform make sure this is // removed in browserify builds if (!true) { module.exports = require('stream'); } },{"./lib/_stream_duplex.js":579,"./lib/_stream_passthrough.js":580,"./lib/_stream_readable.js":581,"./lib/_stream_transform.js":582,"./lib/_stream_writable.js":583,"stream":576}],586:[function(require,module,exports){ module.exports = require("./lib/_stream_transform.js") },{"./lib/_stream_transform.js":582}],587:[function(require,module,exports){ module.exports = require("./lib/_stream_writable.js") },{"./lib/_stream_writable.js":583}],588:[function(require,module,exports){ (function (global){ var ClientRequest = require('./lib/request') var extend = require('xtend') var statusCodes = require('builtin-status-codes') var url = require('url') var http = exports http.request = function (opts, cb) { if (typeof opts === 'string') opts = url.parse(opts) else opts = extend(opts) // Normally, the page is loaded from http or https, so not specifying a protocol // will result in a (valid) protocol-relative url. However, this won't work if // the protocol is something else, like 'file:' var defaultProtocol = global.location.protocol.search(/^https?:$/) === -1 ? 'http:' : '' var protocol = opts.protocol || defaultProtocol var host = opts.hostname || opts.host var port = opts.port var path = opts.path || '/' // Necessary for IPv6 addresses if (host && host.indexOf(':') !== -1) host = '[' + host + ']' // This may be a relative url. The browser should always be able to interpret it correctly. opts.url = (host ? (protocol + '//' + host) : '') + (port ? ':' + port : '') + path opts.method = (opts.method || 'GET').toUpperCase() opts.headers = opts.headers || {} // Also valid opts.auth, opts.mode var req = new ClientRequest(opts) if (cb) req.on('response', cb) return req } http.get = function get (opts, cb) { var req = http.request(opts, cb) req.end() return req } http.Agent = function () {} http.Agent.defaultMaxSockets = 4 http.STATUS_CODES = statusCodes http.METHODS = [ 'CHECKOUT', 'CONNECT', 'COPY', 'DELETE', 'GET', 'HEAD', 'LOCK', 'M-SEARCH', 'MERGE', 'MKACTIVITY', 'MKCOL', 'MOVE', 'NOTIFY', 'OPTIONS', 'PATCH', 'POST', 'PROPFIND', 'PROPPATCH', 'PURGE', 'PUT', 'REPORT', 'SEARCH', 'SUBSCRIBE', 'TRACE', 'UNLOCK', 'UNSUBSCRIBE' ] }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) },{"./lib/request":590,"builtin-status-codes":64,"url":632,"xtend":592}],589:[function(require,module,exports){ (function (global){ exports.fetch = isFunction(global.fetch) && isFunction(global.ReadableByteStream) exports.blobConstructor = false try { new Blob([new ArrayBuffer(1)]) exports.blobConstructor = true } catch (e) {} var xhr = new global.XMLHttpRequest() // If location.host is empty, e.g. if this page/worker was loaded // from a Blob, then use example.com to avoid an error xhr.open('GET', global.location.host ? '/' : 'https://example.com') function checkTypeSupport (type) { try { xhr.responseType = type return xhr.responseType === type } catch (e) {} return false } // For some strange reason, Safari 7.0 reports typeof global.ArrayBuffer === 'object'. // Safari 7.1 appears to have fixed this bug. var haveArrayBuffer = typeof global.ArrayBuffer !== 'undefined' var haveSlice = haveArrayBuffer && isFunction(global.ArrayBuffer.prototype.slice) exports.arraybuffer = haveArrayBuffer && checkTypeSupport('arraybuffer') // These next two tests unavoidably show warnings in Chrome. Since fetch will always // be used if it's available, just return false for these to avoid the warnings. exports.msstream = !exports.fetch && haveSlice && checkTypeSupport('ms-stream') exports.mozchunkedarraybuffer = !exports.fetch && haveArrayBuffer && checkTypeSupport('moz-chunked-arraybuffer') exports.overrideMimeType = isFunction(xhr.overrideMimeType) exports.vbArray = isFunction(global.VBArray) function isFunction (value) { return typeof value === 'function' } xhr = null // Help gc }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) },{}],590:[function(require,module,exports){ (function (process,global,Buffer){ // var Base64 = require('Base64') var capability = require('./capability') var inherits = require('inherits') var response = require('./response') var stream = require('stream') var toArrayBuffer = require('to-arraybuffer') var IncomingMessage = response.IncomingMessage var rStates = response.readyStates function decideMode (preferBinary) { if (capability.fetch) { return 'fetch' } else if (capability.mozchunkedarraybuffer) { return 'moz-chunked-arraybuffer' } else if (capability.msstream) { return 'ms-stream' } else if (capability.arraybuffer && preferBinary) { return 'arraybuffer' } else if (capability.vbArray && preferBinary) { return 'text:vbarray' } else { return 'text' } } var ClientRequest = module.exports = function (opts) { var self = this stream.Writable.call(self) self._opts = opts self._body = [] self._headers = {} if (opts.auth) self.setHeader('Authorization', 'Basic ' + new Buffer(opts.auth).toString('base64')) Object.keys(opts.headers).forEach(function (name) { self.setHeader(name, opts.headers[name]) }) var preferBinary if (opts.mode === 'prefer-streaming') { // If streaming is a high priority but binary compatibility and // the accuracy of the 'content-type' header aren't preferBinary = false } else if (opts.mode === 'allow-wrong-content-type') { // If streaming is more important than preserving the 'content-type' header preferBinary = !capability.overrideMimeType } else if (!opts.mode || opts.mode === 'default' || opts.mode === 'prefer-fast') { // Use binary if text streaming may corrupt data or the content-type header, or for speed preferBinary = true } else { throw new Error('Invalid value for opts.mode') } self._mode = decideMode(preferBinary) self.on('finish', function () { self._onFinish() }) } inherits(ClientRequest, stream.Writable) ClientRequest.prototype.setHeader = function (name, value) { var self = this var lowerName = name.toLowerCase() // This check is not necessary, but it prevents warnings from browsers about setting unsafe // headers. To be honest I'm not entirely sure hiding these warnings is a good thing, but // http-browserify did it, so I will too. if (unsafeHeaders.indexOf(lowerName) !== -1) return self._headers[lowerName] = { name: name, value: value } } ClientRequest.prototype.getHeader = function (name) { var self = this return self._headers[name.toLowerCase()].value } ClientRequest.prototype.removeHeader = function (name) { var self = this delete self._headers[name.toLowerCase()] } ClientRequest.prototype._onFinish = function () { var self = this if (self._destroyed) return var opts = self._opts var headersObj = self._headers var body if (opts.method === 'POST' || opts.method === 'PUT' || opts.method === 'PATCH') { if (capability.blobConstructor) { body = new global.Blob(self._body.map(function (buffer) { return toArrayBuffer(buffer) }), { type: (headersObj['content-type'] || {}).value || '' }) } else { // get utf8 string body = Buffer.concat(self._body).toString() } } if (self._mode === 'fetch') { var headers = Object.keys(headersObj).map(function (name) { return [headersObj[name].name, headersObj[name].value] }) global.fetch(self._opts.url, { method: self._opts.method, headers: headers, body: body, mode: 'cors', credentials: opts.withCredentials ? 'include' : 'same-origin' }).then(function (response) { self._fetchResponse = response self._connect() }, function (reason) { self.emit('error', reason) }) } else { var xhr = self._xhr = new global.XMLHttpRequest() try { xhr.open(self._opts.method, self._opts.url, true) } catch (err) { process.nextTick(function () { self.emit('error', err) }) return } // Can't set responseType on really old browsers if ('responseType' in xhr) xhr.responseType = self._mode.split(':')[0] if ('withCredentials' in xhr) xhr.withCredentials = !!opts.withCredentials if (self._mode === 'text' && 'overrideMimeType' in xhr) xhr.overrideMimeType('text/plain; charset=x-user-defined') Object.keys(headersObj).forEach(function (name) { xhr.setRequestHeader(headersObj[name].name, headersObj[name].value) }) self._response = null xhr.onreadystatechange = function () { switch (xhr.readyState) { case rStates.LOADING: case rStates.DONE: self._onXHRProgress() break } } // Necessary for streaming in Firefox, since xhr.response is ONLY defined // in onprogress, not in onreadystatechange with xhr.readyState = 3 if (self._mode === 'moz-chunked-arraybuffer') { xhr.onprogress = function () { self._onXHRProgress() } } xhr.onerror = function () { if (self._destroyed) return self.emit('error', new Error('XHR error')) } try { xhr.send(body) } catch (err) { process.nextTick(function () { self.emit('error', err) }) return } } } /** * Checks if xhr.status is readable and non-zero, indicating no error. * Even though the spec says it should be available in readyState 3, * accessing it throws an exception in IE8 */ function statusValid (xhr) { try { var status = xhr.status return (status !== null && status !== 0) } catch (e) { return false } } ClientRequest.prototype._onXHRProgress = function () { var self = this if (!statusValid(self._xhr) || self._destroyed) return if (!self._response) self._connect() self._response._onXHRProgress() } ClientRequest.prototype._connect = function () { var self = this if (self._destroyed) return self._response = new IncomingMessage(self._xhr, self._fetchResponse, self._mode) self.emit('response', self._response) } ClientRequest.prototype._write = function (chunk, encoding, cb) { var self = this self._body.push(chunk) cb() } ClientRequest.prototype.abort = ClientRequest.prototype.destroy = function () { var self = this self._destroyed = true if (self._response) self._response._destroyed = true if (self._xhr) self._xhr.abort() // Currently, there isn't a way to truly abort a fetch. // If you like bikeshedding, see https://github.com/whatwg/fetch/issues/27 } ClientRequest.prototype.end = function (data, encoding, cb) { var self = this if (typeof data === 'function') { cb = data data = undefined } stream.Writable.prototype.end.call(self, data, encoding, cb) } ClientRequest.prototype.flushHeaders = function () {} ClientRequest.prototype.setTimeout = function () {} ClientRequest.prototype.setNoDelay = function () {} ClientRequest.prototype.setSocketKeepAlive = function () {} // Taken from http://www.w3.org/TR/XMLHttpRequest/#the-setrequestheader%28%29-method var unsafeHeaders = [ 'accept-charset', 'accept-encoding', 'access-control-request-headers', 'access-control-request-method', 'connection', 'content-length', 'cookie', 'cookie2', 'date', 'dnt', 'expect', 'host', 'keep-alive', 'origin', 'referer', 'te', 'trailer', 'transfer-encoding', 'upgrade', 'user-agent', 'via' ] }).call(this,require('_process'),typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {},require("buffer").Buffer) },{"./capability":589,"./response":591,"_process":295,"buffer":61,"inherits":167,"stream":576,"to-arraybuffer":619}],591:[function(require,module,exports){ (function (process,global,Buffer){ var capability = require('./capability') var inherits = require('inherits') var stream = require('stream') var rStates = exports.readyStates = { UNSENT: 0, OPENED: 1, HEADERS_RECEIVED: 2, LOADING: 3, DONE: 4 } var IncomingMessage = exports.IncomingMessage = function (xhr, response, mode) { var self = this stream.Readable.call(self) self._mode = mode self.headers = {} self.rawHeaders = [] self.trailers = {} self.rawTrailers = [] // Fake the 'close' event, but only once 'end' fires self.on('end', function () { // The nextTick is necessary to prevent the 'request' module from causing an infinite loop process.nextTick(function () { self.emit('close') }) }) if (mode === 'fetch') { self._fetchResponse = response self.statusCode = response.status self.statusMessage = response.statusText // backwards compatible version of for ( of ): // for (var ,_i,_it = [Symbol.iterator](); = (_i = _it.next()).value,!_i.done;) for (var header, _i, _it = response.headers[Symbol.iterator](); header = (_i = _it.next()).value, !_i.done;) { self.headers[header[0].toLowerCase()] = header[1] self.rawHeaders.push(header[0], header[1]) } // TODO: this doesn't respect backpressure. Once WritableStream is available, this can be fixed var reader = response.body.getReader() function read () { reader.read().then(function (result) { if (self._destroyed) return if (result.done) { self.push(null) return } self.push(new Buffer(result.value)) read() }) } read() } else { self._xhr = xhr self._pos = 0 self.statusCode = xhr.status self.statusMessage = xhr.statusText var headers = xhr.getAllResponseHeaders().split(/\r?\n/) headers.forEach(function (header) { var matches = header.match(/^([^:]+):\s*(.*)/) if (matches) { var key = matches[1].toLowerCase() if (key === 'set-cookie') { if (self.headers[key] === undefined) { self.headers[key] = [] } self.headers[key].push(matches[2]) } else if (self.headers[key] !== undefined) { self.headers[key] += ', ' + matches[2] } else { self.headers[key] = matches[2] } self.rawHeaders.push(matches[1], matches[2]) } }) self._charset = 'x-user-defined' if (!capability.overrideMimeType) { var mimeType = self.rawHeaders['mime-type'] if (mimeType) { var charsetMatch = mimeType.match(/;\s*charset=([^;])(;|$)/) if (charsetMatch) { self._charset = charsetMatch[1].toLowerCase() } } if (!self._charset) self._charset = 'utf-8' // best guess } } } inherits(IncomingMessage, stream.Readable) IncomingMessage.prototype._read = function () {} IncomingMessage.prototype._onXHRProgress = function () { var self = this var xhr = self._xhr var response = null switch (self._mode) { case 'text:vbarray': // For IE9 if (xhr.readyState !== rStates.DONE) break try { // This fails in IE8 response = new global.VBArray(xhr.responseBody).toArray() } catch (e) {} if (response !== null) { self.push(new Buffer(response)) break } // Falls through in IE8 case 'text': try { // This will fail when readyState = 3 in IE9. Switch mode and wait for readyState = 4 response = xhr.responseText } catch (e) { self._mode = 'text:vbarray' break } if (response.length > self._pos) { var newData = response.substr(self._pos) if (self._charset === 'x-user-defined') { var buffer = new Buffer(newData.length) for (var i = 0; i < newData.length; i++) buffer[i] = newData.charCodeAt(i) & 0xff self.push(buffer) } else { self.push(newData, self._charset) } self._pos = response.length } break case 'arraybuffer': if (xhr.readyState !== rStates.DONE) break response = xhr.response self.push(new Buffer(new Uint8Array(response))) break case 'moz-chunked-arraybuffer': // take whole response = xhr.response if (xhr.readyState !== rStates.LOADING || !response) break self.push(new Buffer(new Uint8Array(response))) break case 'ms-stream': response = xhr.response if (xhr.readyState !== rStates.LOADING) break var reader = new global.MSStreamReader() reader.onprogress = function () { if (reader.result.byteLength > self._pos) { self.push(new Buffer(new Uint8Array(reader.result.slice(self._pos)))) self._pos = reader.result.byteLength } } reader.onload = function () { self.push(null) } // reader.onerror = ??? // TODO: this reader.readAsArrayBuffer(response) break } // The ms-stream case handles end separately in reader.onload() if (self._xhr.readyState === rStates.DONE && self._mode !== 'ms-stream') { self.push(null) } } }).call(this,require('_process'),typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {},require("buffer").Buffer) },{"./capability":589,"_process":295,"buffer":61,"inherits":167,"stream":576}],592:[function(require,module,exports){ arguments[4][177][0].apply(exports,arguments) },{"dup":177}],593:[function(require,module,exports){ (function (process){ var pull = require('pull-stream/pull') function destroy(stream, cb) { function onClose () { cleanup(); cb() } function onError (err) { cleanup(); cb(err) } function cleanup() { stream.removeListener('close', onClose) stream.removeListener('error', onError) } stream.on('close', onClose) stream.on('error', onError) } function write(read, stream, cb) { var ended, closed = false, did function done () { if(did) return did = true cb && cb(ended === true ? null : ended) } function onClose () { if(closed) return closed = true cleanup() if(!ended) read(ended = true, done) else done() } function onError (err) { cleanup() if(!ended) read(ended = err, done) } function cleanup() { stream.on('finish', onClose) stream.removeListener('close', onClose) stream.removeListener('error', onError) } stream.on('close', onClose) stream.on('finish', onClose) stream.on('error', onError) process.nextTick(function next() { read(null, function (end, data) { ended = ended || end //you can't "end" a stdout stream, so this needs to be handled specially. if(end === true) return stream._isStdio ? done() : stream.end() if(ended = ended || end) { stream.destroy && stream.destroy() return done(ended) } //I noticed a problem streaming to the terminal: //sometimes the end got cut off, creating invalid output. //it seems that stdout always emits "drain" when it ends. //so this seems to work, but i have been unable to reproduce this test //automatically, so you need to run ./test/stdout.js a few times and the end is valid json. if(stream._isStdio) stream.write(data, function () { next() }) else { var pause = stream.write(data) if(pause === false) stream.once('drain', next) else next() } }) }) } function first (emitter, events, handler) { function listener (val) { events.forEach(function (e) { emitter.removeListener(e, listener) }) handler(val) } events.forEach(function (e) { emitter.on(e, listener) }) return emitter } function read2(stream) { var ended = false, waiting = false var _cb function read () { var data = stream.read() if(data !== null && _cb) { var cb = _cb; _cb = null cb(null, data) } } stream.on('readable', function () { waiting = true _cb && read() }) .on('end', function () { ended = true _cb && _cb(ended) }) .on('error', function (err) { ended = err _cb && _cb(ended) }) return function (end, cb) { _cb = cb if(ended) cb(ended) else if(waiting) read() } } function read1(stream) { var buffer = [], cbs = [], ended, paused = false var draining function drain() { while((buffer.length || ended) && cbs.length) cbs.shift()(buffer.length ? null : ended, buffer.shift()) if(!buffer.length && (paused)) { paused = false stream.resume() } } stream.on('data', function (data) { buffer.push(data) drain() if(buffer.length && stream.pause) { paused = true stream.pause() } }) stream.on('end', function () { ended = true drain() }) stream.on('error', function (err) { ended = err drain() }) return function (abort, cb) { if(!cb) throw new Error('*must* provide cb') if(abort) { stream.once('close', function () { cb(abort) }) stream.destroy() } cbs.push(cb) drain() } } var read = read1 var sink = function (stream, cb) { return function (read) { return write(read, stream, cb) } } var source = function (stream) { return read1(stream) } exports = module.exports = function (stream, cb) { return ( (stream.writable && stream.write) ? stream.readable ? function(_read) { write(_read, stream, cb); return read1(stream) } : sink(stream, cb) : source(stream) ) } exports.sink = sink exports.source = source exports.read = read exports.read1 = read1 exports.read2 = read2 exports.duplex = function (stream, cb) { return { source: source(stream), sink: sink(stream, cb) } } }).call(this,require('_process')) },{"_process":295,"pull-stream/pull":594}],594:[function(require,module,exports){ arguments[4][233][0].apply(exports,arguments) },{"dup":233}],595:[function(require,module,exports){ 'use strict' var level = require('level') var pull = require('pull-stream') var Write = require('pull-write') var pl = require('pull-level') var query = require('./query') var select = require('./select') var mfr = require('map-filter-reduce') var keys = require('map-filter-reduce/keys') var bytewise = require('bytewise') var paramap = require('pull-paramap') var u = require('./util') var isArray = Array.isArray //sorted index. module.exports = function (path, indexes, links, version, codec) { codec = codec || require('bytewise') var db = level(path) if('string' !== typeof path) throw new Error('must provide path for leveldb instance') if(!Array.isArray(indexes)) throw new Error('must provide an array of indexes') if('number' !== typeof version) throw new Error('must provide version number') if(!links) links = function (data, emit) { emit(data) } //always write metada to the lowest key, //so the indexes do not interfeer //we don't want to encode this with the codec, //because then we can't change the codec safely //(prehaps the encoding of META is also some indexed value in another codec?) var META = '\x00' return { init: function (cb) { db.get(META, function (err, value) { console.log('RELOAD INDEX:', value) if(value) try { value = JSON.parse(value) } catch (err) { return cb(null, 0) } if(err) //first time this was run cb(null, 0) //if the view has changed, rebuild entire index. //else, read current version. else if(version && value.version !== version) { db.close(function () { level.destroy(path, function (err) { if(err) return cb(err) db = level(path) cb(null, 0) }) }) } else cb(null, value.since || 0) }) }, write: function (cb) { return pull( Write(function (batch, cb) { db.batch(batch, cb) }, function (batch, data) { if(data.sync) return batch if(!batch) batch = [{ key: META, value: {version: version, since: data.ts}, valueEncoding: 'json', type: 'put' }] function push(ary) { batch.push({key: codec.encode(ary), value: ' ', type: 'put'}) } links(data, function (link) { indexes.forEach(function (index) { var a = [index.key] for(var i = 0; i < index.value.length; i++) { var key = index.value[i] if(!u.has(key, link)) return a.push(u.get(key, link)) } push(a) }) }) var ts = data.ts || data.timestamp if(ts) batch[0].value.since = ts return batch }, 100, cb) ) }, close: function (cb) { db.close(cb) }, //get the raw indexes, for debugging. dump: function () { return pl.read(db, {keyEncoding: codec, gt: '\x00'}) }, //read all the messages out, via matching ranges. read: function (opts, get) { var lookup opts = opts || {} var _opts = {} var q, k if(isArray(opts.query)) { q = opts.query[0].$filter || {} k = keys(opts.query) } else if(opts.query) { q = opts.query } else q = {} var index = select(indexes, q) var _opts = query(index, q) _opts.values = false _opts.keys = true _opts.keyEncoding = codec _opts.reverse = opts.reverse _opts.live = opts.live _opts.limit = opts.limit // If a query uses a key not in the index // then we need to get that somehow. // if this is a key from the thing indexed, // it makes sense to look up that record. // how to do that might be different in a view. // just disable this for now. if(get) lookup = paramap(function (link, cb) { get(link.ts || link.timestamp, function (err, data) { if(err) return cb(err) link.key = data.key link.value = data.value cb(null, link) }) }) // else // lookup = pull.through() return pull( pl.read(db, _opts), //rehydrate the index to resemble the original object. pull.map(function (e) { var o = {} for(var i = 0; i < index.value.length; i++) u.set(index.value[i], e[i+1], o) return o }), lookup, isArray(opts.query) ? mfr(opts.query) : pull.through() ) } } } },{"./query":612,"./select":613,"./util":614,"bytewise":598,"level":199,"map-filter-reduce":229,"map-filter-reduce/keys":230,"pull-level":600,"pull-paramap":363,"pull-stream":607,"pull-write":393}],596:[function(require,module,exports){ arguments[4][475][0].apply(exports,arguments) },{"bytewise-core":67,"dup":475,"typewise":627}],597:[function(require,module,exports){ arguments[4][476][0].apply(exports,arguments) },{"./binary":596,"dup":476}],598:[function(require,module,exports){ arguments[4][477][0].apply(exports,arguments) },{"./encoding/":597,"dup":477}],599:[function(require,module,exports){ arguments[4][345][0].apply(exports,arguments) },{"dup":345}],600:[function(require,module,exports){ arguments[4][487][0].apply(exports,arguments) },{"dup":487,"level-post":198,"pull-cat":305,"pull-pushable":601,"pull-stream":607,"pull-window":390,"stream-to-pull-stream":593}],601:[function(require,module,exports){ arguments[4][346][0].apply(exports,arguments) },{"dup":346,"pull-stream":602}],602:[function(require,module,exports){ arguments[4][347][0].apply(exports,arguments) },{"./maybe":603,"./sinks":604,"./sources":605,"./throughs":606,"dup":347,"pull-core":599}],603:[function(require,module,exports){ arguments[4][348][0].apply(exports,arguments) },{"dup":348,"pull-core":599}],604:[function(require,module,exports){ arguments[4][349][0].apply(exports,arguments) },{"dup":349}],605:[function(require,module,exports){ arguments[4][350][0].apply(exports,arguments) },{"dup":350}],606:[function(require,module,exports){ (function (process){ var u = require('pull-core') var sources = require('./sources') var sinks = require('./sinks') var prop = u.prop var id = u.id var tester = u.tester var map = exports.map = function (read, map) { map = prop(map) || id return function (end, cb) { read(end, function (end, data) { var data = !end ? map(data) : null cb(end, data) }) } } var asyncMap = exports.asyncMap = function (read, map) { if(!map) return read return function (end, cb) { if(end) return read(end, cb) //abort read(null, function (end, data) { if(end) return cb(end, data) map(data, cb) }) } } var paraMap = exports.paraMap = function (read, map, width) { if(!map) return read var ended = false, queue = [], _cb function drain () { if(!_cb) return var cb = _cb _cb = null if(queue.length) return cb(null, queue.shift()) else if(ended && !n) return cb(ended) _cb = cb } function pull () { read(null, function (end, data) { if(end) { ended = end return drain() } n++ map(data, function (err, data) { n-- queue.push(data) drain() }) if(n < width && !ended) pull() }) } var n = 0 return function (end, cb) { if(end) return read(end, cb) //abort //continue to read while there are less than 3 maps in flight _cb = cb if(queue.length || ended) pull(), drain() else pull() } return highWaterMark(asyncMap(read, map), width) } var filter = exports.filter = function (read, test) { //regexp test = tester(test) return function next (end, cb) { read(end, function (end, data) { if(!end && !test(data)) return next(end, cb) cb(end, data) }) } } var filterNot = exports.filterNot = function (read, test) { test = tester(test) return filter(read, function (e) { return !test(e) }) } var through = exports.through = function (read, op, onEnd) { var a = false function once (abort) { if(a || !onEnd) return a = true onEnd(abort === true ? null : abort) } return function (end, cb) { if(end) once(end) return read(end, function (end, data) { if(!end) op && op(data) else once(end) cb(end, data) }) } } var take = exports.take = function (read, test) { var ended = false if('number' === typeof test) { var n = test; test = function () { return n -- } } return function (end, cb) { if(ended) return cb(ended) if(ended = end) return read(ended, cb) read(null, function (end, data) { if(ended = ended || end) return cb(ended) if(!test(data)) { ended = true read(true, function (end, data) { cb(ended, data) }) } else cb(null, data) }) } } var unique = exports.unique = function (read, field, invert) { field = prop(field) || id var seen = {} return filter(read, function (data) { var key = field(data) if(seen[key]) return !!invert //false, by default else seen[key] = true return !invert //true by default }) } var nonUnique = exports.nonUnique = function (read, field) { return unique(read, field, true) } var group = exports.group = function (read, size) { var ended; size = size || 5 var queue = [] return function (end, cb) { //this means that the upstream is sending an error. if(end) return read(ended = end, cb) //this means that we read an end before. if(ended) return cb(ended) read(null, function next(end, data) { if(ended = ended || end) { if(!queue.length) return cb(ended) var _queue = queue; queue = [] return cb(null, _queue) } queue.push(data) if(queue.length < size) return read(null, next) var _queue = queue; queue = [] cb(null, _queue) }) } } var flatten = exports.flatten = function (read) { var _read return function (abort, cb) { if(_read) nextChunk() else nextStream() function nextChunk () { _read(null, function (end, data) { if(end) nextStream() else cb(null, data) }) } function nextStream () { read(null, function (end, stream) { if(end) return cb(end) if(Array.isArray(stream)) stream = sources.values(stream) else if('function' != typeof stream) throw new Error('expected stream of streams') _read = stream nextChunk() }) } } } var prepend = exports.prepend = function (read, head) { return function (abort, cb) { if(head !== null) { if(abort) return read(abort, cb) var _head = head head = null cb(null, _head) } else { read(abort, cb) } } } //var drainIf = exports.drainIf = function (op, done) { // sinks.drain( //} var _reduce = exports._reduce = function (read, reduce, initial) { return function (close, cb) { if(close) return read(close, cb) if(ended) return cb(ended) sinks.drain(function (item) { initial = reduce(initial, item) }, function (err, data) { ended = err || true if(!err) cb(null, initial) else cb(ended) }) (read) } } var nextTick = process.nextTick var highWaterMark = exports.highWaterMark = function (read, highWaterMark) { var buffer = [], waiting = [], ended, reading = false highWaterMark = highWaterMark || 10 function readAhead () { while(waiting.length && (buffer.length || ended)) waiting.shift()(ended, ended ? null : buffer.shift()) } function next () { if(ended || reading || buffer.length >= highWaterMark) return reading = true return read(ended, function (end, data) { reading = false ended = ended || end if(data != null) buffer.push(data) next(); readAhead() }) } nextTick(next) return function (end, cb) { ended = ended || end waiting.push(cb) next(); readAhead() } } }).call(this,require('_process')) },{"./sinks":604,"./sources":605,"_process":295,"pull-core":599}],607:[function(require,module,exports){ arguments[4][232][0].apply(exports,arguments) },{"./pull":608,"./sinks":609,"./sources":610,"./throughs":611,"dup":232}],608:[function(require,module,exports){ arguments[4][233][0].apply(exports,arguments) },{"dup":233}],609:[function(require,module,exports){ arguments[4][234][0].apply(exports,arguments) },{"dup":234}],610:[function(require,module,exports){ arguments[4][235][0].apply(exports,arguments) },{"dup":235}],611:[function(require,module,exports){ arguments[4][236][0].apply(exports,arguments) },{"./sinks":609,"./sources":610,"dup":236}],612:[function(require,module,exports){ arguments[4][569][0].apply(exports,arguments) },{"./select":613,"./util":614,"dup":569,"map-filter-reduce/util":238}],613:[function(require,module,exports){ arguments[4][570][0].apply(exports,arguments) },{"./util":614,"dup":570,"map-filter-reduce/util":238}],614:[function(require,module,exports){ arguments[4][571][0].apply(exports,arguments) },{"dup":571}],615:[function(require,module,exports){ //force to a valid range var range = exports.range = function (obj) { return null == obj ? {} : 'string' === typeof range ? { min: range, max: range + '\xff' } : obj } //turn into a sub range. var prefix = exports.prefix = function (range, within, term) { range = exports.range(range) var _range = {} term = term || '\xff' if(range instanceof RegExp || 'function' == typeof range) { _range.min = within _range.max = within + term, _range.inner = function (k) { var j = k.substring(within.length) if(range.test) return range.test(j) return range(j) } } else if('object' === typeof range) { _range.min = within + (range.min || range.start || '') _range.max = within + (range.max || range.end || (term || '~')) _range.reverse = !!range.reverse } return _range } //return a function that checks a range var checker = exports.checker = function (range) { if(!range) range = {} if ('string' === typeof range) return function (key) { return key.indexOf(range) == 0 } else if(range instanceof RegExp) return function (key) { return range.test(key) } else if('object' === typeof range) return function (key) { var min = range.min || range.start var max = range.max || range.end // fixes keys passed as ints from sublevels key = String(key) return ( !min || key >= min ) && ( !max || key <= max ) && ( !range.inner || ( range.inner.test ? range.inner.test(key) : range.inner(key) ) ) } else if('function' === typeof range) return range } //check if a key is within a range. var satifies = exports.satisfies = function (key, range) { return checker(range)(key) } },{}],616:[function(require,module,exports){ // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. var Buffer = require('buffer').Buffer; var isBufferEncoding = Buffer.isEncoding || function(encoding) { switch (encoding && encoding.toLowerCase()) { case 'hex': case 'utf8': case 'utf-8': case 'ascii': case 'binary': case 'base64': case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': case 'raw': return true; default: return false; } } function assertEncoding(encoding) { if (encoding && !isBufferEncoding(encoding)) { throw new Error('Unknown encoding: ' + encoding); } } // StringDecoder provides an interface for efficiently splitting a series of // buffers into a series of JS strings without breaking apart multi-byte // characters. CESU-8 is handled as part of the UTF-8 encoding. // // @TODO Handling all encodings inside a single object makes it very difficult // to reason about this code, so it should be split up in the future. // @TODO There should be a utf8-strict encoding that rejects invalid UTF-8 code // points as used by CESU-8. var StringDecoder = exports.StringDecoder = function(encoding) { this.encoding = (encoding || 'utf8').toLowerCase().replace(/[-_]/, ''); assertEncoding(encoding); switch (this.encoding) { case 'utf8': // CESU-8 represents each of Surrogate Pair by 3-bytes this.surrogateSize = 3; break; case 'ucs2': case 'utf16le': // UTF-16 represents each of Surrogate Pair by 2-bytes this.surrogateSize = 2; this.detectIncompleteChar = utf16DetectIncompleteChar; break; case 'base64': // Base-64 stores 3 bytes in 4 chars, and pads the remainder. this.surrogateSize = 3; this.detectIncompleteChar = base64DetectIncompleteChar; break; default: this.write = passThroughWrite; return; } // Enough space to store all bytes of a single character. UTF-8 needs 4 // bytes, but CESU-8 may require up to 6 (3 bytes per surrogate). this.charBuffer = new Buffer(6); // Number of bytes received for the current incomplete multi-byte character. this.charReceived = 0; // Number of bytes expected for the current incomplete multi-byte character. this.charLength = 0; }; // write decodes the given buffer and returns it as JS string that is // guaranteed to not contain any partial multi-byte characters. Any partial // character found at the end of the buffer is buffered up, and will be // returned when calling write again with the remaining bytes. // // Note: Converting a Buffer containing an orphan surrogate to a String // currently works, but converting a String to a Buffer (via `new Buffer`, or // Buffer#write) will replace incomplete surrogates with the unicode // replacement character. See https://codereview.chromium.org/121173009/ . StringDecoder.prototype.write = function(buffer) { var charStr = ''; // if our last write ended with an incomplete multibyte character while (this.charLength) { // determine how many remaining bytes this buffer has to offer for this char var available = (buffer.length >= this.charLength - this.charReceived) ? this.charLength - this.charReceived : buffer.length; // add the new bytes to the char buffer buffer.copy(this.charBuffer, this.charReceived, 0, available); this.charReceived += available; if (this.charReceived < this.charLength) { // still not enough chars in this buffer? wait for more ... return ''; } // remove bytes belonging to the current character from the buffer buffer = buffer.slice(available, buffer.length); // get the character that was split charStr = this.charBuffer.slice(0, this.charLength).toString(this.encoding); // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character var charCode = charStr.charCodeAt(charStr.length - 1); if (charCode >= 0xD800 && charCode <= 0xDBFF) { this.charLength += this.surrogateSize; charStr = ''; continue; } this.charReceived = this.charLength = 0; // if there are no more bytes in this buffer, just emit our char if (buffer.length === 0) { return charStr; } break; } // determine and set charLength / charReceived this.detectIncompleteChar(buffer); var end = buffer.length; if (this.charLength) { // buffer the incomplete character bytes we got buffer.copy(this.charBuffer, 0, buffer.length - this.charReceived, end); end -= this.charReceived; } charStr += buffer.toString(this.encoding, 0, end); var end = charStr.length - 1; var charCode = charStr.charCodeAt(end); // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character if (charCode >= 0xD800 && charCode <= 0xDBFF) { var size = this.surrogateSize; this.charLength += size; this.charReceived += size; this.charBuffer.copy(this.charBuffer, size, 0, size); buffer.copy(this.charBuffer, 0, 0, size); return charStr.substring(0, end); } // or just emit the charStr return charStr; }; // detectIncompleteChar determines if there is an incomplete UTF-8 character at // the end of the given buffer. If so, it sets this.charLength to the byte // length that character, and sets this.charReceived to the number of bytes // that are available for this character. StringDecoder.prototype.detectIncompleteChar = function(buffer) { // determine how many bytes we have to check at the end of this buffer var i = (buffer.length >= 3) ? 3 : buffer.length; // Figure out if one of the last i bytes of our buffer announces an // incomplete char. for (; i > 0; i--) { var c = buffer[buffer.length - i]; // See http://en.wikipedia.org/wiki/UTF-8#Description // 110XXXXX if (i == 1 && c >> 5 == 0x06) { this.charLength = 2; break; } // 1110XXXX if (i <= 2 && c >> 4 == 0x0E) { this.charLength = 3; break; } // 11110XXX if (i <= 3 && c >> 3 == 0x1E) { this.charLength = 4; break; } } this.charReceived = i; }; StringDecoder.prototype.end = function(buffer) { var res = ''; if (buffer && buffer.length) res = this.write(buffer); if (this.charReceived) { var cr = this.charReceived; var buf = this.charBuffer; var enc = this.encoding; res += buf.slice(0, cr).toString(enc); } return res; }; function passThroughWrite(buffer) { return buffer.toString(this.encoding); } function utf16DetectIncompleteChar(buffer) { this.charReceived = buffer.length % 2; this.charLength = this.charReceived ? 2 : 0; } function base64DetectIncompleteChar(buffer) { this.charReceived = buffer.length % 3; this.charLength = this.charReceived ? 3 : 0; } },{"buffer":61}],617:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015 Titus Wormer * @license MIT * @module stringify-entities * @fileoverview Encode HTML character references and character entities. */ 'use strict'; /* eslint-env commonjs */ /* * Dependencies. */ var entities = require('character-entities-html4'); var EXPRESSION_NAMED = require('./lib/expression.js'); /* * Methods. */ var has = {}.hasOwnProperty; /* * List of enforced escapes. */ var escapes = ['"', '\'', '<', '>', '&', '`']; /* * Map of characters to names. */ var characters = {}; (function () { var name; for (name in entities) { characters[entities[name]] = name; } })(); /* * Regular expressions. */ var EXPRESSION_ESCAPE = new RegExp('[' + escapes.join('') + ']', 'g'); var EXPRESSION_SURROGATE_PAIR = /[\uD800-\uDBFF][\uDC00-\uDFFF]/g; var EXPRESSION_BMP = /[\x01-\t\x0B\f\x0E-\x1F\x7F\x81\x8D\x8F\x90\x9D\xA0-\uFFFF]/g; /** * Transform `code` into a hexadecimal character reference. * * @param {number} code - Number to encode. * @return {string} - `code` encoded as hexadecimal. */ function characterCodeToHexadecimalReference(code) { return '&#x' + code.toString(16).toUpperCase() + ';'; } /** * Transform `character` into a hexadecimal character * reference. * * @param {string} character - Character to encode. * @return {string} - `character` encoded as hexadecimal. */ function characterToHexadecimalReference(character) { return characterCodeToHexadecimalReference(character.charCodeAt(0)); } /** * Transform `code` into an entity. * * @param {string} name - Name to wrap. * @return {string} - `name` encoded as hexadecimal. */ function toNamedEntity(name) { return '&' + name + ';'; } /** * Transform `code` into an entity. * * @param {string} character - Character to encode. * @return {string} - `name` encoded as hexadecimal. */ function characterToNamedEntity(character) { return toNamedEntity(characters[character]); } /** * Encode special characters in `value`. * * @param {string} value - Value to encode. * @param {Object?} [options] - Configuration. * @param {boolean?} [options.escapeOnly=false] * - Whether to only escape required characters. * @param {boolean?} [options.useNamedReferences=false] * - Whether to use entities where possible. * @return {string} - Encoded `value`. */ function encode(value, options) { var settings = options || {}; var escapeOnly = settings.escapeOnly; var named = settings.useNamedReferences; var map = named ? characters : null; value = value.replace(EXPRESSION_ESCAPE, function (character) { return map && has.call(map, character) ? toNamedEntity(map[character]) : characterToHexadecimalReference(character); }); if (escapeOnly) { return value; } if (named) { value = value.replace(EXPRESSION_NAMED, characterToNamedEntity); } return value .replace(EXPRESSION_SURROGATE_PAIR, function (pair) { return characterCodeToHexadecimalReference( (pair.charCodeAt(0) - 0xD800) * 0x400 + pair.charCodeAt(1) - 0xDC00 + 0x10000 ); }) .replace(EXPRESSION_BMP, characterToHexadecimalReference); } /** * Shortcut to escape special characters in HTML. * * @param {string} value - Value to encode. * @return {string} - Encoded `value`. */ function escape(value) { return encode(value, { 'escapeOnly': true, 'useNamedReferences': true }); } encode.escape = escape; /* * Expose. */ module.exports = encode; },{"./lib/expression.js":618,"character-entities-html4":71}],618:[function(require,module,exports){ /* This script was generated by `script/generate-expression.js` */ 'use strict'; /* eslint-env commonjs */ /* eslint-disable no-irregular-whitespace */ module.exports = /[ ¡¢£¤¥¦§¨©ª«¬­®¯°±²³´µ¶·¸¹º»¼½¾¿ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖרÙÚÛÜÝÞßàáâãäåæçèéêëìíîïðñòóôõö÷øùúûüýþÿƒΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΤΥΦΧΨΩαβγδεζηθικλμνξοπρςστυφχψωϑϒϖ•…′″‾⁄℘ℑℜ™ℵ←↑→↓↔↵⇐⇑⇒⇓⇔∀∂∃∅∇∈∉∋∏∑−∗√∝∞∠∧∨∩∪∫∴∼≅≈≠≡≤≥⊂⊃⊄⊆⊇⊕⊗⊥⋅⌈⌉⌊⌋〈〉◊♠♣♥♦ŒœŠšŸˆ˜   ‌‍‎‏–—‘’‚“”„†‡‰‹›€]/g; },{}],619:[function(require,module,exports){ var Buffer = require('buffer').Buffer module.exports = function (buf) { // If the buffer is backed by a Uint8Array, a faster version will work if (buf instanceof Uint8Array) { // If the buffer isn't a subarray, return the underlying ArrayBuffer if (buf.byteOffset === 0 && buf.byteLength === buf.buffer.byteLength) { return buf.buffer } else if (typeof buf.buffer.slice === 'function') { // Otherwise we need to get a proper copy return buf.buffer.slice(buf.byteOffset, buf.byteOffset + buf.byteLength) } } if (Buffer.isBuffer(buf)) { // This is the slow version that will work with any Buffer // implementation (even in old browsers) var arrayCopy = new Uint8Array(buf.length) var len = buf.length for (var i = 0; i < len; i++) { arrayCopy[i] = buf[i] } return arrayCopy.buffer } else { throw new Error('Argument must be a Buffer') } } },{"buffer":61}],620:[function(require,module,exports){ 'use strict'; /* * Constants. */ var WHITE_SPACE_COLLAPSABLE_LINE = /[ \t]*\n+[ \t]*/g; var LINE = '\n'; /** * Remove initial and final spaces and tabs at the * line breaks in `value`. Does not trim initial and * final spaces and tabs of the value itself. * * @example * trimLines(' foo\t\n\n bar \n\tbaz '); // ' foo\nbar\nbaz ' * * @param {string} value - Value with untrimmed line breaks, * coerced to string. * @return {string} - Value with trimmed line breaks. */ function trimLines(value) { return String(value).replace(WHITE_SPACE_COLLAPSABLE_LINE, LINE); } /* * Expose. */ module.exports = trimLines; },{}],621:[function(require,module,exports){ 'use strict'; /* * Constants. */ var LINE = '\n'; /** * Remove final newline characters from `value`. * * @example * trimTrailingLines('foo\nbar'); // 'foo\nbar' * trimTrailingLines('foo\nbar\n'); // 'foo\nbar' * trimTrailingLines('foo\nbar\n\n'); // 'foo\nbar' * * @param {string} value - Value with trailing newlines, * coerced to string. * @return {string} - Value without trailing newlines. */ function trimTrailingLines(value) { var index; value = String(value); index = value.length; while (value.charAt(--index) === LINE) { /* empty */ } return value.slice(0, index + 1); } /* * Expose. */ module.exports = trimTrailingLines; },{}],622:[function(require,module,exports){ exports = module.exports = trim; function trim(str){ return str.replace(/^\s*|\s*$/g, ''); } exports.left = function(str){ return str.replace(/^\s*/, ''); }; exports.right = function(str){ return str.replace(/\s*$/, ''); }; },{}],623:[function(require,module,exports){ (function (Buffer){ var collation = require('./collation') // // base type system // var base = {} // // helper utilities // function _valueOf(instance) { return instance == null ? instance : instance.valueOf() } var _toString = Object.prototype.toString function _isObject(instance) { return instance && _toString.call(instance) === '[object Object]' } // // base typewise compare implementation // base.compare = function (a, b) { // // test for invalid values // if (base.invalid(a, b)) return NaN // // short circuit for identical objects // if (a === b) return 0 // // short circuit for base bound types // var result = base.bound.compare(a, b) if (result !== undefined) return result // // cache typeof and valueOf for both values // var aTypeOf = typeof a var bTypeOf = typeof b var aValueOf = _valueOf(a) var bValueOf = _valueOf(b) // // loop over type tags and attempt compare // var order = base.order var sorts = base.sorts var sort for (var i = 0, length = order.length; i < length; ++i) { sort = sorts[order[i]] // // if first arg is a member of this sort we have an answer // if (sort.is(a, aTypeOf)) // // if b is the same as a then defer to sort's comparator, else a comes first // return sort.is(b, bTypeOf) ? sort.compare(aValueOf, bValueOf) : -1 // // if b is this type but not a then b comes first // if (sort.is(b, bTypeOf)) return 1 } // // values are incomparable as they didn't match against any registered types // return NaN } // // sort equality test // base.equal = function(a, b) { return base.compare(a, b) === 0 } // // test for top-level incomparability using invalid sort definitions // base.invalid = function (a, b) { var types = base.invalid for (var key in types) { var type = types[key] if (type && type.is && (type.is(a) || type.is(b))) return true } return false } // // definitions for explicitly invalid/incomparable types // base.invalid.NAN = { is: function (instance) { var valueOf = _valueOf(instance) return valueOf !== valueOf } } base.invalid.ERROR = { is: function (instance) { return instance && instance instanceof Error } } // // definitions for boundary types, unserializable as values // function BoundedKey(bound, upper, prefix) { this.bound = bound this.upper = !!upper this.prefix = prefix } function Boundary(sort) { this.sort = sort } Boundary.prototype.lower = function (prefix) { return new BoundedKey(this, false, prefix) } Boundary.prototype.upper = function (prefix) { return new BoundedKey(this, true, prefix) } Boundary.prototype.is = function (source) { return source instanceof BoundedKey && source.sort === this.sort } Boundary.add = function (sort) { sort.bound = new Boundary(sort) } Boundary.add(base) base.bound.getBoundary = function (source) { return source instanceof BoundedKey && source.bound } // // compare a values against top level bounds (assumes first arg is an instance) // base.bound.compare = function (a, b) { var aBound = base.bound.is(a) var bBound = base.bound.is(b) if (aBound) { if (bBound && !a.upper === !b.upper) return 0 return a.upper ? 1 : -1 } if (bBound) return -base.bound.compare(b, a) } // // helper to register fixed (nullary) types // function fixed(value) { return { is: function (instance) { return instance === value }, value: value } } // // value types defined as ordered map of "sorts" // var sorts = base.sorts = {} sorts.void = fixed(void 0) sorts.void.compare = collation.inequality sorts.null = fixed(null) sorts.null.compare = collation.inequality var BOOLEAN = sorts.boolean = {} BOOLEAN.compare = collation.inequality BOOLEAN.is = function (instance, typeOf) { return (typeOf || typeof instance) === 'boolean' } BOOLEAN.sorts = {} BOOLEAN.sorts.true = fixed(true) BOOLEAN.sorts.false = fixed(false) Boundary.add(BOOLEAN) var NUMBER = sorts.number = {} NUMBER.compare = collation.difference NUMBER.is = function (instance, typeOf) { return (typeOf || typeof instance) === 'number' } NUMBER.sorts = {} NUMBER.sorts.max = fixed(Number.POSITIVE_INFINITY) NUMBER.sorts.min = fixed(Number.NEGATIVE_INFINITY) NUMBER.sorts.positive = {} NUMBER.sorts.positive.is = function (instance) { return instance >= 0 } NUMBER.sorts.negative = {} NUMBER.sorts.negative.is = function (instance) { return instance < 0 } Boundary.add(NUMBER) var DATE = sorts.date = {} DATE.compare = collation.difference DATE.is = function (instance) { return instance instanceof Date && instance.valueOf() === instance.valueOf() } DATE.sorts = {} DATE.sorts.positive = {} DATE.sorts.positive.is = function (instance) { return instance.valueOf() >= 0 } DATE.sorts.negative = {} DATE.sorts.negative.is = function (instance) { return instance.valueOf() < 0 } Boundary.add(DATE) var BINARY = sorts.binary = {} BINARY.empty = new Buffer([]) BINARY.compare = collation.bitwise BINARY.is = Buffer.isBuffer Boundary.add(BINARY) var STRING = sorts.string = {} STRING.empty = '' STRING.compare = collation.inequality STRING.is = function (instance, typeOf) { return (typeOf || typeof instance) === 'string' } Boundary.add(STRING) var ARRAY = sorts.array = {} ARRAY.empty = [] ARRAY.compare = collation.recursive.elementwise(base.compare) ARRAY.is = Array.isArray Boundary.add(ARRAY) // var OBJECT = sorts.object = {} // OBJECT.empty = {} // OBJECT.compare = collation.recursive.fieldwise(base.compare) // OBJECT.is = _isObject // Boundary.add(OBJECT) // // default order for instance checking in compare operations // base.order = [] for (var key in sorts) { base.order.push(key) } module.exports = base }).call(this,require("buffer").Buffer) },{"./collation":624,"buffer":61}],624:[function(require,module,exports){ // // generic comparator implementations our types can use // var collation = exports // // scalar comparisons // collation.inequality = function (a, b) { return a < b ? -1 : ( a > b ? 1 : 0 ) } collation.difference = function (a, b) { return a - b } // // recursive collations have to be provided a collation function to delegate to // collation.recursive = {} // // element by element (comparison for list-like structures // collation.recursive.elementwise = function (compare, shortlex) { return function (a, b) { var aLength = a.length var bLength = b.length var difference // // short-circuit on length difference for shortlex semantics // if (shortlex && aLength !== bLength) return aLength - bLength for (var i = 0, length = Math.min(aLength, bLength); i < length; ++i) { if (difference = compare(a[i], b[i])) return difference } return aLength - bLength } } // // field by field comparison of record-like structures // collation.recursive.fieldwise = function (compare, shortlex) { return function (a, b) { var aKeys = Object.keys(a) var bKeys = Object.keys(b) var aLength = aKeys.length var bLength = bKeys.length var difference // // short-circuit on length difference for shortlex semantics // if (shortlex && aLength !== bLength) return aLength - bLength for (var i = 0, length = Math.min(aLength, bLength); i < length; ++i) { // // first compare keys // if (difference = compare(aKeys[i], bKeys[i])) return difference // // then compare values // if (difference = compare(a[aKeys[i]], b[bKeys[i]])) return difference } return aLength - bLength } } // // elementwise compare with inequality can be used for binary equality // collation.bitwise = collation.recursive.elementwise(exports.inequality) },{}],625:[function(require,module,exports){ // // extend core typewise // require('./collation') module.exports = require('typewise-core/base') },{"./collation":626,"typewise-core/base":623}],626:[function(require,module,exports){ // // extend core typewise collations // var collation = require('typewise-core/collation') // TODO: set, map module.exports = collation },{"typewise-core/collation":624}],627:[function(require,module,exports){ module.exports = require('./base') },{"./base":625}],628:[function(require,module,exports){ (function (Buffer){ function inequality (a, b) { return a === b ? 0 : a < b ? -1 : 1 } function buffercmp (a, b) { var l = Math.min(a.length, b.length) for(var i = 0; i < l; i++) if(a[i] !== b[i]) return inequality(a[i], b[i]) return a.length - b.length } function arraycmp (a, b) { var l = Math.min(a.length, b.length) for(var i = 0; i < l; i++) { var c = compare(a[i], b[i]) if(c) return c } return inequality(a.length, b.length) } var comparators = [ inequality, // null inequality, // boolean inequality, // number buffercmp, // buffer inequality, // string , // object arraycmp, // array inequality // undefined ] function getType (v) { if(v === null) return 0 var t = typeof v if(t === 'boolean') return 1 if(t === 'number') return 2 if(Buffer.isBuffer(v)) return 3 if(Array.isArray(v)) return 6 if(t === 'string') return 4 if(t === 'undefined') return 7 throw new Error('comparing objects or functions is not supported') // return 5 } function compare (a, b) { var t = getType(a) return inequality(t, getType(b)) || comparators[t](a, b) } module.exports = compare module.exports.equal = function (a, b) { return compare(a, b) === 0 } }).call(this,{"isBuffer":require("../is-buffer/index.js")}) },{"../is-buffer/index.js":170}],629:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015 Titus Wormer * @license MIT * @module unherit * @fileoverview Create a custom constructor which can be modified * without affecting the original class. * @example * var EventEmitter = require('events').EventEmitter; * var Emitter = unherit(EventEmitter); * // Create a private class which acts just like * // `EventEmitter`. * * Emitter.prototype.defaultMaxListeners = 0; * // Now, all instances of `Emitter` have no maximum * // listeners, without affecting other `EventEmitter`s. */ 'use strict'; /* * Dependencies. */ var clone = require('clone'); var inherits = require('inherits'); /** * Create a custom constructor which can be modified * without affecting the original class. * * @param {Function} Super - Super-class. * @return {Function} - Constructor acting like `Super`, * which can be modified without affecting the original * class. */ function unherit(Super) { var base = clone(Super.prototype); var result; var key; /** * Constructor accepting a single argument, * which itself is an `arguments` object. */ function From(parameters) { return Super.apply(this, parameters); } /** * Constructor accepting variadic arguments. */ function Of() { if (!(this instanceof Of)) { return new From(arguments); } return Super.apply(this, arguments); } inherits(Of, Super); inherits(From, Of); /* * Both do duplicate work. However, cloning the * prototype ensures clonable things are cloned * and thus used. The `inherits` call ensures * `instanceof` still thinks an instance subclasses * `Super`. */ result = Of.prototype; for (key in base) { result[key] = base[key]; } return Of; } /* * Expose. */ module.exports = unherit; },{"clone":82,"inherits":167}],630:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015 Titus Wormer * @license MIT * @module unified * @fileoverview Parse / Transform / Compile / Repeat. */ 'use strict'; /* eslint-env commonjs */ /* * Dependencies. */ var bail = require('bail'); var ware = require('ware'); var AttachWare = require('attach-ware')(ware); var VFile = require('vfile'); var unherit = require('unherit'); var extend; try { extend = require('node-extend'); } catch (e) { extend = require('extend'); } /* * Processing pipeline. */ var pipeline = ware() .use(function (ctx) { ctx.tree = ctx.context.parse(ctx.file, ctx.settings); }) .use(function (ctx, next) { ctx.context.run(ctx.tree, ctx.file, next); }) .use(function (ctx) { ctx.result = ctx.context.stringify(ctx.tree, ctx.file, ctx.settings); }); /** * Construct a new Processor class based on the * given options. * * @param {Object} options - Configuration. * @param {string} options.name - Private storage. * @param {Function} options.Parser - Class to turn a * virtual file into a syntax tree. * @param {Function} options.Compiler - Class to turn a * syntax tree into a string. * @return {Processor} - A new constructor. */ function unified(options) { var name = options.name; var Parser = options.Parser; var Compiler = options.Compiler; var data = options.data; /** * Construct a Processor instance. * * @constructor * @class {Processor} */ function Processor(processor) { var self = this; if (!(self instanceof Processor)) { return new Processor(processor); } self.ware = new AttachWare(processor && processor.ware); self.ware.context = self; self.Parser = unherit(Parser); self.Compiler = unherit(Compiler); if (self.data) { self.data = extend(true, {}, self.data); } } /** * Either return `context` if its an instance * of `Processor` or construct a new `Processor` * instance. * * @private * @param {Processor?} [context] - Context object. * @return {Processor} - Either `context` or a new * Processor instance. */ function instance(context) { return context instanceof Processor ? context : new Processor(); } /** * Attach a plugin. * * @this {Processor?} - Either a Processor instance or * the Processor constructor. * @return {Processor} - Either `context` or a new * Processor instance. */ function use() { var self = instance(this); self.ware.use.apply(self.ware, arguments); return self; } /** * Transform. * * @this {Processor?} - Either a Processor instance or * the Processor constructor. * @param {Node} [node] - Syntax tree. * @param {VFile?} [file] - Virtual file. * @param {Function?} [done] - Callback. * @return {Node} - `node`. */ function run(node, file, done) { var self = this; var space; if (typeof file === 'function') { done = file; file = null; } if (!file && node && !node.type) { file = node; node = null; } file = new VFile(file); space = file.namespace(name); if (!node) { node = space.tree || node; } else if (!space.tree) { space.tree = node; } if (!node) { throw new Error('Expected node, got ' + node); } done = typeof done === 'function' ? done : bail; /* * Only run when this is an instance of Processor, * and when there are transformers. */ if (self.ware && self.ware.fns) { self.ware.run(node, file, done); } else { done(null, node, file); } return node; } /** * Parse a file. * * Patches the parsed node onto the `name` * namespace on the `type` property. * * @this {Processor?} - Either a Processor instance or * the Processor constructor. * @param {string|VFile} value - Input to parse. * @param {Object?} [settings] - Configuration. * @return {Node} - `node`. */ function parse(value, settings) { var file = new VFile(value); var CustomParser = (this && this.Parser) || Parser; var node = new CustomParser(file, settings, instance(this)).parse(); file.namespace(name).tree = node; return node; } /** * Compile a file. * * Used the parsed node at the `name` * namespace at `'tree'` when no node was given. * * @this {Processor?} - Either a Processor instance or * the Processor constructor. * @param {Object} [node] - Syntax tree. * @param {VFile} [file] - File with syntax tree. * @param {Object?} [settings] - Configuration. * @return {string} - Compiled `file`. */ function stringify(node, file, settings) { var CustomCompiler = (this && this.Compiler) || Compiler; var space; if (settings === null || settings === undefined) { settings = file; file = null; } if (!file && node && !node.type) { file = node; node = null; } file = new VFile(file); space = file.namespace(name); if (!node) { node = space.tree || node; } else if (!space.tree) { space.tree = node; } if (!node) { throw new Error('Expected node, got ' + node); } return new CustomCompiler(file, settings, instance(this)).compile(); } /** * Parse / Transform / Compile. * * @this {Processor?} - Either a Processor instance or * the Processor constructor. * @param {string|VFile} value - Input to process. * @param {Object?} [settings] - Configuration. * @param {Function?} [done] - Callback. * @return {string?} - Parsed document, when * transformation was async. */ function process(value, settings, done) { var self = instance(this); var file = new VFile(value); var result = null; if (typeof settings === 'function') { done = settings; settings = null; } pipeline.run({ 'context': self, 'file': file, 'settings': settings || {} }, function (err, res) { result = res && res.result; if (done) { done(err, file, result); } else if (err) { bail(err); } }); return result; } /* * Methods / functions. */ var proto = Processor.prototype; Processor.use = proto.use = use; Processor.parse = proto.parse = parse; Processor.run = proto.run = run; Processor.stringify = proto.stringify = stringify; Processor.process = proto.process = process; Processor.data = proto.data = data || null; return Processor; } /* * Expose. */ module.exports = unified; },{"attach-ware":16,"bail":17,"extend":148,"node-extend":148,"unherit":629,"vfile":637,"ware":639}],631:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015 Titus Wormer * @license MIT * @module unist:util:visit * @fileoverview Recursively walk over unist nodes. */ 'use strict'; /* eslint-env commonjs */ /** * Visit. * * @param {Node} tree - Root node * @param {string} [type] - Node type. * @param {function(node): boolean?} visitor - Invoked * with each found node. Can return `false` to stop. * @param {boolean} [reverse] - By default, `visit` will * walk forwards, when `reverse` is `true`, `visit` * walks backwards. */ function visit(tree, type, visitor, reverse) { if (typeof type === 'function') { reverse = visitor; visitor = type; type = null; } /** * Visit children in `parent`. * * @param {Array.} children - Children of `node`. * @param {Node?} parent - Parent of `node`. * @return {boolean?} - `false` if the visiting stopped. */ function all(children, parent) { var step = reverse ? -1 : 1; var max = children.length; var min = -1; var index = (reverse ? max : min) + step; var child; while (index > min && index < max) { child = children[index]; if (child && one(child, index, parent) === false) { return false; } index += step; } return true; } /** * Visit a single node. * * @param {Node} node - Node to visit. * @param {number?} [index] - Position of `node` in `parent`. * @param {Node?} [parent] - Parent of `node`. * @return {boolean?} - A result of invoking `visitor`. */ function one(node, index, parent) { var result; index = index || (parent ? 0 : null); if (!type || node.type === type) { result = visitor(node, index, parent || null); } if (node.children && result !== false) { return all(node.children, node); } return result; } one(tree); } /* * Expose. */ module.exports = visit; },{}],632:[function(require,module,exports){ // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. 'use strict'; var punycode = require('punycode'); var util = require('./util'); exports.parse = urlParse; exports.resolve = urlResolve; exports.resolveObject = urlResolveObject; exports.format = urlFormat; exports.Url = Url; function Url() { this.protocol = null; this.slashes = null; this.auth = null; this.host = null; this.port = null; this.hostname = null; this.hash = null; this.search = null; this.query = null; this.pathname = null; this.path = null; this.href = null; } // Reference: RFC 3986, RFC 1808, RFC 2396 // define these here so at least they only have to be // compiled once on the first module load. var protocolPattern = /^([a-z0-9.+-]+:)/i, portPattern = /:[0-9]*$/, // Special case for a simple path URL simplePathPattern = /^(\/\/?(?!\/)[^\?\s]*)(\?[^\s]*)?$/, // RFC 2396: characters reserved for delimiting URLs. // We actually just auto-escape these. delims = ['<', '>', '"', '`', ' ', '\r', '\n', '\t'], // RFC 2396: characters not allowed for various reasons. unwise = ['{', '}', '|', '\\', '^', '`'].concat(delims), // Allowed by RFCs, but cause of XSS attacks. Always escape these. autoEscape = ['\''].concat(unwise), // Characters that are never ever allowed in a hostname. // Note that any invalid chars are also handled, but these // are the ones that are *expected* to be seen, so we fast-path // them. nonHostChars = ['%', '/', '?', ';', '#'].concat(autoEscape), hostEndingChars = ['/', '?', '#'], hostnameMaxLen = 255, hostnamePartPattern = /^[+a-z0-9A-Z_-]{0,63}$/, hostnamePartStart = /^([+a-z0-9A-Z_-]{0,63})(.*)$/, // protocols that can allow "unsafe" and "unwise" chars. unsafeProtocol = { 'javascript': true, 'javascript:': true }, // protocols that never have a hostname. hostlessProtocol = { 'javascript': true, 'javascript:': true }, // protocols that always contain a // bit. slashedProtocol = { 'http': true, 'https': true, 'ftp': true, 'gopher': true, 'file': true, 'http:': true, 'https:': true, 'ftp:': true, 'gopher:': true, 'file:': true }, querystring = require('querystring'); function urlParse(url, parseQueryString, slashesDenoteHost) { if (url && util.isObject(url) && url instanceof Url) return url; var u = new Url; u.parse(url, parseQueryString, slashesDenoteHost); return u; } Url.prototype.parse = function(url, parseQueryString, slashesDenoteHost) { if (!util.isString(url)) { throw new TypeError("Parameter 'url' must be a string, not " + typeof url); } // Copy chrome, IE, opera backslash-handling behavior. // Back slashes before the query string get converted to forward slashes // See: https://code.google.com/p/chromium/issues/detail?id=25916 var queryIndex = url.indexOf('?'), splitter = (queryIndex !== -1 && queryIndex < url.indexOf('#')) ? '?' : '#', uSplit = url.split(splitter), slashRegex = /\\/g; uSplit[0] = uSplit[0].replace(slashRegex, '/'); url = uSplit.join(splitter); var rest = url; // trim before proceeding. // This is to support parse stuff like " http://foo.com \n" rest = rest.trim(); if (!slashesDenoteHost && url.split('#').length === 1) { // Try fast path regexp var simplePath = simplePathPattern.exec(rest); if (simplePath) { this.path = rest; this.href = rest; this.pathname = simplePath[1]; if (simplePath[2]) { this.search = simplePath[2]; if (parseQueryString) { this.query = querystring.parse(this.search.substr(1)); } else { this.query = this.search.substr(1); } } else if (parseQueryString) { this.search = ''; this.query = {}; } return this; } } var proto = protocolPattern.exec(rest); if (proto) { proto = proto[0]; var lowerProto = proto.toLowerCase(); this.protocol = lowerProto; rest = rest.substr(proto.length); } // figure out if it's got a host // user@server is *always* interpreted as a hostname, and url // resolution will treat //foo/bar as host=foo,path=bar because that's // how the browser resolves relative URLs. if (slashesDenoteHost || proto || rest.match(/^\/\/[^@\/]+@[^@\/]+/)) { var slashes = rest.substr(0, 2) === '//'; if (slashes && !(proto && hostlessProtocol[proto])) { rest = rest.substr(2); this.slashes = true; } } if (!hostlessProtocol[proto] && (slashes || (proto && !slashedProtocol[proto]))) { // there's a hostname. // the first instance of /, ?, ;, or # ends the host. // // If there is an @ in the hostname, then non-host chars *are* allowed // to the left of the last @ sign, unless some host-ending character // comes *before* the @-sign. // URLs are obnoxious. // // ex: // http://a@b@c/ => user:a@b host:c // http://a@b?@c => user:a host:c path:/?@c // v0.12 TODO(isaacs): This is not quite how Chrome does things. // Review our test case against browsers more comprehensively. // find the first instance of any hostEndingChars var hostEnd = -1; for (var i = 0; i < hostEndingChars.length; i++) { var hec = rest.indexOf(hostEndingChars[i]); if (hec !== -1 && (hostEnd === -1 || hec < hostEnd)) hostEnd = hec; } // at this point, either we have an explicit point where the // auth portion cannot go past, or the last @ char is the decider. var auth, atSign; if (hostEnd === -1) { // atSign can be anywhere. atSign = rest.lastIndexOf('@'); } else { // atSign must be in auth portion. // http://a@b/c@d => host:b auth:a path:/c@d atSign = rest.lastIndexOf('@', hostEnd); } // Now we have a portion which is definitely the auth. // Pull that off. if (atSign !== -1) { auth = rest.slice(0, atSign); rest = rest.slice(atSign + 1); this.auth = decodeURIComponent(auth); } // the host is the remaining to the left of the first non-host char hostEnd = -1; for (var i = 0; i < nonHostChars.length; i++) { var hec = rest.indexOf(nonHostChars[i]); if (hec !== -1 && (hostEnd === -1 || hec < hostEnd)) hostEnd = hec; } // if we still have not hit it, then the entire thing is a host. if (hostEnd === -1) hostEnd = rest.length; this.host = rest.slice(0, hostEnd); rest = rest.slice(hostEnd); // pull out port. this.parseHost(); // we've indicated that there is a hostname, // so even if it's empty, it has to be present. this.hostname = this.hostname || ''; // if hostname begins with [ and ends with ] // assume that it's an IPv6 address. var ipv6Hostname = this.hostname[0] === '[' && this.hostname[this.hostname.length - 1] === ']'; // validate a little. if (!ipv6Hostname) { var hostparts = this.hostname.split(/\./); for (var i = 0, l = hostparts.length; i < l; i++) { var part = hostparts[i]; if (!part) continue; if (!part.match(hostnamePartPattern)) { var newpart = ''; for (var j = 0, k = part.length; j < k; j++) { if (part.charCodeAt(j) > 127) { // we replace non-ASCII char with a temporary placeholder // we need this to make sure size of hostname is not // broken by replacing non-ASCII by nothing newpart += 'x'; } else { newpart += part[j]; } } // we test again with ASCII char only if (!newpart.match(hostnamePartPattern)) { var validParts = hostparts.slice(0, i); var notHost = hostparts.slice(i + 1); var bit = part.match(hostnamePartStart); if (bit) { validParts.push(bit[1]); notHost.unshift(bit[2]); } if (notHost.length) { rest = '/' + notHost.join('.') + rest; } this.hostname = validParts.join('.'); break; } } } } if (this.hostname.length > hostnameMaxLen) { this.hostname = ''; } else { // hostnames are always lower case. this.hostname = this.hostname.toLowerCase(); } if (!ipv6Hostname) { // IDNA Support: Returns a punycoded representation of "domain". // It only converts parts of the domain name that // have non-ASCII characters, i.e. it doesn't matter if // you call it with a domain that already is ASCII-only. this.hostname = punycode.toASCII(this.hostname); } var p = this.port ? ':' + this.port : ''; var h = this.hostname || ''; this.host = h + p; this.href += this.host; // strip [ and ] from the hostname // the host field still retains them, though if (ipv6Hostname) { this.hostname = this.hostname.substr(1, this.hostname.length - 2); if (rest[0] !== '/') { rest = '/' + rest; } } } // now rest is set to the post-host stuff. // chop off any delim chars. if (!unsafeProtocol[lowerProto]) { // First, make 100% sure that any "autoEscape" chars get // escaped, even if encodeURIComponent doesn't think they // need to be. for (var i = 0, l = autoEscape.length; i < l; i++) { var ae = autoEscape[i]; if (rest.indexOf(ae) === -1) continue; var esc = encodeURIComponent(ae); if (esc === ae) { esc = escape(ae); } rest = rest.split(ae).join(esc); } } // chop off from the tail first. var hash = rest.indexOf('#'); if (hash !== -1) { // got a fragment string. this.hash = rest.substr(hash); rest = rest.slice(0, hash); } var qm = rest.indexOf('?'); if (qm !== -1) { this.search = rest.substr(qm); this.query = rest.substr(qm + 1); if (parseQueryString) { this.query = querystring.parse(this.query); } rest = rest.slice(0, qm); } else if (parseQueryString) { // no query string, but parseQueryString still requested this.search = ''; this.query = {}; } if (rest) this.pathname = rest; if (slashedProtocol[lowerProto] && this.hostname && !this.pathname) { this.pathname = '/'; } //to support http.request if (this.pathname || this.search) { var p = this.pathname || ''; var s = this.search || ''; this.path = p + s; } // finally, reconstruct the href based on what has been validated. this.href = this.format(); return this; }; // format a parsed object into a url string function urlFormat(obj) { // ensure it's an object, and not a string url. // If it's an obj, this is a no-op. // this way, you can call url_format() on strings // to clean up potentially wonky urls. if (util.isString(obj)) obj = urlParse(obj); if (!(obj instanceof Url)) return Url.prototype.format.call(obj); return obj.format(); } Url.prototype.format = function() { var auth = this.auth || ''; if (auth) { auth = encodeURIComponent(auth); auth = auth.replace(/%3A/i, ':'); auth += '@'; } var protocol = this.protocol || '', pathname = this.pathname || '', hash = this.hash || '', host = false, query = ''; if (this.host) { host = auth + this.host; } else if (this.hostname) { host = auth + (this.hostname.indexOf(':') === -1 ? this.hostname : '[' + this.hostname + ']'); if (this.port) { host += ':' + this.port; } } if (this.query && util.isObject(this.query) && Object.keys(this.query).length) { query = querystring.stringify(this.query); } var search = this.search || (query && ('?' + query)) || ''; if (protocol && protocol.substr(-1) !== ':') protocol += ':'; // only the slashedProtocols get the //. Not mailto:, xmpp:, etc. // unless they had them to begin with. if (this.slashes || (!protocol || slashedProtocol[protocol]) && host !== false) { host = '//' + (host || ''); if (pathname && pathname.charAt(0) !== '/') pathname = '/' + pathname; } else if (!host) { host = ''; } if (hash && hash.charAt(0) !== '#') hash = '#' + hash; if (search && search.charAt(0) !== '?') search = '?' + search; pathname = pathname.replace(/[?#]/g, function(match) { return encodeURIComponent(match); }); search = search.replace('#', '%23'); return protocol + host + pathname + search + hash; }; function urlResolve(source, relative) { return urlParse(source, false, true).resolve(relative); } Url.prototype.resolve = function(relative) { return this.resolveObject(urlParse(relative, false, true)).format(); }; function urlResolveObject(source, relative) { if (!source) return relative; return urlParse(source, false, true).resolveObject(relative); } Url.prototype.resolveObject = function(relative) { if (util.isString(relative)) { var rel = new Url(); rel.parse(relative, false, true); relative = rel; } var result = new Url(); var tkeys = Object.keys(this); for (var tk = 0; tk < tkeys.length; tk++) { var tkey = tkeys[tk]; result[tkey] = this[tkey]; } // hash is always overridden, no matter what. // even href="" will remove it. result.hash = relative.hash; // if the relative url is empty, then there's nothing left to do here. if (relative.href === '') { result.href = result.format(); return result; } // hrefs like //foo/bar always cut to the protocol. if (relative.slashes && !relative.protocol) { // take everything except the protocol from relative var rkeys = Object.keys(relative); for (var rk = 0; rk < rkeys.length; rk++) { var rkey = rkeys[rk]; if (rkey !== 'protocol') result[rkey] = relative[rkey]; } //urlParse appends trailing / to urls like http://www.example.com if (slashedProtocol[result.protocol] && result.hostname && !result.pathname) { result.path = result.pathname = '/'; } result.href = result.format(); return result; } if (relative.protocol && relative.protocol !== result.protocol) { // if it's a known url protocol, then changing // the protocol does weird things // first, if it's not file:, then we MUST have a host, // and if there was a path // to begin with, then we MUST have a path. // if it is file:, then the host is dropped, // because that's known to be hostless. // anything else is assumed to be absolute. if (!slashedProtocol[relative.protocol]) { var keys = Object.keys(relative); for (var v = 0; v < keys.length; v++) { var k = keys[v]; result[k] = relative[k]; } result.href = result.format(); return result; } result.protocol = relative.protocol; if (!relative.host && !hostlessProtocol[relative.protocol]) { var relPath = (relative.pathname || '').split('/'); while (relPath.length && !(relative.host = relPath.shift())); if (!relative.host) relative.host = ''; if (!relative.hostname) relative.hostname = ''; if (relPath[0] !== '') relPath.unshift(''); if (relPath.length < 2) relPath.unshift(''); result.pathname = relPath.join('/'); } else { result.pathname = relative.pathname; } result.search = relative.search; result.query = relative.query; result.host = relative.host || ''; result.auth = relative.auth; result.hostname = relative.hostname || relative.host; result.port = relative.port; // to support http.request if (result.pathname || result.search) { var p = result.pathname || ''; var s = result.search || ''; result.path = p + s; } result.slashes = result.slashes || relative.slashes; result.href = result.format(); return result; } var isSourceAbs = (result.pathname && result.pathname.charAt(0) === '/'), isRelAbs = ( relative.host || relative.pathname && relative.pathname.charAt(0) === '/' ), mustEndAbs = (isRelAbs || isSourceAbs || (result.host && relative.pathname)), removeAllDots = mustEndAbs, srcPath = result.pathname && result.pathname.split('/') || [], relPath = relative.pathname && relative.pathname.split('/') || [], psychotic = result.protocol && !slashedProtocol[result.protocol]; // if the url is a non-slashed url, then relative // links like ../.. should be able // to crawl up to the hostname, as well. This is strange. // result.protocol has already been set by now. // Later on, put the first path part into the host field. if (psychotic) { result.hostname = ''; result.port = null; if (result.host) { if (srcPath[0] === '') srcPath[0] = result.host; else srcPath.unshift(result.host); } result.host = ''; if (relative.protocol) { relative.hostname = null; relative.port = null; if (relative.host) { if (relPath[0] === '') relPath[0] = relative.host; else relPath.unshift(relative.host); } relative.host = null; } mustEndAbs = mustEndAbs && (relPath[0] === '' || srcPath[0] === ''); } if (isRelAbs) { // it's absolute. result.host = (relative.host || relative.host === '') ? relative.host : result.host; result.hostname = (relative.hostname || relative.hostname === '') ? relative.hostname : result.hostname; result.search = relative.search; result.query = relative.query; srcPath = relPath; // fall through to the dot-handling below. } else if (relPath.length) { // it's relative // throw away the existing file, and take the new path instead. if (!srcPath) srcPath = []; srcPath.pop(); srcPath = srcPath.concat(relPath); result.search = relative.search; result.query = relative.query; } else if (!util.isNullOrUndefined(relative.search)) { // just pull out the search. // like href='?foo'. // Put this after the other two cases because it simplifies the booleans if (psychotic) { result.hostname = result.host = srcPath.shift(); //occationaly the auth can get stuck only in host //this especially happens in cases like //url.resolveObject('mailto:local1@domain1', 'local2@domain2') var authInHost = result.host && result.host.indexOf('@') > 0 ? result.host.split('@') : false; if (authInHost) { result.auth = authInHost.shift(); result.host = result.hostname = authInHost.shift(); } } result.search = relative.search; result.query = relative.query; //to support http.request if (!util.isNull(result.pathname) || !util.isNull(result.search)) { result.path = (result.pathname ? result.pathname : '') + (result.search ? result.search : ''); } result.href = result.format(); return result; } if (!srcPath.length) { // no path at all. easy. // we've already handled the other stuff above. result.pathname = null; //to support http.request if (result.search) { result.path = '/' + result.search; } else { result.path = null; } result.href = result.format(); return result; } // if a url ENDs in . or .., then it must get a trailing slash. // however, if it ends in anything else non-slashy, // then it must NOT get a trailing slash. var last = srcPath.slice(-1)[0]; var hasTrailingSlash = ( (result.host || relative.host || srcPath.length > 1) && (last === '.' || last === '..') || last === ''); // strip single dots, resolve double dots to parent dir // if the path tries to go above the root, `up` ends up > 0 var up = 0; for (var i = srcPath.length; i >= 0; i--) { last = srcPath[i]; if (last === '.') { srcPath.splice(i, 1); } else if (last === '..') { srcPath.splice(i, 1); up++; } else if (up) { srcPath.splice(i, 1); up--; } } // if the path is allowed to go above the root, restore leading ..s if (!mustEndAbs && !removeAllDots) { for (; up--; up) { srcPath.unshift('..'); } } if (mustEndAbs && srcPath[0] !== '' && (!srcPath[0] || srcPath[0].charAt(0) !== '/')) { srcPath.unshift(''); } if (hasTrailingSlash && (srcPath.join('/').substr(-1) !== '/')) { srcPath.push(''); } var isAbsolute = srcPath[0] === '' || (srcPath[0] && srcPath[0].charAt(0) === '/'); // put the host back if (psychotic) { result.hostname = result.host = isAbsolute ? '' : srcPath.length ? srcPath.shift() : ''; //occationaly the auth can get stuck only in host //this especially happens in cases like //url.resolveObject('mailto:local1@domain1', 'local2@domain2') var authInHost = result.host && result.host.indexOf('@') > 0 ? result.host.split('@') : false; if (authInHost) { result.auth = authInHost.shift(); result.host = result.hostname = authInHost.shift(); } } mustEndAbs = mustEndAbs || (result.host && srcPath.length); if (mustEndAbs && !isAbsolute) { srcPath.unshift(''); } if (!srcPath.length) { result.pathname = null; result.path = null; } else { result.pathname = srcPath.join('/'); } //to support request.http if (!util.isNull(result.pathname) || !util.isNull(result.search)) { result.path = (result.pathname ? result.pathname : '') + (result.search ? result.search : ''); } result.auth = relative.auth || result.auth; result.slashes = result.slashes || relative.slashes; result.href = result.format(); return result; }; Url.prototype.parseHost = function() { var host = this.host; var port = portPattern.exec(host); if (port) { port = port[0]; if (port !== ':') { this.port = port.substr(1); } host = host.substr(0, host.length - port.length); } if (host) this.hostname = host; }; },{"./util":633,"punycode":399,"querystring":402}],633:[function(require,module,exports){ 'use strict'; module.exports = { isString: function(arg) { return typeof(arg) === 'string'; }, isObject: function(arg) { return typeof(arg) === 'object' && arg !== null; }, isNull: function(arg) { return arg === null; }, isNullOrUndefined: function(arg) { return arg == null; } }; },{}],634:[function(require,module,exports){ (function (global){ /** * Module exports. */ module.exports = deprecate; /** * Mark that a method should not be used. * Returns a modified function which warns once by default. * * If `localStorage.noDeprecation = true` is set, then it is a no-op. * * If `localStorage.throwDeprecation = true` is set, then deprecated functions * will throw an Error when invoked. * * If `localStorage.traceDeprecation = true` is set, then deprecated functions * will invoke `console.trace()` instead of `console.error()`. * * @param {Function} fn - the function to deprecate * @param {String} msg - the string to print to the console when `fn` is invoked * @returns {Function} a new "deprecated" version of `fn` * @api public */ function deprecate (fn, msg) { if (config('noDeprecation')) { return fn; } var warned = false; function deprecated() { if (!warned) { if (config('throwDeprecation')) { throw new Error(msg); } else if (config('traceDeprecation')) { console.trace(msg); } else { console.warn(msg); } warned = true; } return fn.apply(this, arguments); } return deprecated; } /** * Checks `localStorage` for boolean values for the given `name`. * * @param {String} name * @returns {Boolean} * @api private */ function config (name) { // accessing global.localStorage can trigger a DOMException in sandboxed iframes try { if (!global.localStorage) return false; } catch (_) { return false; } var val = global.localStorage[name]; if (null == val) return false; return String(val).toLowerCase() === 'true'; } }).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) },{}],635:[function(require,module,exports){ module.exports = function isBuffer(arg) { return arg && typeof arg === 'object' && typeof arg.copy === 'function' && typeof arg.fill === 'function' && typeof arg.readUInt8 === 'function'; } },{}],636:[function(require,module,exports){ (function (process,global){ // Copyright Joyent, Inc. and other Node contributors. // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to permit // persons to whom the Software is furnished to do so, subject to the // following conditions: // // The above copyright notice and this permission notice shall be included // in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE // USE OR OTHER DEALINGS IN THE SOFTWARE. var formatRegExp = /%[sdj%]/g; exports.format = function(f) { if (!isString(f)) { var objects = []; for (var i = 0; i < arguments.length; i++) { objects.push(inspect(arguments[i])); } return objects.join(' '); } var i = 1; var args = arguments; var len = args.length; var str = String(f).replace(formatRegExp, function(x) { if (x === '%%') return '%'; if (i >= len) return x; switch (x) { case '%s': return String(args[i++]); case '%d': return Number(args[i++]); case '%j': try { return JSON.stringify(args[i++]); } catch (_) { return '[Circular]'; } default: return x; } }); for (var x = args[i]; i < len; x = args[++i]) { if (isNull(x) || !isObject(x)) { str += ' ' + x; } else { str += ' ' + inspect(x); } } return str; }; // Mark that a method should not be used. // Returns a modified function which warns once by default. // If --no-deprecation is set, then it is a no-op. exports.deprecate = function(fn, msg) { // Allow for deprecating things in the process of starting up. if (isUndefined(global.process)) { return function() { return exports.deprecate(fn, msg).apply(this, arguments); }; } if (process.noDeprecation === true) { return fn; } var warned = false; function deprecated() { if (!warned) { if (process.throwDeprecation) { throw new Error(msg); } else if (process.traceDeprecation) { console.trace(msg); } else { console.error(msg); } warned = true; } return fn.apply(this, arguments); } return deprecated; }; var debugs = {}; var debugEnviron; exports.debuglog = function(set) { if (isUndefined(debugEnviron)) debugEnviron = process.env.NODE_DEBUG || ''; set = set.toUpperCase(); if (!debugs[set]) { if (new RegExp('\\b' + set + '\\b', 'i').test(debugEnviron)) { var pid = process.pid; debugs[set] = function() { var msg = exports.format.apply(exports, arguments); console.error('%s %d: %s', set, pid, msg); }; } else { debugs[set] = function() {}; } } return debugs[set]; }; /** * Echos the value of a value. Trys to print the value out * in the best way possible given the different types. * * @param {Object} obj The object to print out. * @param {Object} opts Optional options object that alters the output. */ /* legacy: obj, showHidden, depth, colors*/ function inspect(obj, opts) { // default options var ctx = { seen: [], stylize: stylizeNoColor }; // legacy... if (arguments.length >= 3) ctx.depth = arguments[2]; if (arguments.length >= 4) ctx.colors = arguments[3]; if (isBoolean(opts)) { // legacy... ctx.showHidden = opts; } else if (opts) { // got an "options" object exports._extend(ctx, opts); } // set default options if (isUndefined(ctx.showHidden)) ctx.showHidden = false; if (isUndefined(ctx.depth)) ctx.depth = 2; if (isUndefined(ctx.colors)) ctx.colors = false; if (isUndefined(ctx.customInspect)) ctx.customInspect = true; if (ctx.colors) ctx.stylize = stylizeWithColor; return formatValue(ctx, obj, ctx.depth); } exports.inspect = inspect; // http://en.wikipedia.org/wiki/ANSI_escape_code#graphics inspect.colors = { 'bold' : [1, 22], 'italic' : [3, 23], 'underline' : [4, 24], 'inverse' : [7, 27], 'white' : [37, 39], 'grey' : [90, 39], 'black' : [30, 39], 'blue' : [34, 39], 'cyan' : [36, 39], 'green' : [32, 39], 'magenta' : [35, 39], 'red' : [31, 39], 'yellow' : [33, 39] }; // Don't use 'blue' not visible on cmd.exe inspect.styles = { 'special': 'cyan', 'number': 'yellow', 'boolean': 'yellow', 'undefined': 'grey', 'null': 'bold', 'string': 'green', 'date': 'magenta', // "name": intentionally not styling 'regexp': 'red' }; function stylizeWithColor(str, styleType) { var style = inspect.styles[styleType]; if (style) { return '\u001b[' + inspect.colors[style][0] + 'm' + str + '\u001b[' + inspect.colors[style][1] + 'm'; } else { return str; } } function stylizeNoColor(str, styleType) { return str; } function arrayToHash(array) { var hash = {}; array.forEach(function(val, idx) { hash[val] = true; }); return hash; } function formatValue(ctx, value, recurseTimes) { // Provide a hook for user-specified inspect functions. // Check that value is an object with an inspect function on it if (ctx.customInspect && value && isFunction(value.inspect) && // Filter out the util module, it's inspect function is special value.inspect !== exports.inspect && // Also filter out any prototype objects using the circular check. !(value.constructor && value.constructor.prototype === value)) { var ret = value.inspect(recurseTimes, ctx); if (!isString(ret)) { ret = formatValue(ctx, ret, recurseTimes); } return ret; } // Primitive types cannot have properties var primitive = formatPrimitive(ctx, value); if (primitive) { return primitive; } // Look up the keys of the object. var keys = Object.keys(value); var visibleKeys = arrayToHash(keys); if (ctx.showHidden) { keys = Object.getOwnPropertyNames(value); } // IE doesn't make error fields non-enumerable // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx if (isError(value) && (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) { return formatError(value); } // Some type of object without properties can be shortcutted. if (keys.length === 0) { if (isFunction(value)) { var name = value.name ? ': ' + value.name : ''; return ctx.stylize('[Function' + name + ']', 'special'); } if (isRegExp(value)) { return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp'); } if (isDate(value)) { return ctx.stylize(Date.prototype.toString.call(value), 'date'); } if (isError(value)) { return formatError(value); } } var base = '', array = false, braces = ['{', '}']; // Make Array say that they are Array if (isArray(value)) { array = true; braces = ['[', ']']; } // Make functions say that they are functions if (isFunction(value)) { var n = value.name ? ': ' + value.name : ''; base = ' [Function' + n + ']'; } // Make RegExps say that they are RegExps if (isRegExp(value)) { base = ' ' + RegExp.prototype.toString.call(value); } // Make dates with properties first say the date if (isDate(value)) { base = ' ' + Date.prototype.toUTCString.call(value); } // Make error with message first say the error if (isError(value)) { base = ' ' + formatError(value); } if (keys.length === 0 && (!array || value.length == 0)) { return braces[0] + base + braces[1]; } if (recurseTimes < 0) { if (isRegExp(value)) { return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp'); } else { return ctx.stylize('[Object]', 'special'); } } ctx.seen.push(value); var output; if (array) { output = formatArray(ctx, value, recurseTimes, visibleKeys, keys); } else { output = keys.map(function(key) { return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array); }); } ctx.seen.pop(); return reduceToSingleString(output, base, braces); } function formatPrimitive(ctx, value) { if (isUndefined(value)) return ctx.stylize('undefined', 'undefined'); if (isString(value)) { var simple = '\'' + JSON.stringify(value).replace(/^"|"$/g, '') .replace(/'/g, "\\'") .replace(/\\"/g, '"') + '\''; return ctx.stylize(simple, 'string'); } if (isNumber(value)) return ctx.stylize('' + value, 'number'); if (isBoolean(value)) return ctx.stylize('' + value, 'boolean'); // For some reason typeof null is "object", so special case here. if (isNull(value)) return ctx.stylize('null', 'null'); } function formatError(value) { return '[' + Error.prototype.toString.call(value) + ']'; } function formatArray(ctx, value, recurseTimes, visibleKeys, keys) { var output = []; for (var i = 0, l = value.length; i < l; ++i) { if (hasOwnProperty(value, String(i))) { output.push(formatProperty(ctx, value, recurseTimes, visibleKeys, String(i), true)); } else { output.push(''); } } keys.forEach(function(key) { if (!key.match(/^\d+$/)) { output.push(formatProperty(ctx, value, recurseTimes, visibleKeys, key, true)); } }); return output; } function formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) { var name, str, desc; desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] }; if (desc.get) { if (desc.set) { str = ctx.stylize('[Getter/Setter]', 'special'); } else { str = ctx.stylize('[Getter]', 'special'); } } else { if (desc.set) { str = ctx.stylize('[Setter]', 'special'); } } if (!hasOwnProperty(visibleKeys, key)) { name = '[' + key + ']'; } if (!str) { if (ctx.seen.indexOf(desc.value) < 0) { if (isNull(recurseTimes)) { str = formatValue(ctx, desc.value, null); } else { str = formatValue(ctx, desc.value, recurseTimes - 1); } if (str.indexOf('\n') > -1) { if (array) { str = str.split('\n').map(function(line) { return ' ' + line; }).join('\n').substr(2); } else { str = '\n' + str.split('\n').map(function(line) { return ' ' + line; }).join('\n'); } } } else { str = ctx.stylize('[Circular]', 'special'); } } if (isUndefined(name)) { if (array && key.match(/^\d+$/)) { return str; } name = JSON.stringify('' + key); if (name.match(/^"([a-zA-Z_][a-zA-Z_0-9]*)"$/)) { name = name.substr(1, name.length - 2); name = ctx.stylize(name, 'name'); } else { name = name.replace(/'/g, "\\'") .replace(/\\"/g, '"') .replace(/(^"|"$)/g, "'"); name = ctx.stylize(name, 'string'); } } return name + ': ' + str; } function reduceToSingleString(output, base, braces) { var numLinesEst = 0; var length = output.reduce(function(prev, cur) { numLinesEst++; if (cur.indexOf('\n') >= 0) numLinesEst++; return prev + cur.replace(/\u001b\[\d\d?m/g, '').length + 1; }, 0); if (length > 60) { return braces[0] + (base === '' ? '' : base + '\n ') + ' ' + output.join(',\n ') + ' ' + braces[1]; } return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1]; } // NOTE: These type checking functions intentionally don't use `instanceof` // because it is fragile and can be easily faked with `Object.create()`. function isArray(ar) { return Array.isArray(ar); } exports.isArray = isArray; function isBoolean(arg) { return typeof arg === 'boolean'; } exports.isBoolean = isBoolean; function isNull(arg) { return arg === null; } exports.isNull = isNull; function isNullOrUndefined(arg) { return arg == null; } exports.isNullOrUndefined = isNullOrUndefined; function isNumber(arg) { return typeof arg === 'number'; } exports.isNumber = isNumber; function isString(arg) { return typeof arg === 'string'; } exports.isString = isString; function isSymbol(arg) { return typeof arg === 'symbol'; } exports.isSymbol = isSymbol; function isUndefined(arg) { return arg === void 0; } exports.isUndefined = isUndefined; function isRegExp(re) { return isObject(re) && objectToString(re) === '[object RegExp]'; } exports.isRegExp = isRegExp; function isObject(arg) { return typeof arg === 'object' && arg !== null; } exports.isObject = isObject; function isDate(d) { return isObject(d) && objectToString(d) === '[object Date]'; } exports.isDate = isDate; function isError(e) { return isObject(e) && (objectToString(e) === '[object Error]' || e instanceof Error); } exports.isError = isError; function isFunction(arg) { return typeof arg === 'function'; } exports.isFunction = isFunction; function isPrimitive(arg) { return arg === null || typeof arg === 'boolean' || typeof arg === 'number' || typeof arg === 'string' || typeof arg === 'symbol' || // ES6 symbol typeof arg === 'undefined'; } exports.isPrimitive = isPrimitive; exports.isBuffer = require('./support/isBuffer'); function objectToString(o) { return Object.prototype.toString.call(o); } function pad(n) { return n < 10 ? '0' + n.toString(10) : n.toString(10); } var months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec']; // 26 Feb 16:19:34 function timestamp() { var d = new Date(); var time = [pad(d.getHours()), pad(d.getMinutes()), pad(d.getSeconds())].join(':'); return [d.getDate(), months[d.getMonth()], time].join(' '); } // log is just a thin wrapper to console.log that prepends a timestamp exports.log = function() { console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments)); }; /** * Inherit the prototype methods from one constructor into another. * * The Function.prototype.inherits from lang.js rewritten as a standalone * function (not on Function.prototype). NOTE: If this file is to be loaded * during bootstrapping this function needs to be rewritten using some native * functions as prototype setup using normal JavaScript does not work as * expected during bootstrapping (see mirror.js in r114903). * * @param {function} ctor Constructor function which needs to inherit the * prototype. * @param {function} superCtor Constructor function to inherit prototype from. */ exports.inherits = require('inherits'); exports._extend = function(origin, add) { // Don't do anything if add isn't an object if (!add || !isObject(add)) return origin; var keys = Object.keys(add); var i = keys.length; while (i--) { origin[keys[i]] = add[keys[i]]; } return origin; }; function hasOwnProperty(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); } }).call(this,require('_process'),typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) },{"./support/isBuffer":635,"_process":295,"inherits":167}],637:[function(require,module,exports){ /** * @author Titus Wormer * @copyright 2015 Titus Wormer * @license MIT * @module vfile * @fileoverview Virtual file format to attach additional * information related to processed input. Similar to * `wearefractal/vinyl`. Additionally, `VFile` can be * passed directly to ESLint formatters to visualise * warnings and errors relating to a file. * @example * var VFile = require('vfile'); * * var file = new VFile({ * 'directory': '~', * 'filename': 'example', * 'extension': 'txt', * 'contents': 'Foo *bar* baz' * }); * * file.toString(); // 'Foo *bar* baz' * file.filePath(); // '~/example.txt' * * file.move({'extension': 'md'}); * file.filePath(); // '~/example.md' * * file.warn('Something went wrong', {'line': 2, 'column': 3}); * // { [~/example.md:2:3: Something went wrong] * // name: '~/example.md:2:3', * // file: '~/example.md', * // reason: 'Something went wrong', * // line: 2, * // column: 3, * // fatal: false } */ 'use strict'; /* eslint-env commonjs */ var SEPARATOR = '/'; try { SEPARATOR = require('pa' + 'th').sep; } catch (e) { /* empty */ } /** * Construct a new file message. * * Note: We cannot invoke `Error` on the created context, * as that adds readonly `line` and `column` attributes on * Safari 9, thus throwing and failing the data. * * @example * var message = new VFileMessage('Whoops!'); * * message instanceof Error // true * * @constructor * @class {VFileMessage} * @param {string} reason - Reason for messaging. * @property {boolean} [fatal=null] - Whether the message * is fatal. * @property {string} [name=''] - File-name and positional * information. * @property {string} [file=''] - File-path. * @property {string} [reason=''] - Reason for messaging. * @property {number} [line=null] - Start of message. * @property {number} [column=null] - Start of message. * @property {Position|Location} [location=null] - Place of * message. * @property {string} [stack] - Stack-trace of warning. */ function VFileMessage(reason) { this.message = reason; } /** * Inherit from `Error#`. */ function VFileMessagePrototype() {} VFileMessagePrototype.prototype = Error.prototype; var proto = new VFileMessagePrototype(); VFileMessage.prototype = proto; /* * Expose defaults. */ proto.file = proto.name = proto.reason = proto.message = proto.stack = ''; proto.fatal = proto.column = proto.line = null; /** * File-related message with location information. * * @typedef {Error} VFileMessage * @property {string} name - (Starting) location of the * message, preceded by its file-path when available, * and joined by `:`. Used internally by the native * `Error#toString()`. * @property {string} file - File-path. * @property {string} reason - Reason for message. * @property {number?} line - Line of message, when * available. * @property {number?} column - Column of message, when * available. * @property {string?} stack - Stack of message, when * available. * @property {boolean?} fatal - Whether the associated file * is still processable. */ /** * Stringify a position. * * @example * stringify({'line': 1, 'column': 3}) // '1:3' * stringify({'line': 1}) // '1:1' * stringify({'column': 3}) // '1:3' * stringify() // '1:1' * * @private * @param {Object?} [position] - Single position, like * those available at `node.position.start`. * @return {string} - Compiled location. */ function stringify(position) { if (!position) { position = {}; } return (position.line || 1) + ':' + (position.column || 1); } /** * ESLint's formatter API expects `filePath` to be a * string. This hack supports invocation as well as * implicit coercion. * * @example * var file = new VFile({ * 'filename': 'example', * 'extension': 'txt' * }); * * filePath = filePathFactory(file); * * String(filePath); // 'example.txt' * filePath(); // 'example.txt' * * @private * @param {VFile} file - Virtual file. * @return {Function} - `filePath` getter. */ function filePathFactory(file) { /** * Get the filename, with extension and directory, if applicable. * * @example * var file = new VFile({ * 'directory': '~', * 'filename': 'example', * 'extension': 'txt' * }); * * String(file.filePath); // ~/example.txt * file.filePath() // ~/example.txt * * @memberof {VFile} * @property {Function} toString - Itself. ESLint's * formatter API expects `filePath` to be `string`. * This hack supports invocation as well as implicit * coercion. * @return {string} - If the `vFile` has a `filename`, * it will be prefixed with the directory (slashed), * if applicable, and suffixed with the (dotted) * extension (if applicable). Otherwise, an empty * string is returned. */ function filePath() { var directory = file.directory; var separator; if (file.filename || file.extension) { separator = directory.charAt(directory.length - 1); if (separator === '/' || separator === '\\') { directory = directory.slice(0, -1); } if (directory === '.') { directory = ''; } return (directory ? directory + SEPARATOR : '') + file.filename + (file.extension ? '.' + file.extension : ''); } return ''; } filePath.toString = filePath; return filePath; } /** * Get the filename with extantion. * * @example * var file = new VFile({ * 'directory': '~/foo/bar' * 'filename': 'example', * 'extension': 'txt' * }); * * file.basename() // example.txt * * @memberof {VFile} * @return {string} - name of file with extantion. */ function basename() { var self = this; var extension = self.extension; if (self.filename || extension) { return self.filename + (extension ? '.' + extension : ''); } return ''; } /** * Construct a new file. * * @example * var file = new VFile({ * 'directory': '~', * 'filename': 'example', * 'extension': 'txt', * 'contents': 'Foo *bar* baz' * }); * * file === VFile(file) // true * file === new VFile(file) // true * VFile('foo') instanceof VFile // true * * @constructor * @class {VFile} * @param {Object|VFile|string} [options] - either an * options object, or the value of `contents` (both * optional). When a `file` is passed in, it's * immediately returned. * @property {string} [contents=''] - Content of file. * @property {string} [directory=''] - Path to parent * directory. * @property {string} [filename=''] - Filename. * A file-path can still be generated when no filename * exists. * @property {string} [extension=''] - Extension. * A file-path can still be generated when no extension * exists. * @property {boolean?} quiet - Whether an error created by * `VFile#fail()` is returned (when truthy) or thrown * (when falsey). Ensure all `messages` associated with * a file are handled properly when setting this to * `true`. * @property {Array.} messages - List of associated * messages. */ function VFile(options) { var self = this; /* * No `new` operator. */ if (!(self instanceof VFile)) { return new VFile(options); } /* * Given file. */ if ( options && typeof options.message === 'function' && typeof options.hasFailed === 'function' ) { return options; } if (!options) { options = {}; } else if (typeof options === 'string') { options = { 'contents': options }; } self.contents = options.contents || ''; self.messages = []; /* * Make sure eslint’s formatters stringify `filePath` * properly. */ self.filePath = filePathFactory(self); self.history = []; self.move({ 'filename': options.filename, 'directory': options.directory, 'extension': options.extension }); } /** * Get the value of the file. * * @example * var vFile = new VFile('Foo'); * String(vFile); // 'Foo' * * @this {VFile} * @memberof {VFile} * @return {string} - value at the `contents` property * in context. */ function toString() { return this.contents; } /** * Move a file by passing a new directory, filename, * and extension. When these are not given, the default * values are kept. * * @example * var file = new VFile({ * 'directory': '~', * 'filename': 'example', * 'extension': 'txt', * 'contents': 'Foo *bar* baz' * }); * * file.move({'directory': '/var/www'}); * file.filePath(); // '/var/www/example.txt' * * file.move({'extension': 'md'}); * file.filePath(); // '/var/www/example.md' * * @this {VFile} * @memberof {VFile} * @param {Object?} [options] - Configuration. * @return {VFile} - Context object. */ function move(options) { var self = this; var before = self.filePath(); var after; if (!options) { options = {}; } self.directory = options.directory || self.directory || ''; self.filename = options.filename || self.filename || ''; self.extension = options.extension || self.extension || ''; after = self.filePath(); if (after && before !== after) { self.history.push(after); } return self; } /** * Create a message with `reason` at `position`. * When an error is passed in as `reason`, copies the * stack. This does not add a message to `messages`. * * @example * var file = new VFile(); * * file.message('Something went wrong'); * // { [1:1: Something went wrong] * // name: '1:1', * // file: '', * // reason: 'Something went wrong', * // line: null, * // column: null } * * @this {VFile} * @memberof {VFile} * @param {string|Error} reason - Reason for message. * @param {Node|Location|Position} [position] - Location * of message in file. * @return {VFileMessage} - File-related message with * location information. */ function message(reason, position) { var filePath = this.filePath(); var range; var err; var location = { 'start': { 'line': null, 'column': null }, 'end': { 'line': null, 'column': null } }; /* * Node / location / position. */ if (position && position.position) { position = position.position; } if (position && position.start) { range = stringify(position.start) + '-' + stringify(position.end); location = position; position = position.start; } else { range = stringify(position); if (position) { location.start = position; location.end.line = null; location.end.column = null; } } err = new VFileMessage(reason.message || reason); err.name = (filePath ? filePath + ':' : '') + range; err.file = filePath; err.reason = reason.message || reason; err.line = position ? position.line : null; err.column = position ? position.column : null; err.location = location; if (reason.stack) { err.stack = reason.stack; } return err; } /** * Warn. Creates a non-fatal message (see `VFile#message()`), * and adds it to the file's `messages` list. * * @example * var file = new VFile(); * * file.warn('Something went wrong'); * // { [1:1: Something went wrong] * // name: '1:1', * // file: '', * // reason: 'Something went wrong', * // line: null, * // column: null, * // fatal: false } * * @see VFile#message * @this {VFile} * @memberof {VFile} */ function warn() { var err = this.message.apply(this, arguments); err.fatal = false; this.messages.push(err); return err; } /** * Fail. Creates a fatal message (see `VFile#message()`), * sets `fatal: true`, adds it to the file's * `messages` list. * * If `quiet` is not `true`, throws the error. * * @example * var file = new VFile(); * * file.fail('Something went wrong'); * // 1:1: Something went wrong * // at VFile.exception (vfile/index.js:296:11) * // at VFile.fail (vfile/index.js:360:20) * // at repl:1:6 * * file.quiet = true; * file.fail('Something went wrong'); * // { [1:1: Something went wrong] * // name: '1:1', * // file: '', * // reason: 'Something went wrong', * // line: null, * // column: null, * // fatal: true } * * @this {VFile} * @memberof {VFile} * @throws {VFileMessage} - When not `quiet: true`. * @param {string|Error} reason - Reason for failure. * @param {Node|Location|Position} [position] - Place * of failure in file. * @return {VFileMessage} - Unless thrown, of course. */ function fail(reason, position) { var err = this.message(reason, position); err.fatal = true; this.messages.push(err); if (!this.quiet) { throw err; } return err; } /** * Check if a fatal message occurred making the file no * longer processable. * * @example * var file = new VFile(); * file.quiet = true; * * file.hasFailed(); // false * * file.fail('Something went wrong'); * file.hasFailed(); // true * * @this {VFile} * @memberof {VFile} * @return {boolean} - `true` if at least one of file's * `messages` has a `fatal` property set to `true` */ function hasFailed() { var messages = this.messages; var index = -1; var length = messages.length; while (++index < length) { if (messages[index].fatal) { return true; } } return false; } /** * Access metadata. * * @example * var file = new VFile('Foo'); * * file.namespace('foo').bar = 'baz'; * * console.log(file.namespace('foo').bar) // 'baz'; * * @this {VFile} * @memberof {VFile} * @param {string} key - Namespace key. * @return {Object} - Private space. */ function namespace(key) { var self = this; var space = self.data; if (!space) { space = self.data = {}; } if (!space[key]) { space[key] = {}; } return space[key]; } /* * Methods. */ var vFilePrototype = VFile.prototype; vFilePrototype.basename = basename; vFilePrototype.move = move; vFilePrototype.toString = toString; vFilePrototype.message = message; vFilePrototype.warn = warn; vFilePrototype.fail = fail; vFilePrototype.hasFailed = hasFailed; vFilePrototype.namespace = namespace; /* * Expose. */ module.exports = VFile; },{}],638:[function(require,module,exports){ var indexOf = require('indexof'); var Object_keys = function (obj) { if (Object.keys) return Object.keys(obj) else { var res = []; for (var key in obj) res.push(key) return res; } }; var forEach = function (xs, fn) { if (xs.forEach) return xs.forEach(fn) else for (var i = 0; i < xs.length; i++) { fn(xs[i], i, xs); } }; var defineProp = (function() { try { Object.defineProperty({}, '_', {}); return function(obj, name, value) { Object.defineProperty(obj, name, { writable: true, enumerable: false, configurable: true, value: value }) }; } catch(e) { return function(obj, name, value) { obj[name] = value; }; } }()); var globals = ['Array', 'Boolean', 'Date', 'Error', 'EvalError', 'Function', 'Infinity', 'JSON', 'Math', 'NaN', 'Number', 'Object', 'RangeError', 'ReferenceError', 'RegExp', 'String', 'SyntaxError', 'TypeError', 'URIError', 'decodeURI', 'decodeURIComponent', 'encodeURI', 'encodeURIComponent', 'escape', 'eval', 'isFinite', 'isNaN', 'parseFloat', 'parseInt', 'undefined', 'unescape']; function Context() {} Context.prototype = {}; var Script = exports.Script = function NodeScript (code) { if (!(this instanceof Script)) return new Script(code); this.code = code; }; Script.prototype.runInContext = function (context) { if (!(context instanceof Context)) { throw new TypeError("needs a 'context' argument."); } var iframe = document.createElement('iframe'); if (!iframe.style) iframe.style = {}; iframe.style.display = 'none'; document.body.appendChild(iframe); var win = iframe.contentWindow; var wEval = win.eval, wExecScript = win.execScript; if (!wEval && wExecScript) { // win.eval() magically appears when this is called in IE: wExecScript.call(win, 'null'); wEval = win.eval; } forEach(Object_keys(context), function (key) { win[key] = context[key]; }); forEach(globals, function (key) { if (context[key]) { win[key] = context[key]; } }); var winKeys = Object_keys(win); var res = wEval.call(win, this.code); forEach(Object_keys(win), function (key) { // Avoid copying circular objects like `top` and `window` by only // updating existing context properties or new properties in the `win` // that was only introduced after the eval. if (key in context || indexOf(winKeys, key) === -1) { context[key] = win[key]; } }); forEach(globals, function (key) { if (!(key in context)) { defineProp(context, key, win[key]); } }); document.body.removeChild(iframe); return res; }; Script.prototype.runInThisContext = function () { return eval(this.code); // maybe... }; Script.prototype.runInNewContext = function (context) { var ctx = Script.createContext(context); var res = this.runInContext(ctx); forEach(Object_keys(ctx), function (key) { context[key] = ctx[key]; }); return res; }; forEach(Object_keys(Script.prototype), function (name) { exports[name] = Script[name] = function (code) { var s = Script(code); return s[name].apply(s, [].slice.call(arguments, 1)); }; }); exports.createScript = function (code) { return exports.Script(code); }; exports.createContext = Script.createContext = function (context) { var copy = new Context(); if(typeof context === 'object') { forEach(Object_keys(context), function (key) { copy[key] = context[key]; }); } return copy; }; },{"indexof":165}],639:[function(require,module,exports){ /** * Module Dependencies */ var slice = [].slice; var wrap = require('wrap-fn'); /** * Expose `Ware`. */ module.exports = Ware; /** * Throw an error. * * @param {Error} error */ function fail (err) { throw err; } /** * Initialize a new `Ware` manager, with optional `fns`. * * @param {Function or Array or Ware} fn (optional) */ function Ware (fn) { if (!(this instanceof Ware)) return new Ware(fn); this.fns = []; if (fn) this.use(fn); } /** * Use a middleware `fn`. * * @param {Function or Array or Ware} fn * @return {Ware} */ Ware.prototype.use = function (fn) { if (fn instanceof Ware) { return this.use(fn.fns); } if (fn instanceof Array) { for (var i = 0, f; f = fn[i++];) this.use(f); return this; } this.fns.push(fn); return this; }; /** * Run through the middleware with the given `args` and optional `callback`. * * @param {Mixed} args... * @param {Function} callback (optional) * @return {Ware} */ Ware.prototype.run = function () { var fns = this.fns; var ctx = this; var i = 0; var last = arguments[arguments.length - 1]; var done = 'function' == typeof last && last; var args = done ? slice.call(arguments, 0, arguments.length - 1) : slice.call(arguments); // next step function next (err) { if (err) return (done || fail)(err); var fn = fns[i++]; var arr = slice.call(args); if (!fn) { return done && done.apply(null, [null].concat(args)); } wrap(fn, next).apply(ctx, arr); } next(); return this; }; },{"wrap-fn":640}],640:[function(require,module,exports){ /** * Module Dependencies */ var noop = function(){}; var co = require('co'); /** * Export `wrap-fn` */ module.exports = wrap; /** * Wrap a function to support * sync, async, and gen functions. * * @param {Function} fn * @param {Function} done * @return {Function} * @api public */ function wrap(fn, done) { done = once(done || noop); return function() { // prevents arguments leakage // see https://github.com/petkaantonov/bluebird/wiki/Optimization-killers#3-managing-arguments var i = arguments.length; var args = new Array(i); while (i--) args[i] = arguments[i]; var ctx = this; // done if (!fn) { return done.apply(ctx, [null].concat(args)); } // async if (fn.length > args.length) { // NOTE: this only handles uncaught synchronous errors try { return fn.apply(ctx, args.concat(done)); } catch (e) { return done(e); } } // generator if (generator(fn)) { return co(fn).apply(ctx, args.concat(done)); } // sync return sync(fn, done).apply(ctx, args); } } /** * Wrap a synchronous function execution. * * @param {Function} fn * @param {Function} done * @return {Function} * @api private */ function sync(fn, done) { return function () { var ret; try { ret = fn.apply(this, arguments); } catch (err) { return done(err); } if (promise(ret)) { ret.then(function (value) { done(null, value); }, done); } else { ret instanceof Error ? done(ret) : done(null, ret); } } } /** * Is `value` a generator? * * @param {Mixed} value * @return {Boolean} * @api private */ function generator(value) { return value && value.constructor && 'GeneratorFunction' == value.constructor.name; } /** * Is `value` a promise? * * @param {Mixed} value * @return {Boolean} * @api private */ function promise(value) { return value && 'function' == typeof value.then; } /** * Once */ function once(fn) { return function() { var ret = fn.apply(this, arguments); fn = noop; return ret; }; } },{"co":83}],641:[function(require,module,exports){ // Returns a wrapper function that returns a wrapped callback // The wrapper function should do some stuff, and return a // presumably different callback function. // This makes sure that own properties are retained, so that // decorations and such are not lost along the way. module.exports = wrappy function wrappy (fn, cb) { if (fn && cb) return wrappy(fn)(cb) if (typeof fn !== 'function') throw new TypeError('need wrapper function') Object.keys(fn).forEach(function (k) { wrapper[k] = fn[k] }) return wrapper function wrapper() { var args = new Array(arguments.length) for (var i = 0; i < args.length; i++) { args[i] = arguments[i] } var ret = fn.apply(this, args) var cb = args[args.length-1] if (typeof ret === 'function' && ret !== cb) { Object.keys(cb).forEach(function (k) { ret[k] = cb[k] }) } return ret } } },{}],642:[function(require,module,exports){ /** * Module dependencies. */ var global = (function() { return this; })(); /** * WebSocket constructor. */ var WebSocket = global.WebSocket || global.MozWebSocket; /** * Module exports. */ module.exports = WebSocket ? ws : null; /** * WebSocket constructor. * * The third `opts` options object gets ignored in web browsers, since it's * non-standard, and throws a TypeError if passed to the constructor. * See: https://github.com/einaros/ws/issues/227 * * @param {String} uri * @param {Array} protocols (optional) * @param {Object) opts (optional) * @api public */ function ws(uri, protocols, opts) { var instance; if (protocols) { instance = new WebSocket(uri, protocols); } else { instance = new WebSocket(uri); } return instance; } if (WebSocket) ws.prototype = WebSocket.prototype; },{}],643:[function(require,module,exports){ module.exports = function zerr (name, msgTemplate) { // make sure the name ends with the word Error if (name.slice(-5) != 'Error') name += 'Error' function ZError () { // call as a class constructor if called as a function if (!(this instanceof ZError)) { // a bit tricker than usual, because we have to combine `apply()` with the `new` form... function ZE (args) { return ZError.apply(this, args) } ZE.prototype = ZError.prototype; return new ZE(arguments) } Error.call(this) Error.captureStackTrace(this, arguments.callee) this.name = name // if an error was passed, shift it out of the args var parentErr var args = Array.prototype.slice.call(arguments) if (args[0] instanceof Error) parentErr = args.shift() // create message if (msgTemplate) this.message = interp(msgTemplate, args) else if (typeof args[0] == 'string') this.message = args[0] // modify stack to show parent error if (parentErr) { var stack = removePrefix(getStack(this), getStack(parentErr)).join('\n') this.stack = this.name + ': ' + this.message + '\n' + stack + '\n ' + parentErr.stack } } ZError.prototype = Object.create(Error.prototype) return ZError } // interpolate function // - takes a template string and a list of strings to insert // - replaces '%' token in tmpl using values in `args` // eg interp('hello %, how are you % today?', ['bob', 'doing']) => 'hello bob, how are you doing today?' // eg interp('hello %, how are you % today?', ['bob']) => 'hello bob, how are you today?' var re = /%/g function interp (tmpl, args) { var n = 0 return tmpl.replace(re, function () { return args[n++] || '' }) } function getStack(err) { return err.stack.substring(err.name.length + 3 + err.message.length) .split('\n') } function removePrefix (a, b) { return a.filter(function (e) { return !~b.indexOf(e) }) } },{}],644:[function(require,module,exports){ (function (process,__dirname){ var ssbKeys = require('ssb-keys') var config = require('ssb-config/inject')(process.env.ssb_appname) var fs = require('fs') var path = require('path') var manifestFile = path.join(__dirname, 'manifest.json') var pull = require('pull-stream') var Serializer = require('pull-serializer') var keys = ssbKeys.loadOrCreateSync(path.join(config.path, 'secret')) var createSbot = require('scuttlebot') .use(require('scuttlebot/plugins/master')) .use(require('scuttlebot/plugins/gossip')) .use(require('scuttlebot/plugins/friends')) .use(require('scuttlebot/plugins/replicate')) .use(require('scuttlebot/plugins/blobs')) .use(require('scuttlebot/plugins/invite')) .use(require('scuttlebot/plugins/block')) .use(require('scuttlebot/plugins/local')) .use(require('scuttlebot/plugins/logging')) .use(require('scuttlebot/plugins/private')) .use(require('ssb-links')) .use(require('ssb-query')) .use(require('ssb-http')) config.keys = keys var sbot = createSbot(config) fs.writeFileSync(manifestFile, JSON.stringify(sbot.getManifest(), null, 2)) var http = require('http') var WS = require('pull-ws-server') var MuxRpc = require('muxrpc') var server = http.createServer(function (req, res) { fs.createReadStream(path.join(__dirname, 'static', 'index.html')).pipe(res) }).listen(8000) WS.createServer({server: server}, function (ws) { console.log('RPC connection') var rpc = MuxRpc(sbot.getManifest(), sbot.getManifest(), Serializer) (sbot) pull(ws, pull.through(console.log), rpc.createStream(), pull.through(console.log), ws) }) }).call(this,require('_process'),"/") },{"_process":295,"fs":58,"http":588,"muxrpc":261,"path":290,"pull-serializer":373,"pull-stream":381,"pull-ws-server":394,"scuttlebot":425,"scuttlebot/plugins/blobs":437,"scuttlebot/plugins/block":441,"scuttlebot/plugins/friends":442,"scuttlebot/plugins/gossip":443,"scuttlebot/plugins/invite":446,"scuttlebot/plugins/local":447,"scuttlebot/plugins/logging":448,"scuttlebot/plugins/master":449,"scuttlebot/plugins/private":450,"scuttlebot/plugins/replicate":451,"ssb-config/inject":517,"ssb-http":522,"ssb-keys":530,"ssb-links":535,"ssb-query":544}]},{},[644]) //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","node_modules/asn1.js/lib/asn1.js","node_modules/asn1.js/lib/asn1/api.js","node_modules/asn1.js/lib/asn1/base/buffer.js","node_modules/asn1.js/lib/asn1/base/index.js","node_modules/asn1.js/lib/asn1/base/node.js","node_modules/asn1.js/lib/asn1/base/reporter.js","node_modules/asn1.js/lib/asn1/constants/der.js","node_modules/asn1.js/lib/asn1/constants/index.js","node_modules/asn1.js/lib/asn1/decoders/der.js","node_modules/asn1.js/lib/asn1/decoders/index.js","node_modules/asn1.js/lib/asn1/decoders/pem.js","node_modules/asn1.js/lib/asn1/encoders/der.js","node_modules/asn1.js/lib/asn1/encoders/index.js","node_modules/asn1.js/lib/asn1/encoders/pem.js","node_modules/assert/assert.js","node_modules/attach-ware/index.js","node_modules/bail/index.js","node_modules/balanced-match/index.js","node_modules/bash-color/index.js","node_modules/binary-search/index.js","node_modules/bindings/bindings.js","node_modules/bl/bl.js","node_modules/bl/node_modules/isarray/index.js","node_modules/bl/node_modules/readable-stream/duplex.js","node_modules/bl/node_modules/readable-stream/lib/_stream_duplex.js","node_modules/bl/node_modules/readable-stream/lib/_stream_readable.js","node_modules/bl/node_modules/readable-stream/lib/_stream_writable.js","node_modules/blake2s/index.js","node_modules/bn.js/lib/bn.js","node_modules/brace-expansion/index.js","node_modules/broadcast-stream/index.js","node_modules/brorand/index.js","node_modules/browser-resolve/empty.js","node_modules/browserify-aes/aes.js","node_modules/browserify-aes/authCipher.js","node_modules/browserify-aes/browser.js","node_modules/browserify-aes/decrypter.js","node_modules/browserify-aes/encrypter.js","node_modules/browserify-aes/ghash.js","node_modules/browserify-aes/modes.js","node_modules/browserify-aes/modes/cbc.js","node_modules/browserify-aes/modes/cfb.js","node_modules/browserify-aes/modes/cfb1.js","node_modules/browserify-aes/modes/cfb8.js","node_modules/browserify-aes/modes/ctr.js","node_modules/browserify-aes/modes/ecb.js","node_modules/browserify-aes/modes/ofb.js","node_modules/browserify-aes/streamCipher.js","node_modules/browserify-cipher/browser.js","node_modules/browserify-des/index.js","node_modules/browserify-des/modes.js","node_modules/browserify-rsa/index.js","node_modules/browserify-sign/algos.js","node_modules/browserify-sign/browser.js","node_modules/browserify-sign/curves.js","node_modules/browserify-sign/sign.js","node_modules/browserify-sign/verify.js","node_modules/buffer-equal/index.js","node_modules/buffer-xor/index.js","node_modules/buffer/index.js","node_modules/buffer/node_modules/base64-js/lib/b64.js","node_modules/builtin-status-codes/browser.js","node_modules/bytewise-core/base.js","node_modules/bytewise-core/codecs.js","node_modules/bytewise-core/index.js","node_modules/bytewise-core/util.js","node_modules/ccount/index.js","node_modules/character-entities-html4/index.json","node_modules/character-entities-html4/index.js","node_modules/character-entities-legacy/index.json","node_modules/character-entities-legacy/index.js","node_modules/character-entities/index.json","node_modules/character-entities/index.js","node_modules/character-reference-invalid/index.json","node_modules/character-reference-invalid/index.js","node_modules/chloride/bindings.js","node_modules/chloride/browser.js","node_modules/chloride/index.js","node_modules/cipher-base/index.js","node_modules/clone/clone.js","node_modules/co/index.js","node_modules/collapse-white-space/index.js","node_modules/concat-map/index.js","node_modules/cont/index.js","node_modules/continuable-hash/index.js","node_modules/continuable-hash/node_modules/continuable/maybe-callback.js","node_modules/continuable-list/index.js","node_modules/continuable-para/index.js","node_modules/continuable-series/index.js","node_modules/continuable/both.js","node_modules/continuable/chain.js","node_modules/continuable/either.js","node_modules/continuable/error.js","node_modules/continuable/index.js","node_modules/continuable/join.js","node_modules/continuable/map-async.js","node_modules/continuable/map.js","node_modules/continuable/of.js","node_modules/continuable/to.js","node_modules/core-util-is/lib/util.js","node_modules/create-ecdh/browser.js","node_modules/create-hash/browser.js","node_modules/create-hash/helpers.js","node_modules/create-hash/md5.js","node_modules/create-hmac/browser.js","node_modules/crypto-browserify/index.js","node_modules/deep-extend/lib/deep-extend.js","node_modules/defined/index.js","node_modules/des.js/lib/des.js","node_modules/des.js/lib/des/cbc.js","node_modules/des.js/lib/des/cipher.js","node_modules/des.js/lib/des/des.js","node_modules/des.js/lib/des/ede.js","node_modules/des.js/lib/des/utils.js","node_modules/detab/index.js","node_modules/diffie-hellman/browser.js","node_modules/diffie-hellman/lib/dh.js","node_modules/diffie-hellman/lib/generatePrime.js","node_modules/diffie-hellman/lib/primes.json","node_modules/eccjs/dist/0.3/ecc.js","node_modules/elliptic/lib/elliptic.js","node_modules/elliptic/lib/elliptic/curve/base.js","node_modules/elliptic/lib/elliptic/curve/edwards.js","node_modules/elliptic/lib/elliptic/curve/index.js","node_modules/elliptic/lib/elliptic/curve/mont.js","node_modules/elliptic/lib/elliptic/curve/short.js","node_modules/elliptic/lib/elliptic/curves.js","node_modules/elliptic/lib/elliptic/ec/index.js","node_modules/elliptic/lib/elliptic/ec/key.js","node_modules/elliptic/lib/elliptic/ec/signature.js","node_modules/elliptic/lib/elliptic/eddsa/index.js","node_modules/elliptic/lib/elliptic/eddsa/key.js","node_modules/elliptic/lib/elliptic/eddsa/signature.js","node_modules/elliptic/lib/elliptic/hmac-drbg.js","node_modules/elliptic/lib/elliptic/precomputed/secp256k1.js","node_modules/elliptic/lib/elliptic/utils.js","node_modules/elliptic/package.json","node_modules/errno/custom.js","node_modules/errno/errno.js","node_modules/events/events.js","node_modules/evp_bytestokey/index.js","node_modules/explain-error/index.js","node_modules/extend.js/index.js","node_modules/extend/index.js","node_modules/fast-future/fast-future.js","node_modules/glob/common.js","node_modules/glob/glob.js","node_modules/glob/sync.js","node_modules/graphmitter/algorithms.js","node_modules/graphmitter/index.js","node_modules/hash.js/lib/hash.js","node_modules/hash.js/lib/hash/common.js","node_modules/hash.js/lib/hash/hmac.js","node_modules/hash.js/lib/hash/ripemd.js","node_modules/hash.js/lib/hash/sha.js","node_modules/hash.js/lib/hash/utils.js","node_modules/hmac/index.js","node_modules/hoox/index.js","node_modules/ieee754/index.js","node_modules/increment-buffer/index.js","node_modules/indexof/index.js","node_modules/inflight/inflight.js","node_modules/inherits/inherits_browser.js","node_modules/ip-regex/index.js","node_modules/ip/lib/ip.js","node_modules/is-buffer/index.js","node_modules/is-valid-domain/is-valid-domain.js","node_modules/isarray/index.js","node_modules/level-codec/index.js","node_modules/level-codec/lib/encodings.js","node_modules/level-errors/errors.js","node_modules/level-iterator-stream/index.js","node_modules/level-iterator-stream/node_modules/xtend/immutable.js","node_modules/level-memview/index.js","node_modules/level-memview/node_modules/pull-stream/index.js","node_modules/level-memview/node_modules/pull-stream/maybe.js","node_modules/level-memview/node_modules/pull-stream/sinks.js","node_modules/level-memview/node_modules/pull-stream/sources.js","node_modules/level-memview/node_modules/pull-stream/throughs.js","node_modules/level-packager/level-packager.js","node_modules/level-packager/node_modules/abstract-leveldown/abstract-chained-batch.js","node_modules/level-packager/node_modules/abstract-leveldown/abstract-iterator.js","node_modules/level-packager/node_modules/abstract-leveldown/abstract-leveldown.js","node_modules/level-packager/node_modules/abstract-leveldown/index.js","node_modules/level-packager/node_modules/abstract-leveldown/is-leveldown.js","node_modules/level-packager/node_modules/deferred-leveldown/deferred-iterator.js","node_modules/level-packager/node_modules/deferred-leveldown/deferred-leveldown.js","node_modules/level-packager/node_modules/levelup/lib/batch.js","node_modules/level-packager/node_modules/levelup/lib/levelup.js","node_modules/level-packager/node_modules/levelup/lib/util.js","node_modules/level-packager/node_modules/levelup/package.json","node_modules/level-packager/node_modules/prr/prr.js","node_modules/level-post/index.js","node_modules/level/level.js","node_modules/leveldown/chained-batch.js","node_modules/leveldown/iterator.js","node_modules/leveldown/leveldown.js","node_modules/leveldown/node_modules/abstract-leveldown/abstract-chained-batch.js","node_modules/leveldown/node_modules/abstract-leveldown/abstract-iterator.js","node_modules/leveldown/node_modules/abstract-leveldown/abstract-leveldown.js","node_modules/levelup/lib/codec.js","node_modules/levelup/lib/encodings.js","node_modules/levelup/lib/errors.js","node_modules/levelup/lib/read-stream.js","node_modules/levelup/lib/util.js","node_modules/levelup/node_modules/readable-stream/lib/_stream_duplex.js","node_modules/levelup/node_modules/readable-stream/lib/_stream_passthrough.js","node_modules/levelup/node_modules/readable-stream/lib/_stream_readable.js","node_modules/levelup/node_modules/readable-stream/lib/_stream_transform.js","node_modules/levelup/node_modules/readable-stream/lib/_stream_writable.js","node_modules/levelup/node_modules/readable-stream/readable.js","node_modules/levelup/node_modules/xtend/index.js","node_modules/levelup/package.json","node_modules/libsodium-wrappers/dist/modules/libsodium-wrappers.js","node_modules/libsodium/dist/modules/libsodium.js","node_modules/longest-streak/index.js","node_modules/looper/index.js","node_modules/ltgt/index.js","node_modules/map-filter-reduce/basic.js","node_modules/map-filter-reduce/filter.js","node_modules/map-filter-reduce/index.js","node_modules/map-filter-reduce/keys.js","node_modules/map-filter-reduce/map.js","node_modules/map-filter-reduce/node_modules/pull-stream/index.js","node_modules/map-filter-reduce/node_modules/pull-stream/pull.js","node_modules/map-filter-reduce/node_modules/pull-stream/sinks.js","node_modules/map-filter-reduce/node_modules/pull-stream/sources.js","node_modules/map-filter-reduce/node_modules/pull-stream/throughs.js","node_modules/map-filter-reduce/reduce.js","node_modules/map-filter-reduce/util.js","node_modules/map-merge/index.js","node_modules/markdown-table/index.js","node_modules/mdmanifest/index.js","node_modules/miller-rabin/lib/mr.js","node_modules/mime-db/db.json","node_modules/mime-db/index.js","node_modules/mime-types/index.js","node_modules/minimalistic-assert/index.js","node_modules/minimatch/minimatch.js","node_modules/mkdirp/index.js","node_modules/monotonic-timestamp/index.js","node_modules/multiblob/index.js","node_modules/multiblob/node_modules/pull-notify/index.js","node_modules/multiblob/node_modules/rimraf/rimraf.js","node_modules/multiblob/util.js","node_modules/muxrpc-validation/index.js","node_modules/muxrpc/api.js","node_modules/muxrpc/index.js","node_modules/muxrpc/local-api.js","node_modules/muxrpc/permissions.js","node_modules/muxrpc/pull-weird.js","node_modules/muxrpc/stream.js","node_modules/muxrpc/util.js","node_modules/non-private-ip/index.js","node_modules/normalize-uri/index.js","node_modules/object-assign/index.js","node_modules/observ-debounce/index.js","node_modules/observ/index.js","node_modules/on-wakeup/index.js","node_modules/once/once.js","node_modules/os-browserify/browser.js","node_modules/os-homedir/index.js","node_modules/os-tmpdir/index.js","node_modules/osenv/osenv.js","node_modules/packet-stream-codec/index.js","node_modules/packet-stream/index.js","node_modules/parse-asn1/aesid.json","node_modules/parse-asn1/asn1.js","node_modules/parse-asn1/fixProc.js","node_modules/parse-asn1/index.js","node_modules/parse-entities/index.js","node_modules/path-browserify/index.js","node_modules/path-is-absolute/index.js","node_modules/pbkdf2/browser.js","node_modules/private-box/index.js","node_modules/process-nextick-args/index.js","node_modules/process/browser.js","node_modules/public-encrypt/browser.js","node_modules/public-encrypt/mgf.js","node_modules/public-encrypt/privateDecrypt.js","node_modules/public-encrypt/publicEncrypt.js","node_modules/public-encrypt/withPublic.js","node_modules/public-encrypt/xor.js","node_modules/pull-abortable/index.js","node_modules/pull-box-stream/index.js","node_modules/pull-cat/index.js","node_modules/pull-core/index.js","node_modules/pull-defer/duplex.js","node_modules/pull-defer/index.js","node_modules/pull-defer/sink.js","node_modules/pull-defer/source.js","node_modules/pull-defer/through.js","node_modules/pull-file/index.js","node_modules/pull-fs/core.js","node_modules/pull-fs/index.js","node_modules/pull-fs/util.js","node_modules/pull-glob/index.js","node_modules/pull-goodbye/endable.js","node_modules/pull-goodbye/index.js","node_modules/pull-handshake/index.js","node_modules/pull-identify-filetype/index.js","node_modules/pull-identify-filetype/magic-numbers.js","node_modules/pull-inactivity/index.js","node_modules/pull-inactivity/node_modules/pull-stream/throughs.js","node_modules/pull-inactivity/rate.js","node_modules/pull-level/index.js","node_modules/pull-level/node_modules/pull-core/index.js","node_modules/pull-level/node_modules/pull-pushable/index.js","node_modules/pull-level/node_modules/pull-pushable/node_modules/pull-stream/index.js","node_modules/pull-level/node_modules/pull-pushable/node_modules/pull-stream/maybe.js","node_modules/pull-level/node_modules/pull-pushable/node_modules/pull-stream/sinks.js","node_modules/pull-level/node_modules/pull-pushable/node_modules/pull-stream/sources.js","node_modules/pull-level/node_modules/pull-pushable/node_modules/pull-stream/throughs.js","node_modules/pull-level/node_modules/stream-to-pull-stream/index.js","node_modules/pull-many/index.js","node_modules/pull-notify/node_modules/pull-stream/throughs.js","node_modules/pull-pair/index.js","node_modules/pull-paramap/index.js","node_modules/pull-ping/index.js","node_modules/pull-pushable/index.js","node_modules/pull-reader/bl-state.js","node_modules/pull-reader/index.js","node_modules/pull-serializer/index.js","node_modules/pull-serializer/node_modules/pull-stream/throughs.js","node_modules/pull-sink-through/index.js","node_modules/pull-split/index.js","node_modules/pull-stream/sources.js","node_modules/pull-stream/throughs.js","node_modules/pull-through/index.js","node_modules/pull-through/node_modules/looper/index.js","node_modules/pull-traverse/index.js","node_modules/pull-utf8-decoder/index.js","node_modules/pull-window/index.js","node_modules/pull-write-file/index.js","node_modules/pull-write/index.js","node_modules/pull-ws-server/client.js","node_modules/pull-ws/index.js","node_modules/pull-ws/ready.js","node_modules/pull-ws/sink.js","node_modules/pull-ws/source.js","node_modules/punycode/punycode.js","node_modules/querystring-es3/decode.js","node_modules/querystring-es3/encode.js","node_modules/querystring-es3/index.js","node_modules/randombytes/browser.js","node_modules/rc/browser.js","node_modules/readable-stream/lib/_stream_duplex.js","node_modules/readable-stream/lib/_stream_readable.js","node_modules/readable-stream/lib/_stream_transform.js","node_modules/readable-stream/lib/_stream_writable.js","node_modules/readable-stream/readable.js","node_modules/remark-html/index.js","node_modules/remark-html/lib/compilers.js","node_modules/remark-html/lib/h.js","node_modules/remark-html/lib/transformer.js","node_modules/remark/index.js","node_modules/remark/lib/block-elements.json","node_modules/remark/lib/defaults.js","node_modules/remark/lib/escape.json","node_modules/remark/lib/parse.js","node_modules/remark/lib/stringify.js","node_modules/remark/lib/utilities.js","node_modules/repeat-string/index.js","node_modules/rimraf/rimraf.js","node_modules/ripemd160/lib/ripemd160.js","node_modules/scuttlebot/index.js","node_modules/scuttlebot/lib/apidocs.js","node_modules/scuttlebot/lib/cli-cmd-aliases.js","node_modules/scuttlebot/lib/ssb-cap.js","node_modules/scuttlebot/lib/util.js","node_modules/scuttlebot/lib/validators.js","node_modules/scuttlebot/node_modules/ssb-msgs/index.js","node_modules/scuttlebot/plugins/blobs/index.js","node_modules/scuttlebot/plugins/blobs/queue.js","node_modules/scuttlebot/plugins/blobs/quota.js","node_modules/scuttlebot/plugins/blobs/replication.js","node_modules/scuttlebot/plugins/block.js","node_modules/scuttlebot/plugins/friends.js","node_modules/scuttlebot/plugins/gossip/index.js","node_modules/scuttlebot/plugins/gossip/init.js","node_modules/scuttlebot/plugins/gossip/schedule.js","node_modules/scuttlebot/plugins/invite.js","node_modules/scuttlebot/plugins/local.js","node_modules/scuttlebot/plugins/logging.js","node_modules/scuttlebot/plugins/master.js","node_modules/scuttlebot/plugins/private.js","node_modules/scuttlebot/plugins/replicate.js","node_modules/secret-handshake/handshake.js","node_modules/secret-handshake/index.js","node_modules/secret-handshake/net.js","node_modules/secret-handshake/secure.js","node_modules/secret-handshake/state.js","node_modules/secret-stack/api.js","node_modules/secret-stack/index.js","node_modules/secret-stack/node_modules/non-private-ip/index.js","node_modules/secret-stack/node_modules/pull-stream/throughs.js","node_modules/secret-stack/util.js","node_modules/secure-scuttlebutt/codec.js","node_modules/secure-scuttlebutt/create.js","node_modules/secure-scuttlebutt/defaults.js","node_modules/secure-scuttlebutt/index.js","node_modules/secure-scuttlebutt/node_modules/bytewise/encoding/binary.js","node_modules/secure-scuttlebutt/node_modules/bytewise/encoding/index.js","node_modules/secure-scuttlebutt/node_modules/bytewise/index.js","node_modules/secure-scuttlebutt/node_modules/level-sublevel/bytewise.js","node_modules/secure-scuttlebutt/node_modules/level-sublevel/codec/bytewise.js","node_modules/secure-scuttlebutt/node_modules/level-sublevel/hooks.js","node_modules/secure-scuttlebutt/node_modules/level-sublevel/node_modules/ltgt/index.js","node_modules/secure-scuttlebutt/node_modules/level-sublevel/nut.js","node_modules/secure-scuttlebutt/node_modules/level-sublevel/package.json","node_modules/secure-scuttlebutt/node_modules/level-sublevel/range.js","node_modules/secure-scuttlebutt/node_modules/level-sublevel/shell.js","node_modules/secure-scuttlebutt/node_modules/pull-level/index.js","node_modules/secure-scuttlebutt/node_modules/pull-pushable/node_modules/pull-stream/throughs.js","node_modules/secure-scuttlebutt/node_modules/pull-stream/sources.js","node_modules/secure-scuttlebutt/node_modules/pull-stream/throughs.js","node_modules/secure-scuttlebutt/package.json","node_modules/sha.js/hash.js","node_modules/sha.js/index.js","node_modules/sha.js/sha.js","node_modules/sha.js/sha1.js","node_modules/sha.js/sha224.js","node_modules/sha.js/sha256.js","node_modules/sha.js/sha384.js","node_modules/sha.js/sha512.js","node_modules/sodium-browserify/browser.js","node_modules/sodium-browserify/index.js","node_modules/split-buffer/index.js","node_modules/ssb-config/inject.js","node_modules/ssb-feed/index.js","node_modules/ssb-feed/util.js","node_modules/ssb-feed/validator.js","node_modules/ssb-http/index.js","node_modules/ssb-http/node_modules/ip/lib/ip.js","node_modules/ssb-keys/eccjs.js","node_modules/ssb-keys/index.js","node_modules/ssb-keys/node_modules/deep-equal/index.js","node_modules/ssb-keys/node_modules/deep-equal/lib/is_arguments.js","node_modules/ssb-keys/node_modules/deep-equal/lib/keys.js","node_modules/ssb-keys/sodium.js","node_modules/ssb-links/index.js","node_modules/ssb-links/links.js","node_modules/ssb-links/node_modules/ssb-msgs/index.js","node_modules/ssb-query/index.js","node_modules/ssb-query/node_modules/map-filter-reduce/basic.js","node_modules/ssb-query/node_modules/map-filter-reduce/index.js","node_modules/ssb-query/node_modules/map-filter-reduce/map.js","node_modules/ssb-query/node_modules/map-filter-reduce/reduce.js","node_modules/ssb-query/node_modules/map-filter-reduce/util.js","node_modules/ssb-query/node_modules/pull-pushable/node_modules/pull-stream/throughs.js","node_modules/ssb-query/node_modules/streamview-links/index.js","node_modules/ssb-query/node_modules/streamview-links/query.js","node_modules/ssb-query/node_modules/streamview-links/select.js","node_modules/ssb-query/node_modules/streamview-links/util.js","node_modules/ssb-query/package.json","node_modules/ssb-ref/index.js","node_modules/stack/stack.js","node_modules/statistics/index.js","node_modules/stream-browserify/index.js","node_modules/stream-browserify/node_modules/readable-stream/lib/_stream_passthrough.js","node_modules/stream-browserify/node_modules/readable-stream/lib/_stream_readable.js","node_modules/stream-browserify/node_modules/readable-stream/lib/_stream_transform.js","node_modules/stream-browserify/node_modules/readable-stream/lib/_stream_writable.js","node_modules/stream-browserify/node_modules/readable-stream/passthrough.js","node_modules/stream-browserify/node_modules/readable-stream/readable.js","node_modules/stream-browserify/node_modules/readable-stream/transform.js","node_modules/stream-browserify/node_modules/readable-stream/writable.js","node_modules/stream-http/index.js","node_modules/stream-http/lib/capability.js","node_modules/stream-http/lib/request.js","node_modules/stream-http/lib/response.js","node_modules/stream-to-pull-stream/index.js","node_modules/streamview-links/index.js","node_modules/streamview-links/node_modules/pull-pushable/node_modules/pull-stream/throughs.js","node_modules/string-range/index.js","node_modules/string_decoder/index.js","node_modules/stringify-entities/index.js","node_modules/stringify-entities/lib/expression.js","node_modules/to-arraybuffer/index.js","node_modules/trim-lines/index.js","node_modules/trim-trailing-lines/index.js","node_modules/trim/index.js","node_modules/typewise-core/base.js","node_modules/typewise-core/collation.js","node_modules/typewise/base.js","node_modules/typewise/collation.js","node_modules/typewise/index.js","node_modules/typewiselite/index.js","node_modules/unherit/index.js","node_modules/unified/index.js","node_modules/unist-util-visit/index.js","node_modules/url/url.js","node_modules/url/util.js","node_modules/util-deprecate/browser.js","node_modules/util/support/isBufferBrowser.js","node_modules/util/util.js","node_modules/vfile/index.js","node_modules/vm-browserify/index.js","node_modules/ware/lib/index.js","node_modules/wrap-fn/index.js","node_modules/wrappy/wrappy.js","node_modules/ws/lib/browser.js","node_modules/zerr/index.js","server.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpHA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7mBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjUA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtSA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvWA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACtKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACnPA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC1EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC/2BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACngBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjzCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC31GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC/LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC5EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzDA;;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACjLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACjGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACzIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC1HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AClGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3KA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AClCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACzEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACxBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACxCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACxEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACvGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACzLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;ACvGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACh7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC7GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC1EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC9HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AChMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACtUA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9PA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/kEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;;ACFA;AACA;AACA;;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC1FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AChKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC3GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC1HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACpDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC3JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACpEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC7EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AChJA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACtEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC1CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACpKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACh8GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/VA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1ZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC74BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7MA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9NA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5wBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7KA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC1SA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACpEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACtFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AClOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC7vBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC5cA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACjQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC5CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5XA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrBA;AACA;AACA;AACA;;ACHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC1GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC5EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AChKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACvUA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC/EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACjDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AChRA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AClCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACxDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACnFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC/YA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC9DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACjEA;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACtGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC/EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACjDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;AChRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACnFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACxEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC5FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACzFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC9CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACt9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AClNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AClYA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC/LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACzpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AClCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AClBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AClJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5RA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/6MA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5LA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACh5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AClGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC/NA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACxPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AClDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;ACzCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AChJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACtCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACxBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACxEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC/HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACrHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACrGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AChsBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AChOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AChFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC5DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC3FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC3GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC9FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACtDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACjJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrBA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACtJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AClGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;ACpDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;ACvDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC5BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;AC9EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACvUA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACtJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACpSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC5KA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;ACrIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACpSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AChDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACjEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACvUA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;ACrCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACxKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC5VA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACnGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACnDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC3EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AClhBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrFA;AACA;AACA;AACA;AACA;;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACPA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;ACzFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACv7BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACjNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC7dA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/6BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzhMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpwEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3SA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACpEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC7UA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AClNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACrHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;ACtOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACnCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC1EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACXA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3QA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AClGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;ACpGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACrCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC/KA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACvEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACnMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;AClEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACvUA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACnFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACVA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACbA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACphBA;AACA;AACA;AACA;AACA;AACA;;ACLA;AACA;AACA;;ACFA;AACA;AACA;;ACFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AClJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC5GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACjFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;AC9KA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;;;;AC3EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;ACpSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACtJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;ACxUA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACpHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACrEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC7FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AClGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACpDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACtIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACxDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACnQA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AChFA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC/CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC1DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC1JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9GA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;AC5ZA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC5CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC/TA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACTA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC7BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC9DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;ACjEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC5JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;AC9EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACpDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;ACvKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;ACpSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;AC/HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACzBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC/2BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACngBA;AACA;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClBA;AACA;;ACDA;AACA;;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;AC9EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACxCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;ACtRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;AClLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;AC1MA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;;;;ACnLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;ACpSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACxEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7NA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACdA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACrSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrFA;AACA;AACA;AACA;AACA;AACA;AACA;;ACNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;;;ACDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACrSA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5tBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACnEA;AACA;AACA;AACA;AACA;AACA;;;ACLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC1kBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChnBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1IA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7HA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AChEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","var asn1 = exports;\n\nasn1.bignum = require('bn.js');\n\nasn1.define = require('./asn1/api').define;\nasn1.base = require('./asn1/base');\nasn1.constants = require('./asn1/constants');\nasn1.decoders = require('./asn1/decoders');\nasn1.encoders = require('./asn1/encoders');\n","var asn1 = require('../asn1');\nvar inherits = require('inherits');\n\nvar api = exports;\n\napi.define = function define(name, body) {\n  return new Entity(name, body);\n};\n\nfunction Entity(name, body) {\n  this.name = name;\n  this.body = body;\n\n  this.decoders = {};\n  this.encoders = {};\n};\n\nEntity.prototype._createNamed = function createNamed(base) {\n  var named;\n  try {\n    named = require('vm').runInThisContext(\n      '(function ' + this.name + '(entity) {\\n' +\n      '  this._initNamed(entity);\\n' +\n      '})'\n    );\n  } catch (e) {\n    named = function (entity) {\n      this._initNamed(entity);\n    };\n  }\n  inherits(named, base);\n  named.prototype._initNamed = function initnamed(entity) {\n    base.call(this, entity);\n  };\n\n  return new named(this);\n};\n\nEntity.prototype._getDecoder = function _getDecoder(enc) {\n  // Lazily create decoder\n  if (!this.decoders.hasOwnProperty(enc))\n    this.decoders[enc] = this._createNamed(asn1.decoders[enc]);\n  return this.decoders[enc];\n};\n\nEntity.prototype.decode = function decode(data, enc, options) {\n  return this._getDecoder(enc).decode(data, options);\n};\n\nEntity.prototype._getEncoder = function _getEncoder(enc) {\n  // Lazily create encoder\n  if (!this.encoders.hasOwnProperty(enc))\n    this.encoders[enc] = this._createNamed(asn1.encoders[enc]);\n  return this.encoders[enc];\n};\n\nEntity.prototype.encode = function encode(data, enc, /* internal */ reporter) {\n  return this._getEncoder(enc).encode(data, reporter);\n};\n","var inherits = require('inherits');\nvar Reporter = require('../base').Reporter;\nvar Buffer = require('buffer').Buffer;\n\nfunction DecoderBuffer(base, options) {\n  Reporter.call(this, options);\n  if (!Buffer.isBuffer(base)) {\n    this.error('Input not Buffer');\n    return;\n  }\n\n  this.base = base;\n  this.offset = 0;\n  this.length = base.length;\n}\ninherits(DecoderBuffer, Reporter);\nexports.DecoderBuffer = DecoderBuffer;\n\nDecoderBuffer.prototype.save = function save() {\n  return { offset: this.offset, reporter: Reporter.prototype.save.call(this) };\n};\n\nDecoderBuffer.prototype.restore = function restore(save) {\n  // Return skipped data\n  var res = new DecoderBuffer(this.base);\n  res.offset = save.offset;\n  res.length = this.offset;\n\n  this.offset = save.offset;\n  Reporter.prototype.restore.call(this, save.reporter);\n\n  return res;\n};\n\nDecoderBuffer.prototype.isEmpty = function isEmpty() {\n  return this.offset === this.length;\n};\n\nDecoderBuffer.prototype.readUInt8 = function readUInt8(fail) {\n  if (this.offset + 1 <= this.length)\n    return this.base.readUInt8(this.offset++, true);\n  else\n    return this.error(fail || 'DecoderBuffer overrun');\n}\n\nDecoderBuffer.prototype.skip = function skip(bytes, fail) {\n  if (!(this.offset + bytes <= this.length))\n    return this.error(fail || 'DecoderBuffer overrun');\n\n  var res = new DecoderBuffer(this.base);\n\n  // Share reporter state\n  res._reporterState = this._reporterState;\n\n  res.offset = this.offset;\n  res.length = this.offset + bytes;\n  this.offset += bytes;\n  return res;\n}\n\nDecoderBuffer.prototype.raw = function raw(save) {\n  return this.base.slice(save ? save.offset : this.offset, this.length);\n}\n\nfunction EncoderBuffer(value, reporter) {\n  if (Array.isArray(value)) {\n    this.length = 0;\n    this.value = value.map(function(item) {\n      if (!(item instanceof EncoderBuffer))\n        item = new EncoderBuffer(item, reporter);\n      this.length += item.length;\n      return item;\n    }, this);\n  } else if (typeof value === 'number') {\n    if (!(0 <= value && value <= 0xff))\n      return reporter.error('non-byte EncoderBuffer value');\n    this.value = value;\n    this.length = 1;\n  } else if (typeof value === 'string') {\n    this.value = value;\n    this.length = Buffer.byteLength(value);\n  } else if (Buffer.isBuffer(value)) {\n    this.value = value;\n    this.length = value.length;\n  } else {\n    return reporter.error('Unsupported type: ' + typeof value);\n  }\n}\nexports.EncoderBuffer = EncoderBuffer;\n\nEncoderBuffer.prototype.join = function join(out, offset) {\n  if (!out)\n    out = new Buffer(this.length);\n  if (!offset)\n    offset = 0;\n\n  if (this.length === 0)\n    return out;\n\n  if (Array.isArray(this.value)) {\n    this.value.forEach(function(item) {\n      item.join(out, offset);\n      offset += item.length;\n    });\n  } else {\n    if (typeof this.value === 'number')\n      out[offset] = this.value;\n    else if (typeof this.value === 'string')\n      out.write(this.value, offset);\n    else if (Buffer.isBuffer(this.value))\n      this.value.copy(out, offset);\n    offset += this.length;\n  }\n\n  return out;\n};\n","var base = exports;\n\nbase.Reporter = require('./reporter').Reporter;\nbase.DecoderBuffer = require('./buffer').DecoderBuffer;\nbase.EncoderBuffer = require('./buffer').EncoderBuffer;\nbase.Node = require('./node');\n","var Reporter = require('../base').Reporter;\nvar EncoderBuffer = require('../base').EncoderBuffer;\nvar DecoderBuffer = require('../base').DecoderBuffer;\nvar assert = require('minimalistic-assert');\n\n// Supported tags\nvar tags = [\n  'seq', 'seqof', 'set', 'setof', 'objid', 'bool',\n  'gentime', 'utctime', 'null_', 'enum', 'int',\n  'bitstr', 'bmpstr', 'charstr', 'genstr', 'graphstr', 'ia5str', 'iso646str',\n  'numstr', 'octstr', 'printstr', 't61str', 'unistr', 'utf8str', 'videostr'\n];\n\n// Public methods list\nvar methods = [\n  'key', 'obj', 'use', 'optional', 'explicit', 'implicit', 'def', 'choice',\n  'any', 'contains'\n].concat(tags);\n\n// Overrided methods list\nvar overrided = [\n  '_peekTag', '_decodeTag', '_use',\n  '_decodeStr', '_decodeObjid', '_decodeTime',\n  '_decodeNull', '_decodeInt', '_decodeBool', '_decodeList',\n\n  '_encodeComposite', '_encodeStr', '_encodeObjid', '_encodeTime',\n  '_encodeNull', '_encodeInt', '_encodeBool'\n];\n\nfunction Node(enc, parent) {\n  var state = {};\n  this._baseState = state;\n\n  state.enc = enc;\n\n  state.parent = parent || null;\n  state.children = null;\n\n  // State\n  state.tag = null;\n  state.args = null;\n  state.reverseArgs = null;\n  state.choice = null;\n  state.optional = false;\n  state.any = false;\n  state.obj = false;\n  state.use = null;\n  state.useDecoder = null;\n  state.key = null;\n  state['default'] = null;\n  state.explicit = null;\n  state.implicit = null;\n  state.contains = null;\n\n  // Should create new instance on each method\n  if (!state.parent) {\n    state.children = [];\n    this._wrap();\n  }\n}\nmodule.exports = Node;\n\nvar stateProps = [\n  'enc', 'parent', 'children', 'tag', 'args', 'reverseArgs', 'choice',\n  'optional', 'any', 'obj', 'use', 'alteredUse', 'key', 'default', 'explicit',\n  'implicit'\n];\n\nNode.prototype.clone = function clone() {\n  var state = this._baseState;\n  var cstate = {};\n  stateProps.forEach(function(prop) {\n    cstate[prop] = state[prop];\n  });\n  var res = new this.constructor(cstate.parent);\n  res._baseState = cstate;\n  return res;\n};\n\nNode.prototype._wrap = function wrap() {\n  var state = this._baseState;\n  methods.forEach(function(method) {\n    this[method] = function _wrappedMethod() {\n      var clone = new this.constructor(this);\n      state.children.push(clone);\n      return clone[method].apply(clone, arguments);\n    };\n  }, this);\n};\n\nNode.prototype._init = function init(body) {\n  var state = this._baseState;\n\n  assert(state.parent === null);\n  body.call(this);\n\n  // Filter children\n  state.children = state.children.filter(function(child) {\n    return child._baseState.parent === this;\n  }, this);\n  assert.equal(state.children.length, 1, 'Root node can have only one child');\n};\n\nNode.prototype._useArgs = function useArgs(args) {\n  var state = this._baseState;\n\n  // Filter children and args\n  var children = args.filter(function(arg) {\n    return arg instanceof this.constructor;\n  }, this);\n  args = args.filter(function(arg) {\n    return !(arg instanceof this.constructor);\n  }, this);\n\n  if (children.length !== 0) {\n    assert(state.children === null);\n    state.children = children;\n\n    // Replace parent to maintain backward link\n    children.forEach(function(child) {\n      child._baseState.parent = this;\n    }, this);\n  }\n  if (args.length !== 0) {\n    assert(state.args === null);\n    state.args = args;\n    state.reverseArgs = args.map(function(arg) {\n      if (typeof arg !== 'object' || arg.constructor !== Object)\n        return arg;\n\n      var res = {};\n      Object.keys(arg).forEach(function(key) {\n        if (key == (key | 0))\n          key |= 0;\n        var value = arg[key];\n        res[value] = key;\n      });\n      return res;\n    });\n  }\n};\n\n//\n// Overrided methods\n//\n\noverrided.forEach(function(method) {\n  Node.prototype[method] = function _overrided() {\n    var state = this._baseState;\n    throw new Error(method + ' not implemented for encoding: ' + state.enc);\n  };\n});\n\n//\n// Public methods\n//\n\ntags.forEach(function(tag) {\n  Node.prototype[tag] = function _tagMethod() {\n    var state = this._baseState;\n    var args = Array.prototype.slice.call(arguments);\n\n    assert(state.tag === null);\n    state.tag = tag;\n\n    this._useArgs(args);\n\n    return this;\n  };\n});\n\nNode.prototype.use = function use(item) {\n  var state = this._baseState;\n\n  assert(state.use === null);\n  state.use = item;\n\n  return this;\n};\n\nNode.prototype.optional = function optional() {\n  var state = this._baseState;\n\n  state.optional = true;\n\n  return this;\n};\n\nNode.prototype.def = function def(val) {\n  var state = this._baseState;\n\n  assert(state['default'] === null);\n  state['default'] = val;\n  state.optional = true;\n\n  return this;\n};\n\nNode.prototype.explicit = function explicit(num) {\n  var state = this._baseState;\n\n  assert(state.explicit === null && state.implicit === null);\n  state.explicit = num;\n\n  return this;\n};\n\nNode.prototype.implicit = function implicit(num) {\n  var state = this._baseState;\n\n  assert(state.explicit === null && state.implicit === null);\n  state.implicit = num;\n\n  return this;\n};\n\nNode.prototype.obj = function obj() {\n  var state = this._baseState;\n  var args = Array.prototype.slice.call(arguments);\n\n  state.obj = true;\n\n  if (args.length !== 0)\n    this._useArgs(args);\n\n  return this;\n};\n\nNode.prototype.key = function key(newKey) {\n  var state = this._baseState;\n\n  assert(state.key === null);\n  state.key = newKey;\n\n  return this;\n};\n\nNode.prototype.any = function any() {\n  var state = this._baseState;\n\n  state.any = true;\n\n  return this;\n};\n\nNode.prototype.choice = function choice(obj) {\n  var state = this._baseState;\n\n  assert(state.choice === null);\n  state.choice = obj;\n  this._useArgs(Object.keys(obj).map(function(key) {\n    return obj[key];\n  }));\n\n  return this;\n};\n\nNode.prototype.contains = function contains(item) {\n  var state = this._baseState;\n\n  assert(state.use === null);\n  state.contains = item;\n\n  return this;\n};\n\n//\n// Decoding\n//\n\nNode.prototype._decode = function decode(input) {\n  var state = this._baseState;\n\n  // Decode root node\n  if (state.parent === null)\n    return input.wrapResult(state.children[0]._decode(input));\n\n  var result = state['default'];\n  var present = true;\n\n  var prevKey;\n  if (state.key !== null)\n    prevKey = input.enterKey(state.key);\n\n  // Check if tag is there\n  if (state.optional) {\n    var tag = null;\n    if (state.explicit !== null)\n      tag = state.explicit;\n    else if (state.implicit !== null)\n      tag = state.implicit;\n    else if (state.tag !== null)\n      tag = state.tag;\n\n    if (tag === null && !state.any) {\n      // Trial and Error\n      var save = input.save();\n      try {\n        if (state.choice === null)\n          this._decodeGeneric(state.tag, input);\n        else\n          this._decodeChoice(input);\n        present = true;\n      } catch (e) {\n        present = false;\n      }\n      input.restore(save);\n    } else {\n      present = this._peekTag(input, tag, state.any);\n\n      if (input.isError(present))\n        return present;\n    }\n  }\n\n  // Push object on stack\n  var prevObj;\n  if (state.obj && present)\n    prevObj = input.enterObject();\n\n  if (present) {\n    // Unwrap explicit values\n    if (state.explicit !== null) {\n      var explicit = this._decodeTag(input, state.explicit);\n      if (input.isError(explicit))\n        return explicit;\n      input = explicit;\n    }\n\n    // Unwrap implicit and normal values\n    if (state.use === null && state.choice === null) {\n      if (state.any)\n        var save = input.save();\n      var body = this._decodeTag(\n        input,\n        state.implicit !== null ? state.implicit : state.tag,\n        state.any\n      );\n      if (input.isError(body))\n        return body;\n\n      if (state.any)\n        result = input.raw(save);\n      else\n        input = body;\n    }\n\n    // Select proper method for tag\n    if (state.any)\n      result = result;\n    else if (state.choice === null)\n      result = this._decodeGeneric(state.tag, input);\n    else\n      result = this._decodeChoice(input);\n\n    if (input.isError(result))\n      return result;\n\n    // Decode children\n    if (!state.any && state.choice === null && state.children !== null) {\n      state.children.forEach(function decodeChildren(child) {\n        // NOTE: We are ignoring errors here, to let parser continue with other\n        // parts of encoded data\n        child._decode(input);\n      });\n    }\n\n    // Decode contained/encoded by schema, only in bit or octet strings\n    if (state.contains && (state.tag === 'octstr' || state.tag === 'bitstr')) {\n      var data = new DecoderBuffer(result);\n      result = this._getUse(state.contains, input._reporterState.obj)._decode(data);\n    }\n  }\n\n  // Pop object\n  if (state.obj && present)\n    result = input.leaveObject(prevObj);\n\n  // Set key\n  if (state.key !== null && (result !== null || present === true))\n    input.leaveKey(prevKey, state.key, result);\n\n  return result;\n};\n\nNode.prototype._decodeGeneric = function decodeGeneric(tag, input) {\n  var state = this._baseState;\n\n  if (tag === 'seq' || tag === 'set')\n    return null;\n  if (tag === 'seqof' || tag === 'setof')\n    return this._decodeList(input, tag, state.args[0]);\n  else if (/str$/.test(tag))\n    return this._decodeStr(input, tag);\n  else if (tag === 'objid' && state.args)\n    return this._decodeObjid(input, state.args[0], state.args[1]);\n  else if (tag === 'objid')\n    return this._decodeObjid(input, null, null);\n  else if (tag === 'gentime' || tag === 'utctime')\n    return this._decodeTime(input, tag);\n  else if (tag === 'null_')\n    return this._decodeNull(input);\n  else if (tag === 'bool')\n    return this._decodeBool(input);\n  else if (tag === 'int' || tag === 'enum')\n    return this._decodeInt(input, state.args && state.args[0]);\n  else if (state.use !== null)\n    return this._getUse(state.use, input._reporterState.obj)._decode(input);\n  else\n    return input.error('unknown tag: ' + tag);\n\n  return null;\n};\n\nNode.prototype._getUse = function _getUse(entity, obj) {\n\n  var state = this._baseState;\n  // Create altered use decoder if implicit is set\n  state.useDecoder = this._use(entity, obj);\n  assert(state.useDecoder._baseState.parent === null);\n  state.useDecoder = state.useDecoder._baseState.children[0];\n  if (state.implicit !== state.useDecoder._baseState.implicit) {\n    state.useDecoder = state.useDecoder.clone();\n    state.useDecoder._baseState.implicit = state.implicit;\n  }\n  return state.useDecoder;\n};\n\nNode.prototype._decodeChoice = function decodeChoice(input) {\n  var state = this._baseState;\n  var result = null;\n  var match = false;\n\n  Object.keys(state.choice).some(function(key) {\n    var save = input.save();\n    var node = state.choice[key];\n    try {\n      var value = node._decode(input);\n      if (input.isError(value))\n        return false;\n\n      result = { type: key, value: value };\n      match = true;\n    } catch (e) {\n      input.restore(save);\n      return false;\n    }\n    return true;\n  }, this);\n\n  if (!match)\n    return input.error('Choice not matched');\n\n  return result;\n};\n\n//\n// Encoding\n//\n\nNode.prototype._createEncoderBuffer = function createEncoderBuffer(data) {\n  return new EncoderBuffer(data, this.reporter);\n};\n\nNode.prototype._encode = function encode(data, reporter, parent) {\n  var state = this._baseState;\n  if (state['default'] !== null && state['default'] === data)\n    return;\n\n  var result = this._encodeValue(data, reporter, parent);\n  if (result === undefined)\n    return;\n\n  if (this._skipDefault(result, reporter, parent))\n    return;\n\n  return result;\n};\n\nNode.prototype._encodeValue = function encode(data, reporter, parent) {\n  var state = this._baseState;\n\n  // Decode root node\n  if (state.parent === null)\n    return state.children[0]._encode(data, reporter || new Reporter());\n\n  var result = null;\n  var present = true;\n\n  // Set reporter to share it with a child class\n  this.reporter = reporter;\n\n  // Check if data is there\n  if (state.optional && data === undefined) {\n    if (state['default'] !== null)\n      data = state['default']\n    else\n      return;\n  }\n\n  // For error reporting\n  var prevKey;\n\n  // Encode children first\n  var content = null;\n  var primitive = false;\n  if (state.any) {\n    // Anything that was given is translated to buffer\n    result = this._createEncoderBuffer(data);\n  } else if (state.choice) {\n    result = this._encodeChoice(data, reporter);\n  } else if (state.contains) {\n    content = this._getUse(state.contains, parent)._encode(data, reporter);\n    primitive = true;\n  } else if (state.children) {\n    content = state.children.map(function(child) {\n      if (child._baseState.tag === 'null_')\n        return child._encode(null, reporter, data);\n\n      if (child._baseState.key === null)\n        return reporter.error('Child should have a key');\n      var prevKey = reporter.enterKey(child._baseState.key);\n\n      if (typeof data !== 'object')\n        return reporter.error('Child expected, but input is not object');\n\n      var res = child._encode(data[child._baseState.key], reporter, data);\n      reporter.leaveKey(prevKey);\n\n      return res;\n    }, this).filter(function(child) {\n      return child;\n    });\n    content = this._createEncoderBuffer(content);\n  } else {\n    if (state.tag === 'seqof' || state.tag === 'setof') {\n      // TODO(indutny): this should be thrown on DSL level\n      if (!(state.args && state.args.length === 1))\n        return reporter.error('Too many args for : ' + state.tag);\n\n      if (!Array.isArray(data))\n        return reporter.error('seqof/setof, but data is not Array');\n\n      var child = this.clone();\n      child._baseState.implicit = null;\n      content = this._createEncoderBuffer(data.map(function(item) {\n        var state = this._baseState;\n\n        return this._getUse(state.args[0], data)._encode(item, reporter);\n      }, child));\n    } else if (state.use !== null) {\n      result = this._getUse(state.use, parent)._encode(data, reporter);\n    } else {\n      content = this._encodePrimitive(state.tag, data);\n      primitive = true;\n    }\n  }\n\n  // Encode data itself\n  var result;\n  if (!state.any && state.choice === null) {\n    var tag = state.implicit !== null ? state.implicit : state.tag;\n    var cls = state.implicit === null ? 'universal' : 'context';\n\n    if (tag === null) {\n      if (state.use === null)\n        reporter.error('Tag could be ommited only for .use()');\n    } else {\n      if (state.use === null)\n        result = this._encodeComposite(tag, primitive, cls, content);\n    }\n  }\n\n  // Wrap in explicit\n  if (state.explicit !== null)\n    result = this._encodeComposite(state.explicit, false, 'context', result);\n\n  return result;\n};\n\nNode.prototype._encodeChoice = function encodeChoice(data, reporter) {\n  var state = this._baseState;\n\n  var node = state.choice[data.type];\n  if (!node) {\n    assert(\n        false,\n        data.type + ' not found in ' +\n            JSON.stringify(Object.keys(state.choice)));\n  }\n  return node._encode(data.value, reporter);\n};\n\nNode.prototype._encodePrimitive = function encodePrimitive(tag, data) {\n  var state = this._baseState;\n\n  if (/str$/.test(tag))\n    return this._encodeStr(data, tag);\n  else if (tag === 'objid' && state.args)\n    return this._encodeObjid(data, state.reverseArgs[0], state.args[1]);\n  else if (tag === 'objid')\n    return this._encodeObjid(data, null, null);\n  else if (tag === 'gentime' || tag === 'utctime')\n    return this._encodeTime(data, tag);\n  else if (tag === 'null_')\n    return this._encodeNull();\n  else if (tag === 'int' || tag === 'enum')\n    return this._encodeInt(data, state.args && state.reverseArgs[0]);\n  else if (tag === 'bool')\n    return this._encodeBool(data);\n  else\n    throw new Error('Unsupported tag: ' + tag);\n};\n\nNode.prototype._isNumstr = function isNumstr(str) {\n  return /^[0-9 ]*$/.test(str);\n};\n\nNode.prototype._isPrintstr = function isPrintstr(str) {\n  return /^[A-Za-z0-9 '\\(\\)\\+,\\-\\.\\/:=\\?]*$/.test(str);\n};\n","var inherits = require('inherits');\n\nfunction Reporter(options) {\n  this._reporterState = {\n    obj: null,\n    path: [],\n    options: options || {},\n    errors: []\n  };\n}\nexports.Reporter = Reporter;\n\nReporter.prototype.isError = function isError(obj) {\n  return obj instanceof ReporterError;\n};\n\nReporter.prototype.save = function save() {\n  var state = this._reporterState;\n\n  return { obj: state.obj, pathLen: state.path.length };\n};\n\nReporter.prototype.restore = function restore(data) {\n  var state = this._reporterState;\n\n  state.obj = data.obj;\n  state.path = state.path.slice(0, data.pathLen);\n};\n\nReporter.prototype.enterKey = function enterKey(key) {\n  return this._reporterState.path.push(key);\n};\n\nReporter.prototype.leaveKey = function leaveKey(index, key, value) {\n  var state = this._reporterState;\n\n  state.path = state.path.slice(0, index - 1);\n  if (state.obj !== null)\n    state.obj[key] = value;\n};\n\nReporter.prototype.enterObject = function enterObject() {\n  var state = this._reporterState;\n\n  var prev = state.obj;\n  state.obj = {};\n  return prev;\n};\n\nReporter.prototype.leaveObject = function leaveObject(prev) {\n  var state = this._reporterState;\n\n  var now = state.obj;\n  state.obj = prev;\n  return now;\n};\n\nReporter.prototype.error = function error(msg) {\n  var err;\n  var state = this._reporterState;\n\n  var inherited = msg instanceof ReporterError;\n  if (inherited) {\n    err = msg;\n  } else {\n    err = new ReporterError(state.path.map(function(elem) {\n      return '[' + JSON.stringify(elem) + ']';\n    }).join(''), msg.message || msg, msg.stack);\n  }\n\n  if (!state.options.partial)\n    throw err;\n\n  if (!inherited)\n    state.errors.push(err);\n\n  return err;\n};\n\nReporter.prototype.wrapResult = function wrapResult(result) {\n  var state = this._reporterState;\n  if (!state.options.partial)\n    return result;\n\n  return {\n    result: this.isError(result) ? null : result,\n    errors: state.errors\n  };\n};\n\nfunction ReporterError(path, msg) {\n  this.path = path;\n  this.rethrow(msg);\n};\ninherits(ReporterError, Error);\n\nReporterError.prototype.rethrow = function rethrow(msg) {\n  this.message = msg + ' at: ' + (this.path || '(shallow)');\n  Error.captureStackTrace(this, ReporterError);\n\n  return this;\n};\n","var constants = require('../constants');\n\nexports.tagClass = {\n  0: 'universal',\n  1: 'application',\n  2: 'context',\n  3: 'private'\n};\nexports.tagClassByName = constants._reverse(exports.tagClass);\n\nexports.tag = {\n  0x00: 'end',\n  0x01: 'bool',\n  0x02: 'int',\n  0x03: 'bitstr',\n  0x04: 'octstr',\n  0x05: 'null_',\n  0x06: 'objid',\n  0x07: 'objDesc',\n  0x08: 'external',\n  0x09: 'real',\n  0x0a: 'enum',\n  0x0b: 'embed',\n  0x0c: 'utf8str',\n  0x0d: 'relativeOid',\n  0x10: 'seq',\n  0x11: 'set',\n  0x12: 'numstr',\n  0x13: 'printstr',\n  0x14: 't61str',\n  0x15: 'videostr',\n  0x16: 'ia5str',\n  0x17: 'utctime',\n  0x18: 'gentime',\n  0x19: 'graphstr',\n  0x1a: 'iso646str',\n  0x1b: 'genstr',\n  0x1c: 'unistr',\n  0x1d: 'charstr',\n  0x1e: 'bmpstr'\n};\nexports.tagByName = constants._reverse(exports.tag);\n","var constants = exports;\n\n// Helper\nconstants._reverse = function reverse(map) {\n  var res = {};\n\n  Object.keys(map).forEach(function(key) {\n    // Convert key to integer if it is stringified\n    if ((key | 0) == key)\n      key = key | 0;\n\n    var value = map[key];\n    res[value] = key;\n  });\n\n  return res;\n};\n\nconstants.der = require('./der');\n","var inherits = require('inherits');\n\nvar asn1 = require('../../asn1');\nvar base = asn1.base;\nvar bignum = asn1.bignum;\n\n// Import DER constants\nvar der = asn1.constants.der;\n\nfunction DERDecoder(entity) {\n  this.enc = 'der';\n  this.name = entity.name;\n  this.entity = entity;\n\n  // Construct base tree\n  this.tree = new DERNode();\n  this.tree._init(entity.body);\n};\nmodule.exports = DERDecoder;\n\nDERDecoder.prototype.decode = function decode(data, options) {\n  if (!(data instanceof base.DecoderBuffer))\n    data = new base.DecoderBuffer(data, options);\n\n  return this.tree._decode(data, options);\n};\n\n// Tree methods\n\nfunction DERNode(parent) {\n  base.Node.call(this, 'der', parent);\n}\ninherits(DERNode, base.Node);\n\nDERNode.prototype._peekTag = function peekTag(buffer, tag, any) {\n  if (buffer.isEmpty())\n    return false;\n\n  var state = buffer.save();\n  var decodedTag = derDecodeTag(buffer, 'Failed to peek tag: \"' + tag + '\"');\n  if (buffer.isError(decodedTag))\n    return decodedTag;\n\n  buffer.restore(state);\n\n  return decodedTag.tag === tag || decodedTag.tagStr === tag ||\n    (decodedTag.tagStr + 'of') === tag || any;\n};\n\nDERNode.prototype._decodeTag = function decodeTag(buffer, tag, any) {\n  var decodedTag = derDecodeTag(buffer,\n                                'Failed to decode tag of \"' + tag + '\"');\n  if (buffer.isError(decodedTag))\n    return decodedTag;\n\n  var len = derDecodeLen(buffer,\n                         decodedTag.primitive,\n                         'Failed to get length of \"' + tag + '\"');\n\n  // Failure\n  if (buffer.isError(len))\n    return len;\n\n  if (!any &&\n      decodedTag.tag !== tag &&\n      decodedTag.tagStr !== tag &&\n      decodedTag.tagStr + 'of' !== tag) {\n    return buffer.error('Failed to match tag: \"' + tag + '\"');\n  }\n\n  if (decodedTag.primitive || len !== null)\n    return buffer.skip(len, 'Failed to match body of: \"' + tag + '\"');\n\n  // Indefinite length... find END tag\n  var state = buffer.save();\n  var res = this._skipUntilEnd(\n      buffer,\n      'Failed to skip indefinite length body: \"' + this.tag + '\"');\n  if (buffer.isError(res))\n    return res;\n\n  len = buffer.offset - state.offset;\n  buffer.restore(state);\n  return buffer.skip(len, 'Failed to match body of: \"' + tag + '\"');\n};\n\nDERNode.prototype._skipUntilEnd = function skipUntilEnd(buffer, fail) {\n  while (true) {\n    var tag = derDecodeTag(buffer, fail);\n    if (buffer.isError(tag))\n      return tag;\n    var len = derDecodeLen(buffer, tag.primitive, fail);\n    if (buffer.isError(len))\n      return len;\n\n    var res;\n    if (tag.primitive || len !== null)\n      res = buffer.skip(len)\n    else\n      res = this._skipUntilEnd(buffer, fail);\n\n    // Failure\n    if (buffer.isError(res))\n      return res;\n\n    if (tag.tagStr === 'end')\n      break;\n  }\n};\n\nDERNode.prototype._decodeList = function decodeList(buffer, tag, decoder) {\n  var result = [];\n  while (!buffer.isEmpty()) {\n    var possibleEnd = this._peekTag(buffer, 'end');\n    if (buffer.isError(possibleEnd))\n      return possibleEnd;\n\n    var res = decoder.decode(buffer, 'der');\n    if (buffer.isError(res) && possibleEnd)\n      break;\n    result.push(res);\n  }\n  return result;\n};\n\nDERNode.prototype._decodeStr = function decodeStr(buffer, tag) {\n  if (tag === 'bitstr') {\n    var unused = buffer.readUInt8();\n    if (buffer.isError(unused))\n      return unused;\n    return { unused: unused, data: buffer.raw() };\n  } else if (tag === 'bmpstr') {\n    var raw = buffer.raw();\n    if (raw.length % 2 === 1)\n      return buffer.error('Decoding of string type: bmpstr length mismatch');\n\n    var str = '';\n    for (var i = 0; i < raw.length / 2; i++) {\n      str += String.fromCharCode(raw.readUInt16BE(i * 2));\n    }\n    return str;\n  } else if (tag === 'numstr') {\n    var numstr = buffer.raw().toString('ascii');\n    if (!this._isNumstr(numstr)) {\n      return buffer.error('Decoding of string type: ' +\n                          'numstr unsupported characters');\n    }\n    return numstr;\n  } else if (tag === 'octstr') {\n    return buffer.raw();\n  } else if (tag === 'printstr') {\n    var printstr = buffer.raw().toString('ascii');\n    if (!this._isPrintstr(printstr)) {\n      return buffer.error('Decoding of string type: ' +\n                          'printstr unsupported characters');\n    }\n    return printstr;\n  } else if (/str$/.test(tag)) {\n    return buffer.raw().toString();\n  } else {\n    return buffer.error('Decoding of string type: ' + tag + ' unsupported');\n  }\n};\n\nDERNode.prototype._decodeObjid = function decodeObjid(buffer, values, relative) {\n  var result;\n  var identifiers = [];\n  var ident = 0;\n  while (!buffer.isEmpty()) {\n    var subident = buffer.readUInt8();\n    ident <<= 7;\n    ident |= subident & 0x7f;\n    if ((subident & 0x80) === 0) {\n      identifiers.push(ident);\n      ident = 0;\n    }\n  }\n  if (subident & 0x80)\n    identifiers.push(ident);\n\n  var first = (identifiers[0] / 40) | 0;\n  var second = identifiers[0] % 40;\n\n  if (relative)\n    result = identifiers;\n  else\n    result = [first, second].concat(identifiers.slice(1));\n\n  if (values) {\n    var tmp = values[result.join(' ')];\n    if (tmp === undefined)\n      tmp = values[result.join('.')];\n    if (tmp !== undefined)\n      result = tmp;\n  }\n\n  return result;\n};\n\nDERNode.prototype._decodeTime = function decodeTime(buffer, tag) {\n  var str = buffer.raw().toString();\n  if (tag === 'gentime') {\n    var year = str.slice(0, 4) | 0;\n    var mon = str.slice(4, 6) | 0;\n    var day = str.slice(6, 8) | 0;\n    var hour = str.slice(8, 10) | 0;\n    var min = str.slice(10, 12) | 0;\n    var sec = str.slice(12, 14) | 0;\n  } else if (tag === 'utctime') {\n    var year = str.slice(0, 2) | 0;\n    var mon = str.slice(2, 4) | 0;\n    var day = str.slice(4, 6) | 0;\n    var hour = str.slice(6, 8) | 0;\n    var min = str.slice(8, 10) | 0;\n    var sec = str.slice(10, 12) | 0;\n    if (year < 70)\n      year = 2000 + year;\n    else\n      year = 1900 + year;\n  } else {\n    return buffer.error('Decoding ' + tag + ' time is not supported yet');\n  }\n\n  return Date.UTC(year, mon - 1, day, hour, min, sec, 0);\n};\n\nDERNode.prototype._decodeNull = function decodeNull(buffer) {\n  return null;\n};\n\nDERNode.prototype._decodeBool = function decodeBool(buffer) {\n  var res = buffer.readUInt8();\n  if (buffer.isError(res))\n    return res;\n  else\n    return res !== 0;\n};\n\nDERNode.prototype._decodeInt = function decodeInt(buffer, values) {\n  // Bigint, return as it is (assume big endian)\n  var raw = buffer.raw();\n  var res = new bignum(raw);\n\n  if (values)\n    res = values[res.toString(10)] || res;\n\n  return res;\n};\n\nDERNode.prototype._use = function use(entity, obj) {\n  if (typeof entity === 'function')\n    entity = entity(obj);\n  return entity._getDecoder('der').tree;\n};\n\n// Utility methods\n\nfunction derDecodeTag(buf, fail) {\n  var tag = buf.readUInt8(fail);\n  if (buf.isError(tag))\n    return tag;\n\n  var cls = der.tagClass[tag >> 6];\n  var primitive = (tag & 0x20) === 0;\n\n  // Multi-octet tag - load\n  if ((tag & 0x1f) === 0x1f) {\n    var oct = tag;\n    tag = 0;\n    while ((oct & 0x80) === 0x80) {\n      oct = buf.readUInt8(fail);\n      if (buf.isError(oct))\n        return oct;\n\n      tag <<= 7;\n      tag |= oct & 0x7f;\n    }\n  } else {\n    tag &= 0x1f;\n  }\n  var tagStr = der.tag[tag];\n\n  return {\n    cls: cls,\n    primitive: primitive,\n    tag: tag,\n    tagStr: tagStr\n  };\n}\n\nfunction derDecodeLen(buf, primitive, fail) {\n  var len = buf.readUInt8(fail);\n  if (buf.isError(len))\n    return len;\n\n  // Indefinite form\n  if (!primitive && len === 0x80)\n    return null;\n\n  // Definite form\n  if ((len & 0x80) === 0) {\n    // Short form\n    return len;\n  }\n\n  // Long form\n  var num = len & 0x7f;\n  if (num >= 4)\n    return buf.error('length octect is too long');\n\n  len = 0;\n  for (var i = 0; i < num; i++) {\n    len <<= 8;\n    var j = buf.readUInt8(fail);\n    if (buf.isError(j))\n      return j;\n    len |= j;\n  }\n\n  return len;\n}\n","var decoders = exports;\n\ndecoders.der = require('./der');\ndecoders.pem = require('./pem');\n","var inherits = require('inherits');\nvar Buffer = require('buffer').Buffer;\n\nvar asn1 = require('../../asn1');\nvar DERDecoder = require('./der');\n\nfunction PEMDecoder(entity) {\n  DERDecoder.call(this, entity);\n  this.enc = 'pem';\n};\ninherits(PEMDecoder, DERDecoder);\nmodule.exports = PEMDecoder;\n\nPEMDecoder.prototype.decode = function decode(data, options) {\n  var lines = data.toString().split(/[\\r\\n]+/g);\n\n  var label = options.label.toUpperCase();\n\n  var re = /^-----(BEGIN|END) ([^-]+)-----$/;\n  var start = -1;\n  var end = -1;\n  for (var i = 0; i < lines.length; i++) {\n    var match = lines[i].match(re);\n    if (match === null)\n      continue;\n\n    if (match[2] !== label)\n      continue;\n\n    if (start === -1) {\n      if (match[1] !== 'BEGIN')\n        break;\n      start = i;\n    } else {\n      if (match[1] !== 'END')\n        break;\n      end = i;\n      break;\n    }\n  }\n  if (start === -1 || end === -1)\n    throw new Error('PEM section not found for: ' + label);\n\n  var base64 = lines.slice(start + 1, end).join('');\n  // Remove excessive symbols\n  base64.replace(/[^a-z0-9\\+\\/=]+/gi, '');\n\n  var input = new Buffer(base64, 'base64');\n  return DERDecoder.prototype.decode.call(this, input, options);\n};\n","var inherits = require('inherits');\nvar Buffer = require('buffer').Buffer;\n\nvar asn1 = require('../../asn1');\nvar base = asn1.base;\nvar bignum = asn1.bignum;\n\n// Import DER constants\nvar der = asn1.constants.der;\n\nfunction DEREncoder(entity) {\n  this.enc = 'der';\n  this.name = entity.name;\n  this.entity = entity;\n\n  // Construct base tree\n  this.tree = new DERNode();\n  this.tree._init(entity.body);\n};\nmodule.exports = DEREncoder;\n\nDEREncoder.prototype.encode = function encode(data, reporter) {\n  return this.tree._encode(data, reporter).join();\n};\n\n// Tree methods\n\nfunction DERNode(parent) {\n  base.Node.call(this, 'der', parent);\n}\ninherits(DERNode, base.Node);\n\nDERNode.prototype._encodeComposite = function encodeComposite(tag,\n                                                              primitive,\n                                                              cls,\n                                                              content) {\n  var encodedTag = encodeTag(tag, primitive, cls, this.reporter);\n\n  // Short form\n  if (content.length < 0x80) {\n    var header = new Buffer(2);\n    header[0] = encodedTag;\n    header[1] = content.length;\n    return this._createEncoderBuffer([ header, content ]);\n  }\n\n  // Long form\n  // Count octets required to store length\n  var lenOctets = 1;\n  for (var i = content.length; i >= 0x100; i >>= 8)\n    lenOctets++;\n\n  var header = new Buffer(1 + 1 + lenOctets);\n  header[0] = encodedTag;\n  header[1] = 0x80 | lenOctets;\n\n  for (var i = 1 + lenOctets, j = content.length; j > 0; i--, j >>= 8)\n    header[i] = j & 0xff;\n\n  return this._createEncoderBuffer([ header, content ]);\n};\n\nDERNode.prototype._encodeStr = function encodeStr(str, tag) {\n  if (tag === 'bitstr') {\n    return this._createEncoderBuffer([ str.unused | 0, str.data ]);\n  } else if (tag === 'bmpstr') {\n    var buf = new Buffer(str.length * 2);\n    for (var i = 0; i < str.length; i++) {\n      buf.writeUInt16BE(str.charCodeAt(i), i * 2);\n    }\n    return this._createEncoderBuffer(buf);\n  } else if (tag === 'numstr') {\n    if (!this._isNumstr(str)) {\n      return this.reporter.error('Encoding of string type: numstr supports ' +\n                                 'only digits and space');\n    }\n    return this._createEncoderBuffer(str);\n  } else if (tag === 'printstr') {\n    if (!this._isPrintstr(str)) {\n      return this.reporter.error('Encoding of string type: printstr supports ' +\n                                 'only latin upper and lower case letters, ' +\n                                 'digits, space, apostrophe, left and rigth ' +\n                                 'parenthesis, plus sign, comma, hyphen, ' +\n                                 'dot, slash, colon, equal sign, ' +\n                                 'question mark');\n    }\n    return this._createEncoderBuffer(str);\n  } else if (/str$/.test(tag)) {\n    return this._createEncoderBuffer(str);\n  } else {\n    return this.reporter.error('Encoding of string type: ' + tag +\n                               ' unsupported');\n  }\n};\n\nDERNode.prototype._encodeObjid = function encodeObjid(id, values, relative) {\n  if (typeof id === 'string') {\n    if (!values)\n      return this.reporter.error('string objid given, but no values map found');\n    if (!values.hasOwnProperty(id))\n      return this.reporter.error('objid not found in values map');\n    id = values[id].split(/[\\s\\.]+/g);\n    for (var i = 0; i < id.length; i++)\n      id[i] |= 0;\n  } else if (Array.isArray(id)) {\n    id = id.slice();\n    for (var i = 0; i < id.length; i++)\n      id[i] |= 0;\n  }\n\n  if (!Array.isArray(id)) {\n    return this.reporter.error('objid() should be either array or string, ' +\n                               'got: ' + JSON.stringify(id));\n  }\n\n  if (!relative) {\n    if (id[1] >= 40)\n      return this.reporter.error('Second objid identifier OOB');\n    id.splice(0, 2, id[0] * 40 + id[1]);\n  }\n\n  // Count number of octets\n  var size = 0;\n  for (var i = 0; i < id.length; i++) {\n    var ident = id[i];\n    for (size++; ident >= 0x80; ident >>= 7)\n      size++;\n  }\n\n  var objid = new Buffer(size);\n  var offset = objid.length - 1;\n  for (var i = id.length - 1; i >= 0; i--) {\n    var ident = id[i];\n    objid[offset--] = ident & 0x7f;\n    while ((ident >>= 7) > 0)\n      objid[offset--] = 0x80 | (ident & 0x7f);\n  }\n\n  return this._createEncoderBuffer(objid);\n};\n\nfunction two(num) {\n  if (num < 10)\n    return '0' + num;\n  else\n    return num;\n}\n\nDERNode.prototype._encodeTime = function encodeTime(time, tag) {\n  var str;\n  var date = new Date(time);\n\n  if (tag === 'gentime') {\n    str = [\n      two(date.getFullYear()),\n      two(date.getUTCMonth() + 1),\n      two(date.getUTCDate()),\n      two(date.getUTCHours()),\n      two(date.getUTCMinutes()),\n      two(date.getUTCSeconds()),\n      'Z'\n    ].join('');\n  } else if (tag === 'utctime') {\n    str = [\n      two(date.getFullYear() % 100),\n      two(date.getUTCMonth() + 1),\n      two(date.getUTCDate()),\n      two(date.getUTCHours()),\n      two(date.getUTCMinutes()),\n      two(date.getUTCSeconds()),\n      'Z'\n    ].join('');\n  } else {\n    this.reporter.error('Encoding ' + tag + ' time is not supported yet');\n  }\n\n  return this._encodeStr(str, 'octstr');\n};\n\nDERNode.prototype._encodeNull = function encodeNull() {\n  return this._createEncoderBuffer('');\n};\n\nDERNode.prototype._encodeInt = function encodeInt(num, values) {\n  if (typeof num === 'string') {\n    if (!values)\n      return this.reporter.error('String int or enum given, but no values map');\n    if (!values.hasOwnProperty(num)) {\n      return this.reporter.error('Values map doesn\\'t contain: ' +\n                                 JSON.stringify(num));\n    }\n    num = values[num];\n  }\n\n  // Bignum, assume big endian\n  if (typeof num !== 'number' && !Buffer.isBuffer(num)) {\n    var numArray = num.toArray();\n    if (!num.sign && numArray[0] & 0x80) {\n      numArray.unshift(0);\n    }\n    num = new Buffer(numArray);\n  }\n\n  if (Buffer.isBuffer(num)) {\n    var size = num.length;\n    if (num.length === 0)\n      size++;\n\n    var out = new Buffer(size);\n    num.copy(out);\n    if (num.length === 0)\n      out[0] = 0\n    return this._createEncoderBuffer(out);\n  }\n\n  if (num < 0x80)\n    return this._createEncoderBuffer(num);\n\n  if (num < 0x100)\n    return this._createEncoderBuffer([0, num]);\n\n  var size = 1;\n  for (var i = num; i >= 0x100; i >>= 8)\n    size++;\n\n  var out = new Array(size);\n  for (var i = out.length - 1; i >= 0; i--) {\n    out[i] = num & 0xff;\n    num >>= 8;\n  }\n  if(out[0] & 0x80) {\n    out.unshift(0);\n  }\n\n  return this._createEncoderBuffer(new Buffer(out));\n};\n\nDERNode.prototype._encodeBool = function encodeBool(value) {\n  return this._createEncoderBuffer(value ? 0xff : 0);\n};\n\nDERNode.prototype._use = function use(entity, obj) {\n  if (typeof entity === 'function')\n    entity = entity(obj);\n  return entity._getEncoder('der').tree;\n};\n\nDERNode.prototype._skipDefault = function skipDefault(dataBuffer, reporter, parent) {\n  var state = this._baseState;\n  var i;\n  if (state['default'] === null)\n    return false;\n\n  var data = dataBuffer.join();\n  if (state.defaultBuffer === undefined)\n    state.defaultBuffer = this._encodeValue(state['default'], reporter, parent).join();\n\n  if (data.length !== state.defaultBuffer.length)\n    return false;\n\n  for (i=0; i < data.length; i++)\n    if (data[i] !== state.defaultBuffer[i])\n      return false;\n\n  return true;\n};\n\n// Utility methods\n\nfunction encodeTag(tag, primitive, cls, reporter) {\n  var res;\n\n  if (tag === 'seqof')\n    tag = 'seq';\n  else if (tag === 'setof')\n    tag = 'set';\n\n  if (der.tagByName.hasOwnProperty(tag))\n    res = der.tagByName[tag];\n  else if (typeof tag === 'number' && (tag | 0) === tag)\n    res = tag;\n  else\n    return reporter.error('Unknown tag: ' + tag);\n\n  if (res >= 0x1f)\n    return reporter.error('Multi-octet tag encoding unsupported');\n\n  if (!primitive)\n    res |= 0x20;\n\n  res |= (der.tagClassByName[cls || 'universal'] << 6);\n\n  return res;\n}\n","var encoders = exports;\n\nencoders.der = require('./der');\nencoders.pem = require('./pem');\n","var inherits = require('inherits');\nvar Buffer = require('buffer').Buffer;\n\nvar asn1 = require('../../asn1');\nvar DEREncoder = require('./der');\n\nfunction PEMEncoder(entity) {\n  DEREncoder.call(this, entity);\n  this.enc = 'pem';\n};\ninherits(PEMEncoder, DEREncoder);\nmodule.exports = PEMEncoder;\n\nPEMEncoder.prototype.encode = function encode(data, options) {\n  var buf = DEREncoder.prototype.encode.call(this, data);\n\n  var p = buf.toString('base64');\n  var out = [ '-----BEGIN ' + options.label + '-----' ];\n  for (var i = 0; i < p.length; i += 64)\n    out.push(p.slice(i, i + 64));\n  out.push('-----END ' + options.label + '-----');\n  return out.join('\\n');\n};\n","// http://wiki.commonjs.org/wiki/Unit_Testing/1.0\n//\n// THIS IS NOT TESTED NOR LIKELY TO WORK OUTSIDE V8!\n//\n// Originally from narwhal.js (http://narwhaljs.org)\n// Copyright (c) 2009 Thomas Robinson <280north.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the 'Software'), to\n// deal in the Software without restriction, including without limitation the\n// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n// sell copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN\n// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION\n// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// when used in node, this will actually load the util module we depend on\n// versus loading the builtin util module as happens otherwise\n// this is a bug in node module loading as far as I am concerned\nvar util = require('util/');\n\nvar pSlice = Array.prototype.slice;\nvar hasOwn = Object.prototype.hasOwnProperty;\n\n// 1. The assert module provides functions that throw\n// AssertionError's when particular conditions are not met. The\n// assert module must conform to the following interface.\n\nvar assert = module.exports = ok;\n\n// 2. The AssertionError is defined in assert.\n// new assert.AssertionError({ message: message,\n//                             actual: actual,\n//                             expected: expected })\n\nassert.AssertionError = function AssertionError(options) {\n  this.name = 'AssertionError';\n  this.actual = options.actual;\n  this.expected = options.expected;\n  this.operator = options.operator;\n  if (options.message) {\n    this.message = options.message;\n    this.generatedMessage = false;\n  } else {\n    this.message = getMessage(this);\n    this.generatedMessage = true;\n  }\n  var stackStartFunction = options.stackStartFunction || fail;\n\n  if (Error.captureStackTrace) {\n    Error.captureStackTrace(this, stackStartFunction);\n  }\n  else {\n    // non v8 browsers so we can have a stacktrace\n    var err = new Error();\n    if (err.stack) {\n      var out = err.stack;\n\n      // try to strip useless frames\n      var fn_name = stackStartFunction.name;\n      var idx = out.indexOf('\\n' + fn_name);\n      if (idx >= 0) {\n        // once we have located the function frame\n        // we need to strip out everything before it (and its line)\n        var next_line = out.indexOf('\\n', idx + 1);\n        out = out.substring(next_line + 1);\n      }\n\n      this.stack = out;\n    }\n  }\n};\n\n// assert.AssertionError instanceof Error\nutil.inherits(assert.AssertionError, Error);\n\nfunction replacer(key, value) {\n  if (util.isUndefined(value)) {\n    return '' + value;\n  }\n  if (util.isNumber(value) && !isFinite(value)) {\n    return value.toString();\n  }\n  if (util.isFunction(value) || util.isRegExp(value)) {\n    return value.toString();\n  }\n  return value;\n}\n\nfunction truncate(s, n) {\n  if (util.isString(s)) {\n    return s.length < n ? s : s.slice(0, n);\n  } else {\n    return s;\n  }\n}\n\nfunction getMessage(self) {\n  return truncate(JSON.stringify(self.actual, replacer), 128) + ' ' +\n         self.operator + ' ' +\n         truncate(JSON.stringify(self.expected, replacer), 128);\n}\n\n// At present only the three keys mentioned above are used and\n// understood by the spec. Implementations or sub modules can pass\n// other keys to the AssertionError's constructor - they will be\n// ignored.\n\n// 3. All of the following functions must throw an AssertionError\n// when a corresponding condition is not met, with a message that\n// may be undefined if not provided.  All assertion methods provide\n// both the actual and expected values to the assertion error for\n// display purposes.\n\nfunction fail(actual, expected, message, operator, stackStartFunction) {\n  throw new assert.AssertionError({\n    message: message,\n    actual: actual,\n    expected: expected,\n    operator: operator,\n    stackStartFunction: stackStartFunction\n  });\n}\n\n// EXTENSION! allows for well behaved errors defined elsewhere.\nassert.fail = fail;\n\n// 4. Pure assertion tests whether a value is truthy, as determined\n// by !!guard.\n// assert.ok(guard, message_opt);\n// This statement is equivalent to assert.equal(true, !!guard,\n// message_opt);. To test strictly for the value true, use\n// assert.strictEqual(true, guard, message_opt);.\n\nfunction ok(value, message) {\n  if (!value) fail(value, true, message, '==', assert.ok);\n}\nassert.ok = ok;\n\n// 5. The equality assertion tests shallow, coercive equality with\n// ==.\n// assert.equal(actual, expected, message_opt);\n\nassert.equal = function equal(actual, expected, message) {\n  if (actual != expected) fail(actual, expected, message, '==', assert.equal);\n};\n\n// 6. The non-equality assertion tests for whether two objects are not equal\n// with != assert.notEqual(actual, expected, message_opt);\n\nassert.notEqual = function notEqual(actual, expected, message) {\n  if (actual == expected) {\n    fail(actual, expected, message, '!=', assert.notEqual);\n  }\n};\n\n// 7. The equivalence assertion tests a deep equality relation.\n// assert.deepEqual(actual, expected, message_opt);\n\nassert.deepEqual = function deepEqual(actual, expected, message) {\n  if (!_deepEqual(actual, expected)) {\n    fail(actual, expected, message, 'deepEqual', assert.deepEqual);\n  }\n};\n\nfunction _deepEqual(actual, expected) {\n  // 7.1. All identical values are equivalent, as determined by ===.\n  if (actual === expected) {\n    return true;\n\n  } else if (util.isBuffer(actual) && util.isBuffer(expected)) {\n    if (actual.length != expected.length) return false;\n\n    for (var i = 0; i < actual.length; i++) {\n      if (actual[i] !== expected[i]) return false;\n    }\n\n    return true;\n\n  // 7.2. If the expected value is a Date object, the actual value is\n  // equivalent if it is also a Date object that refers to the same time.\n  } else if (util.isDate(actual) && util.isDate(expected)) {\n    return actual.getTime() === expected.getTime();\n\n  // 7.3 If the expected value is a RegExp object, the actual value is\n  // equivalent if it is also a RegExp object with the same source and\n  // properties (`global`, `multiline`, `lastIndex`, `ignoreCase`).\n  } else if (util.isRegExp(actual) && util.isRegExp(expected)) {\n    return actual.source === expected.source &&\n           actual.global === expected.global &&\n           actual.multiline === expected.multiline &&\n           actual.lastIndex === expected.lastIndex &&\n           actual.ignoreCase === expected.ignoreCase;\n\n  // 7.4. Other pairs that do not both pass typeof value == 'object',\n  // equivalence is determined by ==.\n  } else if (!util.isObject(actual) && !util.isObject(expected)) {\n    return actual == expected;\n\n  // 7.5 For all other Object pairs, including Array objects, equivalence is\n  // determined by having the same number of owned properties (as verified\n  // with Object.prototype.hasOwnProperty.call), the same set of keys\n  // (although not necessarily the same order), equivalent values for every\n  // corresponding key, and an identical 'prototype' property. Note: this\n  // accounts for both named and indexed properties on Arrays.\n  } else {\n    return objEquiv(actual, expected);\n  }\n}\n\nfunction isArguments(object) {\n  return Object.prototype.toString.call(object) == '[object Arguments]';\n}\n\nfunction objEquiv(a, b) {\n  if (util.isNullOrUndefined(a) || util.isNullOrUndefined(b))\n    return false;\n  // an identical 'prototype' property.\n  if (a.prototype !== b.prototype) return false;\n  // if one is a primitive, the other must be same\n  if (util.isPrimitive(a) || util.isPrimitive(b)) {\n    return a === b;\n  }\n  var aIsArgs = isArguments(a),\n      bIsArgs = isArguments(b);\n  if ((aIsArgs && !bIsArgs) || (!aIsArgs && bIsArgs))\n    return false;\n  if (aIsArgs) {\n    a = pSlice.call(a);\n    b = pSlice.call(b);\n    return _deepEqual(a, b);\n  }\n  var ka = objectKeys(a),\n      kb = objectKeys(b),\n      key, i;\n  // having the same number of owned properties (keys incorporates\n  // hasOwnProperty)\n  if (ka.length != kb.length)\n    return false;\n  //the same set of keys (although not necessarily the same order),\n  ka.sort();\n  kb.sort();\n  //~~~cheap key test\n  for (i = ka.length - 1; i >= 0; i--) {\n    if (ka[i] != kb[i])\n      return false;\n  }\n  //equivalent values for every corresponding key, and\n  //~~~possibly expensive deep test\n  for (i = ka.length - 1; i >= 0; i--) {\n    key = ka[i];\n    if (!_deepEqual(a[key], b[key])) return false;\n  }\n  return true;\n}\n\n// 8. The non-equivalence assertion tests for any deep inequality.\n// assert.notDeepEqual(actual, expected, message_opt);\n\nassert.notDeepEqual = function notDeepEqual(actual, expected, message) {\n  if (_deepEqual(actual, expected)) {\n    fail(actual, expected, message, 'notDeepEqual', assert.notDeepEqual);\n  }\n};\n\n// 9. The strict equality assertion tests strict equality, as determined by ===.\n// assert.strictEqual(actual, expected, message_opt);\n\nassert.strictEqual = function strictEqual(actual, expected, message) {\n  if (actual !== expected) {\n    fail(actual, expected, message, '===', assert.strictEqual);\n  }\n};\n\n// 10. The strict non-equality assertion tests for strict inequality, as\n// determined by !==.  assert.notStrictEqual(actual, expected, message_opt);\n\nassert.notStrictEqual = function notStrictEqual(actual, expected, message) {\n  if (actual === expected) {\n    fail(actual, expected, message, '!==', assert.notStrictEqual);\n  }\n};\n\nfunction expectedException(actual, expected) {\n  if (!actual || !expected) {\n    return false;\n  }\n\n  if (Object.prototype.toString.call(expected) == '[object RegExp]') {\n    return expected.test(actual);\n  } else if (actual instanceof expected) {\n    return true;\n  } else if (expected.call({}, actual) === true) {\n    return true;\n  }\n\n  return false;\n}\n\nfunction _throws(shouldThrow, block, expected, message) {\n  var actual;\n\n  if (util.isString(expected)) {\n    message = expected;\n    expected = null;\n  }\n\n  try {\n    block();\n  } catch (e) {\n    actual = e;\n  }\n\n  message = (expected && expected.name ? ' (' + expected.name + ').' : '.') +\n            (message ? ' ' + message : '.');\n\n  if (shouldThrow && !actual) {\n    fail(actual, expected, 'Missing expected exception' + message);\n  }\n\n  if (!shouldThrow && expectedException(actual, expected)) {\n    fail(actual, expected, 'Got unwanted exception' + message);\n  }\n\n  if ((shouldThrow && actual && expected &&\n      !expectedException(actual, expected)) || (!shouldThrow && actual)) {\n    throw actual;\n  }\n}\n\n// 11. Expected to throw an error:\n// assert.throws(block, Error_opt, message_opt);\n\nassert.throws = function(block, /*optional*/error, /*optional*/message) {\n  _throws.apply(this, [true].concat(pSlice.call(arguments)));\n};\n\n// EXTENSION! This is annoying to write outside this module.\nassert.doesNotThrow = function(block, /*optional*/message) {\n  _throws.apply(this, [false].concat(pSlice.call(arguments)));\n};\n\nassert.ifError = function(err) { if (err) {throw err;}};\n\nvar objectKeys = Object.keys || function (obj) {\n  var keys = [];\n  for (var key in obj) {\n    if (hasOwn.call(obj, key)) keys.push(key);\n  }\n  return keys;\n};\n","/**\n * @author Titus Wormer\n * @copyright 2015 Titus Wormer\n * @license MIT\n * @module attach-ware\n * @fileoverview Middleware with configuration.\n * @example\n *   var ware = require('attach-ware')(require('ware'));\n *\n *   var middleware = ware()\n *     .use(function (context, options) {\n *         if (!options.condition) return;\n *\n *         return function (req, res, next) {\n *           res.x = 'hello';\n *           next();\n *         };\n *     }, {\n *         'condition': true\n *     })\n *     .use(function (context, options) {\n *         if (!options.condition) return;\n *\n *         return function (req, res, next) {\n *           res.y = 'world';\n *           next();\n *         };\n *     }, {\n *         'condition': false\n *     });\n *\n *   middleware.run({}, {}, function (err, req, res) {\n *     res.x; // \"hello\"\n *     res.y; // undefined\n *   });\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\nvar slice = [].slice;\nvar unherit = require('unherit');\n\n/**\n * Clone `Ware` without affecting the super-class and\n * turn it into configurable middleware.\n *\n * @param {Function} Ware - Ware-like constructor.\n * @return {Function} AttachWare - Configurable middleware.\n */\nfunction patch(Ware) {\n    /*\n     * Methods.\n     */\n\n    var useFn = Ware.prototype.use;\n\n    /**\n     * @constructor\n     * @class {AttachWare}\n     */\n    var AttachWare = unherit(Ware);\n\n    AttachWare.prototype.foo = true;\n\n    /**\n     * Attach configurable middleware.\n     *\n     * @memberof {AttachWare}\n     * @this {AttachWare}\n     * @param {Function} attach - Attacher.\n     * @return {AttachWare} - `this`.\n     */\n    function use(attach) {\n        var self = this;\n        var params = slice.call(arguments, 1);\n        var index;\n        var length;\n        var fn;\n\n        /*\n         * Accept other `AttachWare`.\n         */\n\n        if (attach instanceof AttachWare) {\n            if (attach.attachers) {\n                return self.use(attach.attachers);\n            }\n\n            return self;\n        }\n\n        /*\n         * Accept normal ware.\n         */\n\n        if (attach instanceof Ware) {\n            self.fns = self.fns.concat(attach.fns);\n            return self;\n        }\n\n        /*\n         * Multiple attachers.\n         */\n\n        if ('length' in attach && typeof attach !== 'function') {\n            index = -1;\n            length = attach.length;\n\n            while (++index < length) {\n                self.use.apply(self, [attach[index]].concat(params));\n            }\n\n            return self;\n        }\n\n        /*\n         * Single attacher.\n         */\n\n        fn = attach.apply(null, [self.context || self].concat(params));\n\n        /*\n         * Store the attacher to not break `new Ware(otherWare)`\n         * functionality.\n         */\n\n        if (!self.attachers) {\n            self.attachers = [];\n        }\n\n        self.attachers.push(attach);\n\n        /*\n         * Pass `fn` to the original `Ware#use()`.\n         */\n\n        if (fn) {\n            useFn.call(self, fn);\n        }\n\n        return self;\n    }\n\n    AttachWare.prototype.use = use;\n\n    return function (fn) {\n        return new AttachWare(fn);\n    };\n}\n\nmodule.exports = patch;\n","/**\n * @author Titus Wormer\n * @copyright 2015 Titus Wormer. All rights reserved.\n * @module bail\n * @fileoverview Throw a given error.\n */\n\n'use strict';\n\n/**\n * Throw a given error.\n *\n * @example\n *   bail();\n *\n * @example\n *   bail(new Error('failure'));\n *   // Error: failure\n *   //     at repl:1:6\n *   //     at REPLServer.defaultEval (repl.js:154:27)\n *   //     ...\n *\n * @param {Error?} [err] - Optional error.\n * @throws {Error} - `err`, when given.\n */\nfunction bail(err) {\n    if (err) {\n        throw err;\n    }\n}\n\n/*\n * Expose.\n */\n\nmodule.exports = bail;\n","module.exports = balanced;\nfunction balanced(a, b, str) {\n  var r = range(a, b, str);\n\n  return r && {\n    start: r[0],\n    end: r[1],\n    pre: str.slice(0, r[0]),\n    body: str.slice(r[0] + a.length, r[1]),\n    post: str.slice(r[1] + b.length)\n  };\n}\n\nbalanced.range = range;\nfunction range(a, b, str) {\n  var begs, beg, left, right, result;\n  var ai = str.indexOf(a);\n  var bi = str.indexOf(b, ai + 1);\n  var i = ai;\n\n  if (ai >= 0 && bi > 0) {\n    begs = [];\n    left = str.length;\n\n    while (i < str.length && i >= 0 && ! result) {\n      if (i == ai) {\n        begs.push(i);\n        ai = str.indexOf(a, i + 1);\n      } else if (begs.length == 1) {\n        result = [ begs.pop(), bi ];\n      } else {\n        beg = begs.pop();\n        if (beg < left) {\n          left = beg;\n          right = bi;\n        }\n\n        bi = str.indexOf(b, i + 1);\n      }\n\n      i = ai < bi && ai >= 0 ? ai : bi;\n    }\n\n    if (begs.length) {\n      result = [ left, right ];\n    }\n  }\n\n  return result;\n}\n","var bash_codes = exports.bash_codes = {\n\t\"BLACK\" : {\n\t\t\"text\" : \"\\033[0;30m\",\n\t\t\"underline\": \"\\033[4;30m\",\n\t\t\"background\": \"\\033[40m\",\n\t\t\"bold\":\"\\033[1;30m\",\n\t\t\"hi_text\":\"\\033[0;90m\",\n\t\t\"hi_bold\" : \"\\033[1;90m\",\n\t\t\"hi_background\" : \"\\033[0;100m\"\n\t},\n\t\"RED\" : {\n\t\t\"text\" : \"\\033[0;31m\",\n\t\t\"bold\":\"\\033[1;31m\",\n\t\t\"underline\": \"\\033[4;31m\",\n\t\t\"background\": \"\\033[41m\",\n\t\t\"hi_text\":\"\\033[0;91m\",\n\t\t\"hi_bold\" : \"\\033[1;91m\",\n\t\t\"hi_background\" : \"\\033[0;101m\"\n\t},\n\t\"GREEN\" : {\n\t\t\"text\" : \"\\033[0;32m\",\n\t\t\"bold\":\"\\033[1;32m\",\n\t\t\"underline\": \"\\033[4;32m\",\n\t\t\"background\": \"\\033[42m\",\n\t\t\"hi_text\":\"\\033[0;92m\",\n\t\t\"hi_bold\" : \"\\033[1;92m\",\n\t\t\"hi_background\" : \"\\033[0;102m\"\n\t},\n\t\"YELLOW\" : {\n\t\t\"text\" : \"\\033[0;33m\",\n\t\t\"bold\":\"\\033[1;33m\",\n\t\t\"underline\": \"\\033[4;33m\",\n\t\t\"background\": \"\\033[43m\",\n\t\t\"hi_text\":\"\\033[0;93m\",\n\t\t\"hi_bold\" : \"\\033[1;93m\",\n\t\t\"hi_background\" : \"\\033[0;103m\"\n\t},\n\t\"BLUE\" : {\n\t\t\"text\" : \"\\033[0;34m\",\n\t\t\"bold\":\"\\033[1;34m\",\n\t\t\"underline\": \"\\033[4;34m\",\n\t\t\"background\": \"\\033[44m\",\n\t\t\"hi_text\":\"\\033[0;94m\",\n\t\t\"hi_bold\" : \"\\033[1;94m\",\n\t\t\"hi_background\" : \"\\033[0;104m\"\n\t},\n\t\"PURPLE\" : {\n\t\t\"text\" : \"\\033[0;35m\",\n\t\t\"bold\":\"\\033[1;35m\",\n\t\t\"underline\": \"\\033[4;35m\",\n\t\t\"background\": \"\\033[45m\",\n\t\t\"hi_text\":\"\\033[0;95m\",\n\t\t\"hi_bold\" : \"\\033[1;95m\",\n\t\t\"hi_background\" : \"\\033[0;105m\"\n\t},\n\t\"CYAN\" : {\n\t\t\"text\" : \"\\033[0;36m\",\n\t\t\"bold\":\"\\033[1;36m\",\n\t\t\"underline\": \"\\033[4;36m\",\n\t\t\"background\": \"\\033[46m\",\n\t\t\"hi_text\":\"\\033[0;96m\",\n\t\t\"hi_bold\" : \"\\033[1;96m\",\n\t\t\"hi_background\" : \"\\033[0;106m\"\n\t},\n\t\"WHITE\" : {\n\t\t\"text\" : \"\\033[0;37m\",\n\t\t\"bold\":\"\\033[1;37m\",\n\t\t\"underline\": \"\\033[4;37m\",\n\t\t\"background\": \"\\033[47m\",\n\t\t\"hi_text\":\"\\033[0;97m\",\n\t\t\"hi_bold\" : \"\\033[1;97m\",\n\t\t\"hi_background\" : \"\\033[0;107m\"\n\t}\n};\n\nexports.colors = {\n\tBLACK: \"BLACK\",\n\tRED: \"RED\",\n\tGREEN: \"GREEN\",\n\tYELLOW: \"YELLOW\",\n\tBLUE: \"BLUE\",\n\tPURPLE: \"PURPLE\",\n\tCYAN: \"CYAN\",\n\tWHITE: \"WHITE\"\n};\n\nvar styles = exports.styles = {\n\tbold: \"bold\",\n\tunderline: \"underline\",\n\tbackground: \"background\",\n\thi_text: \"hi_text\",\n\thi_bold: \"hi_bold\",\n\thi_background: \"hi_background\"\n};\n\nvar REMOVE_COLOR = exports.REMOVE_COLOR = \"\\033[0m\";\n\n\n// various logical inconsistencies in the code below - renderColor and wrap seem like they should be combined, but I'm letting wrap basically stand on its own\n// in case anyone wants access to explicitly handle background or underline stuff. I feel like those are a bit more special-casey, and generally speakign\n// users are going to want to quickly turn a word or phrase into a single color without worrying about background or underline. So the .colorName methods\n// are just syntactic sugar.\nexports.wrap = function(str, color, style) {\n\tvar c = bash_codes[color.toUpperCase()];\n\tvar s = styles[style] || \"text\";\n\t\n\treturn render(c[s], str);\n};\n\nexports.black = function(str, hi) {\n\treturn renderColor(str, bash_codes.BLACK, hi);\n};\n\nexports.red = function(str, hi) {\n\treturn renderColor(str, bash_codes.RED, hi);\n};\n\nexports.green = function(str, hi) {\n\treturn renderColor(str, bash_codes.GREEN, hi);\n};\n\nexports.yellow = function(str, hi) {\n\treturn renderColor(str, bash_codes.YELLOW, hi);\n};\n\nexports.blue = function(str, hi) {\n\treturn renderColor(str, bash_codes.BLUE, hi);\n};\n\nexports.purple = function(str, hi) {\n\treturn renderColor(str, bash_codes.PURPLE, hi);\n};\n\nexports.cyan = function(str, hi) {\n\treturn renderColor(str, bash_codes.CYAN, hi);\n};\n\nexports.white = function(str, hi) {\n\treturn renderColor(str, bash_codes.WHITE, hi);\n};\n\n\nfunction renderColor(str, color, hi) {\n\treturn render(hi ? color.hi_text : color.text, str);\n}\n\nfunction render(code, str) {\n\treturn code + str + REMOVE_COLOR;\n}","module.exports = function(haystack, needle, comparator, low, high) {\n  var mid, cmp;\n\n  if(low === undefined)\n    low = 0;\n\n  else {\n    low = low|0;\n    if(low < 0 || low >= haystack.length)\n      throw new RangeError(\"invalid lower bound\");\n  }\n\n  if(high === undefined)\n    high = haystack.length - 1;\n\n  else {\n    high = high|0;\n    if(high < low || high >= haystack.length)\n      throw new RangeError(\"invalid upper bound\");\n  }\n\n  while(low <= high) {\n    /* Note that \"(low + high) >>> 1\" may overflow, and results in a typecast\n     * to double (which gives the wrong results). */\n    mid = low + (high - low >> 1);\n    cmp = +comparator(haystack[mid], needle);\n\n    /* Too low. */\n    if(cmp < 0.0) \n      low  = mid + 1;\n\n    /* Too high. */\n    else if(cmp > 0.0)\n      high = mid - 1;\n    \n    /* Key found. */\n    else\n      return mid;\n  }\n\n  /* Key not found. */\n  return ~low;\n}\n","\n/**\n * Module dependencies.\n */\n\nvar fs = require('fs')\n  , path = require('path')\n  , join = path.join\n  , dirname = path.dirname\n  , exists = fs.existsSync || path.existsSync\n  , defaults = {\n        arrow: process.env.NODE_BINDINGS_ARROW || ' → '\n      , compiled: process.env.NODE_BINDINGS_COMPILED_DIR || 'compiled'\n      , platform: process.platform\n      , arch: process.arch\n      , version: process.versions.node\n      , bindings: 'bindings.node'\n      , try: [\n          // node-gyp's linked version in the \"build\" dir\n          [ 'module_root', 'build', 'bindings' ]\n          // node-waf and gyp_addon (a.k.a node-gyp)\n        , [ 'module_root', 'build', 'Debug', 'bindings' ]\n        , [ 'module_root', 'build', 'Release', 'bindings' ]\n          // Debug files, for development (legacy behavior, remove for node v0.9)\n        , [ 'module_root', 'out', 'Debug', 'bindings' ]\n        , [ 'module_root', 'Debug', 'bindings' ]\n          // Release files, but manually compiled (legacy behavior, remove for node v0.9)\n        , [ 'module_root', 'out', 'Release', 'bindings' ]\n        , [ 'module_root', 'Release', 'bindings' ]\n          // Legacy from node-waf, node <= 0.4.x\n        , [ 'module_root', 'build', 'default', 'bindings' ]\n          // Production \"Release\" buildtype binary (meh...)\n        , [ 'module_root', 'compiled', 'version', 'platform', 'arch', 'bindings' ]\n        ]\n    }\n\n/**\n * The main `bindings()` function loads the compiled bindings for a given module.\n * It uses V8's Error API to determine the parent filename that this function is\n * being invoked from, which is then used to find the root directory.\n */\n\nfunction bindings (opts) {\n\n  // Argument surgery\n  if (typeof opts == 'string') {\n    opts = { bindings: opts }\n  } else if (!opts) {\n    opts = {}\n  }\n  opts.__proto__ = defaults\n\n  // Get the module root\n  if (!opts.module_root) {\n    opts.module_root = exports.getRoot(exports.getFileName())\n  }\n\n  // Ensure the given bindings name ends with .node\n  if (path.extname(opts.bindings) != '.node') {\n    opts.bindings += '.node'\n  }\n\n  var tries = []\n    , i = 0\n    , l = opts.try.length\n    , n\n    , b\n    , err\n\n  for (; i<l; i++) {\n    n = join.apply(null, opts.try[i].map(function (p) {\n      return opts[p] || p\n    }))\n    tries.push(n)\n    try {\n      b = opts.path ? require.resolve(n) : require(n)\n      if (!opts.path) {\n        b.path = n\n      }\n      return b\n    } catch (e) {\n      if (!/not find/i.test(e.message)) {\n        throw e\n      }\n    }\n  }\n\n  err = new Error('Could not locate the bindings file. Tried:\\n'\n    + tries.map(function (a) { return opts.arrow + a }).join('\\n'))\n  err.tries = tries\n  throw err\n}\nmodule.exports = exports = bindings\n\n\n/**\n * Gets the filename of the JavaScript file that invokes this function.\n * Used to help find the root directory of a module.\n * Optionally accepts an filename argument to skip when searching for the invoking filename\n */\n\nexports.getFileName = function getFileName (calling_file) {\n  var origPST = Error.prepareStackTrace\n    , origSTL = Error.stackTraceLimit\n    , dummy = {}\n    , fileName\n\n  Error.stackTraceLimit = 10\n\n  Error.prepareStackTrace = function (e, st) {\n    for (var i=0, l=st.length; i<l; i++) {\n      fileName = st[i].getFileName()\n      if (fileName !== __filename) {\n        if (calling_file) {\n            if (fileName !== calling_file) {\n              return\n            }\n        } else {\n          return\n        }\n      }\n    }\n  }\n\n  // run the 'prepareStackTrace' function above\n  Error.captureStackTrace(dummy)\n  dummy.stack\n\n  // cleanup\n  Error.prepareStackTrace = origPST\n  Error.stackTraceLimit = origSTL\n\n  return fileName\n}\n\n/**\n * Gets the root directory of a module, given an arbitrary filename\n * somewhere in the module tree. The \"root directory\" is the directory\n * containing the `package.json` file.\n *\n *   In:  /home/nate/node-native-module/lib/index.js\n *   Out: /home/nate/node-native-module\n */\n\nexports.getRoot = function getRoot (file) {\n  var dir = dirname(file)\n    , prev\n  while (true) {\n    if (dir === '.') {\n      // Avoids an infinite loop in rare cases, like the REPL\n      dir = process.cwd()\n    }\n    if (exists(join(dir, 'package.json')) || exists(join(dir, 'node_modules'))) {\n      // Found the 'package.json' file or 'node_modules' dir; we're done\n      return dir\n    }\n    if (prev === dir) {\n      // Got to the top\n      throw new Error('Could not find module root given file: \"' + file\n                    + '\". Do you have a `package.json` file? ')\n    }\n    // Try the parent dir next\n    prev = dir\n    dir = join(dir, '..')\n  }\n}\n","var DuplexStream = require('readable-stream/duplex')\n  , util         = require('util')\n\n\nfunction BufferList (callback) {\n  if (!(this instanceof BufferList))\n    return new BufferList(callback)\n\n  this._bufs  = []\n  this.length = 0\n\n  if (typeof callback == 'function') {\n    this._callback = callback\n\n    var piper = function piper (err) {\n      if (this._callback) {\n        this._callback(err)\n        this._callback = null\n      }\n    }.bind(this)\n\n    this.on('pipe', function onPipe (src) {\n      src.on('error', piper)\n    })\n    this.on('unpipe', function onUnpipe (src) {\n      src.removeListener('error', piper)\n    })\n  } else {\n    this.append(callback)\n  }\n\n  DuplexStream.call(this)\n}\n\n\nutil.inherits(BufferList, DuplexStream)\n\n\nBufferList.prototype._offset = function _offset (offset) {\n  var tot = 0, i = 0, _t\n  for (; i < this._bufs.length; i++) {\n    _t = tot + this._bufs[i].length\n    if (offset < _t)\n      return [ i, offset - tot ]\n    tot = _t\n  }\n}\n\n\nBufferList.prototype.append = function append (buf) {\n  var i = 0\n    , newBuf\n\n  if (Array.isArray(buf)) {\n    for (; i < buf.length; i++)\n      this.append(buf[i])\n  } else if (buf instanceof BufferList) {\n    // unwrap argument into individual BufferLists\n    for (; i < buf._bufs.length; i++)\n      this.append(buf._bufs[i])\n  } else if (buf != null) {\n    // coerce number arguments to strings, since Buffer(number) does\n    // uninitialized memory allocation\n    if (typeof buf == 'number')\n      buf = buf.toString()\n\n    newBuf = Buffer.isBuffer(buf) ? buf : new Buffer(buf)\n    this._bufs.push(newBuf)\n    this.length += newBuf.length\n  }\n\n  return this\n}\n\n\nBufferList.prototype._write = function _write (buf, encoding, callback) {\n  this.append(buf)\n\n  if (typeof callback == 'function')\n    callback()\n}\n\n\nBufferList.prototype._read = function _read (size) {\n  if (!this.length)\n    return this.push(null)\n\n  size = Math.min(size, this.length)\n  this.push(this.slice(0, size))\n  this.consume(size)\n}\n\n\nBufferList.prototype.end = function end (chunk) {\n  DuplexStream.prototype.end.call(this, chunk)\n\n  if (this._callback) {\n    this._callback(null, this.slice())\n    this._callback = null\n  }\n}\n\n\nBufferList.prototype.get = function get (index) {\n  return this.slice(index, index + 1)[0]\n}\n\n\nBufferList.prototype.slice = function slice (start, end) {\n  return this.copy(null, 0, start, end)\n}\n\n\nBufferList.prototype.copy = function copy (dst, dstStart, srcStart, srcEnd) {\n  if (typeof srcStart != 'number' || srcStart < 0)\n    srcStart = 0\n  if (typeof srcEnd != 'number' || srcEnd > this.length)\n    srcEnd = this.length\n  if (srcStart >= this.length)\n    return dst || new Buffer(0)\n  if (srcEnd <= 0)\n    return dst || new Buffer(0)\n\n  var copy   = !!dst\n    , off    = this._offset(srcStart)\n    , len    = srcEnd - srcStart\n    , bytes  = len\n    , bufoff = (copy && dstStart) || 0\n    , start  = off[1]\n    , l\n    , i\n\n  // copy/slice everything\n  if (srcStart === 0 && srcEnd == this.length) {\n    if (!copy) // slice, just return a full concat\n      return Buffer.concat(this._bufs)\n\n    // copy, need to copy individual buffers\n    for (i = 0; i < this._bufs.length; i++) {\n      this._bufs[i].copy(dst, bufoff)\n      bufoff += this._bufs[i].length\n    }\n\n    return dst\n  }\n\n  // easy, cheap case where it's a subset of one of the buffers\n  if (bytes <= this._bufs[off[0]].length - start) {\n    return copy\n      ? this._bufs[off[0]].copy(dst, dstStart, start, start + bytes)\n      : this._bufs[off[0]].slice(start, start + bytes)\n  }\n\n  if (!copy) // a slice, we need something to copy in to\n    dst = new Buffer(len)\n\n  for (i = off[0]; i < this._bufs.length; i++) {\n    l = this._bufs[i].length - start\n\n    if (bytes > l) {\n      this._bufs[i].copy(dst, bufoff, start)\n    } else {\n      this._bufs[i].copy(dst, bufoff, start, start + bytes)\n      break\n    }\n\n    bufoff += l\n    bytes -= l\n\n    if (start)\n      start = 0\n  }\n\n  return dst\n}\n\nBufferList.prototype.toString = function toString (encoding, start, end) {\n  return this.slice(start, end).toString(encoding)\n}\n\nBufferList.prototype.consume = function consume (bytes) {\n  while (this._bufs.length) {\n    if (bytes >= this._bufs[0].length) {\n      bytes -= this._bufs[0].length\n      this.length -= this._bufs[0].length\n      this._bufs.shift()\n    } else {\n      this._bufs[0] = this._bufs[0].slice(bytes)\n      this.length -= bytes\n      break\n    }\n  }\n  return this\n}\n\n\nBufferList.prototype.duplicate = function duplicate () {\n  var i = 0\n    , copy = new BufferList()\n\n  for (; i < this._bufs.length; i++)\n    copy.append(this._bufs[i])\n\n  return copy\n}\n\n\nBufferList.prototype.destroy = function destroy () {\n  this._bufs.length = 0\n  this.length = 0\n  this.push(null)\n}\n\n\n;(function () {\n  var methods = {\n      'readDoubleBE' : 8\n    , 'readDoubleLE' : 8\n    , 'readFloatBE'  : 4\n    , 'readFloatLE'  : 4\n    , 'readInt32BE'  : 4\n    , 'readInt32LE'  : 4\n    , 'readUInt32BE' : 4\n    , 'readUInt32LE' : 4\n    , 'readInt16BE'  : 2\n    , 'readInt16LE'  : 2\n    , 'readUInt16BE' : 2\n    , 'readUInt16LE' : 2\n    , 'readInt8'     : 1\n    , 'readUInt8'    : 1\n  }\n\n  for (var m in methods) {\n    (function (m) {\n      BufferList.prototype[m] = function (offset) {\n        return this.slice(offset, offset + methods[m])[m](0)\n      }\n    }(m))\n  }\n}())\n\n\nmodule.exports = BufferList\n","var toString = {}.toString;\n\nmodule.exports = Array.isArray || function (arr) {\n  return toString.call(arr) == '[object Array]';\n};\n","module.exports = require(\"./lib/_stream_duplex.js\")\n","// a duplex stream is just a stream that is both readable and writable.\n// Since JS doesn't have multiple prototypal inheritance, this class\n// prototypally inherits from Readable, and then parasitically from\n// Writable.\n\n'use strict';\n\n/*<replacement>*/\n\nvar objectKeys = Object.keys || function (obj) {\n  var keys = [];\n  for (var key in obj) {\n    keys.push(key);\n  }return keys;\n};\n/*</replacement>*/\n\nmodule.exports = Duplex;\n\n/*<replacement>*/\nvar processNextTick = require('process-nextick-args');\n/*</replacement>*/\n\n/*<replacement>*/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/*</replacement>*/\n\nvar Readable = require('./_stream_readable');\nvar Writable = require('./_stream_writable');\n\nutil.inherits(Duplex, Readable);\n\nvar keys = objectKeys(Writable.prototype);\nfor (var v = 0; v < keys.length; v++) {\n  var method = keys[v];\n  if (!Duplex.prototype[method]) Duplex.prototype[method] = Writable.prototype[method];\n}\n\nfunction Duplex(options) {\n  if (!(this instanceof Duplex)) return new Duplex(options);\n\n  Readable.call(this, options);\n  Writable.call(this, options);\n\n  if (options && options.readable === false) this.readable = false;\n\n  if (options && options.writable === false) this.writable = false;\n\n  this.allowHalfOpen = true;\n  if (options && options.allowHalfOpen === false) this.allowHalfOpen = false;\n\n  this.once('end', onend);\n}\n\n// the no-half-open enforcer\nfunction onend() {\n  // if we allow half-open state, or if the writable side ended,\n  // then we're ok.\n  if (this.allowHalfOpen || this._writableState.ended) return;\n\n  // no more data can be written.\n  // But allow more writes to happen in this tick.\n  processNextTick(onEndNT, this);\n}\n\nfunction onEndNT(self) {\n  self.end();\n}\n\nfunction forEach(xs, f) {\n  for (var i = 0, l = xs.length; i < l; i++) {\n    f(xs[i], i);\n  }\n}","'use strict';\n\nmodule.exports = Readable;\n\n/*<replacement>*/\nvar processNextTick = require('process-nextick-args');\n/*</replacement>*/\n\n/*<replacement>*/\nvar isArray = require('isarray');\n/*</replacement>*/\n\n/*<replacement>*/\nvar Buffer = require('buffer').Buffer;\n/*</replacement>*/\n\nReadable.ReadableState = ReadableState;\n\nvar EE = require('events');\n\n/*<replacement>*/\nvar EElistenerCount = function (emitter, type) {\n  return emitter.listeners(type).length;\n};\n/*</replacement>*/\n\n/*<replacement>*/\nvar Stream;\n(function () {\n  try {\n    Stream = require('st' + 'ream');\n  } catch (_) {} finally {\n    if (!Stream) Stream = require('events').EventEmitter;\n  }\n})();\n/*</replacement>*/\n\nvar Buffer = require('buffer').Buffer;\n\n/*<replacement>*/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/*</replacement>*/\n\n/*<replacement>*/\nvar debugUtil = require('util');\nvar debug = undefined;\nif (debugUtil && debugUtil.debuglog) {\n  debug = debugUtil.debuglog('stream');\n} else {\n  debug = function () {};\n}\n/*</replacement>*/\n\nvar StringDecoder;\n\nutil.inherits(Readable, Stream);\n\nvar Duplex;\nfunction ReadableState(options, stream) {\n  Duplex = Duplex || require('./_stream_duplex');\n\n  options = options || {};\n\n  // object stream flag. Used to make read(n) ignore n and to\n  // make all the buffer merging and length checks go away\n  this.objectMode = !!options.objectMode;\n\n  if (stream instanceof Duplex) this.objectMode = this.objectMode || !!options.readableObjectMode;\n\n  // the point at which it stops calling _read() to fill the buffer\n  // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n  var hwm = options.highWaterMark;\n  var defaultHwm = this.objectMode ? 16 : 16 * 1024;\n  this.highWaterMark = hwm || hwm === 0 ? hwm : defaultHwm;\n\n  // cast to ints.\n  this.highWaterMark = ~ ~this.highWaterMark;\n\n  this.buffer = [];\n  this.length = 0;\n  this.pipes = null;\n  this.pipesCount = 0;\n  this.flowing = null;\n  this.ended = false;\n  this.endEmitted = false;\n  this.reading = false;\n\n  // a flag to be able to tell if the onwrite cb is called immediately,\n  // or on a later tick.  We set this to true at first, because any\n  // actions that shouldn't happen until \"later\" should generally also\n  // not happen before the first write call.\n  this.sync = true;\n\n  // whenever we return null, then we set a flag to say\n  // that we're awaiting a 'readable' event emission.\n  this.needReadable = false;\n  this.emittedReadable = false;\n  this.readableListening = false;\n  this.resumeScheduled = false;\n\n  // Crypto is kind of old and crusty.  Historically, its default string\n  // encoding is 'binary' so we have to make this configurable.\n  // Everything else in the universe uses 'utf8', though.\n  this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n  // when piping, we only care about 'readable' events that happen\n  // after read()ing all the bytes and not getting any pushback.\n  this.ranOut = false;\n\n  // the number of writers that are awaiting a drain event in .pipe()s\n  this.awaitDrain = 0;\n\n  // if true, a maybeReadMore has been scheduled\n  this.readingMore = false;\n\n  this.decoder = null;\n  this.encoding = null;\n  if (options.encoding) {\n    if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n    this.decoder = new StringDecoder(options.encoding);\n    this.encoding = options.encoding;\n  }\n}\n\nvar Duplex;\nfunction Readable(options) {\n  Duplex = Duplex || require('./_stream_duplex');\n\n  if (!(this instanceof Readable)) return new Readable(options);\n\n  this._readableState = new ReadableState(options, this);\n\n  // legacy\n  this.readable = true;\n\n  if (options && typeof options.read === 'function') this._read = options.read;\n\n  Stream.call(this);\n}\n\n// Manually shove something into the read() buffer.\n// This returns true if the highWaterMark has not been hit yet,\n// similar to how Writable.write() returns true if you should\n// write() some more.\nReadable.prototype.push = function (chunk, encoding) {\n  var state = this._readableState;\n\n  if (!state.objectMode && typeof chunk === 'string') {\n    encoding = encoding || state.defaultEncoding;\n    if (encoding !== state.encoding) {\n      chunk = new Buffer(chunk, encoding);\n      encoding = '';\n    }\n  }\n\n  return readableAddChunk(this, state, chunk, encoding, false);\n};\n\n// Unshift should *always* be something directly out of read()\nReadable.prototype.unshift = function (chunk) {\n  var state = this._readableState;\n  return readableAddChunk(this, state, chunk, '', true);\n};\n\nReadable.prototype.isPaused = function () {\n  return this._readableState.flowing === false;\n};\n\nfunction readableAddChunk(stream, state, chunk, encoding, addToFront) {\n  var er = chunkInvalid(state, chunk);\n  if (er) {\n    stream.emit('error', er);\n  } else if (chunk === null) {\n    state.reading = false;\n    onEofChunk(stream, state);\n  } else if (state.objectMode || chunk && chunk.length > 0) {\n    if (state.ended && !addToFront) {\n      var e = new Error('stream.push() after EOF');\n      stream.emit('error', e);\n    } else if (state.endEmitted && addToFront) {\n      var e = new Error('stream.unshift() after end event');\n      stream.emit('error', e);\n    } else {\n      var skipAdd;\n      if (state.decoder && !addToFront && !encoding) {\n        chunk = state.decoder.write(chunk);\n        skipAdd = !state.objectMode && chunk.length === 0;\n      }\n\n      if (!addToFront) state.reading = false;\n\n      // Don't add to the buffer if we've decoded to an empty string chunk and\n      // we're not in object mode\n      if (!skipAdd) {\n        // if we want the data now, just emit it.\n        if (state.flowing && state.length === 0 && !state.sync) {\n          stream.emit('data', chunk);\n          stream.read(0);\n        } else {\n          // update the buffer info.\n          state.length += state.objectMode ? 1 : chunk.length;\n          if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);\n\n          if (state.needReadable) emitReadable(stream);\n        }\n      }\n\n      maybeReadMore(stream, state);\n    }\n  } else if (!addToFront) {\n    state.reading = false;\n  }\n\n  return needMoreData(state);\n}\n\n// if it's past the high water mark, we can push in some more.\n// Also, if we have no data yet, we can stand some\n// more bytes.  This is to work around cases where hwm=0,\n// such as the repl.  Also, if the push() triggered a\n// readable event, and the user called read(largeNumber) such that\n// needReadable was set, then we ought to push more, so that another\n// 'readable' event will be triggered.\nfunction needMoreData(state) {\n  return !state.ended && (state.needReadable || state.length < state.highWaterMark || state.length === 0);\n}\n\n// backwards compatibility.\nReadable.prototype.setEncoding = function (enc) {\n  if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n  this._readableState.decoder = new StringDecoder(enc);\n  this._readableState.encoding = enc;\n  return this;\n};\n\n// Don't raise the hwm > 8MB\nvar MAX_HWM = 0x800000;\nfunction computeNewHighWaterMark(n) {\n  if (n >= MAX_HWM) {\n    n = MAX_HWM;\n  } else {\n    // Get the next highest power of 2\n    n--;\n    n |= n >>> 1;\n    n |= n >>> 2;\n    n |= n >>> 4;\n    n |= n >>> 8;\n    n |= n >>> 16;\n    n++;\n  }\n  return n;\n}\n\nfunction howMuchToRead(n, state) {\n  if (state.length === 0 && state.ended) return 0;\n\n  if (state.objectMode) return n === 0 ? 0 : 1;\n\n  if (n === null || isNaN(n)) {\n    // only flow one buffer at a time\n    if (state.flowing && state.buffer.length) return state.buffer[0].length;else return state.length;\n  }\n\n  if (n <= 0) return 0;\n\n  // If we're asking for more than the target buffer level,\n  // then raise the water mark.  Bump up to the next highest\n  // power of 2, to prevent increasing it excessively in tiny\n  // amounts.\n  if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);\n\n  // don't have that much.  return null, unless we've ended.\n  if (n > state.length) {\n    if (!state.ended) {\n      state.needReadable = true;\n      return 0;\n    } else {\n      return state.length;\n    }\n  }\n\n  return n;\n}\n\n// you can override either this method, or the async _read(n) below.\nReadable.prototype.read = function (n) {\n  debug('read', n);\n  var state = this._readableState;\n  var nOrig = n;\n\n  if (typeof n !== 'number' || n > 0) state.emittedReadable = false;\n\n  // if we're doing read(0) to trigger a readable event, but we\n  // already have a bunch of data in the buffer, then just trigger\n  // the 'readable' event and move on.\n  if (n === 0 && state.needReadable && (state.length >= state.highWaterMark || state.ended)) {\n    debug('read: emitReadable', state.length, state.ended);\n    if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);\n    return null;\n  }\n\n  n = howMuchToRead(n, state);\n\n  // if we've ended, and we're now clear, then finish it up.\n  if (n === 0 && state.ended) {\n    if (state.length === 0) endReadable(this);\n    return null;\n  }\n\n  // All the actual chunk generation logic needs to be\n  // *below* the call to _read.  The reason is that in certain\n  // synthetic stream cases, such as passthrough streams, _read\n  // may be a completely synchronous operation which may change\n  // the state of the read buffer, providing enough data when\n  // before there was *not* enough.\n  //\n  // So, the steps are:\n  // 1. Figure out what the state of things will be after we do\n  // a read from the buffer.\n  //\n  // 2. If that resulting state will trigger a _read, then call _read.\n  // Note that this may be asynchronous, or synchronous.  Yes, it is\n  // deeply ugly to write APIs this way, but that still doesn't mean\n  // that the Readable class should behave improperly, as streams are\n  // designed to be sync/async agnostic.\n  // Take note if the _read call is sync or async (ie, if the read call\n  // has returned yet), so that we know whether or not it's safe to emit\n  // 'readable' etc.\n  //\n  // 3. Actually pull the requested chunks out of the buffer and return.\n\n  // if we need a readable event, then we need to do some reading.\n  var doRead = state.needReadable;\n  debug('need readable', doRead);\n\n  // if we currently have less than the highWaterMark, then also read some\n  if (state.length === 0 || state.length - n < state.highWaterMark) {\n    doRead = true;\n    debug('length less than watermark', doRead);\n  }\n\n  // however, if we've ended, then there's no point, and if we're already\n  // reading, then it's unnecessary.\n  if (state.ended || state.reading) {\n    doRead = false;\n    debug('reading or ended', doRead);\n  }\n\n  if (doRead) {\n    debug('do read');\n    state.reading = true;\n    state.sync = true;\n    // if the length is currently zero, then we *need* a readable event.\n    if (state.length === 0) state.needReadable = true;\n    // call internal read method\n    this._read(state.highWaterMark);\n    state.sync = false;\n  }\n\n  // If _read pushed data synchronously, then `reading` will be false,\n  // and we need to re-evaluate how much data we can return to the user.\n  if (doRead && !state.reading) n = howMuchToRead(nOrig, state);\n\n  var ret;\n  if (n > 0) ret = fromList(n, state);else ret = null;\n\n  if (ret === null) {\n    state.needReadable = true;\n    n = 0;\n  }\n\n  state.length -= n;\n\n  // If we have nothing in the buffer, then we want to know\n  // as soon as we *do* get something into the buffer.\n  if (state.length === 0 && !state.ended) state.needReadable = true;\n\n  // If we tried to read() past the EOF, then emit end on the next tick.\n  if (nOrig !== n && state.ended && state.length === 0) endReadable(this);\n\n  if (ret !== null) this.emit('data', ret);\n\n  return ret;\n};\n\nfunction chunkInvalid(state, chunk) {\n  var er = null;\n  if (!Buffer.isBuffer(chunk) && typeof chunk !== 'string' && chunk !== null && chunk !== undefined && !state.objectMode) {\n    er = new TypeError('Invalid non-string/buffer chunk');\n  }\n  return er;\n}\n\nfunction onEofChunk(stream, state) {\n  if (state.ended) return;\n  if (state.decoder) {\n    var chunk = state.decoder.end();\n    if (chunk && chunk.length) {\n      state.buffer.push(chunk);\n      state.length += state.objectMode ? 1 : chunk.length;\n    }\n  }\n  state.ended = true;\n\n  // emit 'readable' now to make sure it gets picked up.\n  emitReadable(stream);\n}\n\n// Don't emit readable right away in sync mode, because this can trigger\n// another read() call => stack overflow.  This way, it might trigger\n// a nextTick recursion warning, but that's not so bad.\nfunction emitReadable(stream) {\n  var state = stream._readableState;\n  state.needReadable = false;\n  if (!state.emittedReadable) {\n    debug('emitReadable', state.flowing);\n    state.emittedReadable = true;\n    if (state.sync) processNextTick(emitReadable_, stream);else emitReadable_(stream);\n  }\n}\n\nfunction emitReadable_(stream) {\n  debug('emit readable');\n  stream.emit('readable');\n  flow(stream);\n}\n\n// at this point, the user has presumably seen the 'readable' event,\n// and called read() to consume some data.  that may have triggered\n// in turn another _read(n) call, in which case reading = true if\n// it's in progress.\n// However, if we're not ended, or reading, and the length < hwm,\n// then go ahead and try to read some more preemptively.\nfunction maybeReadMore(stream, state) {\n  if (!state.readingMore) {\n    state.readingMore = true;\n    processNextTick(maybeReadMore_, stream, state);\n  }\n}\n\nfunction maybeReadMore_(stream, state) {\n  var len = state.length;\n  while (!state.reading && !state.flowing && !state.ended && state.length < state.highWaterMark) {\n    debug('maybeReadMore read 0');\n    stream.read(0);\n    if (len === state.length)\n      // didn't get any data, stop spinning.\n      break;else len = state.length;\n  }\n  state.readingMore = false;\n}\n\n// abstract method.  to be overridden in specific implementation classes.\n// call cb(er, data) where data is <= n in length.\n// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n// arbitrary, and perhaps not very meaningful.\nReadable.prototype._read = function (n) {\n  this.emit('error', new Error('not implemented'));\n};\n\nReadable.prototype.pipe = function (dest, pipeOpts) {\n  var src = this;\n  var state = this._readableState;\n\n  switch (state.pipesCount) {\n    case 0:\n      state.pipes = dest;\n      break;\n    case 1:\n      state.pipes = [state.pipes, dest];\n      break;\n    default:\n      state.pipes.push(dest);\n      break;\n  }\n  state.pipesCount += 1;\n  debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);\n\n  var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;\n\n  var endFn = doEnd ? onend : cleanup;\n  if (state.endEmitted) processNextTick(endFn);else src.once('end', endFn);\n\n  dest.on('unpipe', onunpipe);\n  function onunpipe(readable) {\n    debug('onunpipe');\n    if (readable === src) {\n      cleanup();\n    }\n  }\n\n  function onend() {\n    debug('onend');\n    dest.end();\n  }\n\n  // when the dest drains, it reduces the awaitDrain counter\n  // on the source.  This would be more elegant with a .once()\n  // handler in flow(), but adding and removing repeatedly is\n  // too slow.\n  var ondrain = pipeOnDrain(src);\n  dest.on('drain', ondrain);\n\n  var cleanedUp = false;\n  function cleanup() {\n    debug('cleanup');\n    // cleanup event handlers once the pipe is broken\n    dest.removeListener('close', onclose);\n    dest.removeListener('finish', onfinish);\n    dest.removeListener('drain', ondrain);\n    dest.removeListener('error', onerror);\n    dest.removeListener('unpipe', onunpipe);\n    src.removeListener('end', onend);\n    src.removeListener('end', cleanup);\n    src.removeListener('data', ondata);\n\n    cleanedUp = true;\n\n    // if the reader is waiting for a drain event from this\n    // specific writer, then it would cause it to never start\n    // flowing again.\n    // So, if this is awaiting a drain, then we just call it now.\n    // If we don't know, then assume that we are waiting for one.\n    if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();\n  }\n\n  src.on('data', ondata);\n  function ondata(chunk) {\n    debug('ondata');\n    var ret = dest.write(chunk);\n    if (false === ret) {\n      // If the user unpiped during `dest.write()`, it is possible\n      // to get stuck in a permanently paused state if that write\n      // also returned false.\n      if (state.pipesCount === 1 && state.pipes[0] === dest && src.listenerCount('data') === 1 && !cleanedUp) {\n        debug('false write response, pause', src._readableState.awaitDrain);\n        src._readableState.awaitDrain++;\n      }\n      src.pause();\n    }\n  }\n\n  // if the dest has an error, then stop piping into it.\n  // however, don't suppress the throwing behavior for this.\n  function onerror(er) {\n    debug('onerror', er);\n    unpipe();\n    dest.removeListener('error', onerror);\n    if (EElistenerCount(dest, 'error') === 0) dest.emit('error', er);\n  }\n  // This is a brutally ugly hack to make sure that our error handler\n  // is attached before any userland ones.  NEVER DO THIS.\n  if (!dest._events || !dest._events.error) dest.on('error', onerror);else if (isArray(dest._events.error)) dest._events.error.unshift(onerror);else dest._events.error = [onerror, dest._events.error];\n\n  // Both close and finish should trigger unpipe, but only once.\n  function onclose() {\n    dest.removeListener('finish', onfinish);\n    unpipe();\n  }\n  dest.once('close', onclose);\n  function onfinish() {\n    debug('onfinish');\n    dest.removeListener('close', onclose);\n    unpipe();\n  }\n  dest.once('finish', onfinish);\n\n  function unpipe() {\n    debug('unpipe');\n    src.unpipe(dest);\n  }\n\n  // tell the dest that it's being piped to\n  dest.emit('pipe', src);\n\n  // start the flow if it hasn't been started already.\n  if (!state.flowing) {\n    debug('pipe resume');\n    src.resume();\n  }\n\n  return dest;\n};\n\nfunction pipeOnDrain(src) {\n  return function () {\n    var state = src._readableState;\n    debug('pipeOnDrain', state.awaitDrain);\n    if (state.awaitDrain) state.awaitDrain--;\n    if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {\n      state.flowing = true;\n      flow(src);\n    }\n  };\n}\n\nReadable.prototype.unpipe = function (dest) {\n  var state = this._readableState;\n\n  // if we're not piping anywhere, then do nothing.\n  if (state.pipesCount === 0) return this;\n\n  // just one destination.  most common case.\n  if (state.pipesCount === 1) {\n    // passed in one, but it's not the right one.\n    if (dest && dest !== state.pipes) return this;\n\n    if (!dest) dest = state.pipes;\n\n    // got a match.\n    state.pipes = null;\n    state.pipesCount = 0;\n    state.flowing = false;\n    if (dest) dest.emit('unpipe', this);\n    return this;\n  }\n\n  // slow case. multiple pipe destinations.\n\n  if (!dest) {\n    // remove all.\n    var dests = state.pipes;\n    var len = state.pipesCount;\n    state.pipes = null;\n    state.pipesCount = 0;\n    state.flowing = false;\n\n    for (var _i = 0; _i < len; _i++) {\n      dests[_i].emit('unpipe', this);\n    }return this;\n  }\n\n  // try to find the right one.\n  var i = indexOf(state.pipes, dest);\n  if (i === -1) return this;\n\n  state.pipes.splice(i, 1);\n  state.pipesCount -= 1;\n  if (state.pipesCount === 1) state.pipes = state.pipes[0];\n\n  dest.emit('unpipe', this);\n\n  return this;\n};\n\n// set up data events if they are asked for\n// Ensure readable listeners eventually get something\nReadable.prototype.on = function (ev, fn) {\n  var res = Stream.prototype.on.call(this, ev, fn);\n\n  // If listening to data, and it has not explicitly been paused,\n  // then call resume to start the flow of data on the next tick.\n  if (ev === 'data' && false !== this._readableState.flowing) {\n    this.resume();\n  }\n\n  if (ev === 'readable' && !this._readableState.endEmitted) {\n    var state = this._readableState;\n    if (!state.readableListening) {\n      state.readableListening = true;\n      state.emittedReadable = false;\n      state.needReadable = true;\n      if (!state.reading) {\n        processNextTick(nReadingNextTick, this);\n      } else if (state.length) {\n        emitReadable(this, state);\n      }\n    }\n  }\n\n  return res;\n};\nReadable.prototype.addListener = Readable.prototype.on;\n\nfunction nReadingNextTick(self) {\n  debug('readable nexttick read 0');\n  self.read(0);\n}\n\n// pause() and resume() are remnants of the legacy readable stream API\n// If the user uses them, then switch into old mode.\nReadable.prototype.resume = function () {\n  var state = this._readableState;\n  if (!state.flowing) {\n    debug('resume');\n    state.flowing = true;\n    resume(this, state);\n  }\n  return this;\n};\n\nfunction resume(stream, state) {\n  if (!state.resumeScheduled) {\n    state.resumeScheduled = true;\n    processNextTick(resume_, stream, state);\n  }\n}\n\nfunction resume_(stream, state) {\n  if (!state.reading) {\n    debug('resume read 0');\n    stream.read(0);\n  }\n\n  state.resumeScheduled = false;\n  stream.emit('resume');\n  flow(stream);\n  if (state.flowing && !state.reading) stream.read(0);\n}\n\nReadable.prototype.pause = function () {\n  debug('call pause flowing=%j', this._readableState.flowing);\n  if (false !== this._readableState.flowing) {\n    debug('pause');\n    this._readableState.flowing = false;\n    this.emit('pause');\n  }\n  return this;\n};\n\nfunction flow(stream) {\n  var state = stream._readableState;\n  debug('flow', state.flowing);\n  if (state.flowing) {\n    do {\n      var chunk = stream.read();\n    } while (null !== chunk && state.flowing);\n  }\n}\n\n// wrap an old-style stream as the async data source.\n// This is *not* part of the readable stream interface.\n// It is an ugly unfortunate mess of history.\nReadable.prototype.wrap = function (stream) {\n  var state = this._readableState;\n  var paused = false;\n\n  var self = this;\n  stream.on('end', function () {\n    debug('wrapped end');\n    if (state.decoder && !state.ended) {\n      var chunk = state.decoder.end();\n      if (chunk && chunk.length) self.push(chunk);\n    }\n\n    self.push(null);\n  });\n\n  stream.on('data', function (chunk) {\n    debug('wrapped data');\n    if (state.decoder) chunk = state.decoder.write(chunk);\n\n    // don't skip over falsy values in objectMode\n    if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;\n\n    var ret = self.push(chunk);\n    if (!ret) {\n      paused = true;\n      stream.pause();\n    }\n  });\n\n  // proxy all the other methods.\n  // important when wrapping filters and duplexes.\n  for (var i in stream) {\n    if (this[i] === undefined && typeof stream[i] === 'function') {\n      this[i] = function (method) {\n        return function () {\n          return stream[method].apply(stream, arguments);\n        };\n      }(i);\n    }\n  }\n\n  // proxy certain important events.\n  var events = ['error', 'close', 'destroy', 'pause', 'resume'];\n  forEach(events, function (ev) {\n    stream.on(ev, self.emit.bind(self, ev));\n  });\n\n  // when we try to consume some more bytes, simply unpause the\n  // underlying stream.\n  self._read = function (n) {\n    debug('wrapped _read', n);\n    if (paused) {\n      paused = false;\n      stream.resume();\n    }\n  };\n\n  return self;\n};\n\n// exposed for testing purposes only.\nReadable._fromList = fromList;\n\n// Pluck off n bytes from an array of buffers.\n// Length is the combined lengths of all the buffers in the list.\nfunction fromList(n, state) {\n  var list = state.buffer;\n  var length = state.length;\n  var stringMode = !!state.decoder;\n  var objectMode = !!state.objectMode;\n  var ret;\n\n  // nothing in the list, definitely empty.\n  if (list.length === 0) return null;\n\n  if (length === 0) ret = null;else if (objectMode) ret = list.shift();else if (!n || n >= length) {\n    // read it all, truncate the array.\n    if (stringMode) ret = list.join('');else if (list.length === 1) ret = list[0];else ret = Buffer.concat(list, length);\n    list.length = 0;\n  } else {\n    // read just some of it.\n    if (n < list[0].length) {\n      // just take a part of the first list item.\n      // slice is the same for buffers and strings.\n      var buf = list[0];\n      ret = buf.slice(0, n);\n      list[0] = buf.slice(n);\n    } else if (n === list[0].length) {\n      // first list is a perfect match\n      ret = list.shift();\n    } else {\n      // complex case.\n      // we have enough to cover it, but it spans past the first buffer.\n      if (stringMode) ret = '';else ret = new Buffer(n);\n\n      var c = 0;\n      for (var i = 0, l = list.length; i < l && c < n; i++) {\n        var buf = list[0];\n        var cpy = Math.min(n - c, buf.length);\n\n        if (stringMode) ret += buf.slice(0, cpy);else buf.copy(ret, c, 0, cpy);\n\n        if (cpy < buf.length) list[0] = buf.slice(cpy);else list.shift();\n\n        c += cpy;\n      }\n    }\n  }\n\n  return ret;\n}\n\nfunction endReadable(stream) {\n  var state = stream._readableState;\n\n  // If we get here before consuming all the bytes, then that is a\n  // bug in node.  Should never happen.\n  if (state.length > 0) throw new Error('endReadable called on non-empty stream');\n\n  if (!state.endEmitted) {\n    state.ended = true;\n    processNextTick(endReadableNT, state, stream);\n  }\n}\n\nfunction endReadableNT(state, stream) {\n  // Check that we didn't get one last unshift.\n  if (!state.endEmitted && state.length === 0) {\n    state.endEmitted = true;\n    stream.readable = false;\n    stream.emit('end');\n  }\n}\n\nfunction forEach(xs, f) {\n  for (var i = 0, l = xs.length; i < l; i++) {\n    f(xs[i], i);\n  }\n}\n\nfunction indexOf(xs, x) {\n  for (var i = 0, l = xs.length; i < l; i++) {\n    if (xs[i] === x) return i;\n  }\n  return -1;\n}","// A bit simpler than readable streams.\n// Implement an async ._write(chunk, encoding, cb), and it'll handle all\n// the drain event emission and buffering.\n\n'use strict';\n\nmodule.exports = Writable;\n\n/*<replacement>*/\nvar processNextTick = require('process-nextick-args');\n/*</replacement>*/\n\n/*<replacement>*/\nvar asyncWrite = !process.browser && ['v0.10', 'v0.9.'].indexOf(process.version.slice(0, 5)) > -1 ? setImmediate : processNextTick;\n/*</replacement>*/\n\n/*<replacement>*/\nvar Buffer = require('buffer').Buffer;\n/*</replacement>*/\n\nWritable.WritableState = WritableState;\n\n/*<replacement>*/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/*</replacement>*/\n\n/*<replacement>*/\nvar internalUtil = {\n  deprecate: require('util-deprecate')\n};\n/*</replacement>*/\n\n/*<replacement>*/\nvar Stream;\n(function () {\n  try {\n    Stream = require('st' + 'ream');\n  } catch (_) {} finally {\n    if (!Stream) Stream = require('events').EventEmitter;\n  }\n})();\n/*</replacement>*/\n\nvar Buffer = require('buffer').Buffer;\n\nutil.inherits(Writable, Stream);\n\nfunction nop() {}\n\nfunction WriteReq(chunk, encoding, cb) {\n  this.chunk = chunk;\n  this.encoding = encoding;\n  this.callback = cb;\n  this.next = null;\n}\n\nvar Duplex;\nfunction WritableState(options, stream) {\n  Duplex = Duplex || require('./_stream_duplex');\n\n  options = options || {};\n\n  // object stream flag to indicate whether or not this stream\n  // contains buffers or objects.\n  this.objectMode = !!options.objectMode;\n\n  if (stream instanceof Duplex) this.objectMode = this.objectMode || !!options.writableObjectMode;\n\n  // the point at which write() starts returning false\n  // Note: 0 is a valid value, means that we always return false if\n  // the entire buffer is not flushed immediately on write()\n  var hwm = options.highWaterMark;\n  var defaultHwm = this.objectMode ? 16 : 16 * 1024;\n  this.highWaterMark = hwm || hwm === 0 ? hwm : defaultHwm;\n\n  // cast to ints.\n  this.highWaterMark = ~ ~this.highWaterMark;\n\n  this.needDrain = false;\n  // at the start of calling end()\n  this.ending = false;\n  // when end() has been called, and returned\n  this.ended = false;\n  // when 'finish' is emitted\n  this.finished = false;\n\n  // should we decode strings into buffers before passing to _write?\n  // this is here so that some node-core streams can optimize string\n  // handling at a lower level.\n  var noDecode = options.decodeStrings === false;\n  this.decodeStrings = !noDecode;\n\n  // Crypto is kind of old and crusty.  Historically, its default string\n  // encoding is 'binary' so we have to make this configurable.\n  // Everything else in the universe uses 'utf8', though.\n  this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n  // not an actual buffer we keep track of, but a measurement\n  // of how much we're waiting to get pushed to some underlying\n  // socket or file.\n  this.length = 0;\n\n  // a flag to see when we're in the middle of a write.\n  this.writing = false;\n\n  // when true all writes will be buffered until .uncork() call\n  this.corked = 0;\n\n  // a flag to be able to tell if the onwrite cb is called immediately,\n  // or on a later tick.  We set this to true at first, because any\n  // actions that shouldn't happen until \"later\" should generally also\n  // not happen before the first write call.\n  this.sync = true;\n\n  // a flag to know if we're processing previously buffered items, which\n  // may call the _write() callback in the same tick, so that we don't\n  // end up in an overlapped onwrite situation.\n  this.bufferProcessing = false;\n\n  // the callback that's passed to _write(chunk,cb)\n  this.onwrite = function (er) {\n    onwrite(stream, er);\n  };\n\n  // the callback that the user supplies to write(chunk,encoding,cb)\n  this.writecb = null;\n\n  // the amount that is being written when _write is called.\n  this.writelen = 0;\n\n  this.bufferedRequest = null;\n  this.lastBufferedRequest = null;\n\n  // number of pending user-supplied write callbacks\n  // this must be 0 before 'finish' can be emitted\n  this.pendingcb = 0;\n\n  // emit prefinish if the only thing we're waiting for is _write cbs\n  // This is relevant for synchronous Transform streams\n  this.prefinished = false;\n\n  // True if the error was already emitted and should not be thrown again\n  this.errorEmitted = false;\n\n  // count buffered requests\n  this.bufferedRequestCount = 0;\n\n  // create the two objects needed to store the corked requests\n  // they are not a linked list, as no new elements are inserted in there\n  this.corkedRequestsFree = new CorkedRequest(this);\n  this.corkedRequestsFree.next = new CorkedRequest(this);\n}\n\nWritableState.prototype.getBuffer = function writableStateGetBuffer() {\n  var current = this.bufferedRequest;\n  var out = [];\n  while (current) {\n    out.push(current);\n    current = current.next;\n  }\n  return out;\n};\n\n(function () {\n  try {\n    Object.defineProperty(WritableState.prototype, 'buffer', {\n      get: internalUtil.deprecate(function () {\n        return this.getBuffer();\n      }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.')\n    });\n  } catch (_) {}\n})();\n\nvar Duplex;\nfunction Writable(options) {\n  Duplex = Duplex || require('./_stream_duplex');\n\n  // Writable ctor is applied to Duplexes, though they're not\n  // instanceof Writable, they're instanceof Readable.\n  if (!(this instanceof Writable) && !(this instanceof Duplex)) return new Writable(options);\n\n  this._writableState = new WritableState(options, this);\n\n  // legacy.\n  this.writable = true;\n\n  if (options) {\n    if (typeof options.write === 'function') this._write = options.write;\n\n    if (typeof options.writev === 'function') this._writev = options.writev;\n  }\n\n  Stream.call(this);\n}\n\n// Otherwise people can pipe Writable streams, which is just wrong.\nWritable.prototype.pipe = function () {\n  this.emit('error', new Error('Cannot pipe. Not readable.'));\n};\n\nfunction writeAfterEnd(stream, cb) {\n  var er = new Error('write after end');\n  // TODO: defer error events consistently everywhere, not just the cb\n  stream.emit('error', er);\n  processNextTick(cb, er);\n}\n\n// If we get something that is not a buffer, string, null, or undefined,\n// and we're not in objectMode, then that's an error.\n// Otherwise stream chunks are all considered to be of length=1, and the\n// watermarks determine how many objects to keep in the buffer, rather than\n// how many bytes or characters.\nfunction validChunk(stream, state, chunk, cb) {\n  var valid = true;\n\n  if (!Buffer.isBuffer(chunk) && typeof chunk !== 'string' && chunk !== null && chunk !== undefined && !state.objectMode) {\n    var er = new TypeError('Invalid non-string/buffer chunk');\n    stream.emit('error', er);\n    processNextTick(cb, er);\n    valid = false;\n  }\n  return valid;\n}\n\nWritable.prototype.write = function (chunk, encoding, cb) {\n  var state = this._writableState;\n  var ret = false;\n\n  if (typeof encoding === 'function') {\n    cb = encoding;\n    encoding = null;\n  }\n\n  if (Buffer.isBuffer(chunk)) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding;\n\n  if (typeof cb !== 'function') cb = nop;\n\n  if (state.ended) writeAfterEnd(this, cb);else if (validChunk(this, state, chunk, cb)) {\n    state.pendingcb++;\n    ret = writeOrBuffer(this, state, chunk, encoding, cb);\n  }\n\n  return ret;\n};\n\nWritable.prototype.cork = function () {\n  var state = this._writableState;\n\n  state.corked++;\n};\n\nWritable.prototype.uncork = function () {\n  var state = this._writableState;\n\n  if (state.corked) {\n    state.corked--;\n\n    if (!state.writing && !state.corked && !state.finished && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state);\n  }\n};\n\nWritable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {\n  // node::ParseEncoding() requires lower case.\n  if (typeof encoding === 'string') encoding = encoding.toLowerCase();\n  if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new TypeError('Unknown encoding: ' + encoding);\n  this._writableState.defaultEncoding = encoding;\n};\n\nfunction decodeChunk(state, chunk, encoding) {\n  if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') {\n    chunk = new Buffer(chunk, encoding);\n  }\n  return chunk;\n}\n\n// if we're already writing something, then just put this\n// in the queue, and wait our turn.  Otherwise, call _write\n// If we return false, then we need a drain event, so set that flag.\nfunction writeOrBuffer(stream, state, chunk, encoding, cb) {\n  chunk = decodeChunk(state, chunk, encoding);\n\n  if (Buffer.isBuffer(chunk)) encoding = 'buffer';\n  var len = state.objectMode ? 1 : chunk.length;\n\n  state.length += len;\n\n  var ret = state.length < state.highWaterMark;\n  // we must ensure that previous needDrain will not be reset to false.\n  if (!ret) state.needDrain = true;\n\n  if (state.writing || state.corked) {\n    var last = state.lastBufferedRequest;\n    state.lastBufferedRequest = new WriteReq(chunk, encoding, cb);\n    if (last) {\n      last.next = state.lastBufferedRequest;\n    } else {\n      state.bufferedRequest = state.lastBufferedRequest;\n    }\n    state.bufferedRequestCount += 1;\n  } else {\n    doWrite(stream, state, false, len, chunk, encoding, cb);\n  }\n\n  return ret;\n}\n\nfunction doWrite(stream, state, writev, len, chunk, encoding, cb) {\n  state.writelen = len;\n  state.writecb = cb;\n  state.writing = true;\n  state.sync = true;\n  if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite);\n  state.sync = false;\n}\n\nfunction onwriteError(stream, state, sync, er, cb) {\n  --state.pendingcb;\n  if (sync) processNextTick(cb, er);else cb(er);\n\n  stream._writableState.errorEmitted = true;\n  stream.emit('error', er);\n}\n\nfunction onwriteStateUpdate(state) {\n  state.writing = false;\n  state.writecb = null;\n  state.length -= state.writelen;\n  state.writelen = 0;\n}\n\nfunction onwrite(stream, er) {\n  var state = stream._writableState;\n  var sync = state.sync;\n  var cb = state.writecb;\n\n  onwriteStateUpdate(state);\n\n  if (er) onwriteError(stream, state, sync, er, cb);else {\n    // Check if we're actually ready to finish, but don't emit yet\n    var finished = needFinish(state);\n\n    if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) {\n      clearBuffer(stream, state);\n    }\n\n    if (sync) {\n      /*<replacement>*/\n      asyncWrite(afterWrite, stream, state, finished, cb);\n      /*</replacement>*/\n    } else {\n        afterWrite(stream, state, finished, cb);\n      }\n  }\n}\n\nfunction afterWrite(stream, state, finished, cb) {\n  if (!finished) onwriteDrain(stream, state);\n  state.pendingcb--;\n  cb();\n  finishMaybe(stream, state);\n}\n\n// Must force callback to be called on nextTick, so that we don't\n// emit 'drain' before the write() consumer gets the 'false' return\n// value, and has a chance to attach a 'drain' listener.\nfunction onwriteDrain(stream, state) {\n  if (state.length === 0 && state.needDrain) {\n    state.needDrain = false;\n    stream.emit('drain');\n  }\n}\n\n// if there's something in the buffer waiting, then process it\nfunction clearBuffer(stream, state) {\n  state.bufferProcessing = true;\n  var entry = state.bufferedRequest;\n\n  if (stream._writev && entry && entry.next) {\n    // Fast case, write everything using _writev()\n    var l = state.bufferedRequestCount;\n    var buffer = new Array(l);\n    var holder = state.corkedRequestsFree;\n    holder.entry = entry;\n\n    var count = 0;\n    while (entry) {\n      buffer[count] = entry;\n      entry = entry.next;\n      count += 1;\n    }\n\n    doWrite(stream, state, true, state.length, buffer, '', holder.finish);\n\n    // doWrite is always async, defer these to save a bit of time\n    // as the hot path ends with doWrite\n    state.pendingcb++;\n    state.lastBufferedRequest = null;\n    state.corkedRequestsFree = holder.next;\n    holder.next = null;\n  } else {\n    // Slow case, write chunks one-by-one\n    while (entry) {\n      var chunk = entry.chunk;\n      var encoding = entry.encoding;\n      var cb = entry.callback;\n      var len = state.objectMode ? 1 : chunk.length;\n\n      doWrite(stream, state, false, len, chunk, encoding, cb);\n      entry = entry.next;\n      // if we didn't call the onwrite immediately, then\n      // it means that we need to wait until it does.\n      // also, that means that the chunk and cb are currently\n      // being processed, so move the buffer counter past them.\n      if (state.writing) {\n        break;\n      }\n    }\n\n    if (entry === null) state.lastBufferedRequest = null;\n  }\n\n  state.bufferedRequestCount = 0;\n  state.bufferedRequest = entry;\n  state.bufferProcessing = false;\n}\n\nWritable.prototype._write = function (chunk, encoding, cb) {\n  cb(new Error('not implemented'));\n};\n\nWritable.prototype._writev = null;\n\nWritable.prototype.end = function (chunk, encoding, cb) {\n  var state = this._writableState;\n\n  if (typeof chunk === 'function') {\n    cb = chunk;\n    chunk = null;\n    encoding = null;\n  } else if (typeof encoding === 'function') {\n    cb = encoding;\n    encoding = null;\n  }\n\n  if (chunk !== null && chunk !== undefined) this.write(chunk, encoding);\n\n  // .end() fully uncorks\n  if (state.corked) {\n    state.corked = 1;\n    this.uncork();\n  }\n\n  // ignore unnecessary end() calls.\n  if (!state.ending && !state.finished) endWritable(this, state, cb);\n};\n\nfunction needFinish(state) {\n  return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing;\n}\n\nfunction prefinish(stream, state) {\n  if (!state.prefinished) {\n    state.prefinished = true;\n    stream.emit('prefinish');\n  }\n}\n\nfunction finishMaybe(stream, state) {\n  var need = needFinish(state);\n  if (need) {\n    if (state.pendingcb === 0) {\n      prefinish(stream, state);\n      state.finished = true;\n      stream.emit('finish');\n    } else {\n      prefinish(stream, state);\n    }\n  }\n  return need;\n}\n\nfunction endWritable(stream, state, cb) {\n  state.ending = true;\n  finishMaybe(stream, state);\n  if (cb) {\n    if (state.finished) processNextTick(cb);else stream.once('finish', cb);\n  }\n  state.ended = true;\n  stream.writable = false;\n}\n\n// It seems a linked list but it is not\n// there will be only 2 of these for each stream\nfunction CorkedRequest(state) {\n  var _this = this;\n\n  this.next = null;\n  this.entry = null;\n\n  this.finish = function (err) {\n    var entry = _this.entry;\n    _this.entry = null;\n    while (entry) {\n      var cb = entry.callback;\n      state.pendingcb--;\n      cb(err);\n      entry = entry.next;\n    }\n    if (state.corkedRequestsFree) {\n      state.corkedRequestsFree.next = _this;\n    } else {\n      state.corkedRequestsFree = _this;\n    }\n  };\n}","var Buffer = require('buffer').Buffer\n\nvar BLAKE2s = (function () {\n    function BLAKE2s(digestLength, key) {\n        if (typeof digestLength === \"undefined\") { digestLength = 32; }\n        this.isFinished = false;\n        this.digestLength = 32;\n        this.blockLength = 64;\n        this.iv = [\n            0x6a09e667, 0xbb67ae85, 0x3c6ef372, 0xa54ff53a,\n            0x510e527f, 0x9b05688c, 0x1f83d9ab, 0x5be0cd19\n        ];\n        //TODO tree mode.\n        if (digestLength <= 0) {\n            digestLength = this.digestLength;\n        } else if (digestLength > 32) {\n            throw 'digestLength is too large';\n        }\n        var keyLength = 0;\n        if (typeof key == 'string') {\n            key = this.stringToUtf8Array(key);\n            keyLength = key.length;\n        } else if (typeof key == 'object') {\n            keyLength = key.length;\n        }\n        if (keyLength > 32) {\n            throw 'key too long';\n        }\n\n        var param = [digestLength & 0xff, keyLength, 1, 1];\n        this.h = this.iv.slice(0);\n\n        // XOR part of parameter block.\n        this.h[0] ^= this.load32(param, 0);\n\n        this.x = new Array(64);\n        this.t0 = 0;\n        this.t1 = 0;\n        this.f0 = 0;\n        this.f1 = 0;\n        this.nx = 0;\n        this.digestLength = digestLength;\n\n        if (keyLength > 0) {\n            for (var i = 0; i < keyLength; i++) {\n                this.x[i] = key[i];\n            }\n            for (var i = keyLength; i < 64; i++) {\n                this.x[i] = 0;\n            }\n            this.nx = 64;\n        }\n    }\n    BLAKE2s.prototype.load32 = function (p, pos) {\n        return ((p[pos] & 0xff) | ((p[pos + 1] & 0xff) << 8) | ((p[pos + 2] & 0xff) << 16) | ((p[pos + 3] & 0xff) << 24)) >>> 0;\n    };\n\n    BLAKE2s.prototype.store32 = function (p, pos, v) {\n        p[pos] = (v >>> 0) & 0xff;\n        p[pos + 1] = (v >>> 8) & 0xff;\n        p[pos + 2] = (v >>> 16) & 0xff;\n        p[pos + 3] = (v >>> 24) & 0xff;\n    };\n\n    BLAKE2s.prototype.processBlock = function (length) {\n        this.t0 += length;\n        if (this.t0 != this.t0 >>> 0) {\n            this.t0 = 0;\n            this.t1++;\n        }\n\n        var v0 = this.h[0], v1 = this.h[1], v2 = this.h[2], v3 = this.h[3], v4 = this.h[4], v5 = this.h[5], v6 = this.h[6], v7 = this.h[7], v8 = this.iv[0], v9 = this.iv[1], v10 = this.iv[2], v11 = this.iv[3], v12 = this.iv[4] ^ this.t0, v13 = this.iv[5] ^ this.t1, v14 = this.iv[6] ^ this.f0, v15 = this.iv[7] ^ this.f1;\n\n        var m0 = this.load32(this.x, 0), m1 = this.load32(this.x, 4), m2 = this.load32(this.x, 8), m3 = this.load32(this.x, 12), m4 = this.load32(this.x, 16), m5 = this.load32(this.x, 20), m6 = this.load32(this.x, 24), m7 = this.load32(this.x, 28), m8 = this.load32(this.x, 32), m9 = this.load32(this.x, 36), m10 = this.load32(this.x, 40), m11 = this.load32(this.x, 44), m12 = this.load32(this.x, 48), m13 = this.load32(this.x, 52), m14 = this.load32(this.x, 56), m15 = this.load32(this.x, 60);\n\n        // Round 1.\n        v0 += m0;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v1 += m2;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v2 += m4;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v3 += m6;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v2 += m5;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v3 += m7;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v1 += m3;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n        v0 += m1;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v0 += m8;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v1 += m10;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v2 += m12;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v3 += m14;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v2 += m13;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v3 += m15;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v1 += m11;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v0 += m9;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n\n        // Round 2.\n        v0 += m14;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v1 += m4;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v2 += m9;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v3 += m13;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v2 += m15;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v3 += m6;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v1 += m8;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n        v0 += m10;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v0 += m1;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v1 += m0;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v2 += m11;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v3 += m5;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v2 += m7;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v3 += m3;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v1 += m2;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v0 += m12;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n\n        // Round 3.\n        v0 += m11;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v1 += m12;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v2 += m5;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v3 += m15;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v2 += m2;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v3 += m13;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v1 += m0;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n        v0 += m8;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v0 += m10;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v1 += m3;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v2 += m7;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v3 += m9;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v2 += m1;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v3 += m4;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v1 += m6;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v0 += m14;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n\n        // Round 4.\n        v0 += m7;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v1 += m3;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v2 += m13;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v3 += m11;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v2 += m12;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v3 += m14;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v1 += m1;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n        v0 += m9;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v0 += m2;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v1 += m5;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v2 += m4;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v3 += m15;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v2 += m0;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v3 += m8;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v1 += m10;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v0 += m6;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n\n        // Round 5.\n        v0 += m9;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v1 += m5;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v2 += m2;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v3 += m10;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v2 += m4;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v3 += m15;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v1 += m7;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n        v0 += m0;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v0 += m14;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v1 += m11;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v2 += m6;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v3 += m3;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v2 += m8;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v3 += m13;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v1 += m12;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v0 += m1;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n\n        // Round 6.\n        v0 += m2;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v1 += m6;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v2 += m0;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v3 += m8;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v2 += m11;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v3 += m3;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v1 += m10;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n        v0 += m12;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v0 += m4;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v1 += m7;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v2 += m15;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v3 += m1;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v2 += m14;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v3 += m9;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v1 += m5;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v0 += m13;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n\n        // Round 7.\n        v0 += m12;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v1 += m1;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v2 += m14;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v3 += m4;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v2 += m13;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v3 += m10;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v1 += m15;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n        v0 += m5;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v0 += m0;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v1 += m6;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v2 += m9;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v3 += m8;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v2 += m2;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v3 += m11;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v1 += m3;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v0 += m7;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n\n        // Round 8.\n        v0 += m13;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v1 += m7;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v2 += m12;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v3 += m3;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v2 += m1;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v3 += m9;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v1 += m14;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n        v0 += m11;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v0 += m5;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v1 += m15;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v2 += m8;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v3 += m2;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v2 += m6;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v3 += m10;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v1 += m4;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v0 += m0;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n\n        // Round 9.\n        v0 += m6;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v1 += m14;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v2 += m11;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v3 += m0;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v2 += m3;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v3 += m8;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v1 += m9;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n        v0 += m15;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v0 += m12;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v1 += m13;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v2 += m1;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v3 += m10;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v2 += m4;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v3 += m5;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v1 += m7;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v0 += m2;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n\n        // Round 10.\n        v0 += m10;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v1 += m8;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v2 += m7;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v3 += m1;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v2 += m6;\n        v2 += v6;\n        v14 ^= v2;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v10 += v14;\n        v6 ^= v10;\n        v6 = v6 << (32 - 7) | v6 >>> 7;\n        v3 += m5;\n        v3 += v7;\n        v15 ^= v3;\n        v15 = v15 << (32 - 8) | v15 >>> 8;\n        v11 += v15;\n        v7 ^= v11;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v1 += m4;\n        v1 += v5;\n        v13 ^= v1;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v9 += v13;\n        v5 ^= v9;\n        v5 = v5 << (32 - 7) | v5 >>> 7;\n        v0 += m2;\n        v0 += v4;\n        v12 ^= v0;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v8 += v12;\n        v4 ^= v8;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v0 += m15;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = v15 << (32 - 16) | v15 >>> 16;\n        v10 += v15;\n        v5 ^= v10;\n        v5 = v5 << (32 - 12) | v5 >>> 12;\n        v1 += m9;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 16) | v12 >>> 16;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = v6 << (32 - 12) | v6 >>> 12;\n        v2 += m3;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 16) | v13 >>> 16;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 12) | v7 >>> 12;\n        v3 += m13;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 16) | v14 >>> 16;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 12) | v4 >>> 12;\n        v2 += m12;\n        v2 += v7;\n        v13 ^= v2;\n        v13 = v13 << (32 - 8) | v13 >>> 8;\n        v8 += v13;\n        v7 ^= v8;\n        v7 = v7 << (32 - 7) | v7 >>> 7;\n        v3 += m0;\n        v3 += v4;\n        v14 ^= v3;\n        v14 = v14 << (32 - 8) | v14 >>> 8;\n        v9 += v14;\n        v4 ^= v9;\n        v4 = v4 << (32 - 7) | v4 >>> 7;\n        v1 += m14;\n        v1 += v6;\n        v12 ^= v1;\n        v12 = v12 << (32 - 8) | v12 >>> 8;\n        v11 += v12;\n        v6 ^= v11;\n        v6 = (v6 << (32 - 7)) | (v6 >>> 7);\n        v0 += m11;\n        v0 += v5;\n        v15 ^= v0;\n        v15 = (v15 << (32 - 8)) | (v15 >>> 8);\n        v10 += v15;\n        v5 ^= v10;\n        v5 = (v5 << (32 - 7)) | (v5 >>> 7);\n\n        this.h[0] ^= v0 ^ v8;\n        this.h[1] ^= v1 ^ v9;\n        this.h[2] ^= v2 ^ v10;\n        this.h[3] ^= v3 ^ v11;\n        this.h[4] ^= v4 ^ v12;\n        this.h[5] ^= v5 ^ v13;\n        this.h[6] ^= v6 ^ v14;\n        this.h[7] ^= v7 ^ v15;\n    };\n\n    BLAKE2s.prototype.stringToUtf8Array = function (s) {\n        var arr = [];\n        for (var i = 0; i < s.length; i++) {\n            var c = s.charCodeAt(i);\n            if (c < 128) {\n                arr.push(c);\n            } else if (c > 127 && c < 2048) {\n                arr.push((c >> 6) | 192);\n                arr.push((c & 63) | 128);\n            } else {\n                arr.push((c >> 12) | 224);\n                arr.push(((c >> 6) & 63) | 128);\n                arr.push((c & 64) | 128);\n            }\n        }\n        return arr;\n    };\n\n    BLAKE2s.prototype._update = function (p, offset, length) {\n        if (typeof offset === \"undefined\") { offset = 0; }\n        if (typeof length === \"undefined\") { length = p.length; }\n        if (this.isFinished) {\n            throw 'update() after calling digest()';\n        }\n        if (typeof p == 'string') {\n            if (offset != 0) {\n                throw 'offset not supported for strings';\n            }\n            p = this.stringToUtf8Array(p);\n            length = p.length;\n            offset = 0;\n        } else if (typeof p != 'object') {\n            throw 'unsupported object: string or array required';\n        }\n        if (length == 0) {\n            return;\n        }\n        var left = 64 - this.nx;\n        if (length > left) {\n            for (var i = 0; i < left; i++) {\n                this.x[this.nx + i] = p[offset + i];\n            }\n            this.processBlock(64);\n            offset += left;\n            length -= left;\n            this.nx = 0;\n        }\n        while (length > 64) {\n            for (var i = 0; i < 64; i++) {\n                this.x[i] = p[offset + i];\n            }\n            this.processBlock(64);\n            offset += 64;\n            length -= 64;\n            this.nx = 0;\n        }\n        for (var i = 0; i < length; i++) {\n            this.x[this.nx + i] = p[offset + i];\n        }\n        this.nx += length;\n    };\n\n    BLAKE2s.prototype.update = function (buffer, enc) {\n      if(enc)\n        buffer = new Buffer(buffer, enc)\n      this._update(buffer)\n      return this\n    }\n\n    BLAKE2s.prototype.digest = function (enc) {\n        if (this.isFinished) {\n            return this.result;\n        }\n\n        for (var i = this.nx; i < 64; i++) {\n            this.x[i] = 0;\n        }\n\n        // Set last block flag.\n        this.f0 = 0xffffffff;\n\n        //TODO in tree mode, set f1 to 0xffffffff.\n        this.processBlock(this.nx);\n\n        var out = new Buffer(32);\n        for (var i = 0; i < 8; i++) {\n            var h = this.h[i];\n            out[i * 4 + 0] = (h >>> 0) & 0xff;\n            out[i * 4 + 1] = (h >>> 8) & 0xff;\n            out[i * 4 + 2] = (h >>> 16) & 0xff;\n            out[i * 4 + 3] = (h >>> 24) & 0xff;\n        }\n        this.result = out.slice(0, this.digestLength);\n        this.isFinished = true;\n        return enc ? this.result.toString(enc) : this.result;\n    };\n\n    return BLAKE2s;\n})();\n\nif('undefined' === typeof module)\n  window.Blake2s = BLAKE2s\nelse\n  module.exports = BLAKE2s\n","(function (module, exports) {\n  'use strict';\n\n  // Utils\n  function assert (val, msg) {\n    if (!val) throw new Error(msg || 'Assertion failed');\n  }\n\n  // Could use `inherits` module, but don't want to move from single file\n  // architecture yet.\n  function inherits (ctor, superCtor) {\n    ctor.super_ = superCtor;\n    var TempCtor = function () {};\n    TempCtor.prototype = superCtor.prototype;\n    ctor.prototype = new TempCtor();\n    ctor.prototype.constructor = ctor;\n  }\n\n  // BN\n\n  function BN (number, base, endian) {\n    if (BN.isBN(number)) {\n      return number;\n    }\n\n    this.negative = 0;\n    this.words = null;\n    this.length = 0;\n\n    // Reduction context\n    this.red = null;\n\n    if (number !== null) {\n      if (base === 'le' || base === 'be') {\n        endian = base;\n        base = 10;\n      }\n\n      this._init(number || 0, base || 10, endian || 'be');\n    }\n  }\n  if (typeof module === 'object') {\n    module.exports = BN;\n  } else {\n    exports.BN = BN;\n  }\n\n  BN.BN = BN;\n  BN.wordSize = 26;\n\n  var Buffer;\n  try {\n    Buffer = require('buf' + 'fer').Buffer;\n  } catch (e) {\n  }\n\n  BN.isBN = function isBN (num) {\n    return num !== null && typeof num === 'object' &&\n      num.constructor.name === 'BN' && Array.isArray(num.words);\n  };\n\n  BN.max = function max (left, right) {\n    if (left.cmp(right) > 0) return left;\n    return right;\n  };\n\n  BN.min = function min (left, right) {\n    if (left.cmp(right) < 0) return left;\n    return right;\n  };\n\n  BN.prototype._init = function init (number, base, endian) {\n    if (typeof number === 'number') {\n      return this._initNumber(number, base, endian);\n    }\n\n    if (typeof number === 'object') {\n      return this._initArray(number, base, endian);\n    }\n\n    if (base === 'hex') {\n      base = 16;\n    }\n    assert(base === (base | 0) && base >= 2 && base <= 36);\n\n    number = number.toString().replace(/\\s+/g, '');\n    var start = 0;\n    if (number[0] === '-') {\n      start++;\n    }\n\n    if (base === 16) {\n      this._parseHex(number, start);\n    } else {\n      this._parseBase(number, base, start);\n    }\n\n    if (number[0] === '-') {\n      this.negative = 1;\n    }\n\n    this.strip();\n\n    if (endian !== 'le') return;\n\n    this._initArray(this.toArray(), base, endian);\n  };\n\n  BN.prototype._initNumber = function _initNumber (number, base, endian) {\n    if (number < 0) {\n      this.negative = 1;\n      number = -number;\n    }\n    if (number < 0x4000000) {\n      this.words = [ number & 0x3ffffff ];\n      this.length = 1;\n    } else if (number < 0x10000000000000) {\n      this.words = [\n        number & 0x3ffffff,\n        (number / 0x4000000) & 0x3ffffff\n      ];\n      this.length = 2;\n    } else {\n      assert(number < 0x20000000000000); // 2 ^ 53 (unsafe)\n      this.words = [\n        number & 0x3ffffff,\n        (number / 0x4000000) & 0x3ffffff,\n        1\n      ];\n      this.length = 3;\n    }\n\n    if (endian !== 'le') return;\n\n    // Reverse the bytes\n    this._initArray(this.toArray(), base, endian);\n  };\n\n  BN.prototype._initArray = function _initArray (number, base, endian) {\n    // Perhaps a Uint8Array\n    assert(typeof number.length === 'number');\n    if (number.length <= 0) {\n      this.words = [ 0 ];\n      this.length = 1;\n      return this;\n    }\n\n    this.length = Math.ceil(number.length / 3);\n    this.words = new Array(this.length);\n    for (var i = 0; i < this.length; i++) {\n      this.words[i] = 0;\n    }\n\n    var j, w;\n    var off = 0;\n    if (endian === 'be') {\n      for (i = number.length - 1, j = 0; i >= 0; i -= 3) {\n        w = number[i] | (number[i - 1] << 8) | (number[i - 2] << 16);\n        this.words[j] |= (w << off) & 0x3ffffff;\n        this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n        off += 24;\n        if (off >= 26) {\n          off -= 26;\n          j++;\n        }\n      }\n    } else if (endian === 'le') {\n      for (i = 0, j = 0; i < number.length; i += 3) {\n        w = number[i] | (number[i + 1] << 8) | (number[i + 2] << 16);\n        this.words[j] |= (w << off) & 0x3ffffff;\n        this.words[j + 1] = (w >>> (26 - off)) & 0x3ffffff;\n        off += 24;\n        if (off >= 26) {\n          off -= 26;\n          j++;\n        }\n      }\n    }\n    return this.strip();\n  };\n\n  function parseHex (str, start, end) {\n    var r = 0;\n    var len = Math.min(str.length, end);\n    for (var i = start; i < len; i++) {\n      var c = str.charCodeAt(i) - 48;\n\n      r <<= 4;\n\n      // 'a' - 'f'\n      if (c >= 49 && c <= 54) {\n        r |= c - 49 + 0xa;\n\n      // 'A' - 'F'\n      } else if (c >= 17 && c <= 22) {\n        r |= c - 17 + 0xa;\n\n      // '0' - '9'\n      } else {\n        r |= c & 0xf;\n      }\n    }\n    return r;\n  }\n\n  BN.prototype._parseHex = function _parseHex (number, start) {\n    // Create possibly bigger array to ensure that it fits the number\n    this.length = Math.ceil((number.length - start) / 6);\n    this.words = new Array(this.length);\n    for (var i = 0; i < this.length; i++) {\n      this.words[i] = 0;\n    }\n\n    var j, w;\n    // Scan 24-bit chunks and add them to the number\n    var off = 0;\n    for (i = number.length - 6, j = 0; i >= start; i -= 6) {\n      w = parseHex(number, i, i + 6);\n      this.words[j] |= (w << off) & 0x3ffffff;\n      // NOTE: `0x3fffff` is intentional here, 26bits max shift + 24bit hex limb\n      this.words[j + 1] |= w >>> (26 - off) & 0x3fffff;\n      off += 24;\n      if (off >= 26) {\n        off -= 26;\n        j++;\n      }\n    }\n    if (i + 6 !== start) {\n      w = parseHex(number, start, i + 6);\n      this.words[j] |= (w << off) & 0x3ffffff;\n      this.words[j + 1] |= w >>> (26 - off) & 0x3fffff;\n    }\n    this.strip();\n  };\n\n  function parseBase (str, start, end, mul) {\n    var r = 0;\n    var len = Math.min(str.length, end);\n    for (var i = start; i < len; i++) {\n      var c = str.charCodeAt(i) - 48;\n\n      r *= mul;\n\n      // 'a'\n      if (c >= 49) {\n        r += c - 49 + 0xa;\n\n      // 'A'\n      } else if (c >= 17) {\n        r += c - 17 + 0xa;\n\n      // '0' - '9'\n      } else {\n        r += c;\n      }\n    }\n    return r;\n  }\n\n  BN.prototype._parseBase = function _parseBase (number, base, start) {\n    // Initialize as zero\n    this.words = [ 0 ];\n    this.length = 1;\n\n    // Find length of limb in base\n    for (var limbLen = 0, limbPow = 1; limbPow <= 0x3ffffff; limbPow *= base) {\n      limbLen++;\n    }\n    limbLen--;\n    limbPow = (limbPow / base) | 0;\n\n    var total = number.length - start;\n    var mod = total % limbLen;\n    var end = Math.min(total, total - mod) + start;\n\n    var word = 0;\n    for (var i = start; i < end; i += limbLen) {\n      word = parseBase(number, i, i + limbLen, base);\n\n      this.imuln(limbPow);\n      if (this.words[0] + word < 0x4000000) {\n        this.words[0] += word;\n      } else {\n        this._iaddn(word);\n      }\n    }\n\n    if (mod !== 0) {\n      var pow = 1;\n      word = parseBase(number, i, number.length, base);\n\n      for (i = 0; i < mod; i++) {\n        pow *= base;\n      }\n\n      this.imuln(pow);\n      if (this.words[0] + word < 0x4000000) {\n        this.words[0] += word;\n      } else {\n        this._iaddn(word);\n      }\n    }\n  };\n\n  BN.prototype.copy = function copy (dest) {\n    dest.words = new Array(this.length);\n    for (var i = 0; i < this.length; i++) {\n      dest.words[i] = this.words[i];\n    }\n    dest.length = this.length;\n    dest.negative = this.negative;\n    dest.red = this.red;\n  };\n\n  BN.prototype.clone = function clone () {\n    var r = new BN(null);\n    this.copy(r);\n    return r;\n  };\n\n  BN.prototype._expand = function _expand (size) {\n    while (this.length < size) {\n      this.words[this.length++] = 0;\n    }\n    return this;\n  };\n\n  // Remove leading `0` from `this`\n  BN.prototype.strip = function strip () {\n    while (this.length > 1 && this.words[this.length - 1] === 0) {\n      this.length--;\n    }\n    return this._normSign();\n  };\n\n  BN.prototype._normSign = function _normSign () {\n    // -0 = 0\n    if (this.length === 1 && this.words[0] === 0) {\n      this.negative = 0;\n    }\n    return this;\n  };\n\n  BN.prototype.inspect = function inspect () {\n    return (this.red ? '<BN-R: ' : '<BN: ') + this.toString(16) + '>';\n  };\n\n  /*\n\n  var zeros = [];\n  var groupSizes = [];\n  var groupBases = [];\n\n  var s = '';\n  var i = -1;\n  while (++i < BN.wordSize) {\n    zeros[i] = s;\n    s += '0';\n  }\n  groupSizes[0] = 0;\n  groupSizes[1] = 0;\n  groupBases[0] = 0;\n  groupBases[1] = 0;\n  var base = 2 - 1;\n  while (++base < 36 + 1) {\n    var groupSize = 0;\n    var groupBase = 1;\n    while (groupBase < (1 << BN.wordSize) / base) {\n      groupBase *= base;\n      groupSize += 1;\n    }\n    groupSizes[base] = groupSize;\n    groupBases[base] = groupBase;\n  }\n\n  */\n\n  var zeros = [\n    '',\n    '0',\n    '00',\n    '000',\n    '0000',\n    '00000',\n    '000000',\n    '0000000',\n    '00000000',\n    '000000000',\n    '0000000000',\n    '00000000000',\n    '000000000000',\n    '0000000000000',\n    '00000000000000',\n    '000000000000000',\n    '0000000000000000',\n    '00000000000000000',\n    '000000000000000000',\n    '0000000000000000000',\n    '00000000000000000000',\n    '000000000000000000000',\n    '0000000000000000000000',\n    '00000000000000000000000',\n    '000000000000000000000000',\n    '0000000000000000000000000'\n  ];\n\n  var groupSizes = [\n    0, 0,\n    25, 16, 12, 11, 10, 9, 8,\n    8, 7, 7, 7, 7, 6, 6,\n    6, 6, 6, 6, 6, 5, 5,\n    5, 5, 5, 5, 5, 5, 5,\n    5, 5, 5, 5, 5, 5, 5\n  ];\n\n  var groupBases = [\n    0, 0,\n    33554432, 43046721, 16777216, 48828125, 60466176, 40353607, 16777216,\n    43046721, 10000000, 19487171, 35831808, 62748517, 7529536, 11390625,\n    16777216, 24137569, 34012224, 47045881, 64000000, 4084101, 5153632,\n    6436343, 7962624, 9765625, 11881376, 14348907, 17210368, 20511149,\n    24300000, 28629151, 33554432, 39135393, 45435424, 52521875, 60466176\n  ];\n\n  BN.prototype.toString = function toString (base, padding) {\n    base = base || 10;\n    padding = padding | 0 || 1;\n\n    var out;\n    if (base === 16 || base === 'hex') {\n      out = '';\n      var off = 0;\n      var carry = 0;\n      for (var i = 0; i < this.length; i++) {\n        var w = this.words[i];\n        var word = (((w << off) | carry) & 0xffffff).toString(16);\n        carry = (w >>> (24 - off)) & 0xffffff;\n        if (carry !== 0 || i !== this.length - 1) {\n          out = zeros[6 - word.length] + word + out;\n        } else {\n          out = word + out;\n        }\n        off += 2;\n        if (off >= 26) {\n          off -= 26;\n          i--;\n        }\n      }\n      if (carry !== 0) {\n        out = carry.toString(16) + out;\n      }\n      while (out.length % padding !== 0) {\n        out = '0' + out;\n      }\n      if (this.negative !== 0) {\n        out = '-' + out;\n      }\n      return out;\n    }\n\n    if (base === (base | 0) && base >= 2 && base <= 36) {\n      // var groupSize = Math.floor(BN.wordSize * Math.LN2 / Math.log(base));\n      var groupSize = groupSizes[base];\n      // var groupBase = Math.pow(base, groupSize);\n      var groupBase = groupBases[base];\n      out = '';\n      var c = this.clone();\n      c.negative = 0;\n      while (!c.isZero()) {\n        var r = c.modn(groupBase).toString(base);\n        c = c.idivn(groupBase);\n\n        if (!c.isZero()) {\n          out = zeros[groupSize - r.length] + r + out;\n        } else {\n          out = r + out;\n        }\n      }\n      if (this.isZero()) {\n        out = '0' + out;\n      }\n      while (out.length % padding !== 0) {\n        out = '0' + out;\n      }\n      if (this.negative !== 0) {\n        out = '-' + out;\n      }\n      return out;\n    }\n\n    assert(false, 'Base should be between 2 and 36');\n  };\n\n  BN.prototype.toNumber = function toNumber () {\n    var ret = this.words[0];\n    if (this.length === 2) {\n      ret += this.words[1] * 0x4000000;\n    } else if (this.length === 3 && this.words[2] === 0x01) {\n      // NOTE: at this stage it is known that the top bit is set\n      ret += 0x10000000000000 + (this.words[1] * 0x4000000);\n    } else if (this.length > 2) {\n      assert(false, 'Number can only safely store up to 53 bits');\n    }\n    return (this.negative !== 0) ? -ret : ret;\n  };\n\n  BN.prototype.toJSON = function toJSON () {\n    return this.toString(16);\n  };\n\n  BN.prototype.toBuffer = function toBuffer (endian, length) {\n    assert(typeof Buffer !== 'undefined');\n    return this.toArrayLike(Buffer, endian, length);\n  };\n\n  BN.prototype.toArray = function toArray (endian, length) {\n    return this.toArrayLike(Array, endian, length);\n  };\n\n  BN.prototype.toArrayLike = function toArrayLike (ArrayType, endian, length) {\n    var byteLength = this.byteLength();\n    var reqLength = length || Math.max(1, byteLength);\n    assert(byteLength <= reqLength, 'byte array longer than desired length');\n    assert(reqLength > 0, 'Requested array length <= 0');\n\n    this.strip();\n    var littleEndian = endian === 'le';\n    var res = new ArrayType(reqLength);\n\n    var b, i;\n    var q = this.clone();\n    if (!littleEndian) {\n      // Assume big-endian\n      for (i = 0; i < reqLength - byteLength; i++) {\n        res[i] = 0;\n      }\n\n      for (i = 0; !q.isZero(); i++) {\n        b = q.andln(0xff);\n        q.iushrn(8);\n\n        res[reqLength - i - 1] = b;\n      }\n    } else {\n      for (i = 0; !q.isZero(); i++) {\n        b = q.andln(0xff);\n        q.iushrn(8);\n\n        res[i] = b;\n      }\n\n      for (; i < reqLength; i++) {\n        res[i] = 0;\n      }\n    }\n\n    return res;\n  };\n\n  if (Math.clz32) {\n    BN.prototype._countBits = function _countBits (w) {\n      return 32 - Math.clz32(w);\n    };\n  } else {\n    BN.prototype._countBits = function _countBits (w) {\n      var t = w;\n      var r = 0;\n      if (t >= 0x1000) {\n        r += 13;\n        t >>>= 13;\n      }\n      if (t >= 0x40) {\n        r += 7;\n        t >>>= 7;\n      }\n      if (t >= 0x8) {\n        r += 4;\n        t >>>= 4;\n      }\n      if (t >= 0x02) {\n        r += 2;\n        t >>>= 2;\n      }\n      return r + t;\n    };\n  }\n\n  BN.prototype._zeroBits = function _zeroBits (w) {\n    // Short-cut\n    if (w === 0) return 26;\n\n    var t = w;\n    var r = 0;\n    if ((t & 0x1fff) === 0) {\n      r += 13;\n      t >>>= 13;\n    }\n    if ((t & 0x7f) === 0) {\n      r += 7;\n      t >>>= 7;\n    }\n    if ((t & 0xf) === 0) {\n      r += 4;\n      t >>>= 4;\n    }\n    if ((t & 0x3) === 0) {\n      r += 2;\n      t >>>= 2;\n    }\n    if ((t & 0x1) === 0) {\n      r++;\n    }\n    return r;\n  };\n\n  // Return number of used bits in a BN\n  BN.prototype.bitLength = function bitLength () {\n    var w = this.words[this.length - 1];\n    var hi = this._countBits(w);\n    return (this.length - 1) * 26 + hi;\n  };\n\n  function toBitArray (num) {\n    var w = new Array(num.bitLength());\n\n    for (var bit = 0; bit < w.length; bit++) {\n      var off = (bit / 26) | 0;\n      var wbit = bit % 26;\n\n      w[bit] = (num.words[off] & (1 << wbit)) >>> wbit;\n    }\n\n    return w;\n  }\n\n  // Number of trailing zero bits\n  BN.prototype.zeroBits = function zeroBits () {\n    if (this.isZero()) return 0;\n\n    var r = 0;\n    for (var i = 0; i < this.length; i++) {\n      var b = this._zeroBits(this.words[i]);\n      r += b;\n      if (b !== 26) break;\n    }\n    return r;\n  };\n\n  BN.prototype.byteLength = function byteLength () {\n    return Math.ceil(this.bitLength() / 8);\n  };\n\n  BN.prototype.toTwos = function toTwos (width) {\n    if (this.negative !== 0) {\n      return this.abs().inotn(width).iaddn(1);\n    }\n    return this.clone();\n  };\n\n  BN.prototype.fromTwos = function fromTwos (width) {\n    if (this.testn(width - 1)) {\n      return this.notn(width).iaddn(1).ineg();\n    }\n    return this.clone();\n  };\n\n  BN.prototype.isNeg = function isNeg () {\n    return this.negative !== 0;\n  };\n\n  // Return negative clone of `this`\n  BN.prototype.neg = function neg () {\n    return this.clone().ineg();\n  };\n\n  BN.prototype.ineg = function ineg () {\n    if (!this.isZero()) {\n      this.negative ^= 1;\n    }\n\n    return this;\n  };\n\n  // Or `num` with `this` in-place\n  BN.prototype.iuor = function iuor (num) {\n    while (this.length < num.length) {\n      this.words[this.length++] = 0;\n    }\n\n    for (var i = 0; i < num.length; i++) {\n      this.words[i] = this.words[i] | num.words[i];\n    }\n\n    return this.strip();\n  };\n\n  BN.prototype.ior = function ior (num) {\n    assert((this.negative | num.negative) === 0);\n    return this.iuor(num);\n  };\n\n  // Or `num` with `this`\n  BN.prototype.or = function or (num) {\n    if (this.length > num.length) return this.clone().ior(num);\n    return num.clone().ior(this);\n  };\n\n  BN.prototype.uor = function uor (num) {\n    if (this.length > num.length) return this.clone().iuor(num);\n    return num.clone().iuor(this);\n  };\n\n  // And `num` with `this` in-place\n  BN.prototype.iuand = function iuand (num) {\n    // b = min-length(num, this)\n    var b;\n    if (this.length > num.length) {\n      b = num;\n    } else {\n      b = this;\n    }\n\n    for (var i = 0; i < b.length; i++) {\n      this.words[i] = this.words[i] & num.words[i];\n    }\n\n    this.length = b.length;\n\n    return this.strip();\n  };\n\n  BN.prototype.iand = function iand (num) {\n    assert((this.negative | num.negative) === 0);\n    return this.iuand(num);\n  };\n\n  // And `num` with `this`\n  BN.prototype.and = function and (num) {\n    if (this.length > num.length) return this.clone().iand(num);\n    return num.clone().iand(this);\n  };\n\n  BN.prototype.uand = function uand (num) {\n    if (this.length > num.length) return this.clone().iuand(num);\n    return num.clone().iuand(this);\n  };\n\n  // Xor `num` with `this` in-place\n  BN.prototype.iuxor = function iuxor (num) {\n    // a.length > b.length\n    var a;\n    var b;\n    if (this.length > num.length) {\n      a = this;\n      b = num;\n    } else {\n      a = num;\n      b = this;\n    }\n\n    for (var i = 0; i < b.length; i++) {\n      this.words[i] = a.words[i] ^ b.words[i];\n    }\n\n    if (this !== a) {\n      for (; i < a.length; i++) {\n        this.words[i] = a.words[i];\n      }\n    }\n\n    this.length = a.length;\n\n    return this.strip();\n  };\n\n  BN.prototype.ixor = function ixor (num) {\n    assert((this.negative | num.negative) === 0);\n    return this.iuxor(num);\n  };\n\n  // Xor `num` with `this`\n  BN.prototype.xor = function xor (num) {\n    if (this.length > num.length) return this.clone().ixor(num);\n    return num.clone().ixor(this);\n  };\n\n  BN.prototype.uxor = function uxor (num) {\n    if (this.length > num.length) return this.clone().iuxor(num);\n    return num.clone().iuxor(this);\n  };\n\n  // Not ``this`` with ``width`` bitwidth\n  BN.prototype.inotn = function inotn (width) {\n    assert(typeof width === 'number' && width >= 0);\n\n    var bytesNeeded = Math.ceil(width / 26) | 0;\n    var bitsLeft = width % 26;\n\n    // Extend the buffer with leading zeroes\n    this._expand(bytesNeeded);\n\n    if (bitsLeft > 0) {\n      bytesNeeded--;\n    }\n\n    // Handle complete words\n    for (var i = 0; i < bytesNeeded; i++) {\n      this.words[i] = ~this.words[i] & 0x3ffffff;\n    }\n\n    // Handle the residue\n    if (bitsLeft > 0) {\n      this.words[i] = ~this.words[i] & (0x3ffffff >> (26 - bitsLeft));\n    }\n\n    // And remove leading zeroes\n    return this.strip();\n  };\n\n  BN.prototype.notn = function notn (width) {\n    return this.clone().inotn(width);\n  };\n\n  // Set `bit` of `this`\n  BN.prototype.setn = function setn (bit, val) {\n    assert(typeof bit === 'number' && bit >= 0);\n\n    var off = (bit / 26) | 0;\n    var wbit = bit % 26;\n\n    this._expand(off + 1);\n\n    if (val) {\n      this.words[off] = this.words[off] | (1 << wbit);\n    } else {\n      this.words[off] = this.words[off] & ~(1 << wbit);\n    }\n\n    return this.strip();\n  };\n\n  // Add `num` to `this` in-place\n  BN.prototype.iadd = function iadd (num) {\n    var r;\n\n    // negative + positive\n    if (this.negative !== 0 && num.negative === 0) {\n      this.negative = 0;\n      r = this.isub(num);\n      this.negative ^= 1;\n      return this._normSign();\n\n    // positive + negative\n    } else if (this.negative === 0 && num.negative !== 0) {\n      num.negative = 0;\n      r = this.isub(num);\n      num.negative = 1;\n      return r._normSign();\n    }\n\n    // a.length > b.length\n    var a, b;\n    if (this.length > num.length) {\n      a = this;\n      b = num;\n    } else {\n      a = num;\n      b = this;\n    }\n\n    var carry = 0;\n    for (var i = 0; i < b.length; i++) {\n      r = (a.words[i] | 0) + (b.words[i] | 0) + carry;\n      this.words[i] = r & 0x3ffffff;\n      carry = r >>> 26;\n    }\n    for (; carry !== 0 && i < a.length; i++) {\n      r = (a.words[i] | 0) + carry;\n      this.words[i] = r & 0x3ffffff;\n      carry = r >>> 26;\n    }\n\n    this.length = a.length;\n    if (carry !== 0) {\n      this.words[this.length] = carry;\n      this.length++;\n    // Copy the rest of the words\n    } else if (a !== this) {\n      for (; i < a.length; i++) {\n        this.words[i] = a.words[i];\n      }\n    }\n\n    return this;\n  };\n\n  // Add `num` to `this`\n  BN.prototype.add = function add (num) {\n    var res;\n    if (num.negative !== 0 && this.negative === 0) {\n      num.negative = 0;\n      res = this.sub(num);\n      num.negative ^= 1;\n      return res;\n    } else if (num.negative === 0 && this.negative !== 0) {\n      this.negative = 0;\n      res = num.sub(this);\n      this.negative = 1;\n      return res;\n    }\n\n    if (this.length > num.length) return this.clone().iadd(num);\n\n    return num.clone().iadd(this);\n  };\n\n  // Subtract `num` from `this` in-place\n  BN.prototype.isub = function isub (num) {\n    // this - (-num) = this + num\n    if (num.negative !== 0) {\n      num.negative = 0;\n      var r = this.iadd(num);\n      num.negative = 1;\n      return r._normSign();\n\n    // -this - num = -(this + num)\n    } else if (this.negative !== 0) {\n      this.negative = 0;\n      this.iadd(num);\n      this.negative = 1;\n      return this._normSign();\n    }\n\n    // At this point both numbers are positive\n    var cmp = this.cmp(num);\n\n    // Optimization - zeroify\n    if (cmp === 0) {\n      this.negative = 0;\n      this.length = 1;\n      this.words[0] = 0;\n      return this;\n    }\n\n    // a > b\n    var a, b;\n    if (cmp > 0) {\n      a = this;\n      b = num;\n    } else {\n      a = num;\n      b = this;\n    }\n\n    var carry = 0;\n    for (var i = 0; i < b.length; i++) {\n      r = (a.words[i] | 0) - (b.words[i] | 0) + carry;\n      carry = r >> 26;\n      this.words[i] = r & 0x3ffffff;\n    }\n    for (; carry !== 0 && i < a.length; i++) {\n      r = (a.words[i] | 0) + carry;\n      carry = r >> 26;\n      this.words[i] = r & 0x3ffffff;\n    }\n\n    // Copy rest of the words\n    if (carry === 0 && i < a.length && a !== this) {\n      for (; i < a.length; i++) {\n        this.words[i] = a.words[i];\n      }\n    }\n\n    this.length = Math.max(this.length, i);\n\n    if (a !== this) {\n      this.negative = 1;\n    }\n\n    return this.strip();\n  };\n\n  // Subtract `num` from `this`\n  BN.prototype.sub = function sub (num) {\n    return this.clone().isub(num);\n  };\n\n  function smallMulTo (self, num, out) {\n    out.negative = num.negative ^ self.negative;\n    var len = (self.length + num.length) | 0;\n    out.length = len;\n    len = (len - 1) | 0;\n\n    // Peel one iteration (compiler can't do it, because of code complexity)\n    var a = self.words[0] | 0;\n    var b = num.words[0] | 0;\n    var r = a * b;\n\n    var lo = r & 0x3ffffff;\n    var carry = (r / 0x4000000) | 0;\n    out.words[0] = lo;\n\n    for (var k = 1; k < len; k++) {\n      // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n      // note that ncarry could be >= 0x3ffffff\n      var ncarry = carry >>> 26;\n      var rword = carry & 0x3ffffff;\n      var maxJ = Math.min(k, num.length - 1);\n      for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n        var i = (k - j) | 0;\n        a = self.words[i] | 0;\n        b = num.words[j] | 0;\n        r = a * b + rword;\n        ncarry += (r / 0x4000000) | 0;\n        rword = r & 0x3ffffff;\n      }\n      out.words[k] = rword | 0;\n      carry = ncarry | 0;\n    }\n    if (carry !== 0) {\n      out.words[k] = carry | 0;\n    } else {\n      out.length--;\n    }\n\n    return out.strip();\n  }\n\n  // TODO(indutny): it may be reasonable to omit it for users who don't need\n  // to work with 256-bit numbers, otherwise it gives 20% improvement for 256-bit\n  // multiplication (like elliptic secp256k1).\n  var comb10MulTo = function comb10MulTo (self, num, out) {\n    var a = self.words;\n    var b = num.words;\n    var o = out.words;\n    var c = 0;\n    var lo;\n    var mid;\n    var hi;\n    var a0 = a[0] | 0;\n    var al0 = a0 & 0x1fff;\n    var ah0 = a0 >>> 13;\n    var a1 = a[1] | 0;\n    var al1 = a1 & 0x1fff;\n    var ah1 = a1 >>> 13;\n    var a2 = a[2] | 0;\n    var al2 = a2 & 0x1fff;\n    var ah2 = a2 >>> 13;\n    var a3 = a[3] | 0;\n    var al3 = a3 & 0x1fff;\n    var ah3 = a3 >>> 13;\n    var a4 = a[4] | 0;\n    var al4 = a4 & 0x1fff;\n    var ah4 = a4 >>> 13;\n    var a5 = a[5] | 0;\n    var al5 = a5 & 0x1fff;\n    var ah5 = a5 >>> 13;\n    var a6 = a[6] | 0;\n    var al6 = a6 & 0x1fff;\n    var ah6 = a6 >>> 13;\n    var a7 = a[7] | 0;\n    var al7 = a7 & 0x1fff;\n    var ah7 = a7 >>> 13;\n    var a8 = a[8] | 0;\n    var al8 = a8 & 0x1fff;\n    var ah8 = a8 >>> 13;\n    var a9 = a[9] | 0;\n    var al9 = a9 & 0x1fff;\n    var ah9 = a9 >>> 13;\n    var b0 = b[0] | 0;\n    var bl0 = b0 & 0x1fff;\n    var bh0 = b0 >>> 13;\n    var b1 = b[1] | 0;\n    var bl1 = b1 & 0x1fff;\n    var bh1 = b1 >>> 13;\n    var b2 = b[2] | 0;\n    var bl2 = b2 & 0x1fff;\n    var bh2 = b2 >>> 13;\n    var b3 = b[3] | 0;\n    var bl3 = b3 & 0x1fff;\n    var bh3 = b3 >>> 13;\n    var b4 = b[4] | 0;\n    var bl4 = b4 & 0x1fff;\n    var bh4 = b4 >>> 13;\n    var b5 = b[5] | 0;\n    var bl5 = b5 & 0x1fff;\n    var bh5 = b5 >>> 13;\n    var b6 = b[6] | 0;\n    var bl6 = b6 & 0x1fff;\n    var bh6 = b6 >>> 13;\n    var b7 = b[7] | 0;\n    var bl7 = b7 & 0x1fff;\n    var bh7 = b7 >>> 13;\n    var b8 = b[8] | 0;\n    var bl8 = b8 & 0x1fff;\n    var bh8 = b8 >>> 13;\n    var b9 = b[9] | 0;\n    var bl9 = b9 & 0x1fff;\n    var bh9 = b9 >>> 13;\n\n    out.negative = self.negative ^ num.negative;\n    out.length = 19;\n    /* k = 0 */\n    lo = Math.imul(al0, bl0);\n    mid = Math.imul(al0, bh0);\n    mid += Math.imul(ah0, bl0);\n    hi = Math.imul(ah0, bh0);\n    var w0 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w0 >>> 26);\n    w0 &= 0x3ffffff;\n    /* k = 1 */\n    lo = Math.imul(al1, bl0);\n    mid = Math.imul(al1, bh0);\n    mid += Math.imul(ah1, bl0);\n    hi = Math.imul(ah1, bh0);\n    lo += Math.imul(al0, bl1);\n    mid += Math.imul(al0, bh1);\n    mid += Math.imul(ah0, bl1);\n    hi += Math.imul(ah0, bh1);\n    var w1 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w1 >>> 26);\n    w1 &= 0x3ffffff;\n    /* k = 2 */\n    lo = Math.imul(al2, bl0);\n    mid = Math.imul(al2, bh0);\n    mid += Math.imul(ah2, bl0);\n    hi = Math.imul(ah2, bh0);\n    lo += Math.imul(al1, bl1);\n    mid += Math.imul(al1, bh1);\n    mid += Math.imul(ah1, bl1);\n    hi += Math.imul(ah1, bh1);\n    lo += Math.imul(al0, bl2);\n    mid += Math.imul(al0, bh2);\n    mid += Math.imul(ah0, bl2);\n    hi += Math.imul(ah0, bh2);\n    var w2 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w2 >>> 26);\n    w2 &= 0x3ffffff;\n    /* k = 3 */\n    lo = Math.imul(al3, bl0);\n    mid = Math.imul(al3, bh0);\n    mid += Math.imul(ah3, bl0);\n    hi = Math.imul(ah3, bh0);\n    lo += Math.imul(al2, bl1);\n    mid += Math.imul(al2, bh1);\n    mid += Math.imul(ah2, bl1);\n    hi += Math.imul(ah2, bh1);\n    lo += Math.imul(al1, bl2);\n    mid += Math.imul(al1, bh2);\n    mid += Math.imul(ah1, bl2);\n    hi += Math.imul(ah1, bh2);\n    lo += Math.imul(al0, bl3);\n    mid += Math.imul(al0, bh3);\n    mid += Math.imul(ah0, bl3);\n    hi += Math.imul(ah0, bh3);\n    var w3 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w3 >>> 26);\n    w3 &= 0x3ffffff;\n    /* k = 4 */\n    lo = Math.imul(al4, bl0);\n    mid = Math.imul(al4, bh0);\n    mid += Math.imul(ah4, bl0);\n    hi = Math.imul(ah4, bh0);\n    lo += Math.imul(al3, bl1);\n    mid += Math.imul(al3, bh1);\n    mid += Math.imul(ah3, bl1);\n    hi += Math.imul(ah3, bh1);\n    lo += Math.imul(al2, bl2);\n    mid += Math.imul(al2, bh2);\n    mid += Math.imul(ah2, bl2);\n    hi += Math.imul(ah2, bh2);\n    lo += Math.imul(al1, bl3);\n    mid += Math.imul(al1, bh3);\n    mid += Math.imul(ah1, bl3);\n    hi += Math.imul(ah1, bh3);\n    lo += Math.imul(al0, bl4);\n    mid += Math.imul(al0, bh4);\n    mid += Math.imul(ah0, bl4);\n    hi += Math.imul(ah0, bh4);\n    var w4 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w4 >>> 26);\n    w4 &= 0x3ffffff;\n    /* k = 5 */\n    lo = Math.imul(al5, bl0);\n    mid = Math.imul(al5, bh0);\n    mid += Math.imul(ah5, bl0);\n    hi = Math.imul(ah5, bh0);\n    lo += Math.imul(al4, bl1);\n    mid += Math.imul(al4, bh1);\n    mid += Math.imul(ah4, bl1);\n    hi += Math.imul(ah4, bh1);\n    lo += Math.imul(al3, bl2);\n    mid += Math.imul(al3, bh2);\n    mid += Math.imul(ah3, bl2);\n    hi += Math.imul(ah3, bh2);\n    lo += Math.imul(al2, bl3);\n    mid += Math.imul(al2, bh3);\n    mid += Math.imul(ah2, bl3);\n    hi += Math.imul(ah2, bh3);\n    lo += Math.imul(al1, bl4);\n    mid += Math.imul(al1, bh4);\n    mid += Math.imul(ah1, bl4);\n    hi += Math.imul(ah1, bh4);\n    lo += Math.imul(al0, bl5);\n    mid += Math.imul(al0, bh5);\n    mid += Math.imul(ah0, bl5);\n    hi += Math.imul(ah0, bh5);\n    var w5 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w5 >>> 26);\n    w5 &= 0x3ffffff;\n    /* k = 6 */\n    lo = Math.imul(al6, bl0);\n    mid = Math.imul(al6, bh0);\n    mid += Math.imul(ah6, bl0);\n    hi = Math.imul(ah6, bh0);\n    lo += Math.imul(al5, bl1);\n    mid += Math.imul(al5, bh1);\n    mid += Math.imul(ah5, bl1);\n    hi += Math.imul(ah5, bh1);\n    lo += Math.imul(al4, bl2);\n    mid += Math.imul(al4, bh2);\n    mid += Math.imul(ah4, bl2);\n    hi += Math.imul(ah4, bh2);\n    lo += Math.imul(al3, bl3);\n    mid += Math.imul(al3, bh3);\n    mid += Math.imul(ah3, bl3);\n    hi += Math.imul(ah3, bh3);\n    lo += Math.imul(al2, bl4);\n    mid += Math.imul(al2, bh4);\n    mid += Math.imul(ah2, bl4);\n    hi += Math.imul(ah2, bh4);\n    lo += Math.imul(al1, bl5);\n    mid += Math.imul(al1, bh5);\n    mid += Math.imul(ah1, bl5);\n    hi += Math.imul(ah1, bh5);\n    lo += Math.imul(al0, bl6);\n    mid += Math.imul(al0, bh6);\n    mid += Math.imul(ah0, bl6);\n    hi += Math.imul(ah0, bh6);\n    var w6 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w6 >>> 26);\n    w6 &= 0x3ffffff;\n    /* k = 7 */\n    lo = Math.imul(al7, bl0);\n    mid = Math.imul(al7, bh0);\n    mid += Math.imul(ah7, bl0);\n    hi = Math.imul(ah7, bh0);\n    lo += Math.imul(al6, bl1);\n    mid += Math.imul(al6, bh1);\n    mid += Math.imul(ah6, bl1);\n    hi += Math.imul(ah6, bh1);\n    lo += Math.imul(al5, bl2);\n    mid += Math.imul(al5, bh2);\n    mid += Math.imul(ah5, bl2);\n    hi += Math.imul(ah5, bh2);\n    lo += Math.imul(al4, bl3);\n    mid += Math.imul(al4, bh3);\n    mid += Math.imul(ah4, bl3);\n    hi += Math.imul(ah4, bh3);\n    lo += Math.imul(al3, bl4);\n    mid += Math.imul(al3, bh4);\n    mid += Math.imul(ah3, bl4);\n    hi += Math.imul(ah3, bh4);\n    lo += Math.imul(al2, bl5);\n    mid += Math.imul(al2, bh5);\n    mid += Math.imul(ah2, bl5);\n    hi += Math.imul(ah2, bh5);\n    lo += Math.imul(al1, bl6);\n    mid += Math.imul(al1, bh6);\n    mid += Math.imul(ah1, bl6);\n    hi += Math.imul(ah1, bh6);\n    lo += Math.imul(al0, bl7);\n    mid += Math.imul(al0, bh7);\n    mid += Math.imul(ah0, bl7);\n    hi += Math.imul(ah0, bh7);\n    var w7 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w7 >>> 26);\n    w7 &= 0x3ffffff;\n    /* k = 8 */\n    lo = Math.imul(al8, bl0);\n    mid = Math.imul(al8, bh0);\n    mid += Math.imul(ah8, bl0);\n    hi = Math.imul(ah8, bh0);\n    lo += Math.imul(al7, bl1);\n    mid += Math.imul(al7, bh1);\n    mid += Math.imul(ah7, bl1);\n    hi += Math.imul(ah7, bh1);\n    lo += Math.imul(al6, bl2);\n    mid += Math.imul(al6, bh2);\n    mid += Math.imul(ah6, bl2);\n    hi += Math.imul(ah6, bh2);\n    lo += Math.imul(al5, bl3);\n    mid += Math.imul(al5, bh3);\n    mid += Math.imul(ah5, bl3);\n    hi += Math.imul(ah5, bh3);\n    lo += Math.imul(al4, bl4);\n    mid += Math.imul(al4, bh4);\n    mid += Math.imul(ah4, bl4);\n    hi += Math.imul(ah4, bh4);\n    lo += Math.imul(al3, bl5);\n    mid += Math.imul(al3, bh5);\n    mid += Math.imul(ah3, bl5);\n    hi += Math.imul(ah3, bh5);\n    lo += Math.imul(al2, bl6);\n    mid += Math.imul(al2, bh6);\n    mid += Math.imul(ah2, bl6);\n    hi += Math.imul(ah2, bh6);\n    lo += Math.imul(al1, bl7);\n    mid += Math.imul(al1, bh7);\n    mid += Math.imul(ah1, bl7);\n    hi += Math.imul(ah1, bh7);\n    lo += Math.imul(al0, bl8);\n    mid += Math.imul(al0, bh8);\n    mid += Math.imul(ah0, bl8);\n    hi += Math.imul(ah0, bh8);\n    var w8 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w8 >>> 26);\n    w8 &= 0x3ffffff;\n    /* k = 9 */\n    lo = Math.imul(al9, bl0);\n    mid = Math.imul(al9, bh0);\n    mid += Math.imul(ah9, bl0);\n    hi = Math.imul(ah9, bh0);\n    lo += Math.imul(al8, bl1);\n    mid += Math.imul(al8, bh1);\n    mid += Math.imul(ah8, bl1);\n    hi += Math.imul(ah8, bh1);\n    lo += Math.imul(al7, bl2);\n    mid += Math.imul(al7, bh2);\n    mid += Math.imul(ah7, bl2);\n    hi += Math.imul(ah7, bh2);\n    lo += Math.imul(al6, bl3);\n    mid += Math.imul(al6, bh3);\n    mid += Math.imul(ah6, bl3);\n    hi += Math.imul(ah6, bh3);\n    lo += Math.imul(al5, bl4);\n    mid += Math.imul(al5, bh4);\n    mid += Math.imul(ah5, bl4);\n    hi += Math.imul(ah5, bh4);\n    lo += Math.imul(al4, bl5);\n    mid += Math.imul(al4, bh5);\n    mid += Math.imul(ah4, bl5);\n    hi += Math.imul(ah4, bh5);\n    lo += Math.imul(al3, bl6);\n    mid += Math.imul(al3, bh6);\n    mid += Math.imul(ah3, bl6);\n    hi += Math.imul(ah3, bh6);\n    lo += Math.imul(al2, bl7);\n    mid += Math.imul(al2, bh7);\n    mid += Math.imul(ah2, bl7);\n    hi += Math.imul(ah2, bh7);\n    lo += Math.imul(al1, bl8);\n    mid += Math.imul(al1, bh8);\n    mid += Math.imul(ah1, bl8);\n    hi += Math.imul(ah1, bh8);\n    lo += Math.imul(al0, bl9);\n    mid += Math.imul(al0, bh9);\n    mid += Math.imul(ah0, bl9);\n    hi += Math.imul(ah0, bh9);\n    var w9 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w9 >>> 26);\n    w9 &= 0x3ffffff;\n    /* k = 10 */\n    lo = Math.imul(al9, bl1);\n    mid = Math.imul(al9, bh1);\n    mid += Math.imul(ah9, bl1);\n    hi = Math.imul(ah9, bh1);\n    lo += Math.imul(al8, bl2);\n    mid += Math.imul(al8, bh2);\n    mid += Math.imul(ah8, bl2);\n    hi += Math.imul(ah8, bh2);\n    lo += Math.imul(al7, bl3);\n    mid += Math.imul(al7, bh3);\n    mid += Math.imul(ah7, bl3);\n    hi += Math.imul(ah7, bh3);\n    lo += Math.imul(al6, bl4);\n    mid += Math.imul(al6, bh4);\n    mid += Math.imul(ah6, bl4);\n    hi += Math.imul(ah6, bh4);\n    lo += Math.imul(al5, bl5);\n    mid += Math.imul(al5, bh5);\n    mid += Math.imul(ah5, bl5);\n    hi += Math.imul(ah5, bh5);\n    lo += Math.imul(al4, bl6);\n    mid += Math.imul(al4, bh6);\n    mid += Math.imul(ah4, bl6);\n    hi += Math.imul(ah4, bh6);\n    lo += Math.imul(al3, bl7);\n    mid += Math.imul(al3, bh7);\n    mid += Math.imul(ah3, bl7);\n    hi += Math.imul(ah3, bh7);\n    lo += Math.imul(al2, bl8);\n    mid += Math.imul(al2, bh8);\n    mid += Math.imul(ah2, bl8);\n    hi += Math.imul(ah2, bh8);\n    lo += Math.imul(al1, bl9);\n    mid += Math.imul(al1, bh9);\n    mid += Math.imul(ah1, bl9);\n    hi += Math.imul(ah1, bh9);\n    var w10 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w10 >>> 26);\n    w10 &= 0x3ffffff;\n    /* k = 11 */\n    lo = Math.imul(al9, bl2);\n    mid = Math.imul(al9, bh2);\n    mid += Math.imul(ah9, bl2);\n    hi = Math.imul(ah9, bh2);\n    lo += Math.imul(al8, bl3);\n    mid += Math.imul(al8, bh3);\n    mid += Math.imul(ah8, bl3);\n    hi += Math.imul(ah8, bh3);\n    lo += Math.imul(al7, bl4);\n    mid += Math.imul(al7, bh4);\n    mid += Math.imul(ah7, bl4);\n    hi += Math.imul(ah7, bh4);\n    lo += Math.imul(al6, bl5);\n    mid += Math.imul(al6, bh5);\n    mid += Math.imul(ah6, bl5);\n    hi += Math.imul(ah6, bh5);\n    lo += Math.imul(al5, bl6);\n    mid += Math.imul(al5, bh6);\n    mid += Math.imul(ah5, bl6);\n    hi += Math.imul(ah5, bh6);\n    lo += Math.imul(al4, bl7);\n    mid += Math.imul(al4, bh7);\n    mid += Math.imul(ah4, bl7);\n    hi += Math.imul(ah4, bh7);\n    lo += Math.imul(al3, bl8);\n    mid += Math.imul(al3, bh8);\n    mid += Math.imul(ah3, bl8);\n    hi += Math.imul(ah3, bh8);\n    lo += Math.imul(al2, bl9);\n    mid += Math.imul(al2, bh9);\n    mid += Math.imul(ah2, bl9);\n    hi += Math.imul(ah2, bh9);\n    var w11 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w11 >>> 26);\n    w11 &= 0x3ffffff;\n    /* k = 12 */\n    lo = Math.imul(al9, bl3);\n    mid = Math.imul(al9, bh3);\n    mid += Math.imul(ah9, bl3);\n    hi = Math.imul(ah9, bh3);\n    lo += Math.imul(al8, bl4);\n    mid += Math.imul(al8, bh4);\n    mid += Math.imul(ah8, bl4);\n    hi += Math.imul(ah8, bh4);\n    lo += Math.imul(al7, bl5);\n    mid += Math.imul(al7, bh5);\n    mid += Math.imul(ah7, bl5);\n    hi += Math.imul(ah7, bh5);\n    lo += Math.imul(al6, bl6);\n    mid += Math.imul(al6, bh6);\n    mid += Math.imul(ah6, bl6);\n    hi += Math.imul(ah6, bh6);\n    lo += Math.imul(al5, bl7);\n    mid += Math.imul(al5, bh7);\n    mid += Math.imul(ah5, bl7);\n    hi += Math.imul(ah5, bh7);\n    lo += Math.imul(al4, bl8);\n    mid += Math.imul(al4, bh8);\n    mid += Math.imul(ah4, bl8);\n    hi += Math.imul(ah4, bh8);\n    lo += Math.imul(al3, bl9);\n    mid += Math.imul(al3, bh9);\n    mid += Math.imul(ah3, bl9);\n    hi += Math.imul(ah3, bh9);\n    var w12 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w12 >>> 26);\n    w12 &= 0x3ffffff;\n    /* k = 13 */\n    lo = Math.imul(al9, bl4);\n    mid = Math.imul(al9, bh4);\n    mid += Math.imul(ah9, bl4);\n    hi = Math.imul(ah9, bh4);\n    lo += Math.imul(al8, bl5);\n    mid += Math.imul(al8, bh5);\n    mid += Math.imul(ah8, bl5);\n    hi += Math.imul(ah8, bh5);\n    lo += Math.imul(al7, bl6);\n    mid += Math.imul(al7, bh6);\n    mid += Math.imul(ah7, bl6);\n    hi += Math.imul(ah7, bh6);\n    lo += Math.imul(al6, bl7);\n    mid += Math.imul(al6, bh7);\n    mid += Math.imul(ah6, bl7);\n    hi += Math.imul(ah6, bh7);\n    lo += Math.imul(al5, bl8);\n    mid += Math.imul(al5, bh8);\n    mid += Math.imul(ah5, bl8);\n    hi += Math.imul(ah5, bh8);\n    lo += Math.imul(al4, bl9);\n    mid += Math.imul(al4, bh9);\n    mid += Math.imul(ah4, bl9);\n    hi += Math.imul(ah4, bh9);\n    var w13 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w13 >>> 26);\n    w13 &= 0x3ffffff;\n    /* k = 14 */\n    lo = Math.imul(al9, bl5);\n    mid = Math.imul(al9, bh5);\n    mid += Math.imul(ah9, bl5);\n    hi = Math.imul(ah9, bh5);\n    lo += Math.imul(al8, bl6);\n    mid += Math.imul(al8, bh6);\n    mid += Math.imul(ah8, bl6);\n    hi += Math.imul(ah8, bh6);\n    lo += Math.imul(al7, bl7);\n    mid += Math.imul(al7, bh7);\n    mid += Math.imul(ah7, bl7);\n    hi += Math.imul(ah7, bh7);\n    lo += Math.imul(al6, bl8);\n    mid += Math.imul(al6, bh8);\n    mid += Math.imul(ah6, bl8);\n    hi += Math.imul(ah6, bh8);\n    lo += Math.imul(al5, bl9);\n    mid += Math.imul(al5, bh9);\n    mid += Math.imul(ah5, bl9);\n    hi += Math.imul(ah5, bh9);\n    var w14 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w14 >>> 26);\n    w14 &= 0x3ffffff;\n    /* k = 15 */\n    lo = Math.imul(al9, bl6);\n    mid = Math.imul(al9, bh6);\n    mid += Math.imul(ah9, bl6);\n    hi = Math.imul(ah9, bh6);\n    lo += Math.imul(al8, bl7);\n    mid += Math.imul(al8, bh7);\n    mid += Math.imul(ah8, bl7);\n    hi += Math.imul(ah8, bh7);\n    lo += Math.imul(al7, bl8);\n    mid += Math.imul(al7, bh8);\n    mid += Math.imul(ah7, bl8);\n    hi += Math.imul(ah7, bh8);\n    lo += Math.imul(al6, bl9);\n    mid += Math.imul(al6, bh9);\n    mid += Math.imul(ah6, bl9);\n    hi += Math.imul(ah6, bh9);\n    var w15 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w15 >>> 26);\n    w15 &= 0x3ffffff;\n    /* k = 16 */\n    lo = Math.imul(al9, bl7);\n    mid = Math.imul(al9, bh7);\n    mid += Math.imul(ah9, bl7);\n    hi = Math.imul(ah9, bh7);\n    lo += Math.imul(al8, bl8);\n    mid += Math.imul(al8, bh8);\n    mid += Math.imul(ah8, bl8);\n    hi += Math.imul(ah8, bh8);\n    lo += Math.imul(al7, bl9);\n    mid += Math.imul(al7, bh9);\n    mid += Math.imul(ah7, bl9);\n    hi += Math.imul(ah7, bh9);\n    var w16 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w16 >>> 26);\n    w16 &= 0x3ffffff;\n    /* k = 17 */\n    lo = Math.imul(al9, bl8);\n    mid = Math.imul(al9, bh8);\n    mid += Math.imul(ah9, bl8);\n    hi = Math.imul(ah9, bh8);\n    lo += Math.imul(al8, bl9);\n    mid += Math.imul(al8, bh9);\n    mid += Math.imul(ah8, bl9);\n    hi += Math.imul(ah8, bh9);\n    var w17 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w17 >>> 26);\n    w17 &= 0x3ffffff;\n    /* k = 18 */\n    lo = Math.imul(al9, bl9);\n    mid = Math.imul(al9, bh9);\n    mid += Math.imul(ah9, bl9);\n    hi = Math.imul(ah9, bh9);\n    var w18 = c + lo + ((mid & 0x1fff) << 13);\n    c = hi + (mid >>> 13) + (w18 >>> 26);\n    w18 &= 0x3ffffff;\n    o[0] = w0;\n    o[1] = w1;\n    o[2] = w2;\n    o[3] = w3;\n    o[4] = w4;\n    o[5] = w5;\n    o[6] = w6;\n    o[7] = w7;\n    o[8] = w8;\n    o[9] = w9;\n    o[10] = w10;\n    o[11] = w11;\n    o[12] = w12;\n    o[13] = w13;\n    o[14] = w14;\n    o[15] = w15;\n    o[16] = w16;\n    o[17] = w17;\n    o[18] = w18;\n    if (c !== 0) {\n      o[19] = c;\n      out.length++;\n    }\n    return out;\n  };\n\n  // Polyfill comb\n  if (!Math.imul) {\n    comb10MulTo = smallMulTo;\n  }\n\n  function bigMulTo (self, num, out) {\n    out.negative = num.negative ^ self.negative;\n    out.length = self.length + num.length;\n\n    var carry = 0;\n    var hncarry = 0;\n    for (var k = 0; k < out.length - 1; k++) {\n      // Sum all words with the same `i + j = k` and accumulate `ncarry`,\n      // note that ncarry could be >= 0x3ffffff\n      var ncarry = hncarry;\n      hncarry = 0;\n      var rword = carry & 0x3ffffff;\n      var maxJ = Math.min(k, num.length - 1);\n      for (var j = Math.max(0, k - self.length + 1); j <= maxJ; j++) {\n        var i = k - j;\n        var a = self.words[i] | 0;\n        var b = num.words[j] | 0;\n        var r = a * b;\n\n        var lo = r & 0x3ffffff;\n        ncarry = (ncarry + ((r / 0x4000000) | 0)) | 0;\n        lo = (lo + rword) | 0;\n        rword = lo & 0x3ffffff;\n        ncarry = (ncarry + (lo >>> 26)) | 0;\n\n        hncarry += ncarry >>> 26;\n        ncarry &= 0x3ffffff;\n      }\n      out.words[k] = rword;\n      carry = ncarry;\n      ncarry = hncarry;\n    }\n    if (carry !== 0) {\n      out.words[k] = carry;\n    } else {\n      out.length--;\n    }\n\n    return out.strip();\n  }\n\n  function jumboMulTo (self, num, out) {\n    var fftm = new FFTM();\n    return fftm.mulp(self, num, out);\n  }\n\n  BN.prototype.mulTo = function mulTo (num, out) {\n    var res;\n    var len = this.length + num.length;\n    if (this.length === 10 && num.length === 10) {\n      res = comb10MulTo(this, num, out);\n    } else if (len < 63) {\n      res = smallMulTo(this, num, out);\n    } else if (len < 1024) {\n      res = bigMulTo(this, num, out);\n    } else {\n      res = jumboMulTo(this, num, out);\n    }\n\n    return res;\n  };\n\n  // Cooley-Tukey algorithm for FFT\n  // slightly revisited to rely on looping instead of recursion\n\n  function FFTM (x, y) {\n    this.x = x;\n    this.y = y;\n  }\n\n  FFTM.prototype.makeRBT = function makeRBT (N) {\n    var t = new Array(N);\n    var l = BN.prototype._countBits(N) - 1;\n    for (var i = 0; i < N; i++) {\n      t[i] = this.revBin(i, l, N);\n    }\n\n    return t;\n  };\n\n  // Returns binary-reversed representation of `x`\n  FFTM.prototype.revBin = function revBin (x, l, N) {\n    if (x === 0 || x === N - 1) return x;\n\n    var rb = 0;\n    for (var i = 0; i < l; i++) {\n      rb |= (x & 1) << (l - i - 1);\n      x >>= 1;\n    }\n\n    return rb;\n  };\n\n  // Performs \"tweedling\" phase, therefore 'emulating'\n  // behaviour of the recursive algorithm\n  FFTM.prototype.permute = function permute (rbt, rws, iws, rtws, itws, N) {\n    for (var i = 0; i < N; i++) {\n      rtws[i] = rws[rbt[i]];\n      itws[i] = iws[rbt[i]];\n    }\n  };\n\n  FFTM.prototype.transform = function transform (rws, iws, rtws, itws, N, rbt) {\n    this.permute(rbt, rws, iws, rtws, itws, N);\n\n    for (var s = 1; s < N; s <<= 1) {\n      var l = s << 1;\n\n      var rtwdf = Math.cos(2 * Math.PI / l);\n      var itwdf = Math.sin(2 * Math.PI / l);\n\n      for (var p = 0; p < N; p += l) {\n        var rtwdf_ = rtwdf;\n        var itwdf_ = itwdf;\n\n        for (var j = 0; j < s; j++) {\n          var re = rtws[p + j];\n          var ie = itws[p + j];\n\n          var ro = rtws[p + j + s];\n          var io = itws[p + j + s];\n\n          var rx = rtwdf_ * ro - itwdf_ * io;\n\n          io = rtwdf_ * io + itwdf_ * ro;\n          ro = rx;\n\n          rtws[p + j] = re + ro;\n          itws[p + j] = ie + io;\n\n          rtws[p + j + s] = re - ro;\n          itws[p + j + s] = ie - io;\n\n          /* jshint maxdepth : false */\n          if (j !== l) {\n            rx = rtwdf * rtwdf_ - itwdf * itwdf_;\n\n            itwdf_ = rtwdf * itwdf_ + itwdf * rtwdf_;\n            rtwdf_ = rx;\n          }\n        }\n      }\n    }\n  };\n\n  FFTM.prototype.guessLen13b = function guessLen13b (n, m) {\n    var N = Math.max(m, n) | 1;\n    var odd = N & 1;\n    var i = 0;\n    for (N = N / 2 | 0; N; N = N >>> 1) {\n      i++;\n    }\n\n    return 1 << i + 1 + odd;\n  };\n\n  FFTM.prototype.conjugate = function conjugate (rws, iws, N) {\n    if (N <= 1) return;\n\n    for (var i = 0; i < N / 2; i++) {\n      var t = rws[i];\n\n      rws[i] = rws[N - i - 1];\n      rws[N - i - 1] = t;\n\n      t = iws[i];\n\n      iws[i] = -iws[N - i - 1];\n      iws[N - i - 1] = -t;\n    }\n  };\n\n  FFTM.prototype.normalize13b = function normalize13b (ws, N) {\n    var carry = 0;\n    for (var i = 0; i < N / 2; i++) {\n      var w = Math.round(ws[2 * i + 1] / N) * 0x2000 +\n        Math.round(ws[2 * i] / N) +\n        carry;\n\n      ws[i] = w & 0x3ffffff;\n\n      if (w < 0x4000000) {\n        carry = 0;\n      } else {\n        carry = w / 0x4000000 | 0;\n      }\n    }\n\n    return ws;\n  };\n\n  FFTM.prototype.convert13b = function convert13b (ws, len, rws, N) {\n    var carry = 0;\n    for (var i = 0; i < len; i++) {\n      carry = carry + (ws[i] | 0);\n\n      rws[2 * i] = carry & 0x1fff; carry = carry >>> 13;\n      rws[2 * i + 1] = carry & 0x1fff; carry = carry >>> 13;\n    }\n\n    // Pad with zeroes\n    for (i = 2 * len; i < N; ++i) {\n      rws[i] = 0;\n    }\n\n    assert(carry === 0);\n    assert((carry & ~0x1fff) === 0);\n  };\n\n  FFTM.prototype.stub = function stub (N) {\n    var ph = new Array(N);\n    for (var i = 0; i < N; i++) {\n      ph[i] = 0;\n    }\n\n    return ph;\n  };\n\n  FFTM.prototype.mulp = function mulp (x, y, out) {\n    var N = 2 * this.guessLen13b(x.length, y.length);\n\n    var rbt = this.makeRBT(N);\n\n    var _ = this.stub(N);\n\n    var rws = new Array(N);\n    var rwst = new Array(N);\n    var iwst = new Array(N);\n\n    var nrws = new Array(N);\n    var nrwst = new Array(N);\n    var niwst = new Array(N);\n\n    var rmws = out.words;\n    rmws.length = N;\n\n    this.convert13b(x.words, x.length, rws, N);\n    this.convert13b(y.words, y.length, nrws, N);\n\n    this.transform(rws, _, rwst, iwst, N, rbt);\n    this.transform(nrws, _, nrwst, niwst, N, rbt);\n\n    for (var i = 0; i < N; i++) {\n      var rx = rwst[i] * nrwst[i] - iwst[i] * niwst[i];\n      iwst[i] = rwst[i] * niwst[i] + iwst[i] * nrwst[i];\n      rwst[i] = rx;\n    }\n\n    this.conjugate(rwst, iwst, N);\n    this.transform(rwst, iwst, rmws, _, N, rbt);\n    this.conjugate(rmws, _, N);\n    this.normalize13b(rmws, N);\n\n    out.negative = x.negative ^ y.negative;\n    out.length = x.length + y.length;\n    return out.strip();\n  };\n\n  // Multiply `this` by `num`\n  BN.prototype.mul = function mul (num) {\n    var out = new BN(null);\n    out.words = new Array(this.length + num.length);\n    return this.mulTo(num, out);\n  };\n\n  // Multiply employing FFT\n  BN.prototype.mulf = function mulf (num) {\n    var out = new BN(null);\n    out.words = new Array(this.length + num.length);\n    return jumboMulTo(this, num, out);\n  };\n\n  // In-place Multiplication\n  BN.prototype.imul = function imul (num) {\n    return this.clone().mulTo(num, this);\n  };\n\n  BN.prototype.imuln = function imuln (num) {\n    assert(typeof num === 'number');\n    assert(num < 0x4000000);\n\n    // Carry\n    var carry = 0;\n    for (var i = 0; i < this.length; i++) {\n      var w = (this.words[i] | 0) * num;\n      var lo = (w & 0x3ffffff) + (carry & 0x3ffffff);\n      carry >>= 26;\n      carry += (w / 0x4000000) | 0;\n      // NOTE: lo is 27bit maximum\n      carry += lo >>> 26;\n      this.words[i] = lo & 0x3ffffff;\n    }\n\n    if (carry !== 0) {\n      this.words[i] = carry;\n      this.length++;\n    }\n\n    return this;\n  };\n\n  BN.prototype.muln = function muln (num) {\n    return this.clone().imuln(num);\n  };\n\n  // `this` * `this`\n  BN.prototype.sqr = function sqr () {\n    return this.mul(this);\n  };\n\n  // `this` * `this` in-place\n  BN.prototype.isqr = function isqr () {\n    return this.imul(this.clone());\n  };\n\n  // Math.pow(`this`, `num`)\n  BN.prototype.pow = function pow (num) {\n    var w = toBitArray(num);\n    if (w.length === 0) return new BN(1);\n\n    // Skip leading zeroes\n    var res = this;\n    for (var i = 0; i < w.length; i++, res = res.sqr()) {\n      if (w[i] !== 0) break;\n    }\n\n    if (++i < w.length) {\n      for (var q = res.sqr(); i < w.length; i++, q = q.sqr()) {\n        if (w[i] === 0) continue;\n\n        res = res.mul(q);\n      }\n    }\n\n    return res;\n  };\n\n  // Shift-left in-place\n  BN.prototype.iushln = function iushln (bits) {\n    assert(typeof bits === 'number' && bits >= 0);\n    var r = bits % 26;\n    var s = (bits - r) / 26;\n    var carryMask = (0x3ffffff >>> (26 - r)) << (26 - r);\n    var i;\n\n    if (r !== 0) {\n      var carry = 0;\n\n      for (i = 0; i < this.length; i++) {\n        var newCarry = this.words[i] & carryMask;\n        var c = ((this.words[i] | 0) - newCarry) << r;\n        this.words[i] = c | carry;\n        carry = newCarry >>> (26 - r);\n      }\n\n      if (carry) {\n        this.words[i] = carry;\n        this.length++;\n      }\n    }\n\n    if (s !== 0) {\n      for (i = this.length - 1; i >= 0; i--) {\n        this.words[i + s] = this.words[i];\n      }\n\n      for (i = 0; i < s; i++) {\n        this.words[i] = 0;\n      }\n\n      this.length += s;\n    }\n\n    return this.strip();\n  };\n\n  BN.prototype.ishln = function ishln (bits) {\n    // TODO(indutny): implement me\n    assert(this.negative === 0);\n    return this.iushln(bits);\n  };\n\n  // Shift-right in-place\n  // NOTE: `hint` is a lowest bit before trailing zeroes\n  // NOTE: if `extended` is present - it will be filled with destroyed bits\n  BN.prototype.iushrn = function iushrn (bits, hint, extended) {\n    assert(typeof bits === 'number' && bits >= 0);\n    var h;\n    if (hint) {\n      h = (hint - (hint % 26)) / 26;\n    } else {\n      h = 0;\n    }\n\n    var r = bits % 26;\n    var s = Math.min((bits - r) / 26, this.length);\n    var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n    var maskedWords = extended;\n\n    h -= s;\n    h = Math.max(0, h);\n\n    // Extended mode, copy masked part\n    if (maskedWords) {\n      for (var i = 0; i < s; i++) {\n        maskedWords.words[i] = this.words[i];\n      }\n      maskedWords.length = s;\n    }\n\n    if (s === 0) {\n      // No-op, we should not move anything at all\n    } else if (this.length > s) {\n      this.length -= s;\n      for (i = 0; i < this.length; i++) {\n        this.words[i] = this.words[i + s];\n      }\n    } else {\n      this.words[0] = 0;\n      this.length = 1;\n    }\n\n    var carry = 0;\n    for (i = this.length - 1; i >= 0 && (carry !== 0 || i >= h); i--) {\n      var word = this.words[i] | 0;\n      this.words[i] = (carry << (26 - r)) | (word >>> r);\n      carry = word & mask;\n    }\n\n    // Push carried bits as a mask\n    if (maskedWords && carry !== 0) {\n      maskedWords.words[maskedWords.length++] = carry;\n    }\n\n    if (this.length === 0) {\n      this.words[0] = 0;\n      this.length = 1;\n    }\n\n    return this.strip();\n  };\n\n  BN.prototype.ishrn = function ishrn (bits, hint, extended) {\n    // TODO(indutny): implement me\n    assert(this.negative === 0);\n    return this.iushrn(bits, hint, extended);\n  };\n\n  // Shift-left\n  BN.prototype.shln = function shln (bits) {\n    return this.clone().ishln(bits);\n  };\n\n  BN.prototype.ushln = function ushln (bits) {\n    return this.clone().iushln(bits);\n  };\n\n  // Shift-right\n  BN.prototype.shrn = function shrn (bits) {\n    return this.clone().ishrn(bits);\n  };\n\n  BN.prototype.ushrn = function ushrn (bits) {\n    return this.clone().iushrn(bits);\n  };\n\n  // Test if n bit is set\n  BN.prototype.testn = function testn (bit) {\n    assert(typeof bit === 'number' && bit >= 0);\n    var r = bit % 26;\n    var s = (bit - r) / 26;\n    var q = 1 << r;\n\n    // Fast case: bit is much higher than all existing words\n    if (this.length <= s) return false;\n\n    // Check bit and return\n    var w = this.words[s];\n\n    return !!(w & q);\n  };\n\n  // Return only lowers bits of number (in-place)\n  BN.prototype.imaskn = function imaskn (bits) {\n    assert(typeof bits === 'number' && bits >= 0);\n    var r = bits % 26;\n    var s = (bits - r) / 26;\n\n    assert(this.negative === 0, 'imaskn works only with positive numbers');\n\n    if (r !== 0) {\n      s++;\n    }\n    this.length = Math.min(s, this.length);\n\n    if (r !== 0) {\n      var mask = 0x3ffffff ^ ((0x3ffffff >>> r) << r);\n      this.words[this.length - 1] &= mask;\n    }\n\n    return this.strip();\n  };\n\n  // Return only lowers bits of number\n  BN.prototype.maskn = function maskn (bits) {\n    return this.clone().imaskn(bits);\n  };\n\n  // Add plain number `num` to `this`\n  BN.prototype.iaddn = function iaddn (num) {\n    assert(typeof num === 'number');\n    assert(num < 0x4000000);\n    if (num < 0) return this.isubn(-num);\n\n    // Possible sign change\n    if (this.negative !== 0) {\n      if (this.length === 1 && (this.words[0] | 0) < num) {\n        this.words[0] = num - (this.words[0] | 0);\n        this.negative = 0;\n        return this;\n      }\n\n      this.negative = 0;\n      this.isubn(num);\n      this.negative = 1;\n      return this;\n    }\n\n    // Add without checks\n    return this._iaddn(num);\n  };\n\n  BN.prototype._iaddn = function _iaddn (num) {\n    this.words[0] += num;\n\n    // Carry\n    for (var i = 0; i < this.length && this.words[i] >= 0x4000000; i++) {\n      this.words[i] -= 0x4000000;\n      if (i === this.length - 1) {\n        this.words[i + 1] = 1;\n      } else {\n        this.words[i + 1]++;\n      }\n    }\n    this.length = Math.max(this.length, i + 1);\n\n    return this;\n  };\n\n  // Subtract plain number `num` from `this`\n  BN.prototype.isubn = function isubn (num) {\n    assert(typeof num === 'number');\n    assert(num < 0x4000000);\n    if (num < 0) return this.iaddn(-num);\n\n    if (this.negative !== 0) {\n      this.negative = 0;\n      this.iaddn(num);\n      this.negative = 1;\n      return this;\n    }\n\n    this.words[0] -= num;\n\n    if (this.length === 1 && this.words[0] < 0) {\n      this.words[0] = -this.words[0];\n      this.negative = 1;\n    } else {\n      // Carry\n      for (var i = 0; i < this.length && this.words[i] < 0; i++) {\n        this.words[i] += 0x4000000;\n        this.words[i + 1] -= 1;\n      }\n    }\n\n    return this.strip();\n  };\n\n  BN.prototype.addn = function addn (num) {\n    return this.clone().iaddn(num);\n  };\n\n  BN.prototype.subn = function subn (num) {\n    return this.clone().isubn(num);\n  };\n\n  BN.prototype.iabs = function iabs () {\n    this.negative = 0;\n\n    return this;\n  };\n\n  BN.prototype.abs = function abs () {\n    return this.clone().iabs();\n  };\n\n  BN.prototype._ishlnsubmul = function _ishlnsubmul (num, mul, shift) {\n    var len = num.length + shift;\n    var i;\n\n    this._expand(len);\n\n    var w;\n    var carry = 0;\n    for (i = 0; i < num.length; i++) {\n      w = (this.words[i + shift] | 0) + carry;\n      var right = (num.words[i] | 0) * mul;\n      w -= right & 0x3ffffff;\n      carry = (w >> 26) - ((right / 0x4000000) | 0);\n      this.words[i + shift] = w & 0x3ffffff;\n    }\n    for (; i < this.length - shift; i++) {\n      w = (this.words[i + shift] | 0) + carry;\n      carry = w >> 26;\n      this.words[i + shift] = w & 0x3ffffff;\n    }\n\n    if (carry === 0) return this.strip();\n\n    // Subtraction overflow\n    assert(carry === -1);\n    carry = 0;\n    for (i = 0; i < this.length; i++) {\n      w = -(this.words[i] | 0) + carry;\n      carry = w >> 26;\n      this.words[i] = w & 0x3ffffff;\n    }\n    this.negative = 1;\n\n    return this.strip();\n  };\n\n  BN.prototype._wordDiv = function _wordDiv (num, mode) {\n    var shift = this.length - num.length;\n\n    var a = this.clone();\n    var b = num;\n\n    // Normalize\n    var bhi = b.words[b.length - 1] | 0;\n    var bhiBits = this._countBits(bhi);\n    shift = 26 - bhiBits;\n    if (shift !== 0) {\n      b = b.ushln(shift);\n      a.iushln(shift);\n      bhi = b.words[b.length - 1] | 0;\n    }\n\n    // Initialize quotient\n    var m = a.length - b.length;\n    var q;\n\n    if (mode !== 'mod') {\n      q = new BN(null);\n      q.length = m + 1;\n      q.words = new Array(q.length);\n      for (var i = 0; i < q.length; i++) {\n        q.words[i] = 0;\n      }\n    }\n\n    var diff = a.clone()._ishlnsubmul(b, 1, m);\n    if (diff.negative === 0) {\n      a = diff;\n      if (q) {\n        q.words[m] = 1;\n      }\n    }\n\n    for (var j = m - 1; j >= 0; j--) {\n      var qj = (a.words[b.length + j] | 0) * 0x4000000 +\n        (a.words[b.length + j - 1] | 0);\n\n      // NOTE: (qj / bhi) is (0x3ffffff * 0x4000000 + 0x3ffffff) / 0x2000000 max\n      // (0x7ffffff)\n      qj = Math.min((qj / bhi) | 0, 0x3ffffff);\n\n      a._ishlnsubmul(b, qj, j);\n      while (a.negative !== 0) {\n        qj--;\n        a.negative = 0;\n        a._ishlnsubmul(b, 1, j);\n        if (!a.isZero()) {\n          a.negative ^= 1;\n        }\n      }\n      if (q) {\n        q.words[j] = qj;\n      }\n    }\n    if (q) {\n      q.strip();\n    }\n    a.strip();\n\n    // Denormalize\n    if (mode !== 'div' && shift !== 0) {\n      a.iushrn(shift);\n    }\n\n    return {\n      div: q || null,\n      mod: a\n    };\n  };\n\n  // NOTE: 1) `mode` can be set to `mod` to request mod only,\n  //       to `div` to request div only, or be absent to\n  //       request both div & mod\n  //       2) `positive` is true if unsigned mod is requested\n  BN.prototype.divmod = function divmod (num, mode, positive) {\n    assert(!num.isZero());\n\n    if (this.isZero()) {\n      return {\n        div: new BN(0),\n        mod: new BN(0)\n      };\n    }\n\n    var div, mod, res;\n    if (this.negative !== 0 && num.negative === 0) {\n      res = this.neg().divmod(num, mode);\n\n      if (mode !== 'mod') {\n        div = res.div.neg();\n      }\n\n      if (mode !== 'div') {\n        mod = res.mod.neg();\n        if (positive && mod.negative !== 0) {\n          mod.iadd(num);\n        }\n      }\n\n      return {\n        div: div,\n        mod: mod\n      };\n    }\n\n    if (this.negative === 0 && num.negative !== 0) {\n      res = this.divmod(num.neg(), mode);\n\n      if (mode !== 'mod') {\n        div = res.div.neg();\n      }\n\n      return {\n        div: div,\n        mod: res.mod\n      };\n    }\n\n    if ((this.negative & num.negative) !== 0) {\n      res = this.neg().divmod(num.neg(), mode);\n\n      if (mode !== 'div') {\n        mod = res.mod.neg();\n        if (positive && mod.negative !== 0) {\n          mod.isub(num);\n        }\n      }\n\n      return {\n        div: res.div,\n        mod: mod\n      };\n    }\n\n    // Both numbers are positive at this point\n\n    // Strip both numbers to approximate shift value\n    if (num.length > this.length || this.cmp(num) < 0) {\n      return {\n        div: new BN(0),\n        mod: this\n      };\n    }\n\n    // Very short reduction\n    if (num.length === 1) {\n      if (mode === 'div') {\n        return {\n          div: this.divn(num.words[0]),\n          mod: null\n        };\n      }\n\n      if (mode === 'mod') {\n        return {\n          div: null,\n          mod: new BN(this.modn(num.words[0]))\n        };\n      }\n\n      return {\n        div: this.divn(num.words[0]),\n        mod: new BN(this.modn(num.words[0]))\n      };\n    }\n\n    return this._wordDiv(num, mode);\n  };\n\n  // Find `this` / `num`\n  BN.prototype.div = function div (num) {\n    return this.divmod(num, 'div', false).div;\n  };\n\n  // Find `this` % `num`\n  BN.prototype.mod = function mod (num) {\n    return this.divmod(num, 'mod', false).mod;\n  };\n\n  BN.prototype.umod = function umod (num) {\n    return this.divmod(num, 'mod', true).mod;\n  };\n\n  // Find Round(`this` / `num`)\n  BN.prototype.divRound = function divRound (num) {\n    var dm = this.divmod(num);\n\n    // Fast case - exact division\n    if (dm.mod.isZero()) return dm.div;\n\n    var mod = dm.div.negative !== 0 ? dm.mod.isub(num) : dm.mod;\n\n    var half = num.ushrn(1);\n    var r2 = num.andln(1);\n    var cmp = mod.cmp(half);\n\n    // Round down\n    if (cmp < 0 || r2 === 1 && cmp === 0) return dm.div;\n\n    // Round up\n    return dm.div.negative !== 0 ? dm.div.isubn(1) : dm.div.iaddn(1);\n  };\n\n  BN.prototype.modn = function modn (num) {\n    assert(num <= 0x3ffffff);\n    var p = (1 << 26) % num;\n\n    var acc = 0;\n    for (var i = this.length - 1; i >= 0; i--) {\n      acc = (p * acc + (this.words[i] | 0)) % num;\n    }\n\n    return acc;\n  };\n\n  // In-place division by number\n  BN.prototype.idivn = function idivn (num) {\n    assert(num <= 0x3ffffff);\n\n    var carry = 0;\n    for (var i = this.length - 1; i >= 0; i--) {\n      var w = (this.words[i] | 0) + carry * 0x4000000;\n      this.words[i] = (w / num) | 0;\n      carry = w % num;\n    }\n\n    return this.strip();\n  };\n\n  BN.prototype.divn = function divn (num) {\n    return this.clone().idivn(num);\n  };\n\n  BN.prototype.egcd = function egcd (p) {\n    assert(p.negative === 0);\n    assert(!p.isZero());\n\n    var x = this;\n    var y = p.clone();\n\n    if (x.negative !== 0) {\n      x = x.umod(p);\n    } else {\n      x = x.clone();\n    }\n\n    // A * x + B * y = x\n    var A = new BN(1);\n    var B = new BN(0);\n\n    // C * x + D * y = y\n    var C = new BN(0);\n    var D = new BN(1);\n\n    var g = 0;\n\n    while (x.isEven() && y.isEven()) {\n      x.iushrn(1);\n      y.iushrn(1);\n      ++g;\n    }\n\n    var yp = y.clone();\n    var xp = x.clone();\n\n    while (!x.isZero()) {\n      for (var i = 0, im = 1; (x.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n      if (i > 0) {\n        x.iushrn(i);\n        while (i-- > 0) {\n          if (A.isOdd() || B.isOdd()) {\n            A.iadd(yp);\n            B.isub(xp);\n          }\n\n          A.iushrn(1);\n          B.iushrn(1);\n        }\n      }\n\n      for (var j = 0, jm = 1; (y.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n      if (j > 0) {\n        y.iushrn(j);\n        while (j-- > 0) {\n          if (C.isOdd() || D.isOdd()) {\n            C.iadd(yp);\n            D.isub(xp);\n          }\n\n          C.iushrn(1);\n          D.iushrn(1);\n        }\n      }\n\n      if (x.cmp(y) >= 0) {\n        x.isub(y);\n        A.isub(C);\n        B.isub(D);\n      } else {\n        y.isub(x);\n        C.isub(A);\n        D.isub(B);\n      }\n    }\n\n    return {\n      a: C,\n      b: D,\n      gcd: y.iushln(g)\n    };\n  };\n\n  // This is reduced incarnation of the binary EEA\n  // above, designated to invert members of the\n  // _prime_ fields F(p) at a maximal speed\n  BN.prototype._invmp = function _invmp (p) {\n    assert(p.negative === 0);\n    assert(!p.isZero());\n\n    var a = this;\n    var b = p.clone();\n\n    if (a.negative !== 0) {\n      a = a.umod(p);\n    } else {\n      a = a.clone();\n    }\n\n    var x1 = new BN(1);\n    var x2 = new BN(0);\n\n    var delta = b.clone();\n\n    while (a.cmpn(1) > 0 && b.cmpn(1) > 0) {\n      for (var i = 0, im = 1; (a.words[0] & im) === 0 && i < 26; ++i, im <<= 1);\n      if (i > 0) {\n        a.iushrn(i);\n        while (i-- > 0) {\n          if (x1.isOdd()) {\n            x1.iadd(delta);\n          }\n\n          x1.iushrn(1);\n        }\n      }\n\n      for (var j = 0, jm = 1; (b.words[0] & jm) === 0 && j < 26; ++j, jm <<= 1);\n      if (j > 0) {\n        b.iushrn(j);\n        while (j-- > 0) {\n          if (x2.isOdd()) {\n            x2.iadd(delta);\n          }\n\n          x2.iushrn(1);\n        }\n      }\n\n      if (a.cmp(b) >= 0) {\n        a.isub(b);\n        x1.isub(x2);\n      } else {\n        b.isub(a);\n        x2.isub(x1);\n      }\n    }\n\n    var res;\n    if (a.cmpn(1) === 0) {\n      res = x1;\n    } else {\n      res = x2;\n    }\n\n    if (res.cmpn(0) < 0) {\n      res.iadd(p);\n    }\n\n    return res;\n  };\n\n  BN.prototype.gcd = function gcd (num) {\n    if (this.isZero()) return num.abs();\n    if (num.isZero()) return this.abs();\n\n    var a = this.clone();\n    var b = num.clone();\n    a.negative = 0;\n    b.negative = 0;\n\n    // Remove common factor of two\n    for (var shift = 0; a.isEven() && b.isEven(); shift++) {\n      a.iushrn(1);\n      b.iushrn(1);\n    }\n\n    do {\n      while (a.isEven()) {\n        a.iushrn(1);\n      }\n      while (b.isEven()) {\n        b.iushrn(1);\n      }\n\n      var r = a.cmp(b);\n      if (r < 0) {\n        // Swap `a` and `b` to make `a` always bigger than `b`\n        var t = a;\n        a = b;\n        b = t;\n      } else if (r === 0 || b.cmpn(1) === 0) {\n        break;\n      }\n\n      a.isub(b);\n    } while (true);\n\n    return b.iushln(shift);\n  };\n\n  // Invert number in the field F(num)\n  BN.prototype.invm = function invm (num) {\n    return this.egcd(num).a.umod(num);\n  };\n\n  BN.prototype.isEven = function isEven () {\n    return (this.words[0] & 1) === 0;\n  };\n\n  BN.prototype.isOdd = function isOdd () {\n    return (this.words[0] & 1) === 1;\n  };\n\n  // And first word and num\n  BN.prototype.andln = function andln (num) {\n    return this.words[0] & num;\n  };\n\n  // Increment at the bit position in-line\n  BN.prototype.bincn = function bincn (bit) {\n    assert(typeof bit === 'number');\n    var r = bit % 26;\n    var s = (bit - r) / 26;\n    var q = 1 << r;\n\n    // Fast case: bit is much higher than all existing words\n    if (this.length <= s) {\n      this._expand(s + 1);\n      this.words[s] |= q;\n      return this;\n    }\n\n    // Add bit and propagate, if needed\n    var carry = q;\n    for (var i = s; carry !== 0 && i < this.length; i++) {\n      var w = this.words[i] | 0;\n      w += carry;\n      carry = w >>> 26;\n      w &= 0x3ffffff;\n      this.words[i] = w;\n    }\n    if (carry !== 0) {\n      this.words[i] = carry;\n      this.length++;\n    }\n    return this;\n  };\n\n  BN.prototype.isZero = function isZero () {\n    return this.length === 1 && this.words[0] === 0;\n  };\n\n  BN.prototype.cmpn = function cmpn (num) {\n    var negative = num < 0;\n\n    if (this.negative !== 0 && !negative) return -1;\n    if (this.negative === 0 && negative) return 1;\n\n    this.strip();\n\n    var res;\n    if (this.length > 1) {\n      res = 1;\n    } else {\n      if (negative) {\n        num = -num;\n      }\n\n      assert(num <= 0x3ffffff, 'Number is too big');\n\n      var w = this.words[0] | 0;\n      res = w === num ? 0 : w < num ? -1 : 1;\n    }\n    if (this.negative !== 0) return -res | 0;\n    return res;\n  };\n\n  // Compare two numbers and return:\n  // 1 - if `this` > `num`\n  // 0 - if `this` == `num`\n  // -1 - if `this` < `num`\n  BN.prototype.cmp = function cmp (num) {\n    if (this.negative !== 0 && num.negative === 0) return -1;\n    if (this.negative === 0 && num.negative !== 0) return 1;\n\n    var res = this.ucmp(num);\n    if (this.negative !== 0) return -res | 0;\n    return res;\n  };\n\n  // Unsigned comparison\n  BN.prototype.ucmp = function ucmp (num) {\n    // At this point both numbers have the same sign\n    if (this.length > num.length) return 1;\n    if (this.length < num.length) return -1;\n\n    var res = 0;\n    for (var i = this.length - 1; i >= 0; i--) {\n      var a = this.words[i] | 0;\n      var b = num.words[i] | 0;\n\n      if (a === b) continue;\n      if (a < b) {\n        res = -1;\n      } else if (a > b) {\n        res = 1;\n      }\n      break;\n    }\n    return res;\n  };\n\n  BN.prototype.gtn = function gtn (num) {\n    return this.cmpn(num) === 1;\n  };\n\n  BN.prototype.gt = function gt (num) {\n    return this.cmp(num) === 1;\n  };\n\n  BN.prototype.gten = function gten (num) {\n    return this.cmpn(num) >= 0;\n  };\n\n  BN.prototype.gte = function gte (num) {\n    return this.cmp(num) >= 0;\n  };\n\n  BN.prototype.ltn = function ltn (num) {\n    return this.cmpn(num) === -1;\n  };\n\n  BN.prototype.lt = function lt (num) {\n    return this.cmp(num) === -1;\n  };\n\n  BN.prototype.lten = function lten (num) {\n    return this.cmpn(num) <= 0;\n  };\n\n  BN.prototype.lte = function lte (num) {\n    return this.cmp(num) <= 0;\n  };\n\n  BN.prototype.eqn = function eqn (num) {\n    return this.cmpn(num) === 0;\n  };\n\n  BN.prototype.eq = function eq (num) {\n    return this.cmp(num) === 0;\n  };\n\n  //\n  // A reduce context, could be using montgomery or something better, depending\n  // on the `m` itself.\n  //\n  BN.red = function red (num) {\n    return new Red(num);\n  };\n\n  BN.prototype.toRed = function toRed (ctx) {\n    assert(!this.red, 'Already a number in reduction context');\n    assert(this.negative === 0, 'red works only with positives');\n    return ctx.convertTo(this)._forceRed(ctx);\n  };\n\n  BN.prototype.fromRed = function fromRed () {\n    assert(this.red, 'fromRed works only with numbers in reduction context');\n    return this.red.convertFrom(this);\n  };\n\n  BN.prototype._forceRed = function _forceRed (ctx) {\n    this.red = ctx;\n    return this;\n  };\n\n  BN.prototype.forceRed = function forceRed (ctx) {\n    assert(!this.red, 'Already a number in reduction context');\n    return this._forceRed(ctx);\n  };\n\n  BN.prototype.redAdd = function redAdd (num) {\n    assert(this.red, 'redAdd works only with red numbers');\n    return this.red.add(this, num);\n  };\n\n  BN.prototype.redIAdd = function redIAdd (num) {\n    assert(this.red, 'redIAdd works only with red numbers');\n    return this.red.iadd(this, num);\n  };\n\n  BN.prototype.redSub = function redSub (num) {\n    assert(this.red, 'redSub works only with red numbers');\n    return this.red.sub(this, num);\n  };\n\n  BN.prototype.redISub = function redISub (num) {\n    assert(this.red, 'redISub works only with red numbers');\n    return this.red.isub(this, num);\n  };\n\n  BN.prototype.redShl = function redShl (num) {\n    assert(this.red, 'redShl works only with red numbers');\n    return this.red.shl(this, num);\n  };\n\n  BN.prototype.redMul = function redMul (num) {\n    assert(this.red, 'redMul works only with red numbers');\n    this.red._verify2(this, num);\n    return this.red.mul(this, num);\n  };\n\n  BN.prototype.redIMul = function redIMul (num) {\n    assert(this.red, 'redMul works only with red numbers');\n    this.red._verify2(this, num);\n    return this.red.imul(this, num);\n  };\n\n  BN.prototype.redSqr = function redSqr () {\n    assert(this.red, 'redSqr works only with red numbers');\n    this.red._verify1(this);\n    return this.red.sqr(this);\n  };\n\n  BN.prototype.redISqr = function redISqr () {\n    assert(this.red, 'redISqr works only with red numbers');\n    this.red._verify1(this);\n    return this.red.isqr(this);\n  };\n\n  // Square root over p\n  BN.prototype.redSqrt = function redSqrt () {\n    assert(this.red, 'redSqrt works only with red numbers');\n    this.red._verify1(this);\n    return this.red.sqrt(this);\n  };\n\n  BN.prototype.redInvm = function redInvm () {\n    assert(this.red, 'redInvm works only with red numbers');\n    this.red._verify1(this);\n    return this.red.invm(this);\n  };\n\n  // Return negative clone of `this` % `red modulo`\n  BN.prototype.redNeg = function redNeg () {\n    assert(this.red, 'redNeg works only with red numbers');\n    this.red._verify1(this);\n    return this.red.neg(this);\n  };\n\n  BN.prototype.redPow = function redPow (num) {\n    assert(this.red && !num.red, 'redPow(normalNum)');\n    this.red._verify1(this);\n    return this.red.pow(this, num);\n  };\n\n  // Prime numbers with efficient reduction\n  var primes = {\n    k256: null,\n    p224: null,\n    p192: null,\n    p25519: null\n  };\n\n  // Pseudo-Mersenne prime\n  function MPrime (name, p) {\n    // P = 2 ^ N - K\n    this.name = name;\n    this.p = new BN(p, 16);\n    this.n = this.p.bitLength();\n    this.k = new BN(1).iushln(this.n).isub(this.p);\n\n    this.tmp = this._tmp();\n  }\n\n  MPrime.prototype._tmp = function _tmp () {\n    var tmp = new BN(null);\n    tmp.words = new Array(Math.ceil(this.n / 13));\n    return tmp;\n  };\n\n  MPrime.prototype.ireduce = function ireduce (num) {\n    // Assumes that `num` is less than `P^2`\n    // num = HI * (2 ^ N - K) + HI * K + LO = HI * K + LO (mod P)\n    var r = num;\n    var rlen;\n\n    do {\n      this.split(r, this.tmp);\n      r = this.imulK(r);\n      r = r.iadd(this.tmp);\n      rlen = r.bitLength();\n    } while (rlen > this.n);\n\n    var cmp = rlen < this.n ? -1 : r.ucmp(this.p);\n    if (cmp === 0) {\n      r.words[0] = 0;\n      r.length = 1;\n    } else if (cmp > 0) {\n      r.isub(this.p);\n    } else {\n      r.strip();\n    }\n\n    return r;\n  };\n\n  MPrime.prototype.split = function split (input, out) {\n    input.iushrn(this.n, 0, out);\n  };\n\n  MPrime.prototype.imulK = function imulK (num) {\n    return num.imul(this.k);\n  };\n\n  function K256 () {\n    MPrime.call(\n      this,\n      'k256',\n      'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f');\n  }\n  inherits(K256, MPrime);\n\n  K256.prototype.split = function split (input, output) {\n    // 256 = 9 * 26 + 22\n    var mask = 0x3fffff;\n\n    var outLen = Math.min(input.length, 9);\n    for (var i = 0; i < outLen; i++) {\n      output.words[i] = input.words[i];\n    }\n    output.length = outLen;\n\n    if (input.length <= 9) {\n      input.words[0] = 0;\n      input.length = 1;\n      return;\n    }\n\n    // Shift by 9 limbs\n    var prev = input.words[9];\n    output.words[output.length++] = prev & mask;\n\n    for (i = 10; i < input.length; i++) {\n      var next = input.words[i] | 0;\n      input.words[i - 10] = ((next & mask) << 4) | (prev >>> 22);\n      prev = next;\n    }\n    prev >>>= 22;\n    input.words[i - 10] = prev;\n    if (prev === 0 && input.length > 10) {\n      input.length -= 10;\n    } else {\n      input.length -= 9;\n    }\n  };\n\n  K256.prototype.imulK = function imulK (num) {\n    // K = 0x1000003d1 = [ 0x40, 0x3d1 ]\n    num.words[num.length] = 0;\n    num.words[num.length + 1] = 0;\n    num.length += 2;\n\n    // bounded at: 0x40 * 0x3ffffff + 0x3d0 = 0x100000390\n    var lo = 0;\n    for (var i = 0; i < num.length; i++) {\n      var w = num.words[i] | 0;\n      lo += w * 0x3d1;\n      num.words[i] = lo & 0x3ffffff;\n      lo = w * 0x40 + ((lo / 0x4000000) | 0);\n    }\n\n    // Fast length reduction\n    if (num.words[num.length - 1] === 0) {\n      num.length--;\n      if (num.words[num.length - 1] === 0) {\n        num.length--;\n      }\n    }\n    return num;\n  };\n\n  function P224 () {\n    MPrime.call(\n      this,\n      'p224',\n      'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001');\n  }\n  inherits(P224, MPrime);\n\n  function P192 () {\n    MPrime.call(\n      this,\n      'p192',\n      'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff');\n  }\n  inherits(P192, MPrime);\n\n  function P25519 () {\n    // 2 ^ 255 - 19\n    MPrime.call(\n      this,\n      '25519',\n      '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed');\n  }\n  inherits(P25519, MPrime);\n\n  P25519.prototype.imulK = function imulK (num) {\n    // K = 0x13\n    var carry = 0;\n    for (var i = 0; i < num.length; i++) {\n      var hi = (num.words[i] | 0) * 0x13 + carry;\n      var lo = hi & 0x3ffffff;\n      hi >>>= 26;\n\n      num.words[i] = lo;\n      carry = hi;\n    }\n    if (carry !== 0) {\n      num.words[num.length++] = carry;\n    }\n    return num;\n  };\n\n  // Exported mostly for testing purposes, use plain name instead\n  BN._prime = function prime (name) {\n    // Cached version of prime\n    if (primes[name]) return primes[name];\n\n    var prime;\n    if (name === 'k256') {\n      prime = new K256();\n    } else if (name === 'p224') {\n      prime = new P224();\n    } else if (name === 'p192') {\n      prime = new P192();\n    } else if (name === 'p25519') {\n      prime = new P25519();\n    } else {\n      throw new Error('Unknown prime ' + name);\n    }\n    primes[name] = prime;\n\n    return prime;\n  };\n\n  //\n  // Base reduction engine\n  //\n  function Red (m) {\n    if (typeof m === 'string') {\n      var prime = BN._prime(m);\n      this.m = prime.p;\n      this.prime = prime;\n    } else {\n      assert(m.gtn(1), 'modulus must be greater than 1');\n      this.m = m;\n      this.prime = null;\n    }\n  }\n\n  Red.prototype._verify1 = function _verify1 (a) {\n    assert(a.negative === 0, 'red works only with positives');\n    assert(a.red, 'red works only with red numbers');\n  };\n\n  Red.prototype._verify2 = function _verify2 (a, b) {\n    assert((a.negative | b.negative) === 0, 'red works only with positives');\n    assert(a.red && a.red === b.red,\n      'red works only with red numbers');\n  };\n\n  Red.prototype.imod = function imod (a) {\n    if (this.prime) return this.prime.ireduce(a)._forceRed(this);\n    return a.umod(this.m)._forceRed(this);\n  };\n\n  Red.prototype.neg = function neg (a) {\n    if (a.isZero()) {\n      return a.clone();\n    }\n\n    return this.m.sub(a)._forceRed(this);\n  };\n\n  Red.prototype.add = function add (a, b) {\n    this._verify2(a, b);\n\n    var res = a.add(b);\n    if (res.cmp(this.m) >= 0) {\n      res.isub(this.m);\n    }\n    return res._forceRed(this);\n  };\n\n  Red.prototype.iadd = function iadd (a, b) {\n    this._verify2(a, b);\n\n    var res = a.iadd(b);\n    if (res.cmp(this.m) >= 0) {\n      res.isub(this.m);\n    }\n    return res;\n  };\n\n  Red.prototype.sub = function sub (a, b) {\n    this._verify2(a, b);\n\n    var res = a.sub(b);\n    if (res.cmpn(0) < 0) {\n      res.iadd(this.m);\n    }\n    return res._forceRed(this);\n  };\n\n  Red.prototype.isub = function isub (a, b) {\n    this._verify2(a, b);\n\n    var res = a.isub(b);\n    if (res.cmpn(0) < 0) {\n      res.iadd(this.m);\n    }\n    return res;\n  };\n\n  Red.prototype.shl = function shl (a, num) {\n    this._verify1(a);\n    return this.imod(a.ushln(num));\n  };\n\n  Red.prototype.imul = function imul (a, b) {\n    this._verify2(a, b);\n    return this.imod(a.imul(b));\n  };\n\n  Red.prototype.mul = function mul (a, b) {\n    this._verify2(a, b);\n    return this.imod(a.mul(b));\n  };\n\n  Red.prototype.isqr = function isqr (a) {\n    return this.imul(a, a.clone());\n  };\n\n  Red.prototype.sqr = function sqr (a) {\n    return this.mul(a, a);\n  };\n\n  Red.prototype.sqrt = function sqrt (a) {\n    if (a.isZero()) return a.clone();\n\n    var mod3 = this.m.andln(3);\n    assert(mod3 % 2 === 1);\n\n    // Fast case\n    if (mod3 === 3) {\n      var pow = this.m.add(new BN(1)).iushrn(2);\n      return this.pow(a, pow);\n    }\n\n    // Tonelli-Shanks algorithm (Totally unoptimized and slow)\n    //\n    // Find Q and S, that Q * 2 ^ S = (P - 1)\n    var q = this.m.subn(1);\n    var s = 0;\n    while (!q.isZero() && q.andln(1) === 0) {\n      s++;\n      q.iushrn(1);\n    }\n    assert(!q.isZero());\n\n    var one = new BN(1).toRed(this);\n    var nOne = one.redNeg();\n\n    // Find quadratic non-residue\n    // NOTE: Max is such because of generalized Riemann hypothesis.\n    var lpow = this.m.subn(1).iushrn(1);\n    var z = this.m.bitLength();\n    z = new BN(2 * z * z).toRed(this);\n\n    while (this.pow(z, lpow).cmp(nOne) !== 0) {\n      z.redIAdd(nOne);\n    }\n\n    var c = this.pow(z, q);\n    var r = this.pow(a, q.addn(1).iushrn(1));\n    var t = this.pow(a, q);\n    var m = s;\n    while (t.cmp(one) !== 0) {\n      var tmp = t;\n      for (var i = 0; tmp.cmp(one) !== 0; i++) {\n        tmp = tmp.redSqr();\n      }\n      assert(i < m);\n      var b = this.pow(c, new BN(1).iushln(m - i - 1));\n\n      r = r.redMul(b);\n      c = b.redSqr();\n      t = t.redMul(c);\n      m = i;\n    }\n\n    return r;\n  };\n\n  Red.prototype.invm = function invm (a) {\n    var inv = a._invmp(this.m);\n    if (inv.negative !== 0) {\n      inv.negative = 0;\n      return this.imod(inv).redNeg();\n    } else {\n      return this.imod(inv);\n    }\n  };\n\n  Red.prototype.pow = function pow (a, num) {\n    if (num.isZero()) return new BN(1);\n    if (num.cmpn(1) === 0) return a.clone();\n\n    var windowSize = 4;\n    var wnd = new Array(1 << windowSize);\n    wnd[0] = new BN(1).toRed(this);\n    wnd[1] = a;\n    for (var i = 2; i < wnd.length; i++) {\n      wnd[i] = this.mul(wnd[i - 1], a);\n    }\n\n    var res = wnd[0];\n    var current = 0;\n    var currentLen = 0;\n    var start = num.bitLength() % 26;\n    if (start === 0) {\n      start = 26;\n    }\n\n    for (i = num.length - 1; i >= 0; i--) {\n      var word = num.words[i];\n      for (var j = start - 1; j >= 0; j--) {\n        var bit = (word >> j) & 1;\n        if (res !== wnd[0]) {\n          res = this.sqr(res);\n        }\n\n        if (bit === 0 && current === 0) {\n          currentLen = 0;\n          continue;\n        }\n\n        current <<= 1;\n        current |= bit;\n        currentLen++;\n        if (currentLen !== windowSize && (i !== 0 || j !== 0)) continue;\n\n        res = this.mul(res, wnd[current]);\n        currentLen = 0;\n        current = 0;\n      }\n      start = 26;\n    }\n\n    return res;\n  };\n\n  Red.prototype.convertTo = function convertTo (num) {\n    var r = num.umod(this.m);\n\n    return r === num ? r.clone() : r;\n  };\n\n  Red.prototype.convertFrom = function convertFrom (num) {\n    var res = num.clone();\n    res.red = null;\n    return res;\n  };\n\n  //\n  // Montgomery method engine\n  //\n\n  BN.mont = function mont (num) {\n    return new Mont(num);\n  };\n\n  function Mont (m) {\n    Red.call(this, m);\n\n    this.shift = this.m.bitLength();\n    if (this.shift % 26 !== 0) {\n      this.shift += 26 - (this.shift % 26);\n    }\n\n    this.r = new BN(1).iushln(this.shift);\n    this.r2 = this.imod(this.r.sqr());\n    this.rinv = this.r._invmp(this.m);\n\n    this.minv = this.rinv.mul(this.r).isubn(1).div(this.m);\n    this.minv = this.minv.umod(this.r);\n    this.minv = this.r.sub(this.minv);\n  }\n  inherits(Mont, Red);\n\n  Mont.prototype.convertTo = function convertTo (num) {\n    return this.imod(num.ushln(this.shift));\n  };\n\n  Mont.prototype.convertFrom = function convertFrom (num) {\n    var r = this.imod(num.mul(this.rinv));\n    r.red = null;\n    return r;\n  };\n\n  Mont.prototype.imul = function imul (a, b) {\n    if (a.isZero() || b.isZero()) {\n      a.words[0] = 0;\n      a.length = 1;\n      return a;\n    }\n\n    var t = a.imul(b);\n    var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n    var u = t.isub(c).iushrn(this.shift);\n    var res = u;\n\n    if (u.cmp(this.m) >= 0) {\n      res = u.isub(this.m);\n    } else if (u.cmpn(0) < 0) {\n      res = u.iadd(this.m);\n    }\n\n    return res._forceRed(this);\n  };\n\n  Mont.prototype.mul = function mul (a, b) {\n    if (a.isZero() || b.isZero()) return new BN(0)._forceRed(this);\n\n    var t = a.mul(b);\n    var c = t.maskn(this.shift).mul(this.minv).imaskn(this.shift).mul(this.m);\n    var u = t.isub(c).iushrn(this.shift);\n    var res = u;\n    if (u.cmp(this.m) >= 0) {\n      res = u.isub(this.m);\n    } else if (u.cmpn(0) < 0) {\n      res = u.iadd(this.m);\n    }\n\n    return res._forceRed(this);\n  };\n\n  Mont.prototype.invm = function invm (a) {\n    // (AR)^-1 * R^2 = (A^-1 * R^-1) * R^2 = A^-1 * R\n    var res = this.imod(a._invmp(this.m).mul(this.r2));\n    return res._forceRed(this);\n  };\n})(typeof module === 'undefined' || module, this);\n","var concatMap = require('concat-map');\nvar balanced = require('balanced-match');\n\nmodule.exports = expandTop;\n\nvar escSlash = '\\0SLASH'+Math.random()+'\\0';\nvar escOpen = '\\0OPEN'+Math.random()+'\\0';\nvar escClose = '\\0CLOSE'+Math.random()+'\\0';\nvar escComma = '\\0COMMA'+Math.random()+'\\0';\nvar escPeriod = '\\0PERIOD'+Math.random()+'\\0';\n\nfunction numeric(str) {\n  return parseInt(str, 10) == str\n    ? parseInt(str, 10)\n    : str.charCodeAt(0);\n}\n\nfunction escapeBraces(str) {\n  return str.split('\\\\\\\\').join(escSlash)\n            .split('\\\\{').join(escOpen)\n            .split('\\\\}').join(escClose)\n            .split('\\\\,').join(escComma)\n            .split('\\\\.').join(escPeriod);\n}\n\nfunction unescapeBraces(str) {\n  return str.split(escSlash).join('\\\\')\n            .split(escOpen).join('{')\n            .split(escClose).join('}')\n            .split(escComma).join(',')\n            .split(escPeriod).join('.');\n}\n\n\n// Basically just str.split(\",\"), but handling cases\n// where we have nested braced sections, which should be\n// treated as individual members, like {a,{b,c},d}\nfunction parseCommaParts(str) {\n  if (!str)\n    return [''];\n\n  var parts = [];\n  var m = balanced('{', '}', str);\n\n  if (!m)\n    return str.split(',');\n\n  var pre = m.pre;\n  var body = m.body;\n  var post = m.post;\n  var p = pre.split(',');\n\n  p[p.length-1] += '{' + body + '}';\n  var postParts = parseCommaParts(post);\n  if (post.length) {\n    p[p.length-1] += postParts.shift();\n    p.push.apply(p, postParts);\n  }\n\n  parts.push.apply(parts, p);\n\n  return parts;\n}\n\nfunction expandTop(str) {\n  if (!str)\n    return [];\n\n  return expand(escapeBraces(str), true).map(unescapeBraces);\n}\n\nfunction identity(e) {\n  return e;\n}\n\nfunction embrace(str) {\n  return '{' + str + '}';\n}\nfunction isPadded(el) {\n  return /^-?0\\d/.test(el);\n}\n\nfunction lte(i, y) {\n  return i <= y;\n}\nfunction gte(i, y) {\n  return i >= y;\n}\n\nfunction expand(str, isTop) {\n  var expansions = [];\n\n  var m = balanced('{', '}', str);\n  if (!m || /\\$$/.test(m.pre)) return [str];\n\n  var isNumericSequence = /^-?\\d+\\.\\.-?\\d+(?:\\.\\.-?\\d+)?$/.test(m.body);\n  var isAlphaSequence = /^[a-zA-Z]\\.\\.[a-zA-Z](?:\\.\\.-?\\d+)?$/.test(m.body);\n  var isSequence = isNumericSequence || isAlphaSequence;\n  var isOptions = /^(.*,)+(.+)?$/.test(m.body);\n  if (!isSequence && !isOptions) {\n    // {a},b}\n    if (m.post.match(/,.*\\}/)) {\n      str = m.pre + '{' + m.body + escClose + m.post;\n      return expand(str);\n    }\n    return [str];\n  }\n\n  var n;\n  if (isSequence) {\n    n = m.body.split(/\\.\\./);\n  } else {\n    n = parseCommaParts(m.body);\n    if (n.length === 1) {\n      // x{{a,b}}y ==> x{a}y x{b}y\n      n = expand(n[0], false).map(embrace);\n      if (n.length === 1) {\n        var post = m.post.length\n          ? expand(m.post, false)\n          : [''];\n        return post.map(function(p) {\n          return m.pre + n[0] + p;\n        });\n      }\n    }\n  }\n\n  // at this point, n is the parts, and we know it's not a comma set\n  // with a single entry.\n\n  // no need to expand pre, since it is guaranteed to be free of brace-sets\n  var pre = m.pre;\n  var post = m.post.length\n    ? expand(m.post, false)\n    : [''];\n\n  var N;\n\n  if (isSequence) {\n    var x = numeric(n[0]);\n    var y = numeric(n[1]);\n    var width = Math.max(n[0].length, n[1].length)\n    var incr = n.length == 3\n      ? Math.abs(numeric(n[2]))\n      : 1;\n    var test = lte;\n    var reverse = y < x;\n    if (reverse) {\n      incr *= -1;\n      test = gte;\n    }\n    var pad = n.some(isPadded);\n\n    N = [];\n\n    for (var i = x; test(i, y); i += incr) {\n      var c;\n      if (isAlphaSequence) {\n        c = String.fromCharCode(i);\n        if (c === '\\\\')\n          c = '';\n      } else {\n        c = String(i);\n        if (pad) {\n          var need = width - c.length;\n          if (need > 0) {\n            var z = new Array(need + 1).join('0');\n            if (i < 0)\n              c = '-' + z + c.slice(1);\n            else\n              c = z + c;\n          }\n        }\n      }\n      N.push(c);\n    }\n  } else {\n    N = concatMap(n, function(el) { return expand(el, false) });\n  }\n\n  for (var j = 0; j < N.length; j++) {\n    for (var k = 0; k < post.length; k++) {\n      var expansion = pre + N[j] + post[k];\n      if (!isTop || isSequence || expansion)\n        expansions.push(expansion);\n    }\n  }\n\n  return expansions;\n}\n\n","\nvar udp = require('dgram')\nvar pipe = require('stream').prototype.pipe\nvar os = require('os')\n\nmodule.exports = function (port, loopback) {\n\n  var addresses = {}\n  var socket = udp.createSocket('udp4')\n\n  socket.readable = socket.writable = true\n\n  socket.write = function (message) {\n    if('string' === typeof message)\n      message = new Buffer(message, 'utf8')\n    socket.send(message, 0, message.length, port, '255.255.255.255')\n    return true\n  }\n\n  socket.end = function () {\n    socket.close()\n  }\n\n  socket.on('close', function () {\n    socket.emit('end')\n  })\n\n  var latest = null\n\n  socket.on('message', function (msg, other) {\n    if(addresses[other.address] && other.port === port) {\n      if(loopback === false) return\n      msg.loopback = true\n    }\n\n    msg.port = other.port\n    msg.address = other.address\n\n    //if paused, remember the latest item.\n    //otherwise just drop those messages.\n    if(socket.paused)\n      return latest = msg\n\n    latest = null\n    socket.emit('data', msg)\n  })\n\n  socket.pause = function () {\n    socket.paused = true\n    return this\n  }\n\n  socket.resume = function () {\n    socket.paused = false\n    if(latest) {\n      var msg = latest\n      latest = null\n      socket.emit('data', msg)\n    }\n    return this\n  }\n\n  socket.bind(port)\n  socket.on('listening', function () {\n    var ifaces = os.networkInterfaces()\n    for(var k in ifaces)\n      ifaces[k].forEach(function (address) {\n        addresses[address.address] = true\n      })\n    socket.setBroadcast(true)\n  })\n\n  socket.pipe = pipe\n\n  return socket\n}\n","var r;\n\nmodule.exports = function rand(len) {\n  if (!r)\n    r = new Rand(null);\n\n  return r.generate(len);\n};\n\nfunction Rand(rand) {\n  this.rand = rand;\n}\nmodule.exports.Rand = Rand;\n\nRand.prototype.generate = function generate(len) {\n  return this._rand(len);\n};\n\nif (typeof window === 'object') {\n  if (window.crypto && window.crypto.getRandomValues) {\n    // Modern browsers\n    Rand.prototype._rand = function _rand(n) {\n      var arr = new Uint8Array(n);\n      window.crypto.getRandomValues(arr);\n      return arr;\n    };\n  } else if (window.msCrypto && window.msCrypto.getRandomValues) {\n    // IE\n    Rand.prototype._rand = function _rand(n) {\n      var arr = new Uint8Array(n);\n      window.msCrypto.getRandomValues(arr);\n      return arr;\n    };\n  } else {\n    // Old junk\n    Rand.prototype._rand = function() {\n      throw new Error('Not implemented yet');\n    };\n  }\n} else {\n  // Node.js or Web worker\n  try {\n    var crypto = require('cry' + 'pto');\n\n    Rand.prototype._rand = function _rand(n) {\n      return crypto.randomBytes(n);\n    };\n  } catch (e) {\n    // Emulate crypto API using randy\n    Rand.prototype._rand = function _rand(n) {\n      var res = new Uint8Array(n);\n      for (var i = 0; i < res.length; i++)\n        res[i] = this.rand.getByte();\n      return res;\n    };\n  }\n}\n","","// based on the aes implimentation in triple sec\n// https://github.com/keybase/triplesec\n\n// which is in turn based on the one from crypto-js\n// https://code.google.com/p/crypto-js/\n\nvar uint_max = Math.pow(2, 32)\nfunction fixup_uint32 (x) {\n  var ret, x_pos\n  ret = x > uint_max || x < 0 ? (x_pos = Math.abs(x) % uint_max, x < 0 ? uint_max - x_pos : x_pos) : x\n  return ret\n}\nfunction scrub_vec (v) {\n  for (var i = 0; i < v.length; v++) {\n    v[i] = 0\n  }\n  return false\n}\n\nfunction Global () {\n  this.SBOX = []\n  this.INV_SBOX = []\n  this.SUB_MIX = [[], [], [], []]\n  this.INV_SUB_MIX = [[], [], [], []]\n  this.init()\n  this.RCON = [0x00, 0x01, 0x02, 0x04, 0x08, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36]\n}\n\nGlobal.prototype.init = function () {\n  var d, i, sx, t, x, x2, x4, x8, xi, _i\n  d = (function () {\n    var _i, _results\n    _results = []\n    for (i = _i = 0; _i < 256; i = ++_i) {\n      if (i < 128) {\n        _results.push(i << 1)\n      } else {\n        _results.push((i << 1) ^ 0x11b)\n      }\n    }\n    return _results\n  })()\n  x = 0\n  xi = 0\n  for (i = _i = 0; _i < 256; i = ++_i) {\n    sx = xi ^ (xi << 1) ^ (xi << 2) ^ (xi << 3) ^ (xi << 4)\n    sx = (sx >>> 8) ^ (sx & 0xff) ^ 0x63\n    this.SBOX[x] = sx\n    this.INV_SBOX[sx] = x\n    x2 = d[x]\n    x4 = d[x2]\n    x8 = d[x4]\n    t = (d[sx] * 0x101) ^ (sx * 0x1010100)\n    this.SUB_MIX[0][x] = (t << 24) | (t >>> 8)\n    this.SUB_MIX[1][x] = (t << 16) | (t >>> 16)\n    this.SUB_MIX[2][x] = (t << 8) | (t >>> 24)\n    this.SUB_MIX[3][x] = t\n    t = (x8 * 0x1010101) ^ (x4 * 0x10001) ^ (x2 * 0x101) ^ (x * 0x1010100)\n    this.INV_SUB_MIX[0][sx] = (t << 24) | (t >>> 8)\n    this.INV_SUB_MIX[1][sx] = (t << 16) | (t >>> 16)\n    this.INV_SUB_MIX[2][sx] = (t << 8) | (t >>> 24)\n    this.INV_SUB_MIX[3][sx] = t\n    if (x === 0) {\n      x = xi = 1\n    } else {\n      x = x2 ^ d[d[d[x8 ^ x2]]]\n      xi ^= d[d[xi]]\n    }\n  }\n  return true\n}\n\nvar G = new Global()\n\nAES.blockSize = 4 * 4\n\nAES.prototype.blockSize = AES.blockSize\n\nAES.keySize = 256 / 8\n\nAES.prototype.keySize = AES.keySize\n\nfunction bufferToArray (buf) {\n  var len = buf.length / 4\n  var out = new Array(len)\n  var i = -1\n  while (++i < len) {\n    out[i] = buf.readUInt32BE(i * 4)\n  }\n  return out\n}\nfunction AES (key) {\n  this._key = bufferToArray(key)\n  this._doReset()\n}\n\nAES.prototype._doReset = function () {\n  var invKsRow, keySize, keyWords, ksRow, ksRows, t\n  keyWords = this._key\n  keySize = keyWords.length\n  this._nRounds = keySize + 6\n  ksRows = (this._nRounds + 1) * 4\n  this._keySchedule = []\n  for (ksRow = 0; ksRow < ksRows; ksRow++) {\n    this._keySchedule[ksRow] = ksRow < keySize ? keyWords[ksRow] : (t = this._keySchedule[ksRow - 1], (ksRow % keySize) === 0 ? (t = (t << 8) | (t >>> 24), t = (G.SBOX[t >>> 24] << 24) | (G.SBOX[(t >>> 16) & 0xff] << 16) | (G.SBOX[(t >>> 8) & 0xff] << 8) | G.SBOX[t & 0xff], t ^= G.RCON[(ksRow / keySize) | 0] << 24) : keySize > 6 && ksRow % keySize === 4 ? t = (G.SBOX[t >>> 24] << 24) | (G.SBOX[(t >>> 16) & 0xff] << 16) | (G.SBOX[(t >>> 8) & 0xff] << 8) | G.SBOX[t & 0xff] : void 0, this._keySchedule[ksRow - keySize] ^ t)\n  }\n  this._invKeySchedule = []\n  for (invKsRow = 0; invKsRow < ksRows; invKsRow++) {\n    ksRow = ksRows - invKsRow\n    t = this._keySchedule[ksRow - (invKsRow % 4 ? 0 : 4)]\n    this._invKeySchedule[invKsRow] = invKsRow < 4 || ksRow <= 4 ? t : G.INV_SUB_MIX[0][G.SBOX[t >>> 24]] ^ G.INV_SUB_MIX[1][G.SBOX[(t >>> 16) & 0xff]] ^ G.INV_SUB_MIX[2][G.SBOX[(t >>> 8) & 0xff]] ^ G.INV_SUB_MIX[3][G.SBOX[t & 0xff]]\n  }\n  return true\n}\n\nAES.prototype.encryptBlock = function (M) {\n  M = bufferToArray(new Buffer(M))\n  var out = this._doCryptBlock(M, this._keySchedule, G.SUB_MIX, G.SBOX)\n  var buf = new Buffer(16)\n  buf.writeUInt32BE(out[0], 0)\n  buf.writeUInt32BE(out[1], 4)\n  buf.writeUInt32BE(out[2], 8)\n  buf.writeUInt32BE(out[3], 12)\n  return buf\n}\n\nAES.prototype.decryptBlock = function (M) {\n  M = bufferToArray(new Buffer(M))\n  var temp = [M[3], M[1]]\n  M[1] = temp[0]\n  M[3] = temp[1]\n  var out = this._doCryptBlock(M, this._invKeySchedule, G.INV_SUB_MIX, G.INV_SBOX)\n  var buf = new Buffer(16)\n  buf.writeUInt32BE(out[0], 0)\n  buf.writeUInt32BE(out[3], 4)\n  buf.writeUInt32BE(out[2], 8)\n  buf.writeUInt32BE(out[1], 12)\n  return buf\n}\n\nAES.prototype.scrub = function () {\n  scrub_vec(this._keySchedule)\n  scrub_vec(this._invKeySchedule)\n  scrub_vec(this._key)\n}\n\nAES.prototype._doCryptBlock = function (M, keySchedule, SUB_MIX, SBOX) {\n  var ksRow, s0, s1, s2, s3, t0, t1, t2, t3\n\n  s0 = M[0] ^ keySchedule[0]\n  s1 = M[1] ^ keySchedule[1]\n  s2 = M[2] ^ keySchedule[2]\n  s3 = M[3] ^ keySchedule[3]\n  ksRow = 4\n  for (var round = 1; round < this._nRounds; round++) {\n    t0 = SUB_MIX[0][s0 >>> 24] ^ SUB_MIX[1][(s1 >>> 16) & 0xff] ^ SUB_MIX[2][(s2 >>> 8) & 0xff] ^ SUB_MIX[3][s3 & 0xff] ^ keySchedule[ksRow++]\n    t1 = SUB_MIX[0][s1 >>> 24] ^ SUB_MIX[1][(s2 >>> 16) & 0xff] ^ SUB_MIX[2][(s3 >>> 8) & 0xff] ^ SUB_MIX[3][s0 & 0xff] ^ keySchedule[ksRow++]\n    t2 = SUB_MIX[0][s2 >>> 24] ^ SUB_MIX[1][(s3 >>> 16) & 0xff] ^ SUB_MIX[2][(s0 >>> 8) & 0xff] ^ SUB_MIX[3][s1 & 0xff] ^ keySchedule[ksRow++]\n    t3 = SUB_MIX[0][s3 >>> 24] ^ SUB_MIX[1][(s0 >>> 16) & 0xff] ^ SUB_MIX[2][(s1 >>> 8) & 0xff] ^ SUB_MIX[3][s2 & 0xff] ^ keySchedule[ksRow++]\n    s0 = t0\n    s1 = t1\n    s2 = t2\n    s3 = t3\n  }\n  t0 = ((SBOX[s0 >>> 24] << 24) | (SBOX[(s1 >>> 16) & 0xff] << 16) | (SBOX[(s2 >>> 8) & 0xff] << 8) | SBOX[s3 & 0xff]) ^ keySchedule[ksRow++]\n  t1 = ((SBOX[s1 >>> 24] << 24) | (SBOX[(s2 >>> 16) & 0xff] << 16) | (SBOX[(s3 >>> 8) & 0xff] << 8) | SBOX[s0 & 0xff]) ^ keySchedule[ksRow++]\n  t2 = ((SBOX[s2 >>> 24] << 24) | (SBOX[(s3 >>> 16) & 0xff] << 16) | (SBOX[(s0 >>> 8) & 0xff] << 8) | SBOX[s1 & 0xff]) ^ keySchedule[ksRow++]\n  t3 = ((SBOX[s3 >>> 24] << 24) | (SBOX[(s0 >>> 16) & 0xff] << 16) | (SBOX[(s1 >>> 8) & 0xff] << 8) | SBOX[s2 & 0xff]) ^ keySchedule[ksRow++]\n  return [\n    fixup_uint32(t0),\n    fixup_uint32(t1),\n    fixup_uint32(t2),\n    fixup_uint32(t3)\n  ]\n}\n\nexports.AES = AES\n","var aes = require('./aes')\nvar Transform = require('cipher-base')\nvar inherits = require('inherits')\nvar GHASH = require('./ghash')\nvar xor = require('buffer-xor')\ninherits(StreamCipher, Transform)\nmodule.exports = StreamCipher\n\nfunction StreamCipher (mode, key, iv, decrypt) {\n  if (!(this instanceof StreamCipher)) {\n    return new StreamCipher(mode, key, iv)\n  }\n  Transform.call(this)\n  this._finID = Buffer.concat([iv, new Buffer([0, 0, 0, 1])])\n  iv = Buffer.concat([iv, new Buffer([0, 0, 0, 2])])\n  this._cipher = new aes.AES(key)\n  this._prev = new Buffer(iv.length)\n  this._cache = new Buffer('')\n  this._secCache = new Buffer('')\n  this._decrypt = decrypt\n  this._alen = 0\n  this._len = 0\n  iv.copy(this._prev)\n  this._mode = mode\n  var h = new Buffer(4)\n  h.fill(0)\n  this._ghash = new GHASH(this._cipher.encryptBlock(h))\n  this._authTag = null\n  this._called = false\n}\nStreamCipher.prototype._update = function (chunk) {\n  if (!this._called && this._alen) {\n    var rump = 16 - (this._alen % 16)\n    if (rump < 16) {\n      rump = new Buffer(rump)\n      rump.fill(0)\n      this._ghash.update(rump)\n    }\n  }\n  this._called = true\n  var out = this._mode.encrypt(this, chunk)\n  if (this._decrypt) {\n    this._ghash.update(chunk)\n  } else {\n    this._ghash.update(out)\n  }\n  this._len += chunk.length\n  return out\n}\nStreamCipher.prototype._final = function () {\n  if (this._decrypt && !this._authTag) {\n    throw new Error('Unsupported state or unable to authenticate data')\n  }\n  var tag = xor(this._ghash.final(this._alen * 8, this._len * 8), this._cipher.encryptBlock(this._finID))\n  if (this._decrypt) {\n    if (xorTest(tag, this._authTag)) {\n      throw new Error('Unsupported state or unable to authenticate data')\n    }\n  } else {\n    this._authTag = tag\n  }\n  this._cipher.scrub()\n}\nStreamCipher.prototype.getAuthTag = function getAuthTag () {\n  if (!this._decrypt && Buffer.isBuffer(this._authTag)) {\n    return this._authTag\n  } else {\n    throw new Error('Attempting to get auth tag in unsupported state')\n  }\n}\nStreamCipher.prototype.setAuthTag = function setAuthTag (tag) {\n  if (this._decrypt) {\n    this._authTag = tag\n  } else {\n    throw new Error('Attempting to set auth tag in unsupported state')\n  }\n}\nStreamCipher.prototype.setAAD = function setAAD (buf) {\n  if (!this._called) {\n    this._ghash.update(buf)\n    this._alen += buf.length\n  } else {\n    throw new Error('Attempting to set AAD in unsupported state')\n  }\n}\nfunction xorTest (a, b) {\n  var out = 0\n  if (a.length !== b.length) {\n    out++\n  }\n  var len = Math.min(a.length, b.length)\n  var i = -1\n  while (++i < len) {\n    out += (a[i] ^ b[i])\n  }\n  return out\n}\n","var ciphers = require('./encrypter')\nexports.createCipher = exports.Cipher = ciphers.createCipher\nexports.createCipheriv = exports.Cipheriv = ciphers.createCipheriv\nvar deciphers = require('./decrypter')\nexports.createDecipher = exports.Decipher = deciphers.createDecipher\nexports.createDecipheriv = exports.Decipheriv = deciphers.createDecipheriv\nvar modes = require('./modes')\nfunction getCiphers () {\n  return Object.keys(modes)\n}\nexports.listCiphers = exports.getCiphers = getCiphers\n","var aes = require('./aes')\nvar Transform = require('cipher-base')\nvar inherits = require('inherits')\nvar modes = require('./modes')\nvar StreamCipher = require('./streamCipher')\nvar AuthCipher = require('./authCipher')\nvar ebtk = require('evp_bytestokey')\n\ninherits(Decipher, Transform)\nfunction Decipher (mode, key, iv) {\n  if (!(this instanceof Decipher)) {\n    return new Decipher(mode, key, iv)\n  }\n  Transform.call(this)\n  this._cache = new Splitter()\n  this._last = void 0\n  this._cipher = new aes.AES(key)\n  this._prev = new Buffer(iv.length)\n  iv.copy(this._prev)\n  this._mode = mode\n  this._autopadding = true\n}\nDecipher.prototype._update = function (data) {\n  this._cache.add(data)\n  var chunk\n  var thing\n  var out = []\n  while ((chunk = this._cache.get(this._autopadding))) {\n    thing = this._mode.decrypt(this, chunk)\n    out.push(thing)\n  }\n  return Buffer.concat(out)\n}\nDecipher.prototype._final = function () {\n  var chunk = this._cache.flush()\n  if (this._autopadding) {\n    return unpad(this._mode.decrypt(this, chunk))\n  } else if (chunk) {\n    throw new Error('data not multiple of block length')\n  }\n}\nDecipher.prototype.setAutoPadding = function (setTo) {\n  this._autopadding = !!setTo\n  return this\n}\nfunction Splitter () {\n  if (!(this instanceof Splitter)) {\n    return new Splitter()\n  }\n  this.cache = new Buffer('')\n}\nSplitter.prototype.add = function (data) {\n  this.cache = Buffer.concat([this.cache, data])\n}\n\nSplitter.prototype.get = function (autoPadding) {\n  var out\n  if (autoPadding) {\n    if (this.cache.length > 16) {\n      out = this.cache.slice(0, 16)\n      this.cache = this.cache.slice(16)\n      return out\n    }\n  } else {\n    if (this.cache.length >= 16) {\n      out = this.cache.slice(0, 16)\n      this.cache = this.cache.slice(16)\n      return out\n    }\n  }\n  return null\n}\nSplitter.prototype.flush = function () {\n  if (this.cache.length) {\n    return this.cache\n  }\n}\nfunction unpad (last) {\n  var padded = last[15]\n  var i = -1\n  while (++i < padded) {\n    if (last[(i + (16 - padded))] !== padded) {\n      throw new Error('unable to decrypt data')\n    }\n  }\n  if (padded === 16) {\n    return\n  }\n  return last.slice(0, 16 - padded)\n}\n\nvar modelist = {\n  ECB: require('./modes/ecb'),\n  CBC: require('./modes/cbc'),\n  CFB: require('./modes/cfb'),\n  CFB8: require('./modes/cfb8'),\n  CFB1: require('./modes/cfb1'),\n  OFB: require('./modes/ofb'),\n  CTR: require('./modes/ctr'),\n  GCM: require('./modes/ctr')\n}\n\nfunction createDecipheriv (suite, password, iv) {\n  var config = modes[suite.toLowerCase()]\n  if (!config) {\n    throw new TypeError('invalid suite type')\n  }\n  if (typeof iv === 'string') {\n    iv = new Buffer(iv)\n  }\n  if (typeof password === 'string') {\n    password = new Buffer(password)\n  }\n  if (password.length !== config.key / 8) {\n    throw new TypeError('invalid key length ' + password.length)\n  }\n  if (iv.length !== config.iv) {\n    throw new TypeError('invalid iv length ' + iv.length)\n  }\n  if (config.type === 'stream') {\n    return new StreamCipher(modelist[config.mode], password, iv, true)\n  } else if (config.type === 'auth') {\n    return new AuthCipher(modelist[config.mode], password, iv, true)\n  }\n  return new Decipher(modelist[config.mode], password, iv)\n}\n\nfunction createDecipher (suite, password) {\n  var config = modes[suite.toLowerCase()]\n  if (!config) {\n    throw new TypeError('invalid suite type')\n  }\n  var keys = ebtk(password, false, config.key, config.iv)\n  return createDecipheriv(suite, keys.key, keys.iv)\n}\nexports.createDecipher = createDecipher\nexports.createDecipheriv = createDecipheriv\n","var aes = require('./aes')\nvar Transform = require('cipher-base')\nvar inherits = require('inherits')\nvar modes = require('./modes')\nvar ebtk = require('evp_bytestokey')\nvar StreamCipher = require('./streamCipher')\nvar AuthCipher = require('./authCipher')\ninherits(Cipher, Transform)\nfunction Cipher (mode, key, iv) {\n  if (!(this instanceof Cipher)) {\n    return new Cipher(mode, key, iv)\n  }\n  Transform.call(this)\n  this._cache = new Splitter()\n  this._cipher = new aes.AES(key)\n  this._prev = new Buffer(iv.length)\n  iv.copy(this._prev)\n  this._mode = mode\n  this._autopadding = true\n}\nCipher.prototype._update = function (data) {\n  this._cache.add(data)\n  var chunk\n  var thing\n  var out = []\n  while ((chunk = this._cache.get())) {\n    thing = this._mode.encrypt(this, chunk)\n    out.push(thing)\n  }\n  return Buffer.concat(out)\n}\nCipher.prototype._final = function () {\n  var chunk = this._cache.flush()\n  if (this._autopadding) {\n    chunk = this._mode.encrypt(this, chunk)\n    this._cipher.scrub()\n    return chunk\n  } else if (chunk.toString('hex') !== '10101010101010101010101010101010') {\n    this._cipher.scrub()\n    throw new Error('data not multiple of block length')\n  }\n}\nCipher.prototype.setAutoPadding = function (setTo) {\n  this._autopadding = !!setTo\n  return this\n}\n\nfunction Splitter () {\n  if (!(this instanceof Splitter)) {\n    return new Splitter()\n  }\n  this.cache = new Buffer('')\n}\nSplitter.prototype.add = function (data) {\n  this.cache = Buffer.concat([this.cache, data])\n}\n\nSplitter.prototype.get = function () {\n  if (this.cache.length > 15) {\n    var out = this.cache.slice(0, 16)\n    this.cache = this.cache.slice(16)\n    return out\n  }\n  return null\n}\nSplitter.prototype.flush = function () {\n  var len = 16 - this.cache.length\n  var padBuff = new Buffer(len)\n\n  var i = -1\n  while (++i < len) {\n    padBuff.writeUInt8(len, i)\n  }\n  var out = Buffer.concat([this.cache, padBuff])\n  return out\n}\nvar modelist = {\n  ECB: require('./modes/ecb'),\n  CBC: require('./modes/cbc'),\n  CFB: require('./modes/cfb'),\n  CFB8: require('./modes/cfb8'),\n  CFB1: require('./modes/cfb1'),\n  OFB: require('./modes/ofb'),\n  CTR: require('./modes/ctr'),\n  GCM: require('./modes/ctr')\n}\n\nfunction createCipheriv (suite, password, iv) {\n  var config = modes[suite.toLowerCase()]\n  if (!config) {\n    throw new TypeError('invalid suite type')\n  }\n  if (typeof iv === 'string') {\n    iv = new Buffer(iv)\n  }\n  if (typeof password === 'string') {\n    password = new Buffer(password)\n  }\n  if (password.length !== config.key / 8) {\n    throw new TypeError('invalid key length ' + password.length)\n  }\n  if (iv.length !== config.iv) {\n    throw new TypeError('invalid iv length ' + iv.length)\n  }\n  if (config.type === 'stream') {\n    return new StreamCipher(modelist[config.mode], password, iv)\n  } else if (config.type === 'auth') {\n    return new AuthCipher(modelist[config.mode], password, iv)\n  }\n  return new Cipher(modelist[config.mode], password, iv)\n}\nfunction createCipher (suite, password) {\n  var config = modes[suite.toLowerCase()]\n  if (!config) {\n    throw new TypeError('invalid suite type')\n  }\n  var keys = ebtk(password, false, config.key, config.iv)\n  return createCipheriv(suite, keys.key, keys.iv)\n}\n\nexports.createCipheriv = createCipheriv\nexports.createCipher = createCipher\n","var zeros = new Buffer(16)\nzeros.fill(0)\nmodule.exports = GHASH\nfunction GHASH (key) {\n  this.h = key\n  this.state = new Buffer(16)\n  this.state.fill(0)\n  this.cache = new Buffer('')\n}\n// from http://bitwiseshiftleft.github.io/sjcl/doc/symbols/src/core_gcm.js.html\n// by Juho Vähä-Herttua\nGHASH.prototype.ghash = function (block) {\n  var i = -1\n  while (++i < block.length) {\n    this.state[i] ^= block[i]\n  }\n  this._multiply()\n}\n\nGHASH.prototype._multiply = function () {\n  var Vi = toArray(this.h)\n  var Zi = [0, 0, 0, 0]\n  var j, xi, lsb_Vi\n  var i = -1\n  while (++i < 128) {\n    xi = (this.state[~~(i / 8)] & (1 << (7 - i % 8))) !== 0\n    if (xi) {\n      // Z_i+1 = Z_i ^ V_i\n      Zi = xor(Zi, Vi)\n    }\n\n    // Store the value of LSB(V_i)\n    lsb_Vi = (Vi[3] & 1) !== 0\n\n    // V_i+1 = V_i >> 1\n    for (j = 3; j > 0; j--) {\n      Vi[j] = (Vi[j] >>> 1) | ((Vi[j - 1] & 1) << 31)\n    }\n    Vi[0] = Vi[0] >>> 1\n\n    // If LSB(V_i) is 1, V_i+1 = (V_i >> 1) ^ R\n    if (lsb_Vi) {\n      Vi[0] = Vi[0] ^ (0xe1 << 24)\n    }\n  }\n  this.state = fromArray(Zi)\n}\nGHASH.prototype.update = function (buf) {\n  this.cache = Buffer.concat([this.cache, buf])\n  var chunk\n  while (this.cache.length >= 16) {\n    chunk = this.cache.slice(0, 16)\n    this.cache = this.cache.slice(16)\n    this.ghash(chunk)\n  }\n}\nGHASH.prototype.final = function (abl, bl) {\n  if (this.cache.length) {\n    this.ghash(Buffer.concat([this.cache, zeros], 16))\n  }\n  this.ghash(fromArray([\n    0, abl,\n    0, bl\n  ]))\n  return this.state\n}\n\nfunction toArray (buf) {\n  return [\n    buf.readUInt32BE(0),\n    buf.readUInt32BE(4),\n    buf.readUInt32BE(8),\n    buf.readUInt32BE(12)\n  ]\n}\nfunction fromArray (out) {\n  out = out.map(fixup_uint32)\n  var buf = new Buffer(16)\n  buf.writeUInt32BE(out[0], 0)\n  buf.writeUInt32BE(out[1], 4)\n  buf.writeUInt32BE(out[2], 8)\n  buf.writeUInt32BE(out[3], 12)\n  return buf\n}\nvar uint_max = Math.pow(2, 32)\nfunction fixup_uint32 (x) {\n  var ret, x_pos\n  ret = x > uint_max || x < 0 ? (x_pos = Math.abs(x) % uint_max, x < 0 ? uint_max - x_pos : x_pos) : x\n  return ret\n}\nfunction xor (a, b) {\n  return [\n    a[0] ^ b[0],\n    a[1] ^ b[1],\n    a[2] ^ b[2],\n    a[3] ^ b[3]\n  ]\n}\n","exports['aes-128-ecb'] = {\n  cipher: 'AES',\n  key: 128,\n  iv: 0,\n  mode: 'ECB',\n  type: 'block'\n}\nexports['aes-192-ecb'] = {\n  cipher: 'AES',\n  key: 192,\n  iv: 0,\n  mode: 'ECB',\n  type: 'block'\n}\nexports['aes-256-ecb'] = {\n  cipher: 'AES',\n  key: 256,\n  iv: 0,\n  mode: 'ECB',\n  type: 'block'\n}\nexports['aes-128-cbc'] = {\n  cipher: 'AES',\n  key: 128,\n  iv: 16,\n  mode: 'CBC',\n  type: 'block'\n}\nexports['aes-192-cbc'] = {\n  cipher: 'AES',\n  key: 192,\n  iv: 16,\n  mode: 'CBC',\n  type: 'block'\n}\nexports['aes-256-cbc'] = {\n  cipher: 'AES',\n  key: 256,\n  iv: 16,\n  mode: 'CBC',\n  type: 'block'\n}\nexports['aes128'] = exports['aes-128-cbc']\nexports['aes192'] = exports['aes-192-cbc']\nexports['aes256'] = exports['aes-256-cbc']\nexports['aes-128-cfb'] = {\n  cipher: 'AES',\n  key: 128,\n  iv: 16,\n  mode: 'CFB',\n  type: 'stream'\n}\nexports['aes-192-cfb'] = {\n  cipher: 'AES',\n  key: 192,\n  iv: 16,\n  mode: 'CFB',\n  type: 'stream'\n}\nexports['aes-256-cfb'] = {\n  cipher: 'AES',\n  key: 256,\n  iv: 16,\n  mode: 'CFB',\n  type: 'stream'\n}\nexports['aes-128-cfb8'] = {\n  cipher: 'AES',\n  key: 128,\n  iv: 16,\n  mode: 'CFB8',\n  type: 'stream'\n}\nexports['aes-192-cfb8'] = {\n  cipher: 'AES',\n  key: 192,\n  iv: 16,\n  mode: 'CFB8',\n  type: 'stream'\n}\nexports['aes-256-cfb8'] = {\n  cipher: 'AES',\n  key: 256,\n  iv: 16,\n  mode: 'CFB8',\n  type: 'stream'\n}\nexports['aes-128-cfb1'] = {\n  cipher: 'AES',\n  key: 128,\n  iv: 16,\n  mode: 'CFB1',\n  type: 'stream'\n}\nexports['aes-192-cfb1'] = {\n  cipher: 'AES',\n  key: 192,\n  iv: 16,\n  mode: 'CFB1',\n  type: 'stream'\n}\nexports['aes-256-cfb1'] = {\n  cipher: 'AES',\n  key: 256,\n  iv: 16,\n  mode: 'CFB1',\n  type: 'stream'\n}\nexports['aes-128-ofb'] = {\n  cipher: 'AES',\n  key: 128,\n  iv: 16,\n  mode: 'OFB',\n  type: 'stream'\n}\nexports['aes-192-ofb'] = {\n  cipher: 'AES',\n  key: 192,\n  iv: 16,\n  mode: 'OFB',\n  type: 'stream'\n}\nexports['aes-256-ofb'] = {\n  cipher: 'AES',\n  key: 256,\n  iv: 16,\n  mode: 'OFB',\n  type: 'stream'\n}\nexports['aes-128-ctr'] = {\n  cipher: 'AES',\n  key: 128,\n  iv: 16,\n  mode: 'CTR',\n  type: 'stream'\n}\nexports['aes-192-ctr'] = {\n  cipher: 'AES',\n  key: 192,\n  iv: 16,\n  mode: 'CTR',\n  type: 'stream'\n}\nexports['aes-256-ctr'] = {\n  cipher: 'AES',\n  key: 256,\n  iv: 16,\n  mode: 'CTR',\n  type: 'stream'\n}\nexports['aes-128-gcm'] = {\n  cipher: 'AES',\n  key: 128,\n  iv: 12,\n  mode: 'GCM',\n  type: 'auth'\n}\nexports['aes-192-gcm'] = {\n  cipher: 'AES',\n  key: 192,\n  iv: 12,\n  mode: 'GCM',\n  type: 'auth'\n}\nexports['aes-256-gcm'] = {\n  cipher: 'AES',\n  key: 256,\n  iv: 12,\n  mode: 'GCM',\n  type: 'auth'\n}\n","var xor = require('buffer-xor')\n\nexports.encrypt = function (self, block) {\n  var data = xor(block, self._prev)\n\n  self._prev = self._cipher.encryptBlock(data)\n  return self._prev\n}\n\nexports.decrypt = function (self, block) {\n  var pad = self._prev\n\n  self._prev = block\n  var out = self._cipher.decryptBlock(block)\n\n  return xor(out, pad)\n}\n","var xor = require('buffer-xor')\n\nexports.encrypt = function (self, data, decrypt) {\n  var out = new Buffer('')\n  var len\n\n  while (data.length) {\n    if (self._cache.length === 0) {\n      self._cache = self._cipher.encryptBlock(self._prev)\n      self._prev = new Buffer('')\n    }\n\n    if (self._cache.length <= data.length) {\n      len = self._cache.length\n      out = Buffer.concat([out, encryptStart(self, data.slice(0, len), decrypt)])\n      data = data.slice(len)\n    } else {\n      out = Buffer.concat([out, encryptStart(self, data, decrypt)])\n      break\n    }\n  }\n\n  return out\n}\nfunction encryptStart (self, data, decrypt) {\n  var len = data.length\n  var out = xor(data, self._cache)\n  self._cache = self._cache.slice(len)\n  self._prev = Buffer.concat([self._prev, decrypt ? data : out])\n  return out\n}\n","function encryptByte (self, byteParam, decrypt) {\n  var pad\n  var i = -1\n  var len = 8\n  var out = 0\n  var bit, value\n  while (++i < len) {\n    pad = self._cipher.encryptBlock(self._prev)\n    bit = (byteParam & (1 << (7 - i))) ? 0x80 : 0\n    value = pad[0] ^ bit\n    out += ((value & 0x80) >> (i % 8))\n    self._prev = shiftIn(self._prev, decrypt ? bit : value)\n  }\n  return out\n}\nexports.encrypt = function (self, chunk, decrypt) {\n  var len = chunk.length\n  var out = new Buffer(len)\n  var i = -1\n  while (++i < len) {\n    out[i] = encryptByte(self, chunk[i], decrypt)\n  }\n  return out\n}\nfunction shiftIn (buffer, value) {\n  var len = buffer.length\n  var i = -1\n  var out = new Buffer(buffer.length)\n  buffer = Buffer.concat([buffer, new Buffer([value])])\n  while (++i < len) {\n    out[i] = buffer[i] << 1 | buffer[i + 1] >> (7)\n  }\n  return out\n}\n","function encryptByte (self, byteParam, decrypt) {\n  var pad = self._cipher.encryptBlock(self._prev)\n  var out = pad[0] ^ byteParam\n  self._prev = Buffer.concat([self._prev.slice(1), new Buffer([decrypt ? byteParam : out])])\n  return out\n}\nexports.encrypt = function (self, chunk, decrypt) {\n  var len = chunk.length\n  var out = new Buffer(len)\n  var i = -1\n  while (++i < len) {\n    out[i] = encryptByte(self, chunk[i], decrypt)\n  }\n  return out\n}\n","var xor = require('buffer-xor')\n\nfunction incr32 (iv) {\n  var len = iv.length\n  var item\n  while (len--) {\n    item = iv.readUInt8(len)\n    if (item === 255) {\n      iv.writeUInt8(0, len)\n    } else {\n      item++\n      iv.writeUInt8(item, len)\n      break\n    }\n  }\n}\n\nfunction getBlock (self) {\n  var out = self._cipher.encryptBlock(self._prev)\n  incr32(self._prev)\n  return out\n}\n\nexports.encrypt = function (self, chunk) {\n  while (self._cache.length < chunk.length) {\n    self._cache = Buffer.concat([self._cache, getBlock(self)])\n  }\n  var pad = self._cache.slice(0, chunk.length)\n  self._cache = self._cache.slice(chunk.length)\n  return xor(chunk, pad)\n}\n","exports.encrypt = function (self, block) {\n  return self._cipher.encryptBlock(block)\n}\nexports.decrypt = function (self, block) {\n  return self._cipher.decryptBlock(block)\n}\n","var xor = require('buffer-xor')\n\nfunction getBlock (self) {\n  self._prev = self._cipher.encryptBlock(self._prev)\n  return self._prev\n}\n\nexports.encrypt = function (self, chunk) {\n  while (self._cache.length < chunk.length) {\n    self._cache = Buffer.concat([self._cache, getBlock(self)])\n  }\n\n  var pad = self._cache.slice(0, chunk.length)\n  self._cache = self._cache.slice(chunk.length)\n  return xor(chunk, pad)\n}\n","var aes = require('./aes')\nvar Transform = require('cipher-base')\nvar inherits = require('inherits')\n\ninherits(StreamCipher, Transform)\nmodule.exports = StreamCipher\nfunction StreamCipher (mode, key, iv, decrypt) {\n  if (!(this instanceof StreamCipher)) {\n    return new StreamCipher(mode, key, iv)\n  }\n  Transform.call(this)\n  this._cipher = new aes.AES(key)\n  this._prev = new Buffer(iv.length)\n  this._cache = new Buffer('')\n  this._secCache = new Buffer('')\n  this._decrypt = decrypt\n  iv.copy(this._prev)\n  this._mode = mode\n}\nStreamCipher.prototype._update = function (chunk) {\n  return this._mode.encrypt(this, chunk, this._decrypt)\n}\nStreamCipher.prototype._final = function () {\n  this._cipher.scrub()\n}\n","var ebtk = require('evp_bytestokey')\nvar aes = require('browserify-aes/browser')\nvar DES = require('browserify-des')\nvar desModes = require('browserify-des/modes')\nvar aesModes = require('browserify-aes/modes')\nfunction createCipher (suite, password) {\n  var keyLen, ivLen\n  suite = suite.toLowerCase()\n  if (aesModes[suite]) {\n    keyLen = aesModes[suite].key\n    ivLen = aesModes[suite].iv\n  } else if (desModes[suite]) {\n    keyLen = desModes[suite].key * 8\n    ivLen = desModes[suite].iv\n  } else {\n    throw new TypeError('invalid suite type')\n  }\n  var keys = ebtk(password, false, keyLen, ivLen)\n  return createCipheriv(suite, keys.key, keys.iv)\n}\nfunction createDecipher (suite, password) {\n  var keyLen, ivLen\n  suite = suite.toLowerCase()\n  if (aesModes[suite]) {\n    keyLen = aesModes[suite].key\n    ivLen = aesModes[suite].iv\n  } else if (desModes[suite]) {\n    keyLen = desModes[suite].key * 8\n    ivLen = desModes[suite].iv\n  } else {\n    throw new TypeError('invalid suite type')\n  }\n  var keys = ebtk(password, false, keyLen, ivLen)\n  return createDecipheriv(suite, keys.key, keys.iv)\n}\n\nfunction createCipheriv (suite, key, iv) {\n  suite = suite.toLowerCase()\n  if (aesModes[suite]) {\n    return aes.createCipheriv(suite, key, iv)\n  } else if (desModes[suite]) {\n    return new DES({\n      key: key,\n      iv: iv,\n      mode: suite\n    })\n  } else {\n    throw new TypeError('invalid suite type')\n  }\n}\nfunction createDecipheriv (suite, key, iv) {\n  suite = suite.toLowerCase()\n  if (aesModes[suite]) {\n    return aes.createDecipheriv(suite, key, iv)\n  } else if (desModes[suite]) {\n    return new DES({\n      key: key,\n      iv: iv,\n      mode: suite,\n      decrypt: true\n    })\n  } else {\n    throw new TypeError('invalid suite type')\n  }\n}\nexports.createCipher = exports.Cipher = createCipher\nexports.createCipheriv = exports.Cipheriv = createCipheriv\nexports.createDecipher = exports.Decipher = createDecipher\nexports.createDecipheriv = exports.Decipheriv = createDecipheriv\nfunction getCiphers () {\n  return Object.keys(desModes).concat(aes.getCiphers())\n}\nexports.listCiphers = exports.getCiphers = getCiphers\n","var CipherBase = require('cipher-base')\nvar des = require('des.js')\nvar inherits = require('inherits')\n\nvar modes = {\n  'des-ede3-cbc': des.CBC.instantiate(des.EDE),\n  'des-ede3': des.EDE,\n  'des-ede-cbc': des.CBC.instantiate(des.EDE),\n  'des-ede': des.EDE,\n  'des-cbc': des.CBC.instantiate(des.DES),\n  'des-ecb': des.DES\n}\nmodes.des = modes['des-cbc']\nmodes.des3 = modes['des-ede3-cbc']\nmodule.exports = DES\ninherits(DES, CipherBase)\nfunction DES (opts) {\n  CipherBase.call(this)\n  var modeName = opts.mode.toLowerCase()\n  var mode = modes[modeName]\n  var type\n  if (opts.decrypt) {\n    type = 'decrypt'\n  } else {\n    type = 'encrypt'\n  }\n  var key = opts.key\n  if (modeName === 'des-ede' || modeName === 'des-ede-cbc') {\n    key = Buffer.concat([key, key.slice(0, 8)])\n  }\n  var iv = opts.iv\n  this._des = mode.create({\n    key: key,\n    iv: iv,\n    type: type\n  })\n}\nDES.prototype._update = function (data) {\n  return new Buffer(this._des.update(data))\n}\nDES.prototype._final = function () {\n  return new Buffer(this._des.final())\n}\n","exports['des-ecb'] = {\n  key: 8,\n  iv: 0\n}\nexports['des-cbc'] = exports.des = {\n  key: 8,\n  iv: 8\n}\nexports['des-ede3-cbc'] = exports.des3 = {\n  key: 24,\n  iv: 8\n}\nexports['des-ede3'] = {\n  key: 24,\n  iv: 0\n}\nexports['des-ede-cbc'] = {\n  key: 16,\n  iv: 8\n}\nexports['des-ede'] = {\n  key: 16,\n  iv: 0\n}\n","var bn = require('bn.js');\nvar randomBytes = require('randombytes');\nmodule.exports = crt;\nfunction blind(priv) {\n  var r = getr(priv);\n  var blinder = r.toRed(bn.mont(priv.modulus))\n  .redPow(new bn(priv.publicExponent)).fromRed();\n  return {\n    blinder: blinder,\n    unblinder:r.invm(priv.modulus)\n  };\n}\nfunction crt(msg, priv) {\n  var blinds = blind(priv);\n  var len = priv.modulus.byteLength();\n  var mod = bn.mont(priv.modulus);\n  var blinded = new bn(msg).mul(blinds.blinder).umod(priv.modulus);\n  var c1 = blinded.toRed(bn.mont(priv.prime1));\n  var c2 = blinded.toRed(bn.mont(priv.prime2));\n  var qinv = priv.coefficient;\n  var p = priv.prime1;\n  var q = priv.prime2;\n  var m1 = c1.redPow(priv.exponent1);\n  var m2 = c2.redPow(priv.exponent2);\n  m1 = m1.fromRed();\n  m2 = m2.fromRed();\n  var h = m1.isub(m2).imul(qinv).umod(p);\n  h.imul(q);\n  m2.iadd(h);\n  return new Buffer(m2.imul(blinds.unblinder).umod(priv.modulus).toArray(false, len));\n}\ncrt.getr = getr;\nfunction getr(priv) {\n  var len = priv.modulus.byteLength();\n  var r = new bn(randomBytes(len));\n  while (r.cmp(priv.modulus) >=  0 || !r.umod(priv.prime1) || !r.umod(priv.prime2)) {\n    r = new bn(randomBytes(len));\n  }\n  return r;\n}\n","'use strict'\nexports['RSA-SHA224'] = exports.sha224WithRSAEncryption = {\n  sign: 'rsa',\n  hash: 'sha224',\n  id: new Buffer('302d300d06096086480165030402040500041c', 'hex')\n}\nexports['RSA-SHA256'] = exports.sha256WithRSAEncryption = {\n  sign: 'rsa',\n  hash: 'sha256',\n  id: new Buffer('3031300d060960864801650304020105000420', 'hex')\n}\nexports['RSA-SHA384'] = exports.sha384WithRSAEncryption = {\n  sign: 'rsa',\n  hash: 'sha384',\n  id: new Buffer('3041300d060960864801650304020205000430', 'hex')\n}\nexports['RSA-SHA512'] = exports.sha512WithRSAEncryption = {\n  sign: 'rsa',\n  hash: 'sha512',\n  id: new Buffer('3051300d060960864801650304020305000440', 'hex')\n}\nexports['RSA-SHA1'] = {\n  sign: 'rsa',\n  hash: 'sha1',\n  id: new Buffer('3021300906052b0e03021a05000414', 'hex')\n}\nexports['ecdsa-with-SHA1'] = {\n  sign: 'ecdsa',\n  hash: 'sha1',\n  id: new Buffer('', 'hex')\n}\n\nexports.DSA = exports['DSA-SHA1'] = exports['DSA-SHA'] = {\n  sign: 'dsa',\n  hash: 'sha1',\n  id: new Buffer('', 'hex')\n}\nexports['DSA-SHA224'] = exports['DSA-WITH-SHA224'] = {\n  sign: 'dsa',\n  hash: 'sha224',\n  id: new Buffer('', 'hex')\n}\nexports['DSA-SHA256'] = exports['DSA-WITH-SHA256'] = {\n  sign: 'dsa',\n  hash: 'sha256',\n  id: new Buffer('', 'hex')\n}\nexports['DSA-SHA384'] = exports['DSA-WITH-SHA384'] = {\n  sign: 'dsa',\n  hash: 'sha384',\n  id: new Buffer('', 'hex')\n}\nexports['DSA-SHA512'] = exports['DSA-WITH-SHA512'] = {\n  sign: 'dsa',\n  hash: 'sha512',\n  id: new Buffer('', 'hex')\n}\nexports['DSA-RIPEMD160'] = {\n  sign: 'dsa',\n  hash: 'rmd160',\n  id: new Buffer('', 'hex')\n}\nexports['RSA-RIPEMD160'] = exports.ripemd160WithRSA = {\n  sign: 'rsa',\n  hash: 'rmd160',\n  id: new Buffer('3021300906052b2403020105000414', 'hex')\n}\nexports['RSA-MD5'] = exports.md5WithRSAEncryption = {\n  sign: 'rsa',\n  hash: 'md5',\n  id: new Buffer('3020300c06082a864886f70d020505000410', 'hex')\n}\n","var _algos = require('./algos')\nvar createHash = require('create-hash')\nvar inherits = require('inherits')\nvar sign = require('./sign')\nvar stream = require('stream')\nvar verify = require('./verify')\n\nvar algos = {}\nObject.keys(_algos).forEach(function (key) {\n  algos[key] = algos[key.toLowerCase()] = _algos[key]\n})\n\nfunction Sign (algorithm) {\n  stream.Writable.call(this)\n\n  var data = algos[algorithm]\n  if (!data) {\n    throw new Error('Unknown message digest')\n  }\n\n  this._hashType = data.hash\n  this._hash = createHash(data.hash)\n  this._tag = data.id\n  this._signType = data.sign\n}\ninherits(Sign, stream.Writable)\n\nSign.prototype._write = function _write (data, _, done) {\n  this._hash.update(data)\n  done()\n}\n\nSign.prototype.update = function update (data, enc) {\n  if (typeof data === 'string') {\n    data = new Buffer(data, enc)\n  }\n\n  this._hash.update(data)\n  return this\n}\n\nSign.prototype.sign = function signMethod (key, enc) {\n  this.end()\n  var hash = this._hash.digest()\n  var sig = sign(Buffer.concat([this._tag, hash]), key, this._hashType, this._signType)\n\n  return enc ? sig.toString(enc) : sig\n}\n\nfunction Verify (algorithm) {\n  stream.Writable.call(this)\n\n  var data = algos[algorithm]\n  if (!data) {\n    throw new Error('Unknown message digest')\n  }\n\n  this._hash = createHash(data.hash)\n  this._tag = data.id\n  this._signType = data.sign\n}\ninherits(Verify, stream.Writable)\n\nVerify.prototype._write = function _write (data, _, done) {\n  this._hash.update(data)\n\n  done()\n}\n\nVerify.prototype.update = function update (data, enc) {\n  if (typeof data === 'string') {\n    data = new Buffer(data, enc)\n  }\n\n  this._hash.update(data)\n  return this\n}\n\nVerify.prototype.verify = function verifyMethod (key, sig, enc) {\n  if (typeof sig === 'string') {\n    sig = new Buffer(sig, enc)\n  }\n\n  this.end()\n  var hash = this._hash.digest()\n\n  return verify(sig, Buffer.concat([this._tag, hash]), key, this._signType)\n}\n\nfunction createSign (algorithm) {\n  return new Sign(algorithm)\n}\n\nfunction createVerify (algorithm) {\n  return new Verify(algorithm)\n}\n\nmodule.exports = {\n  Sign: createSign,\n  Verify: createVerify,\n  createSign: createSign,\n  createVerify: createVerify\n}\n","'use strict'\nexports['1.3.132.0.10'] = 'secp256k1'\n\nexports['1.3.132.0.33'] = 'p224'\n\nexports['1.2.840.10045.3.1.1'] = 'p192'\n\nexports['1.2.840.10045.3.1.7'] = 'p256'\n\nexports['1.3.132.0.34'] = 'p384'\n\nexports['1.3.132.0.35'] = 'p521'\n","// much of this based on https://github.com/indutny/self-signed/blob/gh-pages/lib/rsa.js\nvar createHmac = require('create-hmac')\nvar crt = require('browserify-rsa')\nvar curves = require('./curves')\nvar elliptic = require('elliptic')\nvar parseKeys = require('parse-asn1')\n\nvar BN = require('bn.js')\nvar EC = elliptic.ec\n\nfunction sign (hash, key, hashType, signType) {\n  var priv = parseKeys(key)\n  if (priv.curve) {\n    if (signType !== 'ecdsa') throw new Error('wrong private key type')\n\n    return ecSign(hash, priv)\n  } else if (priv.type === 'dsa') {\n    if (signType !== 'dsa') {\n      throw new Error('wrong private key type')\n    }\n    return dsaSign(hash, priv, hashType)\n  } else {\n    if (signType !== 'rsa') throw new Error('wrong private key type')\n  }\n\n  var len = priv.modulus.byteLength()\n  var pad = [ 0, 1 ]\n  while (hash.length + pad.length + 1 < len) {\n    pad.push(0xff)\n  }\n  pad.push(0x00)\n  var i = -1\n  while (++i < hash.length) {\n    pad.push(hash[i])\n  }\n\n  var out = crt(pad, priv)\n  return out\n}\n\nfunction ecSign (hash, priv) {\n  var curveId = curves[priv.curve.join('.')]\n  if (!curveId) throw new Error('unknown curve ' + priv.curve.join('.'))\n\n  var curve = new EC(curveId)\n  var key = curve.genKeyPair()\n\n  key._importPrivate(priv.privateKey)\n  var out = key.sign(hash)\n\n  return new Buffer(out.toDER())\n}\n\nfunction dsaSign (hash, priv, algo) {\n  var x = priv.params.priv_key\n  var p = priv.params.p\n  var q = priv.params.q\n  var g = priv.params.g\n  var r = new BN(0)\n  var k\n  var H = bits2int(hash, q).mod(q)\n  var s = false\n  var kv = getKey(x, q, hash, algo)\n  while (s === false) {\n    k = makeKey(q, kv, algo)\n    r = makeR(g, k, p, q)\n    s = k.invm(q).imul(H.add(x.mul(r))).mod(q)\n    if (!s.cmpn(0)) {\n      s = false\n      r = new BN(0)\n    }\n  }\n  return toDER(r, s)\n}\n\nfunction toDER (r, s) {\n  r = r.toArray()\n  s = s.toArray()\n\n  // Pad values\n  if (r[0] & 0x80) {\n    r = [ 0 ].concat(r)\n  }\n  // Pad values\n  if (s[0] & 0x80) {\n    s = [0].concat(s)\n  }\n\n  var total = r.length + s.length + 4\n  var res = [ 0x30, total, 0x02, r.length ]\n  res = res.concat(r, [ 0x02, s.length ], s)\n  return new Buffer(res)\n}\n\nfunction getKey (x, q, hash, algo) {\n  x = new Buffer(x.toArray())\n  if (x.length < q.byteLength()) {\n    var zeros = new Buffer(q.byteLength() - x.length)\n    zeros.fill(0)\n    x = Buffer.concat([zeros, x])\n  }\n  var hlen = hash.length\n  var hbits = bits2octets(hash, q)\n  var v = new Buffer(hlen)\n  v.fill(1)\n  var k = new Buffer(hlen)\n  k.fill(0)\n  k = createHmac(algo, k)\n    .update(v)\n    .update(new Buffer([0]))\n    .update(x)\n    .update(hbits)\n    .digest()\n  v = createHmac(algo, k)\n    .update(v)\n    .digest()\n  k = createHmac(algo, k)\n    .update(v)\n    .update(new Buffer([1]))\n    .update(x)\n    .update(hbits)\n    .digest()\n  v = createHmac(algo, k)\n    .update(v)\n    .digest()\n  return {\n    k: k,\n    v: v\n  }\n}\n\nfunction bits2int (obits, q) {\n  var bits = new BN(obits)\n  var shift = (obits.length << 3) - q.bitLength()\n  if (shift > 0) {\n    bits.ishrn(shift)\n  }\n  return bits\n}\n\nfunction bits2octets (bits, q) {\n  bits = bits2int(bits, q)\n  bits = bits.mod(q)\n  var out = new Buffer(bits.toArray())\n  if (out.length < q.byteLength()) {\n    var zeros = new Buffer(q.byteLength() - out.length)\n    zeros.fill(0)\n    out = Buffer.concat([zeros, out])\n  }\n  return out\n}\n\nfunction makeKey (q, kv, algo) {\n  var t, k\n\n  do {\n    t = new Buffer('')\n\n    while (t.length * 8 < q.bitLength()) {\n      kv.v = createHmac(algo, kv.k)\n        .update(kv.v)\n        .digest()\n      t = Buffer.concat([t, kv.v])\n    }\n\n    k = bits2int(t, q)\n    kv.k = createHmac(algo, kv.k)\n      .update(kv.v)\n      .update(new Buffer([0]))\n      .digest()\n    kv.v = createHmac(algo, kv.k)\n      .update(kv.v)\n      .digest()\n  } while (k.cmp(q) !== -1)\n\n  return k\n}\n\nfunction makeR (g, k, p, q) {\n  return g.toRed(BN.mont(p)).redPow(k).fromRed().mod(q)\n}\n\nmodule.exports = sign\nmodule.exports.getKey = getKey\nmodule.exports.makeKey = makeKey\n","// much of this based on https://github.com/indutny/self-signed/blob/gh-pages/lib/rsa.js\nvar curves = require('./curves')\nvar elliptic = require('elliptic')\nvar parseKeys = require('parse-asn1')\n\nvar BN = require('bn.js')\nvar EC = elliptic.ec\n\nfunction verify (sig, hash, key, signType) {\n  var pub = parseKeys(key)\n  if (pub.type === 'ec') {\n    if (signType !== 'ecdsa') {\n      throw new Error('wrong public key type')\n    }\n    return ecVerify(sig, hash, pub)\n  } else if (pub.type === 'dsa') {\n    if (signType !== 'dsa') {\n      throw new Error('wrong public key type')\n    }\n    return dsaVerify(sig, hash, pub)\n  } else {\n    if (signType !== 'rsa') {\n      throw new Error('wrong public key type')\n    }\n  }\n  var len = pub.modulus.byteLength()\n  var pad = [ 1 ]\n  var padNum = 0\n  while (hash.length + pad.length + 2 < len) {\n    pad.push(0xff)\n    padNum++\n  }\n  pad.push(0x00)\n  var i = -1\n  while (++i < hash.length) {\n    pad.push(hash[i])\n  }\n  pad = new Buffer(pad)\n  var red = BN.mont(pub.modulus)\n  sig = new BN(sig).toRed(red)\n\n  sig = sig.redPow(new BN(pub.publicExponent))\n\n  sig = new Buffer(sig.fromRed().toArray())\n  var out = 0\n  if (padNum < 8) {\n    out = 1\n  }\n  len = Math.min(sig.length, pad.length)\n  if (sig.length !== pad.length) {\n    out = 1\n  }\n\n  i = -1\n  while (++i < len) {\n    out |= (sig[i] ^ pad[i])\n  }\n  return out === 0\n}\n\nfunction ecVerify (sig, hash, pub) {\n  var curveId = curves[pub.data.algorithm.curve.join('.')]\n  if (!curveId) throw new Error('unknown curve ' + pub.data.algorithm.curve.join('.'))\n\n  var curve = new EC(curveId)\n  var pubkey = pub.data.subjectPrivateKey.data\n\n  return curve.verify(hash, sig, pubkey)\n}\n\nfunction dsaVerify (sig, hash, pub) {\n  var p = pub.data.p\n  var q = pub.data.q\n  var g = pub.data.g\n  var y = pub.data.pub_key\n  var unpacked = parseKeys.signature.decode(sig, 'der')\n  var s = unpacked.s\n  var r = unpacked.r\n  checkValue(s, q)\n  checkValue(r, q)\n  var montp = BN.mont(p)\n  var w = s.invm(q)\n  var v = g.toRed(montp)\n    .redPow(new BN(hash).mul(w).mod(q))\n    .fromRed()\n    .mul(\n      y.toRed(montp)\n        .redPow(r.mul(w).mod(q))\n        .fromRed()\n  ).mod(p).mod(q)\n  return !v.cmp(r)\n}\n\nfunction checkValue (b, q) {\n  if (b.cmpn(0) <= 0) {\n    throw new Error('invalid sig')\n  }\n  if (b.cmp(q) >= q) {\n    throw new Error('invalid sig')\n  }\n}\n\nmodule.exports = verify\n","var Buffer = require('buffer').Buffer; // for use with browserify\n\nmodule.exports = function (a, b) {\n    if (!Buffer.isBuffer(a)) return undefined;\n    if (!Buffer.isBuffer(b)) return undefined;\n    if (typeof a.equals === 'function') return a.equals(b);\n    if (a.length !== b.length) return false;\n    \n    for (var i = 0; i < a.length; i++) {\n        if (a[i] !== b[i]) return false;\n    }\n    \n    return true;\n};\n","module.exports = function xor (a, b) {\n  var length = Math.min(a.length, b.length)\n  var buffer = new Buffer(length)\n\n  for (var i = 0; i < length; ++i) {\n    buffer[i] = a[i] ^ b[i]\n  }\n\n  return buffer\n}\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>\n * @license  MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\nvar isArray = require('isarray')\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\nBuffer.poolSize = 8192 // not used by this implementation\n\nvar rootParent = {}\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n *   === true    Use Uint8Array implementation (fastest)\n *   === false   Use Object implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * Due to various browser bugs, sometimes the Object implementation will be used even\n * when the browser supports typed arrays.\n *\n * Note:\n *\n *   - Firefox 4-29 lacks support for adding new properties to `Uint8Array` instances,\n *     See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438.\n *\n *   - Chrome 9-10 is missing the `TypedArray.prototype.subarray` function.\n *\n *   - IE10 has a broken `TypedArray.prototype.subarray` function which returns arrays of\n *     incorrect length in some situations.\n\n * We detect these buggy browsers and set `Buffer.TYPED_ARRAY_SUPPORT` to `false` so they\n * get the Object implementation, which is slower but behaves correctly.\n */\nBuffer.TYPED_ARRAY_SUPPORT = global.TYPED_ARRAY_SUPPORT !== undefined\n  ? global.TYPED_ARRAY_SUPPORT\n  : typedArraySupport()\n\nfunction typedArraySupport () {\n  try {\n    var arr = new Uint8Array(1)\n    arr.foo = function () { return 42 }\n    return arr.foo() === 42 && // typed array instances can be augmented\n        typeof arr.subarray === 'function' && // chrome 9-10 lack `subarray`\n        arr.subarray(1, 1).byteLength === 0 // ie10 has broken `subarray`\n  } catch (e) {\n    return false\n  }\n}\n\nfunction kMaxLength () {\n  return Buffer.TYPED_ARRAY_SUPPORT\n    ? 0x7fffffff\n    : 0x3fffffff\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\nfunction Buffer (arg) {\n  if (!(this instanceof Buffer)) {\n    // Avoid going through an ArgumentsAdaptorTrampoline in the common case.\n    if (arguments.length > 1) return new Buffer(arg, arguments[1])\n    return new Buffer(arg)\n  }\n\n  if (!Buffer.TYPED_ARRAY_SUPPORT) {\n    this.length = 0\n    this.parent = undefined\n  }\n\n  // Common case.\n  if (typeof arg === 'number') {\n    return fromNumber(this, arg)\n  }\n\n  // Slightly less common case.\n  if (typeof arg === 'string') {\n    return fromString(this, arg, arguments.length > 1 ? arguments[1] : 'utf8')\n  }\n\n  // Unusual.\n  return fromObject(this, arg)\n}\n\n// TODO: Legacy, not needed anymore. Remove in next major version.\nBuffer._augment = function (arr) {\n  arr.__proto__ = Buffer.prototype\n  return arr\n}\n\nfunction fromNumber (that, length) {\n  that = allocate(that, length < 0 ? 0 : checked(length) | 0)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) {\n    for (var i = 0; i < length; i++) {\n      that[i] = 0\n    }\n  }\n  return that\n}\n\nfunction fromString (that, string, encoding) {\n  if (typeof encoding !== 'string' || encoding === '') encoding = 'utf8'\n\n  // Assumption: byteLength() return value is always < kMaxLength.\n  var length = byteLength(string, encoding) | 0\n  that = allocate(that, length)\n\n  that.write(string, encoding)\n  return that\n}\n\nfunction fromObject (that, object) {\n  if (Buffer.isBuffer(object)) return fromBuffer(that, object)\n\n  if (isArray(object)) return fromArray(that, object)\n\n  if (object == null) {\n    throw new TypeError('must start with number, buffer, array or string')\n  }\n\n  if (typeof ArrayBuffer !== 'undefined') {\n    if (object.buffer instanceof ArrayBuffer) {\n      return fromTypedArray(that, object)\n    }\n    if (object instanceof ArrayBuffer) {\n      return fromArrayBuffer(that, object)\n    }\n  }\n\n  if (object.length) return fromArrayLike(that, object)\n\n  return fromJsonObject(that, object)\n}\n\nfunction fromBuffer (that, buffer) {\n  var length = checked(buffer.length) | 0\n  that = allocate(that, length)\n  buffer.copy(that, 0, 0, length)\n  return that\n}\n\nfunction fromArray (that, array) {\n  var length = checked(array.length) | 0\n  that = allocate(that, length)\n  for (var i = 0; i < length; i += 1) {\n    that[i] = array[i] & 255\n  }\n  return that\n}\n\n// Duplicate of fromArray() to keep fromArray() monomorphic.\nfunction fromTypedArray (that, array) {\n  var length = checked(array.length) | 0\n  that = allocate(that, length)\n  // Truncating the elements is probably not what people expect from typed\n  // arrays with BYTES_PER_ELEMENT > 1 but it's compatible with the behavior\n  // of the old Buffer constructor.\n  for (var i = 0; i < length; i += 1) {\n    that[i] = array[i] & 255\n  }\n  return that\n}\n\nfunction fromArrayBuffer (that, array) {\n  array.byteLength // this throws if `array` is not a valid ArrayBuffer\n\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    // Return an augmented `Uint8Array` instance, for best performance\n    that = new Uint8Array(array)\n    that.__proto__ = Buffer.prototype\n  } else {\n    // Fallback: Return an object instance of the Buffer class\n    that = fromTypedArray(that, new Uint8Array(array))\n  }\n  return that\n}\n\nfunction fromArrayLike (that, array) {\n  var length = checked(array.length) | 0\n  that = allocate(that, length)\n  for (var i = 0; i < length; i += 1) {\n    that[i] = array[i] & 255\n  }\n  return that\n}\n\n// Deserialize { type: 'Buffer', data: [1,2,3,...] } into a Buffer object.\n// Returns a zero-length buffer for inputs that don't conform to the spec.\nfunction fromJsonObject (that, object) {\n  var array\n  var length = 0\n\n  if (object.type === 'Buffer' && isArray(object.data)) {\n    array = object.data\n    length = checked(array.length) | 0\n  }\n  that = allocate(that, length)\n\n  for (var i = 0; i < length; i += 1) {\n    that[i] = array[i] & 255\n  }\n  return that\n}\n\nif (Buffer.TYPED_ARRAY_SUPPORT) {\n  Buffer.prototype.__proto__ = Uint8Array.prototype\n  Buffer.__proto__ = Uint8Array\n  if (typeof Symbol !== 'undefined' && Symbol.species &&\n      Buffer[Symbol.species] === Buffer) {\n    // Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97\n    Object.defineProperty(Buffer, Symbol.species, {\n      value: null,\n      configurable: true\n    })\n  }\n} else {\n  // pre-set for values that may exist in the future\n  Buffer.prototype.length = undefined\n  Buffer.prototype.parent = undefined\n}\n\nfunction allocate (that, length) {\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    // Return an augmented `Uint8Array` instance, for best performance\n    that = new Uint8Array(length)\n    that.__proto__ = Buffer.prototype\n  } else {\n    // Fallback: Return an object instance of the Buffer class\n    that.length = length\n  }\n\n  var fromPool = length !== 0 && length <= Buffer.poolSize >>> 1\n  if (fromPool) that.parent = rootParent\n\n  return that\n}\n\nfunction checked (length) {\n  // Note: cannot use `length < kMaxLength` here because that fails when\n  // length is NaN (which is otherwise coerced to zero.)\n  if (length >= kMaxLength()) {\n    throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n                         'size: 0x' + kMaxLength().toString(16) + ' bytes')\n  }\n  return length | 0\n}\n\nfunction SlowBuffer (subject, encoding) {\n  if (!(this instanceof SlowBuffer)) return new SlowBuffer(subject, encoding)\n\n  var buf = new Buffer(subject, encoding)\n  delete buf.parent\n  return buf\n}\n\nBuffer.isBuffer = function isBuffer (b) {\n  return !!(b != null && b._isBuffer)\n}\n\nBuffer.compare = function compare (a, b) {\n  if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n    throw new TypeError('Arguments must be Buffers')\n  }\n\n  if (a === b) return 0\n\n  var x = a.length\n  var y = b.length\n\n  for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n    if (a[i] !== b[i]) {\n      x = a[i]\n      y = b[i]\n      break\n    }\n  }\n\n  if (x < y) return -1\n  if (y < x) return 1\n  return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n  switch (String(encoding).toLowerCase()) {\n    case 'hex':\n    case 'utf8':\n    case 'utf-8':\n    case 'ascii':\n    case 'binary':\n    case 'base64':\n    case 'raw':\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      return true\n    default:\n      return false\n  }\n}\n\nBuffer.concat = function concat (list, length) {\n  if (!isArray(list)) throw new TypeError('list argument must be an Array of Buffers.')\n\n  if (list.length === 0) {\n    return new Buffer(0)\n  }\n\n  var i\n  if (length === undefined) {\n    length = 0\n    for (i = 0; i < list.length; i++) {\n      length += list[i].length\n    }\n  }\n\n  var buf = new Buffer(length)\n  var pos = 0\n  for (i = 0; i < list.length; i++) {\n    var item = list[i]\n    item.copy(buf, pos)\n    pos += item.length\n  }\n  return buf\n}\n\nfunction byteLength (string, encoding) {\n  if (typeof string !== 'string') string = '' + string\n\n  var len = string.length\n  if (len === 0) return 0\n\n  // Use a for loop to avoid recursion\n  var loweredCase = false\n  for (;;) {\n    switch (encoding) {\n      case 'ascii':\n      case 'binary':\n      // Deprecated\n      case 'raw':\n      case 'raws':\n        return len\n      case 'utf8':\n      case 'utf-8':\n        return utf8ToBytes(string).length\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return len * 2\n      case 'hex':\n        return len >>> 1\n      case 'base64':\n        return base64ToBytes(string).length\n      default:\n        if (loweredCase) return utf8ToBytes(string).length // assume utf8\n        encoding = ('' + encoding).toLowerCase()\n        loweredCase = true\n    }\n  }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n  var loweredCase = false\n\n  start = start | 0\n  end = end === undefined || end === Infinity ? this.length : end | 0\n\n  if (!encoding) encoding = 'utf8'\n  if (start < 0) start = 0\n  if (end > this.length) end = this.length\n  if (end <= start) return ''\n\n  while (true) {\n    switch (encoding) {\n      case 'hex':\n        return hexSlice(this, start, end)\n\n      case 'utf8':\n      case 'utf-8':\n        return utf8Slice(this, start, end)\n\n      case 'ascii':\n        return asciiSlice(this, start, end)\n\n      case 'binary':\n        return binarySlice(this, start, end)\n\n      case 'base64':\n        return base64Slice(this, start, end)\n\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return utf16leSlice(this, start, end)\n\n      default:\n        if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n        encoding = (encoding + '').toLowerCase()\n        loweredCase = true\n    }\n  }\n}\n\n// The property is used by `Buffer.isBuffer` and `is-buffer` (in Safari 5-7) to detect\n// Buffer instances.\nBuffer.prototype._isBuffer = true\n\nBuffer.prototype.toString = function toString () {\n  var length = this.length | 0\n  if (length === 0) return ''\n  if (arguments.length === 0) return utf8Slice(this, 0, length)\n  return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.equals = function equals (b) {\n  if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n  if (this === b) return true\n  return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n  var str = ''\n  var max = exports.INSPECT_MAX_BYTES\n  if (this.length > 0) {\n    str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')\n    if (this.length > max) str += ' ... '\n  }\n  return '<Buffer ' + str + '>'\n}\n\nBuffer.prototype.compare = function compare (b) {\n  if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n  return Buffer.compare(this, b)\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset) {\n  if (byteOffset > 0x7fffffff) byteOffset = 0x7fffffff\n  else if (byteOffset < -0x80000000) byteOffset = -0x80000000\n  byteOffset >>= 0\n\n  if (this.length === 0) return -1\n  if (byteOffset >= this.length) return -1\n\n  // Negative offsets start from the end of the buffer\n  if (byteOffset < 0) byteOffset = Math.max(this.length + byteOffset, 0)\n\n  if (typeof val === 'string') {\n    if (val.length === 0) return -1 // special case: looking for empty string always fails\n    return String.prototype.indexOf.call(this, val, byteOffset)\n  }\n  if (Buffer.isBuffer(val)) {\n    return arrayIndexOf(this, val, byteOffset)\n  }\n  if (typeof val === 'number') {\n    if (Buffer.TYPED_ARRAY_SUPPORT && Uint8Array.prototype.indexOf === 'function') {\n      return Uint8Array.prototype.indexOf.call(this, val, byteOffset)\n    }\n    return arrayIndexOf(this, [ val ], byteOffset)\n  }\n\n  function arrayIndexOf (arr, val, byteOffset) {\n    var foundIndex = -1\n    for (var i = 0; byteOffset + i < arr.length; i++) {\n      if (arr[byteOffset + i] === val[foundIndex === -1 ? 0 : i - foundIndex]) {\n        if (foundIndex === -1) foundIndex = i\n        if (i - foundIndex + 1 === val.length) return byteOffset + foundIndex\n      } else {\n        foundIndex = -1\n      }\n    }\n    return -1\n  }\n\n  throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction hexWrite (buf, string, offset, length) {\n  offset = Number(offset) || 0\n  var remaining = buf.length - offset\n  if (!length) {\n    length = remaining\n  } else {\n    length = Number(length)\n    if (length > remaining) {\n      length = remaining\n    }\n  }\n\n  // must be an even number of digits\n  var strLen = string.length\n  if (strLen % 2 !== 0) throw new Error('Invalid hex string')\n\n  if (length > strLen / 2) {\n    length = strLen / 2\n  }\n  for (var i = 0; i < length; i++) {\n    var parsed = parseInt(string.substr(i * 2, 2), 16)\n    if (isNaN(parsed)) throw new Error('Invalid hex string')\n    buf[offset + i] = parsed\n  }\n  return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n  return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n  return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction binaryWrite (buf, string, offset, length) {\n  return asciiWrite(buf, string, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n  return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n  return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n  // Buffer#write(string)\n  if (offset === undefined) {\n    encoding = 'utf8'\n    length = this.length\n    offset = 0\n  // Buffer#write(string, encoding)\n  } else if (length === undefined && typeof offset === 'string') {\n    encoding = offset\n    length = this.length\n    offset = 0\n  // Buffer#write(string, offset[, length][, encoding])\n  } else if (isFinite(offset)) {\n    offset = offset | 0\n    if (isFinite(length)) {\n      length = length | 0\n      if (encoding === undefined) encoding = 'utf8'\n    } else {\n      encoding = length\n      length = undefined\n    }\n  // legacy write(string, encoding, offset, length) - remove in v0.13\n  } else {\n    var swap = encoding\n    encoding = offset\n    offset = length | 0\n    length = swap\n  }\n\n  var remaining = this.length - offset\n  if (length === undefined || length > remaining) length = remaining\n\n  if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n    throw new RangeError('attempt to write outside buffer bounds')\n  }\n\n  if (!encoding) encoding = 'utf8'\n\n  var loweredCase = false\n  for (;;) {\n    switch (encoding) {\n      case 'hex':\n        return hexWrite(this, string, offset, length)\n\n      case 'utf8':\n      case 'utf-8':\n        return utf8Write(this, string, offset, length)\n\n      case 'ascii':\n        return asciiWrite(this, string, offset, length)\n\n      case 'binary':\n        return binaryWrite(this, string, offset, length)\n\n      case 'base64':\n        // Warning: maxLength not taken into account in base64Write\n        return base64Write(this, string, offset, length)\n\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return ucs2Write(this, string, offset, length)\n\n      default:\n        if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n        encoding = ('' + encoding).toLowerCase()\n        loweredCase = true\n    }\n  }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n  return {\n    type: 'Buffer',\n    data: Array.prototype.slice.call(this._arr || this, 0)\n  }\n}\n\nfunction base64Slice (buf, start, end) {\n  if (start === 0 && end === buf.length) {\n    return base64.fromByteArray(buf)\n  } else {\n    return base64.fromByteArray(buf.slice(start, end))\n  }\n}\n\nfunction utf8Slice (buf, start, end) {\n  end = Math.min(buf.length, end)\n  var res = []\n\n  var i = start\n  while (i < end) {\n    var firstByte = buf[i]\n    var codePoint = null\n    var bytesPerSequence = (firstByte > 0xEF) ? 4\n      : (firstByte > 0xDF) ? 3\n      : (firstByte > 0xBF) ? 2\n      : 1\n\n    if (i + bytesPerSequence <= end) {\n      var secondByte, thirdByte, fourthByte, tempCodePoint\n\n      switch (bytesPerSequence) {\n        case 1:\n          if (firstByte < 0x80) {\n            codePoint = firstByte\n          }\n          break\n        case 2:\n          secondByte = buf[i + 1]\n          if ((secondByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n            if (tempCodePoint > 0x7F) {\n              codePoint = tempCodePoint\n            }\n          }\n          break\n        case 3:\n          secondByte = buf[i + 1]\n          thirdByte = buf[i + 2]\n          if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n            if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n              codePoint = tempCodePoint\n            }\n          }\n          break\n        case 4:\n          secondByte = buf[i + 1]\n          thirdByte = buf[i + 2]\n          fourthByte = buf[i + 3]\n          if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n            if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n              codePoint = tempCodePoint\n            }\n          }\n      }\n    }\n\n    if (codePoint === null) {\n      // we did not generate a valid codePoint so insert a\n      // replacement char (U+FFFD) and advance only 1 byte\n      codePoint = 0xFFFD\n      bytesPerSequence = 1\n    } else if (codePoint > 0xFFFF) {\n      // encode to utf16 (surrogate pair dance)\n      codePoint -= 0x10000\n      res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n      codePoint = 0xDC00 | codePoint & 0x3FF\n    }\n\n    res.push(codePoint)\n    i += bytesPerSequence\n  }\n\n  return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nvar MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n  var len = codePoints.length\n  if (len <= MAX_ARGUMENTS_LENGTH) {\n    return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n  }\n\n  // Decode in chunks to avoid \"call stack size exceeded\".\n  var res = ''\n  var i = 0\n  while (i < len) {\n    res += String.fromCharCode.apply(\n      String,\n      codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n    )\n  }\n  return res\n}\n\nfunction asciiSlice (buf, start, end) {\n  var ret = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; i++) {\n    ret += String.fromCharCode(buf[i] & 0x7F)\n  }\n  return ret\n}\n\nfunction binarySlice (buf, start, end) {\n  var ret = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; i++) {\n    ret += String.fromCharCode(buf[i])\n  }\n  return ret\n}\n\nfunction hexSlice (buf, start, end) {\n  var len = buf.length\n\n  if (!start || start < 0) start = 0\n  if (!end || end < 0 || end > len) end = len\n\n  var out = ''\n  for (var i = start; i < end; i++) {\n    out += toHex(buf[i])\n  }\n  return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n  var bytes = buf.slice(start, end)\n  var res = ''\n  for (var i = 0; i < bytes.length; i += 2) {\n    res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256)\n  }\n  return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n  var len = this.length\n  start = ~~start\n  end = end === undefined ? len : ~~end\n\n  if (start < 0) {\n    start += len\n    if (start < 0) start = 0\n  } else if (start > len) {\n    start = len\n  }\n\n  if (end < 0) {\n    end += len\n    if (end < 0) end = 0\n  } else if (end > len) {\n    end = len\n  }\n\n  if (end < start) end = start\n\n  var newBuf\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    newBuf = this.subarray(start, end)\n    newBuf.__proto__ = Buffer.prototype\n  } else {\n    var sliceLen = end - start\n    newBuf = new Buffer(sliceLen, undefined)\n    for (var i = 0; i < sliceLen; i++) {\n      newBuf[i] = this[i + start]\n    }\n  }\n\n  if (newBuf.length) newBuf.parent = this.parent || this\n\n  return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n  if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n  if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var val = this[offset]\n  var mul = 1\n  var i = 0\n  while (++i < byteLength && (mul *= 0x100)) {\n    val += this[offset + i] * mul\n  }\n\n  return val\n}\n\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) {\n    checkOffset(offset, byteLength, this.length)\n  }\n\n  var val = this[offset + --byteLength]\n  var mul = 1\n  while (byteLength > 0 && (mul *= 0x100)) {\n    val += this[offset + --byteLength] * mul\n  }\n\n  return val\n}\n\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 1, this.length)\n  return this[offset]\n}\n\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return ((this[offset]) |\n      (this[offset + 1] << 8) |\n      (this[offset + 2] << 16)) +\n      (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return (this[offset] * 0x1000000) +\n    ((this[offset + 1] << 16) |\n    (this[offset + 2] << 8) |\n    this[offset + 3])\n}\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var val = this[offset]\n  var mul = 1\n  var i = 0\n  while (++i < byteLength && (mul *= 0x100)) {\n    val += this[offset + i] * mul\n  }\n  mul *= 0x80\n\n  if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n  return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var i = byteLength\n  var mul = 1\n  var val = this[offset + --i]\n  while (i > 0 && (mul *= 0x100)) {\n    val += this[offset + --i] * mul\n  }\n  mul *= 0x80\n\n  if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n  return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 1, this.length)\n  if (!(this[offset] & 0x80)) return (this[offset])\n  return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  var val = this[offset] | (this[offset + 1] << 8)\n  return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  var val = this[offset + 1] | (this[offset] << 8)\n  return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return (this[offset]) |\n    (this[offset + 1] << 8) |\n    (this[offset + 2] << 16) |\n    (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return (this[offset] << 24) |\n    (this[offset + 1] << 16) |\n    (this[offset + 2] << 8) |\n    (this[offset + 3])\n}\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n  return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 4, this.length)\n  return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 8, this.length)\n  return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n  if (!noAssert) checkOffset(offset, 8, this.length)\n  return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n  if (!Buffer.isBuffer(buf)) throw new TypeError('buffer must be a Buffer instance')\n  if (value > max || value < min) throw new RangeError('value is out of bounds')\n  if (offset + ext > buf.length) throw new RangeError('index out of range')\n}\n\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkInt(this, value, offset, byteLength, Math.pow(2, 8 * byteLength), 0)\n\n  var mul = 1\n  var i = 0\n  this[offset] = value & 0xFF\n  while (++i < byteLength && (mul *= 0x100)) {\n    this[offset + i] = (value / mul) & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  byteLength = byteLength | 0\n  if (!noAssert) checkInt(this, value, offset, byteLength, Math.pow(2, 8 * byteLength), 0)\n\n  var i = byteLength - 1\n  var mul = 1\n  this[offset + i] = value & 0xFF\n  while (--i >= 0 && (mul *= 0x100)) {\n    this[offset + i] = (value / mul) & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n  this[offset] = (value & 0xff)\n  return offset + 1\n}\n\nfunction objectWriteUInt16 (buf, value, offset, littleEndian) {\n  if (value < 0) value = 0xffff + value + 1\n  for (var i = 0, j = Math.min(buf.length - offset, 2); i < j; i++) {\n    buf[offset + i] = (value & (0xff << (8 * (littleEndian ? i : 1 - i)))) >>>\n      (littleEndian ? i : 1 - i) * 8\n  }\n}\n\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value & 0xff)\n    this[offset + 1] = (value >>> 8)\n  } else {\n    objectWriteUInt16(this, value, offset, true)\n  }\n  return offset + 2\n}\n\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 8)\n    this[offset + 1] = (value & 0xff)\n  } else {\n    objectWriteUInt16(this, value, offset, false)\n  }\n  return offset + 2\n}\n\nfunction objectWriteUInt32 (buf, value, offset, littleEndian) {\n  if (value < 0) value = 0xffffffff + value + 1\n  for (var i = 0, j = Math.min(buf.length - offset, 4); i < j; i++) {\n    buf[offset + i] = (value >>> (littleEndian ? i : 3 - i) * 8) & 0xff\n  }\n}\n\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset + 3] = (value >>> 24)\n    this[offset + 2] = (value >>> 16)\n    this[offset + 1] = (value >>> 8)\n    this[offset] = (value & 0xff)\n  } else {\n    objectWriteUInt32(this, value, offset, true)\n  }\n  return offset + 4\n}\n\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 24)\n    this[offset + 1] = (value >>> 16)\n    this[offset + 2] = (value >>> 8)\n    this[offset + 3] = (value & 0xff)\n  } else {\n    objectWriteUInt32(this, value, offset, false)\n  }\n  return offset + 4\n}\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) {\n    var limit = Math.pow(2, 8 * byteLength - 1)\n\n    checkInt(this, value, offset, byteLength, limit - 1, -limit)\n  }\n\n  var i = 0\n  var mul = 1\n  var sub = value < 0 ? 1 : 0\n  this[offset] = value & 0xFF\n  while (++i < byteLength && (mul *= 0x100)) {\n    this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) {\n    var limit = Math.pow(2, 8 * byteLength - 1)\n\n    checkInt(this, value, offset, byteLength, limit - 1, -limit)\n  }\n\n  var i = byteLength - 1\n  var mul = 1\n  var sub = value < 0 ? 1 : 0\n  this[offset + i] = value & 0xFF\n  while (--i >= 0 && (mul *= 0x100)) {\n    this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n  if (!Buffer.TYPED_ARRAY_SUPPORT) value = Math.floor(value)\n  if (value < 0) value = 0xff + value + 1\n  this[offset] = (value & 0xff)\n  return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value & 0xff)\n    this[offset + 1] = (value >>> 8)\n  } else {\n    objectWriteUInt16(this, value, offset, true)\n  }\n  return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 8)\n    this[offset + 1] = (value & 0xff)\n  } else {\n    objectWriteUInt16(this, value, offset, false)\n  }\n  return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value & 0xff)\n    this[offset + 1] = (value >>> 8)\n    this[offset + 2] = (value >>> 16)\n    this[offset + 3] = (value >>> 24)\n  } else {\n    objectWriteUInt32(this, value, offset, true)\n  }\n  return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n  value = +value\n  offset = offset | 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n  if (value < 0) value = 0xffffffff + value + 1\n  if (Buffer.TYPED_ARRAY_SUPPORT) {\n    this[offset] = (value >>> 24)\n    this[offset + 1] = (value >>> 16)\n    this[offset + 2] = (value >>> 8)\n    this[offset + 3] = (value & 0xff)\n  } else {\n    objectWriteUInt32(this, value, offset, false)\n  }\n  return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n  if (offset + ext > buf.length) throw new RangeError('index out of range')\n  if (offset < 0) throw new RangeError('index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n  }\n  ieee754.write(buf, value, offset, littleEndian, 23, 4)\n  return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n  return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n  return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n  if (!noAssert) {\n    checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n  }\n  ieee754.write(buf, value, offset, littleEndian, 52, 8)\n  return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n  return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n  return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n  if (!start) start = 0\n  if (!end && end !== 0) end = this.length\n  if (targetStart >= target.length) targetStart = target.length\n  if (!targetStart) targetStart = 0\n  if (end > 0 && end < start) end = start\n\n  // Copy 0 bytes; we're done\n  if (end === start) return 0\n  if (target.length === 0 || this.length === 0) return 0\n\n  // Fatal error conditions\n  if (targetStart < 0) {\n    throw new RangeError('targetStart out of bounds')\n  }\n  if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds')\n  if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n  // Are we oob?\n  if (end > this.length) end = this.length\n  if (target.length - targetStart < end - start) {\n    end = target.length - targetStart + start\n  }\n\n  var len = end - start\n  var i\n\n  if (this === target && start < targetStart && targetStart < end) {\n    // descending copy from end\n    for (i = len - 1; i >= 0; i--) {\n      target[i + targetStart] = this[i + start]\n    }\n  } else if (len < 1000 || !Buffer.TYPED_ARRAY_SUPPORT) {\n    // ascending copy from start\n    for (i = 0; i < len; i++) {\n      target[i + targetStart] = this[i + start]\n    }\n  } else {\n    Uint8Array.prototype.set.call(\n      target,\n      this.subarray(start, start + len),\n      targetStart\n    )\n  }\n\n  return len\n}\n\n// fill(value, start=0, end=buffer.length)\nBuffer.prototype.fill = function fill (value, start, end) {\n  if (!value) value = 0\n  if (!start) start = 0\n  if (!end) end = this.length\n\n  if (end < start) throw new RangeError('end < start')\n\n  // Fill 0 bytes; we're done\n  if (end === start) return\n  if (this.length === 0) return\n\n  if (start < 0 || start >= this.length) throw new RangeError('start out of bounds')\n  if (end < 0 || end > this.length) throw new RangeError('end out of bounds')\n\n  var i\n  if (typeof value === 'number') {\n    for (i = start; i < end; i++) {\n      this[i] = value\n    }\n  } else {\n    var bytes = utf8ToBytes(value.toString())\n    var len = bytes.length\n    for (i = start; i < end; i++) {\n      this[i] = bytes[i % len]\n    }\n  }\n\n  return this\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar INVALID_BASE64_RE = /[^+\\/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n  // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n  str = stringtrim(str).replace(INVALID_BASE64_RE, '')\n  // Node converts strings with length < 2 to ''\n  if (str.length < 2) return ''\n  // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n  while (str.length % 4 !== 0) {\n    str = str + '='\n  }\n  return str\n}\n\nfunction stringtrim (str) {\n  if (str.trim) return str.trim()\n  return str.replace(/^\\s+|\\s+$/g, '')\n}\n\nfunction toHex (n) {\n  if (n < 16) return '0' + n.toString(16)\n  return n.toString(16)\n}\n\nfunction utf8ToBytes (string, units) {\n  units = units || Infinity\n  var codePoint\n  var length = string.length\n  var leadSurrogate = null\n  var bytes = []\n\n  for (var i = 0; i < length; i++) {\n    codePoint = string.charCodeAt(i)\n\n    // is surrogate component\n    if (codePoint > 0xD7FF && codePoint < 0xE000) {\n      // last char was a lead\n      if (!leadSurrogate) {\n        // no lead yet\n        if (codePoint > 0xDBFF) {\n          // unexpected trail\n          if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n          continue\n        } else if (i + 1 === length) {\n          // unpaired lead\n          if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n          continue\n        }\n\n        // valid lead\n        leadSurrogate = codePoint\n\n        continue\n      }\n\n      // 2 leads in a row\n      if (codePoint < 0xDC00) {\n        if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n        leadSurrogate = codePoint\n        continue\n      }\n\n      // valid surrogate pair\n      codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n    } else if (leadSurrogate) {\n      // valid bmp char, but last char was a lead\n      if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n    }\n\n    leadSurrogate = null\n\n    // encode utf8\n    if (codePoint < 0x80) {\n      if ((units -= 1) < 0) break\n      bytes.push(codePoint)\n    } else if (codePoint < 0x800) {\n      if ((units -= 2) < 0) break\n      bytes.push(\n        codePoint >> 0x6 | 0xC0,\n        codePoint & 0x3F | 0x80\n      )\n    } else if (codePoint < 0x10000) {\n      if ((units -= 3) < 0) break\n      bytes.push(\n        codePoint >> 0xC | 0xE0,\n        codePoint >> 0x6 & 0x3F | 0x80,\n        codePoint & 0x3F | 0x80\n      )\n    } else if (codePoint < 0x110000) {\n      if ((units -= 4) < 0) break\n      bytes.push(\n        codePoint >> 0x12 | 0xF0,\n        codePoint >> 0xC & 0x3F | 0x80,\n        codePoint >> 0x6 & 0x3F | 0x80,\n        codePoint & 0x3F | 0x80\n      )\n    } else {\n      throw new Error('Invalid code point')\n    }\n  }\n\n  return bytes\n}\n\nfunction asciiToBytes (str) {\n  var byteArray = []\n  for (var i = 0; i < str.length; i++) {\n    // Node's code seems to be doing this and not & 0x7F..\n    byteArray.push(str.charCodeAt(i) & 0xFF)\n  }\n  return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n  var c, hi, lo\n  var byteArray = []\n  for (var i = 0; i < str.length; i++) {\n    if ((units -= 2) < 0) break\n\n    c = str.charCodeAt(i)\n    hi = c >> 8\n    lo = c % 256\n    byteArray.push(lo)\n    byteArray.push(hi)\n  }\n\n  return byteArray\n}\n\nfunction base64ToBytes (str) {\n  return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n  for (var i = 0; i < length; i++) {\n    if ((i + offset >= dst.length) || (i >= src.length)) break\n    dst[i + offset] = src[i]\n  }\n  return i\n}\n","'use strict'\n\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nfunction init () {\n  var code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\n  for (var i = 0, len = code.length; i < len; ++i) {\n    lookup[i] = code[i]\n    revLookup[code.charCodeAt(i)] = i\n  }\n\n  revLookup['-'.charCodeAt(0)] = 62\n  revLookup['_'.charCodeAt(0)] = 63\n}\n\ninit()\n\nfunction toByteArray (b64) {\n  var i, j, l, tmp, placeHolders, arr\n  var len = b64.length\n\n  if (len % 4 > 0) {\n    throw new Error('Invalid string. Length must be a multiple of 4')\n  }\n\n  // the number of equal signs (place holders)\n  // if there are two placeholders, than the two characters before it\n  // represent one byte\n  // if there is only one, then the three characters before it represent 2 bytes\n  // this is just a cheap hack to not do indexOf twice\n  placeHolders = b64[len - 2] === '=' ? 2 : b64[len - 1] === '=' ? 1 : 0\n\n  // base64 is 4/3 + up to two characters of the original data\n  arr = new Arr(len * 3 / 4 - placeHolders)\n\n  // if there are placeholders, only get up to the last complete 4 chars\n  l = placeHolders > 0 ? len - 4 : len\n\n  var L = 0\n\n  for (i = 0, j = 0; i < l; i += 4, j += 3) {\n    tmp = (revLookup[b64.charCodeAt(i)] << 18) | (revLookup[b64.charCodeAt(i + 1)] << 12) | (revLookup[b64.charCodeAt(i + 2)] << 6) | revLookup[b64.charCodeAt(i + 3)]\n    arr[L++] = (tmp >> 16) & 0xFF\n    arr[L++] = (tmp >> 8) & 0xFF\n    arr[L++] = tmp & 0xFF\n  }\n\n  if (placeHolders === 2) {\n    tmp = (revLookup[b64.charCodeAt(i)] << 2) | (revLookup[b64.charCodeAt(i + 1)] >> 4)\n    arr[L++] = tmp & 0xFF\n  } else if (placeHolders === 1) {\n    tmp = (revLookup[b64.charCodeAt(i)] << 10) | (revLookup[b64.charCodeAt(i + 1)] << 4) | (revLookup[b64.charCodeAt(i + 2)] >> 2)\n    arr[L++] = (tmp >> 8) & 0xFF\n    arr[L++] = tmp & 0xFF\n  }\n\n  return arr\n}\n\nfunction tripletToBase64 (num) {\n  return lookup[num >> 18 & 0x3F] + lookup[num >> 12 & 0x3F] + lookup[num >> 6 & 0x3F] + lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n  var tmp\n  var output = []\n  for (var i = start; i < end; i += 3) {\n    tmp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2])\n    output.push(tripletToBase64(tmp))\n  }\n  return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n  var tmp\n  var len = uint8.length\n  var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n  var output = ''\n  var parts = []\n  var maxChunkLength = 16383 // must be multiple of 3\n\n  // go through the array every three bytes, we'll deal with trailing stuff later\n  for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n    parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\n  }\n\n  // pad the end with zeros, but make sure to not forget the extra bytes\n  if (extraBytes === 1) {\n    tmp = uint8[len - 1]\n    output += lookup[tmp >> 2]\n    output += lookup[(tmp << 4) & 0x3F]\n    output += '=='\n  } else if (extraBytes === 2) {\n    tmp = (uint8[len - 2] << 8) + (uint8[len - 1])\n    output += lookup[tmp >> 10]\n    output += lookup[(tmp >> 4) & 0x3F]\n    output += lookup[(tmp << 2) & 0x3F]\n    output += '='\n  }\n\n  parts.push(output)\n\n  return parts.join('')\n}\n","module.exports = {\n  \"100\": \"Continue\",\n  \"101\": \"Switching Protocols\",\n  \"102\": \"Processing\",\n  \"200\": \"OK\",\n  \"201\": \"Created\",\n  \"202\": \"Accepted\",\n  \"203\": \"Non-Authoritative Information\",\n  \"204\": \"No Content\",\n  \"205\": \"Reset Content\",\n  \"206\": \"Partial Content\",\n  \"207\": \"Multi-Status\",\n  \"208\": \"Already Reported\",\n  \"226\": \"IM Used\",\n  \"300\": \"Multiple Choices\",\n  \"301\": \"Moved Permanently\",\n  \"302\": \"Found\",\n  \"303\": \"See Other\",\n  \"304\": \"Not Modified\",\n  \"305\": \"Use Proxy\",\n  \"307\": \"Temporary Redirect\",\n  \"308\": \"Permanent Redirect\",\n  \"400\": \"Bad Request\",\n  \"401\": \"Unauthorized\",\n  \"402\": \"Payment Required\",\n  \"403\": \"Forbidden\",\n  \"404\": \"Not Found\",\n  \"405\": \"Method Not Allowed\",\n  \"406\": \"Not Acceptable\",\n  \"407\": \"Proxy Authentication Required\",\n  \"408\": \"Request Timeout\",\n  \"409\": \"Conflict\",\n  \"410\": \"Gone\",\n  \"411\": \"Length Required\",\n  \"412\": \"Precondition Failed\",\n  \"413\": \"Payload Too Large\",\n  \"414\": \"URI Too Long\",\n  \"415\": \"Unsupported Media Type\",\n  \"416\": \"Range Not Satisfiable\",\n  \"417\": \"Expectation Failed\",\n  \"418\": \"I'm a teapot\",\n  \"421\": \"Misdirected Request\",\n  \"422\": \"Unprocessable Entity\",\n  \"423\": \"Locked\",\n  \"424\": \"Failed Dependency\",\n  \"425\": \"Unordered Collection\",\n  \"426\": \"Upgrade Required\",\n  \"428\": \"Precondition Required\",\n  \"429\": \"Too Many Requests\",\n  \"431\": \"Request Header Fields Too Large\",\n  \"500\": \"Internal Server Error\",\n  \"501\": \"Not Implemented\",\n  \"502\": \"Bad Gateway\",\n  \"503\": \"Service Unavailable\",\n  \"504\": \"Gateway Timeout\",\n  \"505\": \"HTTP Version Not Supported\",\n  \"506\": \"Variant Also Negotiates\",\n  \"507\": \"Insufficient Storage\",\n  \"508\": \"Loop Detected\",\n  \"509\": \"Bandwidth Limit Exceeded\",\n  \"510\": \"Not Extended\",\n  \"511\": \"Network Authentication Required\"\n}\n","var base = require('typewise-core/base')\nvar codecs = require('./codecs')\nvar util = require('./util')\n\n//\n// extend core sorts defined by typewise with bytewise-specific functionality\n//\n\n// byte represents byte tag prefix in encoded form, enforcing binary total order\n// type tag is 1 byte, which gives us plenty of room to grow\n\n//\n// boundary types\n//\nbase.bound.encode = util.encodeBaseBound\n\n//\n// value types\n//\nvar sorts = base.sorts\n\nsorts.void.byte = 0xf0\n\nsorts.null.byte = 0x10\n\n\nvar BOOLEAN = sorts.boolean\nBOOLEAN.sorts.false.byte = 0x20\nBOOLEAN.sorts.true.byte = 0x21\nBOOLEAN.bound.encode = util.encodeBound\n\n\nvar NUMBER = sorts.number\nNUMBER.sorts.min.byte = 0x40\nNUMBER.sorts.negative.byte = 0x41\nNUMBER.sorts.positive.byte = 0x42\nNUMBER.sorts.max.byte = 0x43\nNUMBER.sorts.negative.codec = codecs.NEGATIVE_FLOAT\nNUMBER.sorts.positive.codec = codecs.POSITIVE_FLOAT\nNUMBER.bound.encode = util.encodeBound\n\n\nvar DATE = sorts.date\nDATE.sorts.negative.byte = 0x51\nDATE.sorts.positive.byte = 0x52\nDATE.sorts.negative.codec = codecs.PRE_EPOCH_DATE\nDATE.sorts.positive.codec = codecs.POST_EPOCH_DATE\nDATE.bound.encode = util.encodeBound\n\n\nvar BINARY = sorts.binary\nBINARY.byte = 0x60\nBINARY.codec = codecs.UINT8\nBINARY.bound.encode = util.encodeBound\n\n\nvar STRING = sorts.string\nSTRING.byte = 0x70\nSTRING.codec = codecs.UTF8\nSTRING.bound.encode = util.encodeBound\n\n\nvar ARRAY = sorts.array\nARRAY.byte = 0xa0\nARRAY.codec = codecs.LIST\nARRAY.bound.encode = util.encodeListBound\n\n\n// var OBJECT = sorts.object\n// OBJECT.byte = 0xb0\n// OBJECT.codec = codecs.HASH\n// OBJECT.bound.encode = util.encodeListBound\n\nmodule.exports = base\n","var util = require('./util')\n\nvar FLOAT_LENGTH = 8\n\nfunction identity(value) {\n  return value\n}\n\nfunction shortlexEncode(codec) {\n  return function (source, base) {\n    // stupid lazy implementation\n    // TODO: allow length getter to be provided\n    var length = util.encodeFloat(source.length)\n    var body = codec.encode(source, base)\n    return Buffer.concat([ length, body ])\n  }\n}\n\nfunction shortlexDecode(codec) {\n  return function (buffer) {\n    // stupid lazy implementation\n    return codec.decode(this, buffer.slice(FLOAT_LENGTH))\n  }\n}\n\nfunction shortlexParse(codec) {\n  // TODO\n  return function (buffer, base) {\n    throw new Error('NYI')\n  }\n}\n\nfunction shortlex(codec) {\n  return {\n    encode: shortlexEncode(codec),\n    decode: shortlexDecode(codec),\n    parse: shortlexParse(codec)\n  }\n}\n\n//\n// pairs of encode/decode functions\n//\nvar codecs = exports\n\ncodecs.HEX = {\n  encode: function (source) {\n    return new Buffer(source, 'hex')\n  },\n  decode: function (buffer) {\n    return buffer.toString('hex')\n  }\n}\n\ncodecs.UINT8 = {\n  encode: identity,\n  decode: identity,\n  escape: util.escapeFlat,\n  unescape: util.unescapeFlat\n}\n\ncodecs.UINT8_SHORTLEX = shortlex(codecs.UINT8)\n\ncodecs.UTF8 = {\n  encode: function (source) {\n    return new Buffer(source, 'utf8')\n  },\n  decode: function (buffer) {\n    return buffer.toString('utf8')\n  },\n  escape: util.escapeFlatLow,\n  unescape: util.unescapeFlatLow\n}\n\ncodecs.UTF8_SHORTLEX = shortlex(codecs.UTF8)\n\ncodecs.POSITIVE_FLOAT = {\n  length: FLOAT_LENGTH,\n  encode: util.encodeFloat,\n  decode: util.decodeFloat\n}\n\ncodecs.NEGATIVE_FLOAT = {\n  length: FLOAT_LENGTH,\n  encode: util.encodeFloat,\n  decode: function (buffer) {\n    return util.decodeFloat(buffer, null, true)\n  }\n}\n\ncodecs.POST_EPOCH_DATE = {\n  length: FLOAT_LENGTH,\n  encode: util.encodeFloat,\n  decode: function (buffer) {\n    return new Date(util.decodeFloat(buffer))\n  }\n}\n\ncodecs.PRE_EPOCH_DATE = {\n  length: FLOAT_LENGTH,\n  encode: util.encodeFloat,\n  decode: function (buffer) {\n    return new Date(util.decodeFloat(buffer, null, true))\n  }\n}\n\n//\n// base encoding for complex structures\n//\ncodecs.LIST = {\n  encode: util.encodeList,\n  decode: util.decodeList\n}\n\ncodecs.TUPLE = shortlex(codecs.LIST)\n\n//\n// member order is preserved and accounted for in sort (except for number keys)\n//\ncodecs.HASH = {\n  // TODO\n  // encode: util.encodeHash,\n  // decode: util.decodeHash\n}\n\ncodecs.RECORD = shortlex(codecs.HASH)\n","var assert = require('./util').assert\nvar base = require('./base')\nvar codecs = require('./codecs')\n\nvar bytewise = exports\n\n//\n// expose type information\n//\nvar sorts = bytewise.sorts = base.sorts\nbytewise.bound = base.bound\nbytewise.compare = base.compare\nbytewise.equal = base.equal\n\n//\n// generate a buffer with type's byte prefix from source value\n//\nfunction serialize(type, source, options) {\n  var codec = type.codec\n  if (!codec)\n    return postEncode(new Buffer([ type.byte ]), options)\n\n  var buffer = codec.encode(source, bytewise)\n\n  if (options && options.nested && codec.escape)\n    buffer = codec.escape(buffer)\n\n  var hint = typeof codec.length === 'number' ? (codec.length + 1) : void 0 \n  var buffers = [ new Buffer([ type.byte ]), buffer ]\n  return postEncode(Buffer.concat(buffers, hint), options)\n}\n\n//\n// core encode logic\n//\nbytewise.encode = function(source, options) {\n\n  // check for invalid/incomparable values\n  assert(!base.invalid(source), 'Invalid value')\n\n  // encode bound types (ranges)\n  var boundary = base.bound.getBoundary(source)\n  if (boundary)\n    return boundary.encode(source, bytewise)\n\n  // encode standard value-typed sorts\n  var order = base.order\n  var sort\n  for (var i = 0, length = order.length; i < length; ++i) {\n    sort = sorts[order[i]]\n\n    if (sort.is(source)) {\n\n      // loop over any subsorts defined on sort\n      // TODO: clean up\n      var subsorts = sort.sorts ||  { '': sort }\n      for (key in subsorts) {\n        var subsort = subsorts[key]\n        if (subsort.is(source)) \n          return serialize(subsort, source, options)\n      }\n\n      // source is an unsupported subsort\n      assert(false, 'Unsupported sort value')\n    }\n  }\n\n  // no type descriptor found\n  assert(false, 'Unknown value')\n}\n\n//\n// core decode logic\n//\nbytewise.decode = function (buffer, options) {\n  // attempt to decode string input using configurable codec\n  if (typeof buffer === 'string') {\n    buffer = bytewise.stringCodec.encode(buffer)\n  }\n\n  assert(!buffer || !buffer.undecodable, 'Encoded value not decodable')\n\n  var byte = buffer[0]\n  var type = bytewise.getType(byte)\n  assert(type, 'Invalid encoding: ' + buffer)\n\n  // if type provides a decoder it is passed the base type system as second arg\n  var codec = type.codec\n  if (codec) {\n    var decoded = codec.decode(buffer.slice(1), bytewise)\n\n    if (options && options.nested && codec.unescape)\n      decoded = codec.unescape(decoded)\n\n    return postDecode(decoded, options)\n  }\n\n  // nullary types without a codec must provide a value for their decoded form\n  assert('value' in type, 'Unsupported encoding: ' + buffer)\n  return postDecode(type.value, options)\n}\n\n//\n// process top level\n//\nfunction postEncode(encoded, options) {\n  if (options === null)\n    return encoded\n\n  return bytewise.postEncode(encoded, options)\n}\n\n//\n// invoked after encoding with encoded buffer instance\n//\nbytewise.postEncode = function (encoded, options) {\n\n  // override buffer toString method to default to hex to help coercion issues\n  // TODO: just return pure buffer, do this toString hackery in bytewise\n  encoded.toString = function (encoding) {\n    if (!encoding)\n      return bytewise.stringCodec.decode(encoded)\n\n    return Buffer.prototype.toString.apply(encoded, arguments)\n  }\n\n  return encoded\n}\n\nfunction postDecode(decoded, options) {\n  if (options === null)\n    return decoded\n\n  return bytewise.postDecode(decoded, options)\n}\n\n//\n// invoked after decoding with decoded value\n//\nbytewise.postDecode = function (decoded, options) {\n  return decoded\n}\n\n\n//\n// registry mapping byte prefixes to type descriptors\n//\nvar PREFIX_REGISTRY\n\nfunction registerType(type) {\n  var byte = type && type.byte\n  if (byte == null)\n    return\n\n  if (byte in PREFIX_REGISTRY)\n    assert.deepEqual(type, PREFIX_REGISTRY[byte], 'Duplicate prefix: ' + byte)\n\n  PREFIX_REGISTRY[type.byte] = type\n}\n\nfunction registerTypes(types) {\n  for (var key in types) {\n    registerType(types[key])\n  }\n}\n\n//\n// look up type descriptor associated with a given byte prefix\n//\nbytewise.getType = function (byte) {\n\n  // construct and memoize byte prefix registry on first run\n  if (!PREFIX_REGISTRY) {\n    PREFIX_REGISTRY = {}\n\n    // register sorts\n    var sort\n    for (var key in sorts) {\n      sort = sorts[key]\n\n      // if sort has subsorts register these instead\n      sort.sorts ? registerTypes(sort.sorts) : registerType(sort)\n    }\n  }\n\n  return PREFIX_REGISTRY[byte]\n}\n\nbytewise.buffer = true\nbytewise.stringCodec = codecs.HEX\nbytewise.type = 'bytewise-core'\n\n","var util = exports\n\n//\n// buffer compare\n//\nutil.compare = require('typewise-core/collation').bitwise\n\n//\n// buffer equality\n//\nutil.equal = function (a, b) {\n  if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b))\n    return\n\n  if (a === b)\n    return true\n\n  if (typeof a.equals === 'function')\n    return a.equals(b)\n\n  return util.compare(a, b) === 0\n}\n\nvar assert = util.assert = function (test, message) {\n  if (!test)\n    throw new TypeError(message)\n}\n\nvar FLOAT_LENGTH = 8\n\nutil.invertBytes = function (buffer) {\n  var bytes = []\n  for (var i = 0, end = buffer.length; i < end; ++i) {\n    bytes.push(~buffer[i])\n  }\n\n  return new Buffer(bytes)\n}\n\nutil.encodeFloat = function (value) {\n  var buffer = new Buffer(FLOAT_LENGTH)\n  if (value < 0) {\n    //\n    // write negative numbers as negated positive values to invert bytes\n    //\n    buffer.writeDoubleBE(-value.valueOf(), 0)\n    return util.invertBytes(buffer)\n  }\n\n  //\n  // normalize -0 values to 0\n  //\n  buffer.writeDoubleBE(value.valueOf() || 0, 0)\n  return buffer\n}\n\nutil.decodeFloat = function (buffer, base, negative) {\n  assert(buffer.length === FLOAT_LENGTH, 'Invalid float encoding length')\n\n  if (negative)\n    buffer = util.invertBytes(buffer)\n\n  var value = buffer.readDoubleBE(0)\n  return negative ? -value : value\n}\n\n//\n// sigil for controlling the escapement functions (TODO: clean this up)\n//\nvar SKIP_HIGH_BYTES = {}\n\nutil.escapeFlat = function (buffer, options) {\n  //\n  // escape high and low bytes 0x00 and 0xff (and by necessity, 0x01 and 0xfe)\n  //\n  var b, bytes = []\n  for (var i = 0, end = buffer.length; i < end; ++i) {\n    b = buffer[i]\n\n    //\n    // escape low bytes with 0x01 and by adding 1\n    //\n    if (b === 0x01 || b === 0x00)\n      bytes.push(0x01, b + 1)\n\n    //\n    // escape high bytes with 0xfe and by subtracting 1\n    //\n    else if (options !== SKIP_HIGH_BYTES && (b === 0xfe || b === 0xff))\n      bytes.push(0xfe, b - 1)\n\n    //\n    // no escapement needed\n    //\n    else\n      bytes.push(b)\n  }\n\n  return new Buffer(bytes)\n}\n\nutil.unescapeFlat = function (buffer, options) {\n  var b, bytes = []\n  //\n  // don't escape last byte\n  //\n  for (var i = 0, end = buffer.length; i < end; ++i) {\n    b = buffer[i]\n\n    //\n    // if low-byte escape tag use the following byte minus 1\n    //\n    if (b === 0x01)\n      bytes.push(buffer[++i] - 1)\n\n    //\n    // if high-byte escape tag use the following byte plus 1\n    //\n    else if (options !== SKIP_HIGH_BYTES && b === 0xfe)\n      bytes.push(buffer[++i] + 1)\n\n    //\n    // no unescapement needed\n    //\n    else\n      bytes.push(b)\n  }\n  return new Buffer(bytes)\n}\n\nutil.escapeFlatLow = function (buffer) {\n  return util.escapeFlat(buffer, SKIP_HIGH_BYTES)\n}\n\nutil.unescapeFlatLow = function (buffer) {\n  return util.unescapeFlat(buffer, SKIP_HIGH_BYTES)\n}\n\nutil.encodeList = function (source, base) {\n  // TODO: cycle detection\n  var buffers = []\n  var undecodable\n\n  for (var i = 0, end = source.length; i < end; ++i) {\n    var buffer = base.encode(source[i], null)\n\n    //\n    // bypass assertions for undecodable types (i.e. range bounds)\n    //\n    undecodable || (undecodable = buffer.undecodable)\n    if (undecodable) {\n      buffers.push(buffer)\n      continue\n    }\n\n    var sort = base.getType(buffer[0])\n    assert(sort, 'List encoding failure: ' + buffer)\n\n    //\n    // escape sorts if it requires it and add closing byte for element\n    //\n    if (sort.codec && sort.codec.escape)\n      buffers.push(sort.codec.escape(buffer), new Buffer([ 0x00 ]))\n\n    else\n      buffers.push(buffer)\n  }\n\n  //\n  // close the list with an end byte\n  //\n  buffers.push(new Buffer([ 0x00 ]))\n  buffer = Buffer.concat(buffers)\n\n  //\n  // propagate undecoable bit if set\n  //\n  undecodable && (buffer.undecodable = undecodable)\n  return buffer\n}\n\nutil.decodeList = function (buffer, base) {\n  var result = util.parse(buffer, base)\n\n  assert(result[1] === buffer.length, 'Invalid encoding')\n  return result[0]\n}\n\nutil.encodeHash = function (source, base) {\n  //\n  // packs hash into an array, e.g. `[ k1, v1, k2, v2, ... ]`\n  //\n  var list = []\n  Object.keys(source).forEach(function(key) {\n    list.push(key)\n    list.push(source[key])\n  })\n  return util.encodeList(list, base)\n}\n\nutil.decodeHash = function (buffer, base) {\n  var list = util.decodeList(buffer, base)\n  var hash = Object.create(null)\n\n  for (var i = 0, end = list.length; i < end; ++i) {\n    hash[list[i]] = list[++i]\n  }\n\n  return hash\n}\n\n//\n// base parser for nested/recursive sorts\n//\nutil.parse = function (buffer, base, sort) {\n  //\n  // parses and returns the first sort on the buffer and total bytes consumed\n  //\n  var codec = sort && sort.codec\n  var index, end\n\n  //\n  // nullary\n  //\n  if (sort && !codec)\n    return [ base.decode(new Buffer([ sort.byte ]), null), 0 ]\n\n  //\n  // custom parse implementation provided by sort\n  //\n  if (codec && codec.parse)\n    return codec.parse(buffer, base, sort)\n\n  //\n  // fixed length sort, decode fixed bytes\n  //\n  var length = codec && codec.length\n  if (typeof length === 'number')\n    return [ codec.decode(buffer.slice(0, length)), length ]\n\n  //\n  // escaped sort, seek to end byte and unescape\n  //\n  if (codec && codec.unescape) {\n    for (index = 0, end = buffer.length; index < end; ++index) {\n      if (buffer[index] === 0x00)\n        break\n    }\n\n    assert(index < buffer.length, 'No closing byte found for sequence')\n    var unescaped = codec.unescape(buffer.slice(0, index))\n\n    //\n    // add 1 to index to account for closing tag byte\n    //\n    return [ codec.decode(unescaped), index + 1 ]\n  }\n\n  //\n  // recursive sort, resolve each item iteratively\n  //\n  index = 0\n  var list = []\n  var next\n  while ((next = buffer[index]) !== 0x00) {\n    sort = base.getType(next)\n    var result = util.parse(buffer.slice(index + 1), base, sort)\n    list.push(result[0])\n\n    //\n    // offset current index by bytes consumed (plus a byte for the sort tag)\n    //\n    index += result[1] + 1\n    assert(index < buffer.length, 'No closing byte found for nested sequence')\n  }\n\n  //\n  // return parsed list and bytes consumed (plus a byte for the closing tag)\n  //\n  return [ list, index + 1 ]\n}\n\n//\n// helpers for encoding boundary types\n//\nfunction encodeBound(data, base) {\n  var prefix = data.prefix\n  var buffer = prefix ? base.encode(prefix, null) : new Buffer([ data.byte ])\n\n  if (data.upper)\n    buffer = Buffer.concat([ buffer, new Buffer([ 0xff ]) ])\n\n  return util.encodedBound(data, buffer)\n}\n\nutil.encodeBound = function (data, base) {\n  return util.encodedBound(data, encodeBound(data, base))\n}\n\nutil.encodeBaseBound = function (data, base) {\n  return util.encodedBound(data, new Buffer([ data.upper ? 0xff : 0x00 ]))\n}\n\nutil.encodeListBound = function (data, base) {\n  var buffer = encodeBound(data, base)\n\n  if (data.prefix) {\n    //\n    // trim off end byte if a prefix, and do some hackery if an upper bound\n    //\n    var endByte = buffer[buffer.length - 1]\n    buffer = buffer.slice(0, -1)\n    if (data.upper)\n      buffer[buffer.length - 1] = endByte\n  }\n\n  return util.encodedBound(data, buffer)\n}\n\n//\n// add some metadata to generated buffer instance\n//\nutil.encodedBound = function (data, buffer) {\n  buffer.undecodable = true\n  return buffer\n}\n","/**\n * @author Titus Wormer\n * @copyright 2015 Titus Wormer. All rights reserved.\n * @module ccount\n * @fileoverview Count characters.\n */\n\n'use strict';\n\n/**\n * Count how many characters `character` occur in `value`.\n *\n * @example\n *   ccount('foo(bar(baz)', '(') // 2\n *   ccount('foo(bar(baz)', ')') // 1\n *\n * @param {string} value - Content, coerced to string.\n * @param {string} character - Single character to look\n *   for.\n * @return {number} - Count.\n * @throws {Error} - when `character` is not a single\n *   character.\n */\nfunction ccount(value, character) {\n    var index = -1;\n    var count = 0;\n    var length;\n\n    value = String(value);\n    length = value.length;\n\n    if (typeof character !== 'string' || character.length !== 1) {\n        throw new Error('Expected character');\n    }\n\n    while (++index < length) {\n        if (value.charAt(index) === character) {\n            count++;\n        }\n    }\n\n    return count;\n}\n\n/*\n * Expose.\n */\n\nmodule.exports = ccount;\n","module.exports={\n  \"nbsp\": \" \",\n  \"iexcl\": \"¡\",\n  \"cent\": \"¢\",\n  \"pound\": \"£\",\n  \"curren\": \"¤\",\n  \"yen\": \"¥\",\n  \"brvbar\": \"¦\",\n  \"sect\": \"§\",\n  \"uml\": \"¨\",\n  \"copy\": \"©\",\n  \"ordf\": \"ª\",\n  \"laquo\": \"«\",\n  \"not\": \"¬\",\n  \"shy\": \"­\",\n  \"reg\": \"®\",\n  \"macr\": \"¯\",\n  \"deg\": \"°\",\n  \"plusmn\": \"±\",\n  \"sup2\": \"²\",\n  \"sup3\": \"³\",\n  \"acute\": \"´\",\n  \"micro\": \"µ\",\n  \"para\": \"¶\",\n  \"middot\": \"·\",\n  \"cedil\": \"¸\",\n  \"sup1\": \"¹\",\n  \"ordm\": \"º\",\n  \"raquo\": \"»\",\n  \"frac14\": \"¼\",\n  \"frac12\": \"½\",\n  \"frac34\": \"¾\",\n  \"iquest\": \"¿\",\n  \"Agrave\": \"À\",\n  \"Aacute\": \"Á\",\n  \"Acirc\": \"Â\",\n  \"Atilde\": \"Ã\",\n  \"Auml\": \"Ä\",\n  \"Aring\": \"Å\",\n  \"AElig\": \"Æ\",\n  \"Ccedil\": \"Ç\",\n  \"Egrave\": \"È\",\n  \"Eacute\": \"É\",\n  \"Ecirc\": \"Ê\",\n  \"Euml\": \"Ë\",\n  \"Igrave\": \"Ì\",\n  \"Iacute\": \"Í\",\n  \"Icirc\": \"Î\",\n  \"Iuml\": \"Ï\",\n  \"ETH\": \"Ð\",\n  \"Ntilde\": \"Ñ\",\n  \"Ograve\": \"Ò\",\n  \"Oacute\": \"Ó\",\n  \"Ocirc\": \"Ô\",\n  \"Otilde\": \"Õ\",\n  \"Ouml\": \"Ö\",\n  \"times\": \"×\",\n  \"Oslash\": \"Ø\",\n  \"Ugrave\": \"Ù\",\n  \"Uacute\": \"Ú\",\n  \"Ucirc\": \"Û\",\n  \"Uuml\": \"Ü\",\n  \"Yacute\": \"Ý\",\n  \"THORN\": \"Þ\",\n  \"szlig\": \"ß\",\n  \"agrave\": \"à\",\n  \"aacute\": \"á\",\n  \"acirc\": \"â\",\n  \"atilde\": \"ã\",\n  \"auml\": \"ä\",\n  \"aring\": \"å\",\n  \"aelig\": \"æ\",\n  \"ccedil\": \"ç\",\n  \"egrave\": \"è\",\n  \"eacute\": \"é\",\n  \"ecirc\": \"ê\",\n  \"euml\": \"ë\",\n  \"igrave\": \"ì\",\n  \"iacute\": \"í\",\n  \"icirc\": \"î\",\n  \"iuml\": \"ï\",\n  \"eth\": \"ð\",\n  \"ntilde\": \"ñ\",\n  \"ograve\": \"ò\",\n  \"oacute\": \"ó\",\n  \"ocirc\": \"ô\",\n  \"otilde\": \"õ\",\n  \"ouml\": \"ö\",\n  \"divide\": \"÷\",\n  \"oslash\": \"ø\",\n  \"ugrave\": \"ù\",\n  \"uacute\": \"ú\",\n  \"ucirc\": \"û\",\n  \"uuml\": \"ü\",\n  \"yacute\": \"ý\",\n  \"thorn\": \"þ\",\n  \"yuml\": \"ÿ\",\n  \"fnof\": \"ƒ\",\n  \"Alpha\": \"Α\",\n  \"Beta\": \"Β\",\n  \"Gamma\": \"Γ\",\n  \"Delta\": \"Δ\",\n  \"Epsilon\": \"Ε\",\n  \"Zeta\": \"Ζ\",\n  \"Eta\": \"Η\",\n  \"Theta\": \"Θ\",\n  \"Iota\": \"Ι\",\n  \"Kappa\": \"Κ\",\n  \"Lambda\": \"Λ\",\n  \"Mu\": \"Μ\",\n  \"Nu\": \"Ν\",\n  \"Xi\": \"Ξ\",\n  \"Omicron\": \"Ο\",\n  \"Pi\": \"Π\",\n  \"Rho\": \"Ρ\",\n  \"Sigma\": \"Σ\",\n  \"Tau\": \"Τ\",\n  \"Upsilon\": \"Υ\",\n  \"Phi\": \"Φ\",\n  \"Chi\": \"Χ\",\n  \"Psi\": \"Ψ\",\n  \"Omega\": \"Ω\",\n  \"alpha\": \"α\",\n  \"beta\": \"β\",\n  \"gamma\": \"γ\",\n  \"delta\": \"δ\",\n  \"epsilon\": \"ε\",\n  \"zeta\": \"ζ\",\n  \"eta\": \"η\",\n  \"theta\": \"θ\",\n  \"iota\": \"ι\",\n  \"kappa\": \"κ\",\n  \"lambda\": \"λ\",\n  \"mu\": \"μ\",\n  \"nu\": \"ν\",\n  \"xi\": \"ξ\",\n  \"omicron\": \"ο\",\n  \"pi\": \"π\",\n  \"rho\": \"ρ\",\n  \"sigmaf\": \"ς\",\n  \"sigma\": \"σ\",\n  \"tau\": \"τ\",\n  \"upsilon\": \"υ\",\n  \"phi\": \"φ\",\n  \"chi\": \"χ\",\n  \"psi\": \"ψ\",\n  \"omega\": \"ω\",\n  \"thetasym\": \"ϑ\",\n  \"upsih\": \"ϒ\",\n  \"piv\": \"ϖ\",\n  \"bull\": \"•\",\n  \"hellip\": \"…\",\n  \"prime\": \"′\",\n  \"Prime\": \"″\",\n  \"oline\": \"‾\",\n  \"frasl\": \"⁄\",\n  \"weierp\": \"℘\",\n  \"image\": \"ℑ\",\n  \"real\": \"ℜ\",\n  \"trade\": \"™\",\n  \"alefsym\": \"ℵ\",\n  \"larr\": \"←\",\n  \"uarr\": \"↑\",\n  \"rarr\": \"→\",\n  \"darr\": \"↓\",\n  \"harr\": \"↔\",\n  \"crarr\": \"↵\",\n  \"lArr\": \"⇐\",\n  \"uArr\": \"⇑\",\n  \"rArr\": \"⇒\",\n  \"dArr\": \"⇓\",\n  \"hArr\": \"⇔\",\n  \"forall\": \"∀\",\n  \"part\": \"∂\",\n  \"exist\": \"∃\",\n  \"empty\": \"∅\",\n  \"nabla\": \"∇\",\n  \"isin\": \"∈\",\n  \"notin\": \"∉\",\n  \"ni\": \"∋\",\n  \"prod\": \"∏\",\n  \"sum\": \"∑\",\n  \"minus\": \"−\",\n  \"lowast\": \"∗\",\n  \"radic\": \"√\",\n  \"prop\": \"∝\",\n  \"infin\": \"∞\",\n  \"ang\": \"∠\",\n  \"and\": \"∧\",\n  \"or\": \"∨\",\n  \"cap\": \"∩\",\n  \"cup\": \"∪\",\n  \"int\": \"∫\",\n  \"there4\": \"∴\",\n  \"sim\": \"∼\",\n  \"cong\": \"≅\",\n  \"asymp\": \"≈\",\n  \"ne\": \"≠\",\n  \"equiv\": \"≡\",\n  \"le\": \"≤\",\n  \"ge\": \"≥\",\n  \"sub\": \"⊂\",\n  \"sup\": \"⊃\",\n  \"nsub\": \"⊄\",\n  \"sube\": \"⊆\",\n  \"supe\": \"⊇\",\n  \"oplus\": \"⊕\",\n  \"otimes\": \"⊗\",\n  \"perp\": \"⊥\",\n  \"sdot\": \"⋅\",\n  \"lceil\": \"⌈\",\n  \"rceil\": \"⌉\",\n  \"lfloor\": \"⌊\",\n  \"rfloor\": \"⌋\",\n  \"lang\": \"〈\",\n  \"rang\": \"〉\",\n  \"loz\": \"◊\",\n  \"spades\": \"♠\",\n  \"clubs\": \"♣\",\n  \"hearts\": \"♥\",\n  \"diams\": \"♦\",\n  \"quot\": \"\\\"\",\n  \"amp\": \"&\",\n  \"lt\": \"<\",\n  \"gt\": \">\",\n  \"OElig\": \"Œ\",\n  \"oelig\": \"œ\",\n  \"Scaron\": \"Š\",\n  \"scaron\": \"š\",\n  \"Yuml\": \"Ÿ\",\n  \"circ\": \"ˆ\",\n  \"tilde\": \"˜\",\n  \"ensp\": \" \",\n  \"emsp\": \" \",\n  \"thinsp\": \" \",\n  \"zwnj\": \"‌\",\n  \"zwj\": \"‍\",\n  \"lrm\": \"‎\",\n  \"rlm\": \"‏\",\n  \"ndash\": \"–\",\n  \"mdash\": \"—\",\n  \"lsquo\": \"‘\",\n  \"rsquo\": \"’\",\n  \"sbquo\": \"‚\",\n  \"ldquo\": \"“\",\n  \"rdquo\": \"”\",\n  \"bdquo\": \"„\",\n  \"dagger\": \"†\",\n  \"Dagger\": \"‡\",\n  \"permil\": \"‰\",\n  \"lsaquo\": \"‹\",\n  \"rsaquo\": \"›\",\n  \"euro\": \"€\"\n}\n","/**\n * @author Titus Wormer\n * @copyright 2015 Titus Wormer\n * @license MIT\n * @module character-entities-html4\n * @fileoverview HTML4 character entity information.\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\n/*\n * Expose.\n */\n\nmodule.exports = require('./index.json');\n","module.exports={\n  \"AElig\": \"Æ\",\n  \"AMP\": \"&\",\n  \"Aacute\": \"Á\",\n  \"Acirc\": \"Â\",\n  \"Agrave\": \"À\",\n  \"Aring\": \"Å\",\n  \"Atilde\": \"Ã\",\n  \"Auml\": \"Ä\",\n  \"COPY\": \"©\",\n  \"Ccedil\": \"Ç\",\n  \"ETH\": \"Ð\",\n  \"Eacute\": \"É\",\n  \"Ecirc\": \"Ê\",\n  \"Egrave\": \"È\",\n  \"Euml\": \"Ë\",\n  \"GT\": \">\",\n  \"Iacute\": \"Í\",\n  \"Icirc\": \"Î\",\n  \"Igrave\": \"Ì\",\n  \"Iuml\": \"Ï\",\n  \"LT\": \"<\",\n  \"Ntilde\": \"Ñ\",\n  \"Oacute\": \"Ó\",\n  \"Ocirc\": \"Ô\",\n  \"Ograve\": \"Ò\",\n  \"Oslash\": \"Ø\",\n  \"Otilde\": \"Õ\",\n  \"Ouml\": \"Ö\",\n  \"QUOT\": \"\\\"\",\n  \"REG\": \"®\",\n  \"THORN\": \"Þ\",\n  \"Uacute\": \"Ú\",\n  \"Ucirc\": \"Û\",\n  \"Ugrave\": \"Ù\",\n  \"Uuml\": \"Ü\",\n  \"Yacute\": \"Ý\",\n  \"aacute\": \"á\",\n  \"acirc\": \"â\",\n  \"acute\": \"´\",\n  \"aelig\": \"æ\",\n  \"agrave\": \"à\",\n  \"amp\": \"&\",\n  \"aring\": \"å\",\n  \"atilde\": \"ã\",\n  \"auml\": \"ä\",\n  \"brvbar\": \"¦\",\n  \"ccedil\": \"ç\",\n  \"cedil\": \"¸\",\n  \"cent\": \"¢\",\n  \"copy\": \"©\",\n  \"curren\": \"¤\",\n  \"deg\": \"°\",\n  \"divide\": \"÷\",\n  \"eacute\": \"é\",\n  \"ecirc\": \"ê\",\n  \"egrave\": \"è\",\n  \"eth\": \"ð\",\n  \"euml\": \"ë\",\n  \"frac12\": \"½\",\n  \"frac14\": \"¼\",\n  \"frac34\": \"¾\",\n  \"gt\": \">\",\n  \"iacute\": \"í\",\n  \"icirc\": \"î\",\n  \"iexcl\": \"¡\",\n  \"igrave\": \"ì\",\n  \"iquest\": \"¿\",\n  \"iuml\": \"ï\",\n  \"laquo\": \"«\",\n  \"lt\": \"<\",\n  \"macr\": \"¯\",\n  \"micro\": \"µ\",\n  \"middot\": \"·\",\n  \"nbsp\": \" \",\n  \"not\": \"¬\",\n  \"ntilde\": \"ñ\",\n  \"oacute\": \"ó\",\n  \"ocirc\": \"ô\",\n  \"ograve\": \"ò\",\n  \"ordf\": \"ª\",\n  \"ordm\": \"º\",\n  \"oslash\": \"ø\",\n  \"otilde\": \"õ\",\n  \"ouml\": \"ö\",\n  \"para\": \"¶\",\n  \"plusmn\": \"±\",\n  \"pound\": \"£\",\n  \"quot\": \"\\\"\",\n  \"raquo\": \"»\",\n  \"reg\": \"®\",\n  \"sect\": \"§\",\n  \"shy\": \"­\",\n  \"sup1\": \"¹\",\n  \"sup2\": \"²\",\n  \"sup3\": \"³\",\n  \"szlig\": \"ß\",\n  \"thorn\": \"þ\",\n  \"times\": \"×\",\n  \"uacute\": \"ú\",\n  \"ucirc\": \"û\",\n  \"ugrave\": \"ù\",\n  \"uml\": \"¨\",\n  \"uuml\": \"ü\",\n  \"yacute\": \"ý\",\n  \"yen\": \"¥\",\n  \"yuml\": \"ÿ\"\n}\n","/**\n * @author Titus Wormer\n * @copyright 2015 Titus Wormer\n * @license MIT\n * @module character-entities-legacy\n * @fileoverview HTML legacy character entity information.\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\n/*\n * Expose.\n */\n\nmodule.exports = require('./index.json');\n","module.exports={\n  \"AElig\": \"Æ\",\n  \"AMP\": \"&\",\n  \"Aacute\": \"Á\",\n  \"Abreve\": \"Ă\",\n  \"Acirc\": \"Â\",\n  \"Acy\": \"А\",\n  \"Afr\": \"𝔄\",\n  \"Agrave\": \"À\",\n  \"Alpha\": \"Α\",\n  \"Amacr\": \"Ā\",\n  \"And\": \"⩓\",\n  \"Aogon\": \"Ą\",\n  \"Aopf\": \"𝔸\",\n  \"ApplyFunction\": \"⁡\",\n  \"Aring\": \"Å\",\n  \"Ascr\": \"𝒜\",\n  \"Assign\": \"≔\",\n  \"Atilde\": \"Ã\",\n  \"Auml\": \"Ä\",\n  \"Backslash\": \"∖\",\n  \"Barv\": \"⫧\",\n  \"Barwed\": \"⌆\",\n  \"Bcy\": \"Б\",\n  \"Because\": \"∵\",\n  \"Bernoullis\": \"ℬ\",\n  \"Beta\": \"Β\",\n  \"Bfr\": \"𝔅\",\n  \"Bopf\": \"𝔹\",\n  \"Breve\": \"˘\",\n  \"Bscr\": \"ℬ\",\n  \"Bumpeq\": \"≎\",\n  \"CHcy\": \"Ч\",\n  \"COPY\": \"©\",\n  \"Cacute\": \"Ć\",\n  \"Cap\": \"⋒\",\n  \"CapitalDifferentialD\": \"ⅅ\",\n  \"Cayleys\": \"ℭ\",\n  \"Ccaron\": \"Č\",\n  \"Ccedil\": \"Ç\",\n  \"Ccirc\": \"Ĉ\",\n  \"Cconint\": \"∰\",\n  \"Cdot\": \"Ċ\",\n  \"Cedilla\": \"¸\",\n  \"CenterDot\": \"·\",\n  \"Cfr\": \"ℭ\",\n  \"Chi\": \"Χ\",\n  \"CircleDot\": \"⊙\",\n  \"CircleMinus\": \"⊖\",\n  \"CirclePlus\": \"⊕\",\n  \"CircleTimes\": \"⊗\",\n  \"ClockwiseContourIntegral\": \"∲\",\n  \"CloseCurlyDoubleQuote\": \"”\",\n  \"CloseCurlyQuote\": \"’\",\n  \"Colon\": \"∷\",\n  \"Colone\": \"⩴\",\n  \"Congruent\": \"≡\",\n  \"Conint\": \"∯\",\n  \"ContourIntegral\": \"∮\",\n  \"Copf\": \"ℂ\",\n  \"Coproduct\": \"∐\",\n  \"CounterClockwiseContourIntegral\": \"∳\",\n  \"Cross\": \"⨯\",\n  \"Cscr\": \"𝒞\",\n  \"Cup\": \"⋓\",\n  \"CupCap\": \"≍\",\n  \"DD\": \"ⅅ\",\n  \"DDotrahd\": \"⤑\",\n  \"DJcy\": \"Ђ\",\n  \"DScy\": \"Ѕ\",\n  \"DZcy\": \"Џ\",\n  \"Dagger\": \"‡\",\n  \"Darr\": \"↡\",\n  \"Dashv\": \"⫤\",\n  \"Dcaron\": \"Ď\",\n  \"Dcy\": \"Д\",\n  \"Del\": \"∇\",\n  \"Delta\": \"Δ\",\n  \"Dfr\": \"𝔇\",\n  \"DiacriticalAcute\": \"´\",\n  \"DiacriticalDot\": \"˙\",\n  \"DiacriticalDoubleAcute\": \"˝\",\n  \"DiacriticalGrave\": \"`\",\n  \"DiacriticalTilde\": \"˜\",\n  \"Diamond\": \"⋄\",\n  \"DifferentialD\": \"ⅆ\",\n  \"Dopf\": \"𝔻\",\n  \"Dot\": \"¨\",\n  \"DotDot\": \"⃜\",\n  \"DotEqual\": \"≐\",\n  \"DoubleContourIntegral\": \"∯\",\n  \"DoubleDot\": \"¨\",\n  \"DoubleDownArrow\": \"⇓\",\n  \"DoubleLeftArrow\": \"⇐\",\n  \"DoubleLeftRightArrow\": \"⇔\",\n  \"DoubleLeftTee\": \"⫤\",\n  \"DoubleLongLeftArrow\": \"⟸\",\n  \"DoubleLongLeftRightArrow\": \"⟺\",\n  \"DoubleLongRightArrow\": \"⟹\",\n  \"DoubleRightArrow\": \"⇒\",\n  \"DoubleRightTee\": \"⊨\",\n  \"DoubleUpArrow\": \"⇑\",\n  \"DoubleUpDownArrow\": \"⇕\",\n  \"DoubleVerticalBar\": \"∥\",\n  \"DownArrow\": \"↓\",\n  \"DownArrowBar\": \"⤓\",\n  \"DownArrowUpArrow\": \"⇵\",\n  \"DownBreve\": \"̑\",\n  \"DownLeftRightVector\": \"⥐\",\n  \"DownLeftTeeVector\": \"⥞\",\n  \"DownLeftVector\": \"↽\",\n  \"DownLeftVectorBar\": \"⥖\",\n  \"DownRightTeeVector\": \"⥟\",\n  \"DownRightVector\": \"⇁\",\n  \"DownRightVectorBar\": \"⥗\",\n  \"DownTee\": \"⊤\",\n  \"DownTeeArrow\": \"↧\",\n  \"Downarrow\": \"⇓\",\n  \"Dscr\": \"𝒟\",\n  \"Dstrok\": \"Đ\",\n  \"ENG\": \"Ŋ\",\n  \"ETH\": \"Ð\",\n  \"Eacute\": \"É\",\n  \"Ecaron\": \"Ě\",\n  \"Ecirc\": \"Ê\",\n  \"Ecy\": \"Э\",\n  \"Edot\": \"Ė\",\n  \"Efr\": \"𝔈\",\n  \"Egrave\": \"È\",\n  \"Element\": \"∈\",\n  \"Emacr\": \"Ē\",\n  \"EmptySmallSquare\": \"◻\",\n  \"EmptyVerySmallSquare\": \"▫\",\n  \"Eogon\": \"Ę\",\n  \"Eopf\": \"𝔼\",\n  \"Epsilon\": \"Ε\",\n  \"Equal\": \"⩵\",\n  \"EqualTilde\": \"≂\",\n  \"Equilibrium\": \"⇌\",\n  \"Escr\": \"ℰ\",\n  \"Esim\": \"⩳\",\n  \"Eta\": \"Η\",\n  \"Euml\": \"Ë\",\n  \"Exists\": \"∃\",\n  \"ExponentialE\": \"ⅇ\",\n  \"Fcy\": \"Ф\",\n  \"Ffr\": \"𝔉\",\n  \"FilledSmallSquare\": \"◼\",\n  \"FilledVerySmallSquare\": \"▪\",\n  \"Fopf\": \"𝔽\",\n  \"ForAll\": \"∀\",\n  \"Fouriertrf\": \"ℱ\",\n  \"Fscr\": \"ℱ\",\n  \"GJcy\": \"Ѓ\",\n  \"GT\": \">\",\n  \"Gamma\": \"Γ\",\n  \"Gammad\": \"Ϝ\",\n  \"Gbreve\": \"Ğ\",\n  \"Gcedil\": \"Ģ\",\n  \"Gcirc\": \"Ĝ\",\n  \"Gcy\": \"Г\",\n  \"Gdot\": \"Ġ\",\n  \"Gfr\": \"𝔊\",\n  \"Gg\": \"⋙\",\n  \"Gopf\": \"𝔾\",\n  \"GreaterEqual\": \"≥\",\n  \"GreaterEqualLess\": \"⋛\",\n  \"GreaterFullEqual\": \"≧\",\n  \"GreaterGreater\": \"⪢\",\n  \"GreaterLess\": \"≷\",\n  \"GreaterSlantEqual\": \"⩾\",\n  \"GreaterTilde\": \"≳\",\n  \"Gscr\": \"𝒢\",\n  \"Gt\": \"≫\",\n  \"HARDcy\": \"Ъ\",\n  \"Hacek\": \"ˇ\",\n  \"Hat\": \"^\",\n  \"Hcirc\": \"Ĥ\",\n  \"Hfr\": \"ℌ\",\n  \"HilbertSpace\": \"ℋ\",\n  \"Hopf\": \"ℍ\",\n  \"HorizontalLine\": \"─\",\n  \"Hscr\": \"ℋ\",\n  \"Hstrok\": \"Ħ\",\n  \"HumpDownHump\": \"≎\",\n  \"HumpEqual\": \"≏\",\n  \"IEcy\": \"Е\",\n  \"IJlig\": \"Ĳ\",\n  \"IOcy\": \"Ё\",\n  \"Iacute\": \"Í\",\n  \"Icirc\": \"Î\",\n  \"Icy\": \"И\",\n  \"Idot\": \"İ\",\n  \"Ifr\": \"ℑ\",\n  \"Igrave\": \"Ì\",\n  \"Im\": \"ℑ\",\n  \"Imacr\": \"Ī\",\n  \"ImaginaryI\": \"ⅈ\",\n  \"Implies\": \"⇒\",\n  \"Int\": \"∬\",\n  \"Integral\": \"∫\",\n  \"Intersection\": \"⋂\",\n  \"InvisibleComma\": \"⁣\",\n  \"InvisibleTimes\": \"⁢\",\n  \"Iogon\": \"Į\",\n  \"Iopf\": \"𝕀\",\n  \"Iota\": \"Ι\",\n  \"Iscr\": \"ℐ\",\n  \"Itilde\": \"Ĩ\",\n  \"Iukcy\": \"І\",\n  \"Iuml\": \"Ï\",\n  \"Jcirc\": \"Ĵ\",\n  \"Jcy\": \"Й\",\n  \"Jfr\": \"𝔍\",\n  \"Jopf\": \"𝕁\",\n  \"Jscr\": \"𝒥\",\n  \"Jsercy\": \"Ј\",\n  \"Jukcy\": \"Є\",\n  \"KHcy\": \"Х\",\n  \"KJcy\": \"Ќ\",\n  \"Kappa\": \"Κ\",\n  \"Kcedil\": \"Ķ\",\n  \"Kcy\": \"К\",\n  \"Kfr\": \"𝔎\",\n  \"Kopf\": \"𝕂\",\n  \"Kscr\": \"𝒦\",\n  \"LJcy\": \"Љ\",\n  \"LT\": \"<\",\n  \"Lacute\": \"Ĺ\",\n  \"Lambda\": \"Λ\",\n  \"Lang\": \"⟪\",\n  \"Laplacetrf\": \"ℒ\",\n  \"Larr\": \"↞\",\n  \"Lcaron\": \"Ľ\",\n  \"Lcedil\": \"Ļ\",\n  \"Lcy\": \"Л\",\n  \"LeftAngleBracket\": \"⟨\",\n  \"LeftArrow\": \"←\",\n  \"LeftArrowBar\": \"⇤\",\n  \"LeftArrowRightArrow\": \"⇆\",\n  \"LeftCeiling\": \"⌈\",\n  \"LeftDoubleBracket\": \"⟦\",\n  \"LeftDownTeeVector\": \"⥡\",\n  \"LeftDownVector\": \"⇃\",\n  \"LeftDownVectorBar\": \"⥙\",\n  \"LeftFloor\": \"⌊\",\n  \"LeftRightArrow\": \"↔\",\n  \"LeftRightVector\": \"⥎\",\n  \"LeftTee\": \"⊣\",\n  \"LeftTeeArrow\": \"↤\",\n  \"LeftTeeVector\": \"⥚\",\n  \"LeftTriangle\": \"⊲\",\n  \"LeftTriangleBar\": \"⧏\",\n  \"LeftTriangleEqual\": \"⊴\",\n  \"LeftUpDownVector\": \"⥑\",\n  \"LeftUpTeeVector\": \"⥠\",\n  \"LeftUpVector\": \"↿\",\n  \"LeftUpVectorBar\": \"⥘\",\n  \"LeftVector\": \"↼\",\n  \"LeftVectorBar\": \"⥒\",\n  \"Leftarrow\": \"⇐\",\n  \"Leftrightarrow\": \"⇔\",\n  \"LessEqualGreater\": \"⋚\",\n  \"LessFullEqual\": \"≦\",\n  \"LessGreater\": \"≶\",\n  \"LessLess\": \"⪡\",\n  \"LessSlantEqual\": \"⩽\",\n  \"LessTilde\": \"≲\",\n  \"Lfr\": \"𝔏\",\n  \"Ll\": \"⋘\",\n  \"Lleftarrow\": \"⇚\",\n  \"Lmidot\": \"Ŀ\",\n  \"LongLeftArrow\": \"⟵\",\n  \"LongLeftRightArrow\": \"⟷\",\n  \"LongRightArrow\": \"⟶\",\n  \"Longleftarrow\": \"⟸\",\n  \"Longleftrightarrow\": \"⟺\",\n  \"Longrightarrow\": \"⟹\",\n  \"Lopf\": \"𝕃\",\n  \"LowerLeftArrow\": \"↙\",\n  \"LowerRightArrow\": \"↘\",\n  \"Lscr\": \"ℒ\",\n  \"Lsh\": \"↰\",\n  \"Lstrok\": \"Ł\",\n  \"Lt\": \"≪\",\n  \"Map\": \"⤅\",\n  \"Mcy\": \"М\",\n  \"MediumSpace\": \" \",\n  \"Mellintrf\": \"ℳ\",\n  \"Mfr\": \"𝔐\",\n  \"MinusPlus\": \"∓\",\n  \"Mopf\": \"𝕄\",\n  \"Mscr\": \"ℳ\",\n  \"Mu\": \"Μ\",\n  \"NJcy\": \"Њ\",\n  \"Nacute\": \"Ń\",\n  \"Ncaron\": \"Ň\",\n  \"Ncedil\": \"Ņ\",\n  \"Ncy\": \"Н\",\n  \"NegativeMediumSpace\": \"​\",\n  \"NegativeThickSpace\": \"​\",\n  \"NegativeThinSpace\": \"​\",\n  \"NegativeVeryThinSpace\": \"​\",\n  \"NestedGreaterGreater\": \"≫\",\n  \"NestedLessLess\": \"≪\",\n  \"NewLine\": \"\\n\",\n  \"Nfr\": \"𝔑\",\n  \"NoBreak\": \"⁠\",\n  \"NonBreakingSpace\": \" \",\n  \"Nopf\": \"ℕ\",\n  \"Not\": \"⫬\",\n  \"NotCongruent\": \"≢\",\n  \"NotCupCap\": \"≭\",\n  \"NotDoubleVerticalBar\": \"∦\",\n  \"NotElement\": \"∉\",\n  \"NotEqual\": \"≠\",\n  \"NotEqualTilde\": \"≂̸\",\n  \"NotExists\": \"∄\",\n  \"NotGreater\": \"≯\",\n  \"NotGreaterEqual\": \"≱\",\n  \"NotGreaterFullEqual\": \"≧̸\",\n  \"NotGreaterGreater\": \"≫̸\",\n  \"NotGreaterLess\": \"≹\",\n  \"NotGreaterSlantEqual\": \"⩾̸\",\n  \"NotGreaterTilde\": \"≵\",\n  \"NotHumpDownHump\": \"≎̸\",\n  \"NotHumpEqual\": \"≏̸\",\n  \"NotLeftTriangle\": \"⋪\",\n  \"NotLeftTriangleBar\": \"⧏̸\",\n  \"NotLeftTriangleEqual\": \"⋬\",\n  \"NotLess\": \"≮\",\n  \"NotLessEqual\": \"≰\",\n  \"NotLessGreater\": \"≸\",\n  \"NotLessLess\": \"≪̸\",\n  \"NotLessSlantEqual\": \"⩽̸\",\n  \"NotLessTilde\": \"≴\",\n  \"NotNestedGreaterGreater\": \"⪢̸\",\n  \"NotNestedLessLess\": \"⪡̸\",\n  \"NotPrecedes\": \"⊀\",\n  \"NotPrecedesEqual\": \"⪯̸\",\n  \"NotPrecedesSlantEqual\": \"⋠\",\n  \"NotReverseElement\": \"∌\",\n  \"NotRightTriangle\": \"⋫\",\n  \"NotRightTriangleBar\": \"⧐̸\",\n  \"NotRightTriangleEqual\": \"⋭\",\n  \"NotSquareSubset\": \"⊏̸\",\n  \"NotSquareSubsetEqual\": \"⋢\",\n  \"NotSquareSuperset\": \"⊐̸\",\n  \"NotSquareSupersetEqual\": \"⋣\",\n  \"NotSubset\": \"⊂⃒\",\n  \"NotSubsetEqual\": \"⊈\",\n  \"NotSucceeds\": \"⊁\",\n  \"NotSucceedsEqual\": \"⪰̸\",\n  \"NotSucceedsSlantEqual\": \"⋡\",\n  \"NotSucceedsTilde\": \"≿̸\",\n  \"NotSuperset\": \"⊃⃒\",\n  \"NotSupersetEqual\": \"⊉\",\n  \"NotTilde\": \"≁\",\n  \"NotTildeEqual\": \"≄\",\n  \"NotTildeFullEqual\": \"≇\",\n  \"NotTildeTilde\": \"≉\",\n  \"NotVerticalBar\": \"∤\",\n  \"Nscr\": \"𝒩\",\n  \"Ntilde\": \"Ñ\",\n  \"Nu\": \"Ν\",\n  \"OElig\": \"Œ\",\n  \"Oacute\": \"Ó\",\n  \"Ocirc\": \"Ô\",\n  \"Ocy\": \"О\",\n  \"Odblac\": \"Ő\",\n  \"Ofr\": \"𝔒\",\n  \"Ograve\": \"Ò\",\n  \"Omacr\": \"Ō\",\n  \"Omega\": \"Ω\",\n  \"Omicron\": \"Ο\",\n  \"Oopf\": \"𝕆\",\n  \"OpenCurlyDoubleQuote\": \"“\",\n  \"OpenCurlyQuote\": \"‘\",\n  \"Or\": \"⩔\",\n  \"Oscr\": \"𝒪\",\n  \"Oslash\": \"Ø\",\n  \"Otilde\": \"Õ\",\n  \"Otimes\": \"⨷\",\n  \"Ouml\": \"Ö\",\n  \"OverBar\": \"‾\",\n  \"OverBrace\": \"⏞\",\n  \"OverBracket\": \"⎴\",\n  \"OverParenthesis\": \"⏜\",\n  \"PartialD\": \"∂\",\n  \"Pcy\": \"П\",\n  \"Pfr\": \"𝔓\",\n  \"Phi\": \"Φ\",\n  \"Pi\": \"Π\",\n  \"PlusMinus\": \"±\",\n  \"Poincareplane\": \"ℌ\",\n  \"Popf\": \"ℙ\",\n  \"Pr\": \"⪻\",\n  \"Precedes\": \"≺\",\n  \"PrecedesEqual\": \"⪯\",\n  \"PrecedesSlantEqual\": \"≼\",\n  \"PrecedesTilde\": \"≾\",\n  \"Prime\": \"″\",\n  \"Product\": \"∏\",\n  \"Proportion\": \"∷\",\n  \"Proportional\": \"∝\",\n  \"Pscr\": \"𝒫\",\n  \"Psi\": \"Ψ\",\n  \"QUOT\": \"\\\"\",\n  \"Qfr\": \"𝔔\",\n  \"Qopf\": \"ℚ\",\n  \"Qscr\": \"𝒬\",\n  \"RBarr\": \"⤐\",\n  \"REG\": \"®\",\n  \"Racute\": \"Ŕ\",\n  \"Rang\": \"⟫\",\n  \"Rarr\": \"↠\",\n  \"Rarrtl\": \"⤖\",\n  \"Rcaron\": \"Ř\",\n  \"Rcedil\": \"Ŗ\",\n  \"Rcy\": \"Р\",\n  \"Re\": \"ℜ\",\n  \"ReverseElement\": \"∋\",\n  \"ReverseEquilibrium\": \"⇋\",\n  \"ReverseUpEquilibrium\": \"⥯\",\n  \"Rfr\": \"ℜ\",\n  \"Rho\": \"Ρ\",\n  \"RightAngleBracket\": \"⟩\",\n  \"RightArrow\": \"→\",\n  \"RightArrowBar\": \"⇥\",\n  \"RightArrowLeftArrow\": \"⇄\",\n  \"RightCeiling\": \"⌉\",\n  \"RightDoubleBracket\": \"⟧\",\n  \"RightDownTeeVector\": \"⥝\",\n  \"RightDownVector\": \"⇂\",\n  \"RightDownVectorBar\": \"⥕\",\n  \"RightFloor\": \"⌋\",\n  \"RightTee\": \"⊢\",\n  \"RightTeeArrow\": \"↦\",\n  \"RightTeeVector\": \"⥛\",\n  \"RightTriangle\": \"⊳\",\n  \"RightTriangleBar\": \"⧐\",\n  \"RightTriangleEqual\": \"⊵\",\n  \"RightUpDownVector\": \"⥏\",\n  \"RightUpTeeVector\": \"⥜\",\n  \"RightUpVector\": \"↾\",\n  \"RightUpVectorBar\": \"⥔\",\n  \"RightVector\": \"⇀\",\n  \"RightVectorBar\": \"⥓\",\n  \"Rightarrow\": \"⇒\",\n  \"Ropf\": \"ℝ\",\n  \"RoundImplies\": \"⥰\",\n  \"Rrightarrow\": \"⇛\",\n  \"Rscr\": \"ℛ\",\n  \"Rsh\": \"↱\",\n  \"RuleDelayed\": \"⧴\",\n  \"SHCHcy\": \"Щ\",\n  \"SHcy\": \"Ш\",\n  \"SOFTcy\": \"Ь\",\n  \"Sacute\": \"Ś\",\n  \"Sc\": \"⪼\",\n  \"Scaron\": \"Š\",\n  \"Scedil\": \"Ş\",\n  \"Scirc\": \"Ŝ\",\n  \"Scy\": \"С\",\n  \"Sfr\": \"𝔖\",\n  \"ShortDownArrow\": \"↓\",\n  \"ShortLeftArrow\": \"←\",\n  \"ShortRightArrow\": \"→\",\n  \"ShortUpArrow\": \"↑\",\n  \"Sigma\": \"Σ\",\n  \"SmallCircle\": \"∘\",\n  \"Sopf\": \"𝕊\",\n  \"Sqrt\": \"√\",\n  \"Square\": \"□\",\n  \"SquareIntersection\": \"⊓\",\n  \"SquareSubset\": \"⊏\",\n  \"SquareSubsetEqual\": \"⊑\",\n  \"SquareSuperset\": \"⊐\",\n  \"SquareSupersetEqual\": \"⊒\",\n  \"SquareUnion\": \"⊔\",\n  \"Sscr\": \"𝒮\",\n  \"Star\": \"⋆\",\n  \"Sub\": \"⋐\",\n  \"Subset\": \"⋐\",\n  \"SubsetEqual\": \"⊆\",\n  \"Succeeds\": \"≻\",\n  \"SucceedsEqual\": \"⪰\",\n  \"SucceedsSlantEqual\": \"≽\",\n  \"SucceedsTilde\": \"≿\",\n  \"SuchThat\": \"∋\",\n  \"Sum\": \"∑\",\n  \"Sup\": \"⋑\",\n  \"Superset\": \"⊃\",\n  \"SupersetEqual\": \"⊇\",\n  \"Supset\": \"⋑\",\n  \"THORN\": \"Þ\",\n  \"TRADE\": \"™\",\n  \"TSHcy\": \"Ћ\",\n  \"TScy\": \"Ц\",\n  \"Tab\": \"\\t\",\n  \"Tau\": \"Τ\",\n  \"Tcaron\": \"Ť\",\n  \"Tcedil\": \"Ţ\",\n  \"Tcy\": \"Т\",\n  \"Tfr\": \"𝔗\",\n  \"Therefore\": \"∴\",\n  \"Theta\": \"Θ\",\n  \"ThickSpace\": \"  \",\n  \"ThinSpace\": \" \",\n  \"Tilde\": \"∼\",\n  \"TildeEqual\": \"≃\",\n  \"TildeFullEqual\": \"≅\",\n  \"TildeTilde\": \"≈\",\n  \"Topf\": \"𝕋\",\n  \"TripleDot\": \"⃛\",\n  \"Tscr\": \"𝒯\",\n  \"Tstrok\": \"Ŧ\",\n  \"Uacute\": \"Ú\",\n  \"Uarr\": \"↟\",\n  \"Uarrocir\": \"⥉\",\n  \"Ubrcy\": \"Ў\",\n  \"Ubreve\": \"Ŭ\",\n  \"Ucirc\": \"Û\",\n  \"Ucy\": \"У\",\n  \"Udblac\": \"Ű\",\n  \"Ufr\": \"𝔘\",\n  \"Ugrave\": \"Ù\",\n  \"Umacr\": \"Ū\",\n  \"UnderBar\": \"_\",\n  \"UnderBrace\": \"⏟\",\n  \"UnderBracket\": \"⎵\",\n  \"UnderParenthesis\": \"⏝\",\n  \"Union\": \"⋃\",\n  \"UnionPlus\": \"⊎\",\n  \"Uogon\": \"Ų\",\n  \"Uopf\": \"𝕌\",\n  \"UpArrow\": \"↑\",\n  \"UpArrowBar\": \"⤒\",\n  \"UpArrowDownArrow\": \"⇅\",\n  \"UpDownArrow\": \"↕\",\n  \"UpEquilibrium\": \"⥮\",\n  \"UpTee\": \"⊥\",\n  \"UpTeeArrow\": \"↥\",\n  \"Uparrow\": \"⇑\",\n  \"Updownarrow\": \"⇕\",\n  \"UpperLeftArrow\": \"↖\",\n  \"UpperRightArrow\": \"↗\",\n  \"Upsi\": \"ϒ\",\n  \"Upsilon\": \"Υ\",\n  \"Uring\": \"Ů\",\n  \"Uscr\": \"𝒰\",\n  \"Utilde\": \"Ũ\",\n  \"Uuml\": \"Ü\",\n  \"VDash\": \"⊫\",\n  \"Vbar\": \"⫫\",\n  \"Vcy\": \"В\",\n  \"Vdash\": \"⊩\",\n  \"Vdashl\": \"⫦\",\n  \"Vee\": \"⋁\",\n  \"Verbar\": \"‖\",\n  \"Vert\": \"‖\",\n  \"VerticalBar\": \"∣\",\n  \"VerticalLine\": \"|\",\n  \"VerticalSeparator\": \"❘\",\n  \"VerticalTilde\": \"≀\",\n  \"VeryThinSpace\": \" \",\n  \"Vfr\": \"𝔙\",\n  \"Vopf\": \"𝕍\",\n  \"Vscr\": \"𝒱\",\n  \"Vvdash\": \"⊪\",\n  \"Wcirc\": \"Ŵ\",\n  \"Wedge\": \"⋀\",\n  \"Wfr\": \"𝔚\",\n  \"Wopf\": \"𝕎\",\n  \"Wscr\": \"𝒲\",\n  \"Xfr\": \"𝔛\",\n  \"Xi\": \"Ξ\",\n  \"Xopf\": \"𝕏\",\n  \"Xscr\": \"𝒳\",\n  \"YAcy\": \"Я\",\n  \"YIcy\": \"Ї\",\n  \"YUcy\": \"Ю\",\n  \"Yacute\": \"Ý\",\n  \"Ycirc\": \"Ŷ\",\n  \"Ycy\": \"Ы\",\n  \"Yfr\": \"𝔜\",\n  \"Yopf\": \"𝕐\",\n  \"Yscr\": \"𝒴\",\n  \"Yuml\": \"Ÿ\",\n  \"ZHcy\": \"Ж\",\n  \"Zacute\": \"Ź\",\n  \"Zcaron\": \"Ž\",\n  \"Zcy\": \"З\",\n  \"Zdot\": \"Ż\",\n  \"ZeroWidthSpace\": \"​\",\n  \"Zeta\": \"Ζ\",\n  \"Zfr\": \"ℨ\",\n  \"Zopf\": \"ℤ\",\n  \"Zscr\": \"𝒵\",\n  \"aacute\": \"á\",\n  \"abreve\": \"ă\",\n  \"ac\": \"∾\",\n  \"acE\": \"∾̳\",\n  \"acd\": \"∿\",\n  \"acirc\": \"â\",\n  \"acute\": \"´\",\n  \"acy\": \"а\",\n  \"aelig\": \"æ\",\n  \"af\": \"⁡\",\n  \"afr\": \"𝔞\",\n  \"agrave\": \"à\",\n  \"alefsym\": \"ℵ\",\n  \"aleph\": \"ℵ\",\n  \"alpha\": \"α\",\n  \"amacr\": \"ā\",\n  \"amalg\": \"⨿\",\n  \"amp\": \"&\",\n  \"and\": \"∧\",\n  \"andand\": \"⩕\",\n  \"andd\": \"⩜\",\n  \"andslope\": \"⩘\",\n  \"andv\": \"⩚\",\n  \"ang\": \"∠\",\n  \"ange\": \"⦤\",\n  \"angle\": \"∠\",\n  \"angmsd\": \"∡\",\n  \"angmsdaa\": \"⦨\",\n  \"angmsdab\": \"⦩\",\n  \"angmsdac\": \"⦪\",\n  \"angmsdad\": \"⦫\",\n  \"angmsdae\": \"⦬\",\n  \"angmsdaf\": \"⦭\",\n  \"angmsdag\": \"⦮\",\n  \"angmsdah\": \"⦯\",\n  \"angrt\": \"∟\",\n  \"angrtvb\": \"⊾\",\n  \"angrtvbd\": \"⦝\",\n  \"angsph\": \"∢\",\n  \"angst\": \"Å\",\n  \"angzarr\": \"⍼\",\n  \"aogon\": \"ą\",\n  \"aopf\": \"𝕒\",\n  \"ap\": \"≈\",\n  \"apE\": \"⩰\",\n  \"apacir\": \"⩯\",\n  \"ape\": \"≊\",\n  \"apid\": \"≋\",\n  \"apos\": \"'\",\n  \"approx\": \"≈\",\n  \"approxeq\": \"≊\",\n  \"aring\": \"å\",\n  \"ascr\": \"𝒶\",\n  \"ast\": \"*\",\n  \"asymp\": \"≈\",\n  \"asympeq\": \"≍\",\n  \"atilde\": \"ã\",\n  \"auml\": \"ä\",\n  \"awconint\": \"∳\",\n  \"awint\": \"⨑\",\n  \"bNot\": \"⫭\",\n  \"backcong\": \"≌\",\n  \"backepsilon\": \"϶\",\n  \"backprime\": \"‵\",\n  \"backsim\": \"∽\",\n  \"backsimeq\": \"⋍\",\n  \"barvee\": \"⊽\",\n  \"barwed\": \"⌅\",\n  \"barwedge\": \"⌅\",\n  \"bbrk\": \"⎵\",\n  \"bbrktbrk\": \"⎶\",\n  \"bcong\": \"≌\",\n  \"bcy\": \"б\",\n  \"bdquo\": \"„\",\n  \"becaus\": \"∵\",\n  \"because\": \"∵\",\n  \"bemptyv\": \"⦰\",\n  \"bepsi\": \"϶\",\n  \"bernou\": \"ℬ\",\n  \"beta\": \"β\",\n  \"beth\": \"ℶ\",\n  \"between\": \"≬\",\n  \"bfr\": \"𝔟\",\n  \"bigcap\": \"⋂\",\n  \"bigcirc\": \"◯\",\n  \"bigcup\": \"⋃\",\n  \"bigodot\": \"⨀\",\n  \"bigoplus\": \"⨁\",\n  \"bigotimes\": \"⨂\",\n  \"bigsqcup\": \"⨆\",\n  \"bigstar\": \"★\",\n  \"bigtriangledown\": \"▽\",\n  \"bigtriangleup\": \"△\",\n  \"biguplus\": \"⨄\",\n  \"bigvee\": \"⋁\",\n  \"bigwedge\": \"⋀\",\n  \"bkarow\": \"⤍\",\n  \"blacklozenge\": \"⧫\",\n  \"blacksquare\": \"▪\",\n  \"blacktriangle\": \"▴\",\n  \"blacktriangledown\": \"▾\",\n  \"blacktriangleleft\": \"◂\",\n  \"blacktriangleright\": \"▸\",\n  \"blank\": \"␣\",\n  \"blk12\": \"▒\",\n  \"blk14\": \"░\",\n  \"blk34\": \"▓\",\n  \"block\": \"█\",\n  \"bne\": \"=⃥\",\n  \"bnequiv\": \"≡⃥\",\n  \"bnot\": \"⌐\",\n  \"bopf\": \"𝕓\",\n  \"bot\": \"⊥\",\n  \"bottom\": \"⊥\",\n  \"bowtie\": \"⋈\",\n  \"boxDL\": \"╗\",\n  \"boxDR\": \"╔\",\n  \"boxDl\": \"╖\",\n  \"boxDr\": \"╓\",\n  \"boxH\": \"═\",\n  \"boxHD\": \"╦\",\n  \"boxHU\": \"╩\",\n  \"boxHd\": \"╤\",\n  \"boxHu\": \"╧\",\n  \"boxUL\": \"╝\",\n  \"boxUR\": \"╚\",\n  \"boxUl\": \"╜\",\n  \"boxUr\": \"╙\",\n  \"boxV\": \"║\",\n  \"boxVH\": \"╬\",\n  \"boxVL\": \"╣\",\n  \"boxVR\": \"╠\",\n  \"boxVh\": \"╫\",\n  \"boxVl\": \"╢\",\n  \"boxVr\": \"╟\",\n  \"boxbox\": \"⧉\",\n  \"boxdL\": \"╕\",\n  \"boxdR\": \"╒\",\n  \"boxdl\": \"┐\",\n  \"boxdr\": \"┌\",\n  \"boxh\": \"─\",\n  \"boxhD\": \"╥\",\n  \"boxhU\": \"╨\",\n  \"boxhd\": \"┬\",\n  \"boxhu\": \"┴\",\n  \"boxminus\": \"⊟\",\n  \"boxplus\": \"⊞\",\n  \"boxtimes\": \"⊠\",\n  \"boxuL\": \"╛\",\n  \"boxuR\": \"╘\",\n  \"boxul\": \"┘\",\n  \"boxur\": \"└\",\n  \"boxv\": \"│\",\n  \"boxvH\": \"╪\",\n  \"boxvL\": \"╡\",\n  \"boxvR\": \"╞\",\n  \"boxvh\": \"┼\",\n  \"boxvl\": \"┤\",\n  \"boxvr\": \"├\",\n  \"bprime\": \"‵\",\n  \"breve\": \"˘\",\n  \"brvbar\": \"¦\",\n  \"bscr\": \"𝒷\",\n  \"bsemi\": \"⁏\",\n  \"bsim\": \"∽\",\n  \"bsime\": \"⋍\",\n  \"bsol\": \"\\\\\",\n  \"bsolb\": \"⧅\",\n  \"bsolhsub\": \"⟈\",\n  \"bull\": \"•\",\n  \"bullet\": \"•\",\n  \"bump\": \"≎\",\n  \"bumpE\": \"⪮\",\n  \"bumpe\": \"≏\",\n  \"bumpeq\": \"≏\",\n  \"cacute\": \"ć\",\n  \"cap\": \"∩\",\n  \"capand\": \"⩄\",\n  \"capbrcup\": \"⩉\",\n  \"capcap\": \"⩋\",\n  \"capcup\": \"⩇\",\n  \"capdot\": \"⩀\",\n  \"caps\": \"∩︀\",\n  \"caret\": \"⁁\",\n  \"caron\": \"ˇ\",\n  \"ccaps\": \"⩍\",\n  \"ccaron\": \"č\",\n  \"ccedil\": \"ç\",\n  \"ccirc\": \"ĉ\",\n  \"ccups\": \"⩌\",\n  \"ccupssm\": \"⩐\",\n  \"cdot\": \"ċ\",\n  \"cedil\": \"¸\",\n  \"cemptyv\": \"⦲\",\n  \"cent\": \"¢\",\n  \"centerdot\": \"·\",\n  \"cfr\": \"𝔠\",\n  \"chcy\": \"ч\",\n  \"check\": \"✓\",\n  \"checkmark\": \"✓\",\n  \"chi\": \"χ\",\n  \"cir\": \"○\",\n  \"cirE\": \"⧃\",\n  \"circ\": \"ˆ\",\n  \"circeq\": \"≗\",\n  \"circlearrowleft\": \"↺\",\n  \"circlearrowright\": \"↻\",\n  \"circledR\": \"®\",\n  \"circledS\": \"Ⓢ\",\n  \"circledast\": \"⊛\",\n  \"circledcirc\": \"⊚\",\n  \"circleddash\": \"⊝\",\n  \"cire\": \"≗\",\n  \"cirfnint\": \"⨐\",\n  \"cirmid\": \"⫯\",\n  \"cirscir\": \"⧂\",\n  \"clubs\": \"♣\",\n  \"clubsuit\": \"♣\",\n  \"colon\": \":\",\n  \"colone\": \"≔\",\n  \"coloneq\": \"≔\",\n  \"comma\": \",\",\n  \"commat\": \"@\",\n  \"comp\": \"∁\",\n  \"compfn\": \"∘\",\n  \"complement\": \"∁\",\n  \"complexes\": \"ℂ\",\n  \"cong\": \"≅\",\n  \"congdot\": \"⩭\",\n  \"conint\": \"∮\",\n  \"copf\": \"𝕔\",\n  \"coprod\": \"∐\",\n  \"copy\": \"©\",\n  \"copysr\": \"℗\",\n  \"crarr\": \"↵\",\n  \"cross\": \"✗\",\n  \"cscr\": \"𝒸\",\n  \"csub\": \"⫏\",\n  \"csube\": \"⫑\",\n  \"csup\": \"⫐\",\n  \"csupe\": \"⫒\",\n  \"ctdot\": \"⋯\",\n  \"cudarrl\": \"⤸\",\n  \"cudarrr\": \"⤵\",\n  \"cuepr\": \"⋞\",\n  \"cuesc\": \"⋟\",\n  \"cularr\": \"↶\",\n  \"cularrp\": \"⤽\",\n  \"cup\": \"∪\",\n  \"cupbrcap\": \"⩈\",\n  \"cupcap\": \"⩆\",\n  \"cupcup\": \"⩊\",\n  \"cupdot\": \"⊍\",\n  \"cupor\": \"⩅\",\n  \"cups\": \"∪︀\",\n  \"curarr\": \"↷\",\n  \"curarrm\": \"⤼\",\n  \"curlyeqprec\": \"⋞\",\n  \"curlyeqsucc\": \"⋟\",\n  \"curlyvee\": \"⋎\",\n  \"curlywedge\": \"⋏\",\n  \"curren\": \"¤\",\n  \"curvearrowleft\": \"↶\",\n  \"curvearrowright\": \"↷\",\n  \"cuvee\": \"⋎\",\n  \"cuwed\": \"⋏\",\n  \"cwconint\": \"∲\",\n  \"cwint\": \"∱\",\n  \"cylcty\": \"⌭\",\n  \"dArr\": \"⇓\",\n  \"dHar\": \"⥥\",\n  \"dagger\": \"†\",\n  \"daleth\": \"ℸ\",\n  \"darr\": \"↓\",\n  \"dash\": \"‐\",\n  \"dashv\": \"⊣\",\n  \"dbkarow\": \"⤏\",\n  \"dblac\": \"˝\",\n  \"dcaron\": \"ď\",\n  \"dcy\": \"д\",\n  \"dd\": \"ⅆ\",\n  \"ddagger\": \"‡\",\n  \"ddarr\": \"⇊\",\n  \"ddotseq\": \"⩷\",\n  \"deg\": \"°\",\n  \"delta\": \"δ\",\n  \"demptyv\": \"⦱\",\n  \"dfisht\": \"⥿\",\n  \"dfr\": \"𝔡\",\n  \"dharl\": \"⇃\",\n  \"dharr\": \"⇂\",\n  \"diam\": \"⋄\",\n  \"diamond\": \"⋄\",\n  \"diamondsuit\": \"♦\",\n  \"diams\": \"♦\",\n  \"die\": \"¨\",\n  \"digamma\": \"ϝ\",\n  \"disin\": \"⋲\",\n  \"div\": \"÷\",\n  \"divide\": \"÷\",\n  \"divideontimes\": \"⋇\",\n  \"divonx\": \"⋇\",\n  \"djcy\": \"ђ\",\n  \"dlcorn\": \"⌞\",\n  \"dlcrop\": \"⌍\",\n  \"dollar\": \"$\",\n  \"dopf\": \"𝕕\",\n  \"dot\": \"˙\",\n  \"doteq\": \"≐\",\n  \"doteqdot\": \"≑\",\n  \"dotminus\": \"∸\",\n  \"dotplus\": \"∔\",\n  \"dotsquare\": \"⊡\",\n  \"doublebarwedge\": \"⌆\",\n  \"downarrow\": \"↓\",\n  \"downdownarrows\": \"⇊\",\n  \"downharpoonleft\": \"⇃\",\n  \"downharpoonright\": \"⇂\",\n  \"drbkarow\": \"⤐\",\n  \"drcorn\": \"⌟\",\n  \"drcrop\": \"⌌\",\n  \"dscr\": \"𝒹\",\n  \"dscy\": \"ѕ\",\n  \"dsol\": \"⧶\",\n  \"dstrok\": \"đ\",\n  \"dtdot\": \"⋱\",\n  \"dtri\": \"▿\",\n  \"dtrif\": \"▾\",\n  \"duarr\": \"⇵\",\n  \"duhar\": \"⥯\",\n  \"dwangle\": \"⦦\",\n  \"dzcy\": \"џ\",\n  \"dzigrarr\": \"⟿\",\n  \"eDDot\": \"⩷\",\n  \"eDot\": \"≑\",\n  \"eacute\": \"é\",\n  \"easter\": \"⩮\",\n  \"ecaron\": \"ě\",\n  \"ecir\": \"≖\",\n  \"ecirc\": \"ê\",\n  \"ecolon\": \"≕\",\n  \"ecy\": \"э\",\n  \"edot\": \"ė\",\n  \"ee\": \"ⅇ\",\n  \"efDot\": \"≒\",\n  \"efr\": \"𝔢\",\n  \"eg\": \"⪚\",\n  \"egrave\": \"è\",\n  \"egs\": \"⪖\",\n  \"egsdot\": \"⪘\",\n  \"el\": \"⪙\",\n  \"elinters\": \"⏧\",\n  \"ell\": \"ℓ\",\n  \"els\": \"⪕\",\n  \"elsdot\": \"⪗\",\n  \"emacr\": \"ē\",\n  \"empty\": \"∅\",\n  \"emptyset\": \"∅\",\n  \"emptyv\": \"∅\",\n  \"emsp13\": \" \",\n  \"emsp14\": \" \",\n  \"emsp\": \" \",\n  \"eng\": \"ŋ\",\n  \"ensp\": \" \",\n  \"eogon\": \"ę\",\n  \"eopf\": \"𝕖\",\n  \"epar\": \"⋕\",\n  \"eparsl\": \"⧣\",\n  \"eplus\": \"⩱\",\n  \"epsi\": \"ε\",\n  \"epsilon\": \"ε\",\n  \"epsiv\": \"ϵ\",\n  \"eqcirc\": \"≖\",\n  \"eqcolon\": \"≕\",\n  \"eqsim\": \"≂\",\n  \"eqslantgtr\": \"⪖\",\n  \"eqslantless\": \"⪕\",\n  \"equals\": \"=\",\n  \"equest\": \"≟\",\n  \"equiv\": \"≡\",\n  \"equivDD\": \"⩸\",\n  \"eqvparsl\": \"⧥\",\n  \"erDot\": \"≓\",\n  \"erarr\": \"⥱\",\n  \"escr\": \"ℯ\",\n  \"esdot\": \"≐\",\n  \"esim\": \"≂\",\n  \"eta\": \"η\",\n  \"eth\": \"ð\",\n  \"euml\": \"ë\",\n  \"euro\": \"€\",\n  \"excl\": \"!\",\n  \"exist\": \"∃\",\n  \"expectation\": \"ℰ\",\n  \"exponentiale\": \"ⅇ\",\n  \"fallingdotseq\": \"≒\",\n  \"fcy\": \"ф\",\n  \"female\": \"♀\",\n  \"ffilig\": \"ﬃ\",\n  \"fflig\": \"ﬀ\",\n  \"ffllig\": \"ﬄ\",\n  \"ffr\": \"𝔣\",\n  \"filig\": \"ﬁ\",\n  \"fjlig\": \"fj\",\n  \"flat\": \"♭\",\n  \"fllig\": \"ﬂ\",\n  \"fltns\": \"▱\",\n  \"fnof\": \"ƒ\",\n  \"fopf\": \"𝕗\",\n  \"forall\": \"∀\",\n  \"fork\": \"⋔\",\n  \"forkv\": \"⫙\",\n  \"fpartint\": \"⨍\",\n  \"frac12\": \"½\",\n  \"frac13\": \"⅓\",\n  \"frac14\": \"¼\",\n  \"frac15\": \"⅕\",\n  \"frac16\": \"⅙\",\n  \"frac18\": \"⅛\",\n  \"frac23\": \"⅔\",\n  \"frac25\": \"⅖\",\n  \"frac34\": \"¾\",\n  \"frac35\": \"⅗\",\n  \"frac38\": \"⅜\",\n  \"frac45\": \"⅘\",\n  \"frac56\": \"⅚\",\n  \"frac58\": \"⅝\",\n  \"frac78\": \"⅞\",\n  \"frasl\": \"⁄\",\n  \"frown\": \"⌢\",\n  \"fscr\": \"𝒻\",\n  \"gE\": \"≧\",\n  \"gEl\": \"⪌\",\n  \"gacute\": \"ǵ\",\n  \"gamma\": \"γ\",\n  \"gammad\": \"ϝ\",\n  \"gap\": \"⪆\",\n  \"gbreve\": \"ğ\",\n  \"gcirc\": \"ĝ\",\n  \"gcy\": \"г\",\n  \"gdot\": \"ġ\",\n  \"ge\": \"≥\",\n  \"gel\": \"⋛\",\n  \"geq\": \"≥\",\n  \"geqq\": \"≧\",\n  \"geqslant\": \"⩾\",\n  \"ges\": \"⩾\",\n  \"gescc\": \"⪩\",\n  \"gesdot\": \"⪀\",\n  \"gesdoto\": \"⪂\",\n  \"gesdotol\": \"⪄\",\n  \"gesl\": \"⋛︀\",\n  \"gesles\": \"⪔\",\n  \"gfr\": \"𝔤\",\n  \"gg\": \"≫\",\n  \"ggg\": \"⋙\",\n  \"gimel\": \"ℷ\",\n  \"gjcy\": \"ѓ\",\n  \"gl\": \"≷\",\n  \"glE\": \"⪒\",\n  \"gla\": \"⪥\",\n  \"glj\": \"⪤\",\n  \"gnE\": \"≩\",\n  \"gnap\": \"⪊\",\n  \"gnapprox\": \"⪊\",\n  \"gne\": \"⪈\",\n  \"gneq\": \"⪈\",\n  \"gneqq\": \"≩\",\n  \"gnsim\": \"⋧\",\n  \"gopf\": \"𝕘\",\n  \"grave\": \"`\",\n  \"gscr\": \"ℊ\",\n  \"gsim\": \"≳\",\n  \"gsime\": \"⪎\",\n  \"gsiml\": \"⪐\",\n  \"gt\": \">\",\n  \"gtcc\": \"⪧\",\n  \"gtcir\": \"⩺\",\n  \"gtdot\": \"⋗\",\n  \"gtlPar\": \"⦕\",\n  \"gtquest\": \"⩼\",\n  \"gtrapprox\": \"⪆\",\n  \"gtrarr\": \"⥸\",\n  \"gtrdot\": \"⋗\",\n  \"gtreqless\": \"⋛\",\n  \"gtreqqless\": \"⪌\",\n  \"gtrless\": \"≷\",\n  \"gtrsim\": \"≳\",\n  \"gvertneqq\": \"≩︀\",\n  \"gvnE\": \"≩︀\",\n  \"hArr\": \"⇔\",\n  \"hairsp\": \" \",\n  \"half\": \"½\",\n  \"hamilt\": \"ℋ\",\n  \"hardcy\": \"ъ\",\n  \"harr\": \"↔\",\n  \"harrcir\": \"⥈\",\n  \"harrw\": \"↭\",\n  \"hbar\": \"ℏ\",\n  \"hcirc\": \"ĥ\",\n  \"hearts\": \"♥\",\n  \"heartsuit\": \"♥\",\n  \"hellip\": \"…\",\n  \"hercon\": \"⊹\",\n  \"hfr\": \"𝔥\",\n  \"hksearow\": \"⤥\",\n  \"hkswarow\": \"⤦\",\n  \"hoarr\": \"⇿\",\n  \"homtht\": \"∻\",\n  \"hookleftarrow\": \"↩\",\n  \"hookrightarrow\": \"↪\",\n  \"hopf\": \"𝕙\",\n  \"horbar\": \"―\",\n  \"hscr\": \"𝒽\",\n  \"hslash\": \"ℏ\",\n  \"hstrok\": \"ħ\",\n  \"hybull\": \"⁃\",\n  \"hyphen\": \"‐\",\n  \"iacute\": \"í\",\n  \"ic\": \"⁣\",\n  \"icirc\": \"î\",\n  \"icy\": \"и\",\n  \"iecy\": \"е\",\n  \"iexcl\": \"¡\",\n  \"iff\": \"⇔\",\n  \"ifr\": \"𝔦\",\n  \"igrave\": \"ì\",\n  \"ii\": \"ⅈ\",\n  \"iiiint\": \"⨌\",\n  \"iiint\": \"∭\",\n  \"iinfin\": \"⧜\",\n  \"iiota\": \"℩\",\n  \"ijlig\": \"ĳ\",\n  \"imacr\": \"ī\",\n  \"image\": \"ℑ\",\n  \"imagline\": \"ℐ\",\n  \"imagpart\": \"ℑ\",\n  \"imath\": \"ı\",\n  \"imof\": \"⊷\",\n  \"imped\": \"Ƶ\",\n  \"in\": \"∈\",\n  \"incare\": \"℅\",\n  \"infin\": \"∞\",\n  \"infintie\": \"⧝\",\n  \"inodot\": \"ı\",\n  \"int\": \"∫\",\n  \"intcal\": \"⊺\",\n  \"integers\": \"ℤ\",\n  \"intercal\": \"⊺\",\n  \"intlarhk\": \"⨗\",\n  \"intprod\": \"⨼\",\n  \"iocy\": \"ё\",\n  \"iogon\": \"į\",\n  \"iopf\": \"𝕚\",\n  \"iota\": \"ι\",\n  \"iprod\": \"⨼\",\n  \"iquest\": \"¿\",\n  \"iscr\": \"𝒾\",\n  \"isin\": \"∈\",\n  \"isinE\": \"⋹\",\n  \"isindot\": \"⋵\",\n  \"isins\": \"⋴\",\n  \"isinsv\": \"⋳\",\n  \"isinv\": \"∈\",\n  \"it\": \"⁢\",\n  \"itilde\": \"ĩ\",\n  \"iukcy\": \"і\",\n  \"iuml\": \"ï\",\n  \"jcirc\": \"ĵ\",\n  \"jcy\": \"й\",\n  \"jfr\": \"𝔧\",\n  \"jmath\": \"ȷ\",\n  \"jopf\": \"𝕛\",\n  \"jscr\": \"𝒿\",\n  \"jsercy\": \"ј\",\n  \"jukcy\": \"є\",\n  \"kappa\": \"κ\",\n  \"kappav\": \"ϰ\",\n  \"kcedil\": \"ķ\",\n  \"kcy\": \"к\",\n  \"kfr\": \"𝔨\",\n  \"kgreen\": \"ĸ\",\n  \"khcy\": \"х\",\n  \"kjcy\": \"ќ\",\n  \"kopf\": \"𝕜\",\n  \"kscr\": \"𝓀\",\n  \"lAarr\": \"⇚\",\n  \"lArr\": \"⇐\",\n  \"lAtail\": \"⤛\",\n  \"lBarr\": \"⤎\",\n  \"lE\": \"≦\",\n  \"lEg\": \"⪋\",\n  \"lHar\": \"⥢\",\n  \"lacute\": \"ĺ\",\n  \"laemptyv\": \"⦴\",\n  \"lagran\": \"ℒ\",\n  \"lambda\": \"λ\",\n  \"lang\": \"⟨\",\n  \"langd\": \"⦑\",\n  \"langle\": \"⟨\",\n  \"lap\": \"⪅\",\n  \"laquo\": \"«\",\n  \"larr\": \"←\",\n  \"larrb\": \"⇤\",\n  \"larrbfs\": \"⤟\",\n  \"larrfs\": \"⤝\",\n  \"larrhk\": \"↩\",\n  \"larrlp\": \"↫\",\n  \"larrpl\": \"⤹\",\n  \"larrsim\": \"⥳\",\n  \"larrtl\": \"↢\",\n  \"lat\": \"⪫\",\n  \"latail\": \"⤙\",\n  \"late\": \"⪭\",\n  \"lates\": \"⪭︀\",\n  \"lbarr\": \"⤌\",\n  \"lbbrk\": \"❲\",\n  \"lbrace\": \"{\",\n  \"lbrack\": \"[\",\n  \"lbrke\": \"⦋\",\n  \"lbrksld\": \"⦏\",\n  \"lbrkslu\": \"⦍\",\n  \"lcaron\": \"ľ\",\n  \"lcedil\": \"ļ\",\n  \"lceil\": \"⌈\",\n  \"lcub\": \"{\",\n  \"lcy\": \"л\",\n  \"ldca\": \"⤶\",\n  \"ldquo\": \"“\",\n  \"ldquor\": \"„\",\n  \"ldrdhar\": \"⥧\",\n  \"ldrushar\": \"⥋\",\n  \"ldsh\": \"↲\",\n  \"le\": \"≤\",\n  \"leftarrow\": \"←\",\n  \"leftarrowtail\": \"↢\",\n  \"leftharpoondown\": \"↽\",\n  \"leftharpoonup\": \"↼\",\n  \"leftleftarrows\": \"⇇\",\n  \"leftrightarrow\": \"↔\",\n  \"leftrightarrows\": \"⇆\",\n  \"leftrightharpoons\": \"⇋\",\n  \"leftrightsquigarrow\": \"↭\",\n  \"leftthreetimes\": \"⋋\",\n  \"leg\": \"⋚\",\n  \"leq\": \"≤\",\n  \"leqq\": \"≦\",\n  \"leqslant\": \"⩽\",\n  \"les\": \"⩽\",\n  \"lescc\": \"⪨\",\n  \"lesdot\": \"⩿\",\n  \"lesdoto\": \"⪁\",\n  \"lesdotor\": \"⪃\",\n  \"lesg\": \"⋚︀\",\n  \"lesges\": \"⪓\",\n  \"lessapprox\": \"⪅\",\n  \"lessdot\": \"⋖\",\n  \"lesseqgtr\": \"⋚\",\n  \"lesseqqgtr\": \"⪋\",\n  \"lessgtr\": \"≶\",\n  \"lesssim\": \"≲\",\n  \"lfisht\": \"⥼\",\n  \"lfloor\": \"⌊\",\n  \"lfr\": \"𝔩\",\n  \"lg\": \"≶\",\n  \"lgE\": \"⪑\",\n  \"lhard\": \"↽\",\n  \"lharu\": \"↼\",\n  \"lharul\": \"⥪\",\n  \"lhblk\": \"▄\",\n  \"ljcy\": \"љ\",\n  \"ll\": \"≪\",\n  \"llarr\": \"⇇\",\n  \"llcorner\": \"⌞\",\n  \"llhard\": \"⥫\",\n  \"lltri\": \"◺\",\n  \"lmidot\": \"ŀ\",\n  \"lmoust\": \"⎰\",\n  \"lmoustache\": \"⎰\",\n  \"lnE\": \"≨\",\n  \"lnap\": \"⪉\",\n  \"lnapprox\": \"⪉\",\n  \"lne\": \"⪇\",\n  \"lneq\": \"⪇\",\n  \"lneqq\": \"≨\",\n  \"lnsim\": \"⋦\",\n  \"loang\": \"⟬\",\n  \"loarr\": \"⇽\",\n  \"lobrk\": \"⟦\",\n  \"longleftarrow\": \"⟵\",\n  \"longleftrightarrow\": \"⟷\",\n  \"longmapsto\": \"⟼\",\n  \"longrightarrow\": \"⟶\",\n  \"looparrowleft\": \"↫\",\n  \"looparrowright\": \"↬\",\n  \"lopar\": \"⦅\",\n  \"lopf\": \"𝕝\",\n  \"loplus\": \"⨭\",\n  \"lotimes\": \"⨴\",\n  \"lowast\": \"∗\",\n  \"lowbar\": \"_\",\n  \"loz\": \"◊\",\n  \"lozenge\": \"◊\",\n  \"lozf\": \"⧫\",\n  \"lpar\": \"(\",\n  \"lparlt\": \"⦓\",\n  \"lrarr\": \"⇆\",\n  \"lrcorner\": \"⌟\",\n  \"lrhar\": \"⇋\",\n  \"lrhard\": \"⥭\",\n  \"lrm\": \"‎\",\n  \"lrtri\": \"⊿\",\n  \"lsaquo\": \"‹\",\n  \"lscr\": \"𝓁\",\n  \"lsh\": \"↰\",\n  \"lsim\": \"≲\",\n  \"lsime\": \"⪍\",\n  \"lsimg\": \"⪏\",\n  \"lsqb\": \"[\",\n  \"lsquo\": \"‘\",\n  \"lsquor\": \"‚\",\n  \"lstrok\": \"ł\",\n  \"lt\": \"<\",\n  \"ltcc\": \"⪦\",\n  \"ltcir\": \"⩹\",\n  \"ltdot\": \"⋖\",\n  \"lthree\": \"⋋\",\n  \"ltimes\": \"⋉\",\n  \"ltlarr\": \"⥶\",\n  \"ltquest\": \"⩻\",\n  \"ltrPar\": \"⦖\",\n  \"ltri\": \"◃\",\n  \"ltrie\": \"⊴\",\n  \"ltrif\": \"◂\",\n  \"lurdshar\": \"⥊\",\n  \"luruhar\": \"⥦\",\n  \"lvertneqq\": \"≨︀\",\n  \"lvnE\": \"≨︀\",\n  \"mDDot\": \"∺\",\n  \"macr\": \"¯\",\n  \"male\": \"♂\",\n  \"malt\": \"✠\",\n  \"maltese\": \"✠\",\n  \"map\": \"↦\",\n  \"mapsto\": \"↦\",\n  \"mapstodown\": \"↧\",\n  \"mapstoleft\": \"↤\",\n  \"mapstoup\": \"↥\",\n  \"marker\": \"▮\",\n  \"mcomma\": \"⨩\",\n  \"mcy\": \"м\",\n  \"mdash\": \"—\",\n  \"measuredangle\": \"∡\",\n  \"mfr\": \"𝔪\",\n  \"mho\": \"℧\",\n  \"micro\": \"µ\",\n  \"mid\": \"∣\",\n  \"midast\": \"*\",\n  \"midcir\": \"⫰\",\n  \"middot\": \"·\",\n  \"minus\": \"−\",\n  \"minusb\": \"⊟\",\n  \"minusd\": \"∸\",\n  \"minusdu\": \"⨪\",\n  \"mlcp\": \"⫛\",\n  \"mldr\": \"…\",\n  \"mnplus\": \"∓\",\n  \"models\": \"⊧\",\n  \"mopf\": \"𝕞\",\n  \"mp\": \"∓\",\n  \"mscr\": \"𝓂\",\n  \"mstpos\": \"∾\",\n  \"mu\": \"μ\",\n  \"multimap\": \"⊸\",\n  \"mumap\": \"⊸\",\n  \"nGg\": \"⋙̸\",\n  \"nGt\": \"≫⃒\",\n  \"nGtv\": \"≫̸\",\n  \"nLeftarrow\": \"⇍\",\n  \"nLeftrightarrow\": \"⇎\",\n  \"nLl\": \"⋘̸\",\n  \"nLt\": \"≪⃒\",\n  \"nLtv\": \"≪̸\",\n  \"nRightarrow\": \"⇏\",\n  \"nVDash\": \"⊯\",\n  \"nVdash\": \"⊮\",\n  \"nabla\": \"∇\",\n  \"nacute\": \"ń\",\n  \"nang\": \"∠⃒\",\n  \"nap\": \"≉\",\n  \"napE\": \"⩰̸\",\n  \"napid\": \"≋̸\",\n  \"napos\": \"ŉ\",\n  \"napprox\": \"≉\",\n  \"natur\": \"♮\",\n  \"natural\": \"♮\",\n  \"naturals\": \"ℕ\",\n  \"nbsp\": \" \",\n  \"nbump\": \"≎̸\",\n  \"nbumpe\": \"≏̸\",\n  \"ncap\": \"⩃\",\n  \"ncaron\": \"ň\",\n  \"ncedil\": \"ņ\",\n  \"ncong\": \"≇\",\n  \"ncongdot\": \"⩭̸\",\n  \"ncup\": \"⩂\",\n  \"ncy\": \"н\",\n  \"ndash\": \"–\",\n  \"ne\": \"≠\",\n  \"neArr\": \"⇗\",\n  \"nearhk\": \"⤤\",\n  \"nearr\": \"↗\",\n  \"nearrow\": \"↗\",\n  \"nedot\": \"≐̸\",\n  \"nequiv\": \"≢\",\n  \"nesear\": \"⤨\",\n  \"nesim\": \"≂̸\",\n  \"nexist\": \"∄\",\n  \"nexists\": \"∄\",\n  \"nfr\": \"𝔫\",\n  \"ngE\": \"≧̸\",\n  \"nge\": \"≱\",\n  \"ngeq\": \"≱\",\n  \"ngeqq\": \"≧̸\",\n  \"ngeqslant\": \"⩾̸\",\n  \"nges\": \"⩾̸\",\n  \"ngsim\": \"≵\",\n  \"ngt\": \"≯\",\n  \"ngtr\": \"≯\",\n  \"nhArr\": \"⇎\",\n  \"nharr\": \"↮\",\n  \"nhpar\": \"⫲\",\n  \"ni\": \"∋\",\n  \"nis\": \"⋼\",\n  \"nisd\": \"⋺\",\n  \"niv\": \"∋\",\n  \"njcy\": \"њ\",\n  \"nlArr\": \"⇍\",\n  \"nlE\": \"≦̸\",\n  \"nlarr\": \"↚\",\n  \"nldr\": \"‥\",\n  \"nle\": \"≰\",\n  \"nleftarrow\": \"↚\",\n  \"nleftrightarrow\": \"↮\",\n  \"nleq\": \"≰\",\n  \"nleqq\": \"≦̸\",\n  \"nleqslant\": \"⩽̸\",\n  \"nles\": \"⩽̸\",\n  \"nless\": \"≮\",\n  \"nlsim\": \"≴\",\n  \"nlt\": \"≮\",\n  \"nltri\": \"⋪\",\n  \"nltrie\": \"⋬\",\n  \"nmid\": \"∤\",\n  \"nopf\": \"𝕟\",\n  \"not\": \"¬\",\n  \"notin\": \"∉\",\n  \"notinE\": \"⋹̸\",\n  \"notindot\": \"⋵̸\",\n  \"notinva\": \"∉\",\n  \"notinvb\": \"⋷\",\n  \"notinvc\": \"⋶\",\n  \"notni\": \"∌\",\n  \"notniva\": \"∌\",\n  \"notnivb\": \"⋾\",\n  \"notnivc\": \"⋽\",\n  \"npar\": \"∦\",\n  \"nparallel\": \"∦\",\n  \"nparsl\": \"⫽⃥\",\n  \"npart\": \"∂̸\",\n  \"npolint\": \"⨔\",\n  \"npr\": \"⊀\",\n  \"nprcue\": \"⋠\",\n  \"npre\": \"⪯̸\",\n  \"nprec\": \"⊀\",\n  \"npreceq\": \"⪯̸\",\n  \"nrArr\": \"⇏\",\n  \"nrarr\": \"↛\",\n  \"nrarrc\": \"⤳̸\",\n  \"nrarrw\": \"↝̸\",\n  \"nrightarrow\": \"↛\",\n  \"nrtri\": \"⋫\",\n  \"nrtrie\": \"⋭\",\n  \"nsc\": \"⊁\",\n  \"nsccue\": \"⋡\",\n  \"nsce\": \"⪰̸\",\n  \"nscr\": \"𝓃\",\n  \"nshortmid\": \"∤\",\n  \"nshortparallel\": \"∦\",\n  \"nsim\": \"≁\",\n  \"nsime\": \"≄\",\n  \"nsimeq\": \"≄\",\n  \"nsmid\": \"∤\",\n  \"nspar\": \"∦\",\n  \"nsqsube\": \"⋢\",\n  \"nsqsupe\": \"⋣\",\n  \"nsub\": \"⊄\",\n  \"nsubE\": \"⫅̸\",\n  \"nsube\": \"⊈\",\n  \"nsubset\": \"⊂⃒\",\n  \"nsubseteq\": \"⊈\",\n  \"nsubseteqq\": \"⫅̸\",\n  \"nsucc\": \"⊁\",\n  \"nsucceq\": \"⪰̸\",\n  \"nsup\": \"⊅\",\n  \"nsupE\": \"⫆̸\",\n  \"nsupe\": \"⊉\",\n  \"nsupset\": \"⊃⃒\",\n  \"nsupseteq\": \"⊉\",\n  \"nsupseteqq\": \"⫆̸\",\n  \"ntgl\": \"≹\",\n  \"ntilde\": \"ñ\",\n  \"ntlg\": \"≸\",\n  \"ntriangleleft\": \"⋪\",\n  \"ntrianglelefteq\": \"⋬\",\n  \"ntriangleright\": \"⋫\",\n  \"ntrianglerighteq\": \"⋭\",\n  \"nu\": \"ν\",\n  \"num\": \"#\",\n  \"numero\": \"№\",\n  \"numsp\": \" \",\n  \"nvDash\": \"⊭\",\n  \"nvHarr\": \"⤄\",\n  \"nvap\": \"≍⃒\",\n  \"nvdash\": \"⊬\",\n  \"nvge\": \"≥⃒\",\n  \"nvgt\": \">⃒\",\n  \"nvinfin\": \"⧞\",\n  \"nvlArr\": \"⤂\",\n  \"nvle\": \"≤⃒\",\n  \"nvlt\": \"<⃒\",\n  \"nvltrie\": \"⊴⃒\",\n  \"nvrArr\": \"⤃\",\n  \"nvrtrie\": \"⊵⃒\",\n  \"nvsim\": \"∼⃒\",\n  \"nwArr\": \"⇖\",\n  \"nwarhk\": \"⤣\",\n  \"nwarr\": \"↖\",\n  \"nwarrow\": \"↖\",\n  \"nwnear\": \"⤧\",\n  \"oS\": \"Ⓢ\",\n  \"oacute\": \"ó\",\n  \"oast\": \"⊛\",\n  \"ocir\": \"⊚\",\n  \"ocirc\": \"ô\",\n  \"ocy\": \"о\",\n  \"odash\": \"⊝\",\n  \"odblac\": \"ő\",\n  \"odiv\": \"⨸\",\n  \"odot\": \"⊙\",\n  \"odsold\": \"⦼\",\n  \"oelig\": \"œ\",\n  \"ofcir\": \"⦿\",\n  \"ofr\": \"𝔬\",\n  \"ogon\": \"˛\",\n  \"ograve\": \"ò\",\n  \"ogt\": \"⧁\",\n  \"ohbar\": \"⦵\",\n  \"ohm\": \"Ω\",\n  \"oint\": \"∮\",\n  \"olarr\": \"↺\",\n  \"olcir\": \"⦾\",\n  \"olcross\": \"⦻\",\n  \"oline\": \"‾\",\n  \"olt\": \"⧀\",\n  \"omacr\": \"ō\",\n  \"omega\": \"ω\",\n  \"omicron\": \"ο\",\n  \"omid\": \"⦶\",\n  \"ominus\": \"⊖\",\n  \"oopf\": \"𝕠\",\n  \"opar\": \"⦷\",\n  \"operp\": \"⦹\",\n  \"oplus\": \"⊕\",\n  \"or\": \"∨\",\n  \"orarr\": \"↻\",\n  \"ord\": \"⩝\",\n  \"order\": \"ℴ\",\n  \"orderof\": \"ℴ\",\n  \"ordf\": \"ª\",\n  \"ordm\": \"º\",\n  \"origof\": \"⊶\",\n  \"oror\": \"⩖\",\n  \"orslope\": \"⩗\",\n  \"orv\": \"⩛\",\n  \"oscr\": \"ℴ\",\n  \"oslash\": \"ø\",\n  \"osol\": \"⊘\",\n  \"otilde\": \"õ\",\n  \"otimes\": \"⊗\",\n  \"otimesas\": \"⨶\",\n  \"ouml\": \"ö\",\n  \"ovbar\": \"⌽\",\n  \"par\": \"∥\",\n  \"para\": \"¶\",\n  \"parallel\": \"∥\",\n  \"parsim\": \"⫳\",\n  \"parsl\": \"⫽\",\n  \"part\": \"∂\",\n  \"pcy\": \"п\",\n  \"percnt\": \"%\",\n  \"period\": \".\",\n  \"permil\": \"‰\",\n  \"perp\": \"⊥\",\n  \"pertenk\": \"‱\",\n  \"pfr\": \"𝔭\",\n  \"phi\": \"φ\",\n  \"phiv\": \"ϕ\",\n  \"phmmat\": \"ℳ\",\n  \"phone\": \"☎\",\n  \"pi\": \"π\",\n  \"pitchfork\": \"⋔\",\n  \"piv\": \"ϖ\",\n  \"planck\": \"ℏ\",\n  \"planckh\": \"ℎ\",\n  \"plankv\": \"ℏ\",\n  \"plus\": \"+\",\n  \"plusacir\": \"⨣\",\n  \"plusb\": \"⊞\",\n  \"pluscir\": \"⨢\",\n  \"plusdo\": \"∔\",\n  \"plusdu\": \"⨥\",\n  \"pluse\": \"⩲\",\n  \"plusmn\": \"±\",\n  \"plussim\": \"⨦\",\n  \"plustwo\": \"⨧\",\n  \"pm\": \"±\",\n  \"pointint\": \"⨕\",\n  \"popf\": \"𝕡\",\n  \"pound\": \"£\",\n  \"pr\": \"≺\",\n  \"prE\": \"⪳\",\n  \"prap\": \"⪷\",\n  \"prcue\": \"≼\",\n  \"pre\": \"⪯\",\n  \"prec\": \"≺\",\n  \"precapprox\": \"⪷\",\n  \"preccurlyeq\": \"≼\",\n  \"preceq\": \"⪯\",\n  \"precnapprox\": \"⪹\",\n  \"precneqq\": \"⪵\",\n  \"precnsim\": \"⋨\",\n  \"precsim\": \"≾\",\n  \"prime\": \"′\",\n  \"primes\": \"ℙ\",\n  \"prnE\": \"⪵\",\n  \"prnap\": \"⪹\",\n  \"prnsim\": \"⋨\",\n  \"prod\": \"∏\",\n  \"profalar\": \"⌮\",\n  \"profline\": \"⌒\",\n  \"profsurf\": \"⌓\",\n  \"prop\": \"∝\",\n  \"propto\": \"∝\",\n  \"prsim\": \"≾\",\n  \"prurel\": \"⊰\",\n  \"pscr\": \"𝓅\",\n  \"psi\": \"ψ\",\n  \"puncsp\": \" \",\n  \"qfr\": \"𝔮\",\n  \"qint\": \"⨌\",\n  \"qopf\": \"𝕢\",\n  \"qprime\": \"⁗\",\n  \"qscr\": \"𝓆\",\n  \"quaternions\": \"ℍ\",\n  \"quatint\": \"⨖\",\n  \"quest\": \"?\",\n  \"questeq\": \"≟\",\n  \"quot\": \"\\\"\",\n  \"rAarr\": \"⇛\",\n  \"rArr\": \"⇒\",\n  \"rAtail\": \"⤜\",\n  \"rBarr\": \"⤏\",\n  \"rHar\": \"⥤\",\n  \"race\": \"∽̱\",\n  \"racute\": \"ŕ\",\n  \"radic\": \"√\",\n  \"raemptyv\": \"⦳\",\n  \"rang\": \"⟩\",\n  \"rangd\": \"⦒\",\n  \"range\": \"⦥\",\n  \"rangle\": \"⟩\",\n  \"raquo\": \"»\",\n  \"rarr\": \"→\",\n  \"rarrap\": \"⥵\",\n  \"rarrb\": \"⇥\",\n  \"rarrbfs\": \"⤠\",\n  \"rarrc\": \"⤳\",\n  \"rarrfs\": \"⤞\",\n  \"rarrhk\": \"↪\",\n  \"rarrlp\": \"↬\",\n  \"rarrpl\": \"⥅\",\n  \"rarrsim\": \"⥴\",\n  \"rarrtl\": \"↣\",\n  \"rarrw\": \"↝\",\n  \"ratail\": \"⤚\",\n  \"ratio\": \"∶\",\n  \"rationals\": \"ℚ\",\n  \"rbarr\": \"⤍\",\n  \"rbbrk\": \"❳\",\n  \"rbrace\": \"}\",\n  \"rbrack\": \"]\",\n  \"rbrke\": \"⦌\",\n  \"rbrksld\": \"⦎\",\n  \"rbrkslu\": \"⦐\",\n  \"rcaron\": \"ř\",\n  \"rcedil\": \"ŗ\",\n  \"rceil\": \"⌉\",\n  \"rcub\": \"}\",\n  \"rcy\": \"р\",\n  \"rdca\": \"⤷\",\n  \"rdldhar\": \"⥩\",\n  \"rdquo\": \"”\",\n  \"rdquor\": \"”\",\n  \"rdsh\": \"↳\",\n  \"real\": \"ℜ\",\n  \"realine\": \"ℛ\",\n  \"realpart\": \"ℜ\",\n  \"reals\": \"ℝ\",\n  \"rect\": \"▭\",\n  \"reg\": \"®\",\n  \"rfisht\": \"⥽\",\n  \"rfloor\": \"⌋\",\n  \"rfr\": \"𝔯\",\n  \"rhard\": \"⇁\",\n  \"rharu\": \"⇀\",\n  \"rharul\": \"⥬\",\n  \"rho\": \"ρ\",\n  \"rhov\": \"ϱ\",\n  \"rightarrow\": \"→\",\n  \"rightarrowtail\": \"↣\",\n  \"rightharpoondown\": \"⇁\",\n  \"rightharpoonup\": \"⇀\",\n  \"rightleftarrows\": \"⇄\",\n  \"rightleftharpoons\": \"⇌\",\n  \"rightrightarrows\": \"⇉\",\n  \"rightsquigarrow\": \"↝\",\n  \"rightthreetimes\": \"⋌\",\n  \"ring\": \"˚\",\n  \"risingdotseq\": \"≓\",\n  \"rlarr\": \"⇄\",\n  \"rlhar\": \"⇌\",\n  \"rlm\": \"‏\",\n  \"rmoust\": \"⎱\",\n  \"rmoustache\": \"⎱\",\n  \"rnmid\": \"⫮\",\n  \"roang\": \"⟭\",\n  \"roarr\": \"⇾\",\n  \"robrk\": \"⟧\",\n  \"ropar\": \"⦆\",\n  \"ropf\": \"𝕣\",\n  \"roplus\": \"⨮\",\n  \"rotimes\": \"⨵\",\n  \"rpar\": \")\",\n  \"rpargt\": \"⦔\",\n  \"rppolint\": \"⨒\",\n  \"rrarr\": \"⇉\",\n  \"rsaquo\": \"›\",\n  \"rscr\": \"𝓇\",\n  \"rsh\": \"↱\",\n  \"rsqb\": \"]\",\n  \"rsquo\": \"’\",\n  \"rsquor\": \"’\",\n  \"rthree\": \"⋌\",\n  \"rtimes\": \"⋊\",\n  \"rtri\": \"▹\",\n  \"rtrie\": \"⊵\",\n  \"rtrif\": \"▸\",\n  \"rtriltri\": \"⧎\",\n  \"ruluhar\": \"⥨\",\n  \"rx\": \"℞\",\n  \"sacute\": \"ś\",\n  \"sbquo\": \"‚\",\n  \"sc\": \"≻\",\n  \"scE\": \"⪴\",\n  \"scap\": \"⪸\",\n  \"scaron\": \"š\",\n  \"sccue\": \"≽\",\n  \"sce\": \"⪰\",\n  \"scedil\": \"ş\",\n  \"scirc\": \"ŝ\",\n  \"scnE\": \"⪶\",\n  \"scnap\": \"⪺\",\n  \"scnsim\": \"⋩\",\n  \"scpolint\": \"⨓\",\n  \"scsim\": \"≿\",\n  \"scy\": \"с\",\n  \"sdot\": \"⋅\",\n  \"sdotb\": \"⊡\",\n  \"sdote\": \"⩦\",\n  \"seArr\": \"⇘\",\n  \"searhk\": \"⤥\",\n  \"searr\": \"↘\",\n  \"searrow\": \"↘\",\n  \"sect\": \"§\",\n  \"semi\": \";\",\n  \"seswar\": \"⤩\",\n  \"setminus\": \"∖\",\n  \"setmn\": \"∖\",\n  \"sext\": \"✶\",\n  \"sfr\": \"𝔰\",\n  \"sfrown\": \"⌢\",\n  \"sharp\": \"♯\",\n  \"shchcy\": \"щ\",\n  \"shcy\": \"ш\",\n  \"shortmid\": \"∣\",\n  \"shortparallel\": \"∥\",\n  \"shy\": \"­\",\n  \"sigma\": \"σ\",\n  \"sigmaf\": \"ς\",\n  \"sigmav\": \"ς\",\n  \"sim\": \"∼\",\n  \"simdot\": \"⩪\",\n  \"sime\": \"≃\",\n  \"simeq\": \"≃\",\n  \"simg\": \"⪞\",\n  \"simgE\": \"⪠\",\n  \"siml\": \"⪝\",\n  \"simlE\": \"⪟\",\n  \"simne\": \"≆\",\n  \"simplus\": \"⨤\",\n  \"simrarr\": \"⥲\",\n  \"slarr\": \"←\",\n  \"smallsetminus\": \"∖\",\n  \"smashp\": \"⨳\",\n  \"smeparsl\": \"⧤\",\n  \"smid\": \"∣\",\n  \"smile\": \"⌣\",\n  \"smt\": \"⪪\",\n  \"smte\": \"⪬\",\n  \"smtes\": \"⪬︀\",\n  \"softcy\": \"ь\",\n  \"sol\": \"/\",\n  \"solb\": \"⧄\",\n  \"solbar\": \"⌿\",\n  \"sopf\": \"𝕤\",\n  \"spades\": \"♠\",\n  \"spadesuit\": \"♠\",\n  \"spar\": \"∥\",\n  \"sqcap\": \"⊓\",\n  \"sqcaps\": \"⊓︀\",\n  \"sqcup\": \"⊔\",\n  \"sqcups\": \"⊔︀\",\n  \"sqsub\": \"⊏\",\n  \"sqsube\": \"⊑\",\n  \"sqsubset\": \"⊏\",\n  \"sqsubseteq\": \"⊑\",\n  \"sqsup\": \"⊐\",\n  \"sqsupe\": \"⊒\",\n  \"sqsupset\": \"⊐\",\n  \"sqsupseteq\": \"⊒\",\n  \"squ\": \"□\",\n  \"square\": \"□\",\n  \"squarf\": \"▪\",\n  \"squf\": \"▪\",\n  \"srarr\": \"→\",\n  \"sscr\": \"𝓈\",\n  \"ssetmn\": \"∖\",\n  \"ssmile\": \"⌣\",\n  \"sstarf\": \"⋆\",\n  \"star\": \"☆\",\n  \"starf\": \"★\",\n  \"straightepsilon\": \"ϵ\",\n  \"straightphi\": \"ϕ\",\n  \"strns\": \"¯\",\n  \"sub\": \"⊂\",\n  \"subE\": \"⫅\",\n  \"subdot\": \"⪽\",\n  \"sube\": \"⊆\",\n  \"subedot\": \"⫃\",\n  \"submult\": \"⫁\",\n  \"subnE\": \"⫋\",\n  \"subne\": \"⊊\",\n  \"subplus\": \"⪿\",\n  \"subrarr\": \"⥹\",\n  \"subset\": \"⊂\",\n  \"subseteq\": \"⊆\",\n  \"subseteqq\": \"⫅\",\n  \"subsetneq\": \"⊊\",\n  \"subsetneqq\": \"⫋\",\n  \"subsim\": \"⫇\",\n  \"subsub\": \"⫕\",\n  \"subsup\": \"⫓\",\n  \"succ\": \"≻\",\n  \"succapprox\": \"⪸\",\n  \"succcurlyeq\": \"≽\",\n  \"succeq\": \"⪰\",\n  \"succnapprox\": \"⪺\",\n  \"succneqq\": \"⪶\",\n  \"succnsim\": \"⋩\",\n  \"succsim\": \"≿\",\n  \"sum\": \"∑\",\n  \"sung\": \"♪\",\n  \"sup1\": \"¹\",\n  \"sup2\": \"²\",\n  \"sup3\": \"³\",\n  \"sup\": \"⊃\",\n  \"supE\": \"⫆\",\n  \"supdot\": \"⪾\",\n  \"supdsub\": \"⫘\",\n  \"supe\": \"⊇\",\n  \"supedot\": \"⫄\",\n  \"suphsol\": \"⟉\",\n  \"suphsub\": \"⫗\",\n  \"suplarr\": \"⥻\",\n  \"supmult\": \"⫂\",\n  \"supnE\": \"⫌\",\n  \"supne\": \"⊋\",\n  \"supplus\": \"⫀\",\n  \"supset\": \"⊃\",\n  \"supseteq\": \"⊇\",\n  \"supseteqq\": \"⫆\",\n  \"supsetneq\": \"⊋\",\n  \"supsetneqq\": \"⫌\",\n  \"supsim\": \"⫈\",\n  \"supsub\": \"⫔\",\n  \"supsup\": \"⫖\",\n  \"swArr\": \"⇙\",\n  \"swarhk\": \"⤦\",\n  \"swarr\": \"↙\",\n  \"swarrow\": \"↙\",\n  \"swnwar\": \"⤪\",\n  \"szlig\": \"ß\",\n  \"target\": \"⌖\",\n  \"tau\": \"τ\",\n  \"tbrk\": \"⎴\",\n  \"tcaron\": \"ť\",\n  \"tcedil\": \"ţ\",\n  \"tcy\": \"т\",\n  \"tdot\": \"⃛\",\n  \"telrec\": \"⌕\",\n  \"tfr\": \"𝔱\",\n  \"there4\": \"∴\",\n  \"therefore\": \"∴\",\n  \"theta\": \"θ\",\n  \"thetasym\": \"ϑ\",\n  \"thetav\": \"ϑ\",\n  \"thickapprox\": \"≈\",\n  \"thicksim\": \"∼\",\n  \"thinsp\": \" \",\n  \"thkap\": \"≈\",\n  \"thksim\": \"∼\",\n  \"thorn\": \"þ\",\n  \"tilde\": \"˜\",\n  \"times\": \"×\",\n  \"timesb\": \"⊠\",\n  \"timesbar\": \"⨱\",\n  \"timesd\": \"⨰\",\n  \"tint\": \"∭\",\n  \"toea\": \"⤨\",\n  \"top\": \"⊤\",\n  \"topbot\": \"⌶\",\n  \"topcir\": \"⫱\",\n  \"topf\": \"𝕥\",\n  \"topfork\": \"⫚\",\n  \"tosa\": \"⤩\",\n  \"tprime\": \"‴\",\n  \"trade\": \"™\",\n  \"triangle\": \"▵\",\n  \"triangledown\": \"▿\",\n  \"triangleleft\": \"◃\",\n  \"trianglelefteq\": \"⊴\",\n  \"triangleq\": \"≜\",\n  \"triangleright\": \"▹\",\n  \"trianglerighteq\": \"⊵\",\n  \"tridot\": \"◬\",\n  \"trie\": \"≜\",\n  \"triminus\": \"⨺\",\n  \"triplus\": \"⨹\",\n  \"trisb\": \"⧍\",\n  \"tritime\": \"⨻\",\n  \"trpezium\": \"⏢\",\n  \"tscr\": \"𝓉\",\n  \"tscy\": \"ц\",\n  \"tshcy\": \"ћ\",\n  \"tstrok\": \"ŧ\",\n  \"twixt\": \"≬\",\n  \"twoheadleftarrow\": \"↞\",\n  \"twoheadrightarrow\": \"↠\",\n  \"uArr\": \"⇑\",\n  \"uHar\": \"⥣\",\n  \"uacute\": \"ú\",\n  \"uarr\": \"↑\",\n  \"ubrcy\": \"ў\",\n  \"ubreve\": \"ŭ\",\n  \"ucirc\": \"û\",\n  \"ucy\": \"у\",\n  \"udarr\": \"⇅\",\n  \"udblac\": \"ű\",\n  \"udhar\": \"⥮\",\n  \"ufisht\": \"⥾\",\n  \"ufr\": \"𝔲\",\n  \"ugrave\": \"ù\",\n  \"uharl\": \"↿\",\n  \"uharr\": \"↾\",\n  \"uhblk\": \"▀\",\n  \"ulcorn\": \"⌜\",\n  \"ulcorner\": \"⌜\",\n  \"ulcrop\": \"⌏\",\n  \"ultri\": \"◸\",\n  \"umacr\": \"ū\",\n  \"uml\": \"¨\",\n  \"uogon\": \"ų\",\n  \"uopf\": \"𝕦\",\n  \"uparrow\": \"↑\",\n  \"updownarrow\": \"↕\",\n  \"upharpoonleft\": \"↿\",\n  \"upharpoonright\": \"↾\",\n  \"uplus\": \"⊎\",\n  \"upsi\": \"υ\",\n  \"upsih\": \"ϒ\",\n  \"upsilon\": \"υ\",\n  \"upuparrows\": \"⇈\",\n  \"urcorn\": \"⌝\",\n  \"urcorner\": \"⌝\",\n  \"urcrop\": \"⌎\",\n  \"uring\": \"ů\",\n  \"urtri\": \"◹\",\n  \"uscr\": \"𝓊\",\n  \"utdot\": \"⋰\",\n  \"utilde\": \"ũ\",\n  \"utri\": \"▵\",\n  \"utrif\": \"▴\",\n  \"uuarr\": \"⇈\",\n  \"uuml\": \"ü\",\n  \"uwangle\": \"⦧\",\n  \"vArr\": \"⇕\",\n  \"vBar\": \"⫨\",\n  \"vBarv\": \"⫩\",\n  \"vDash\": \"⊨\",\n  \"vangrt\": \"⦜\",\n  \"varepsilon\": \"ϵ\",\n  \"varkappa\": \"ϰ\",\n  \"varnothing\": \"∅\",\n  \"varphi\": \"ϕ\",\n  \"varpi\": \"ϖ\",\n  \"varpropto\": \"∝\",\n  \"varr\": \"↕\",\n  \"varrho\": \"ϱ\",\n  \"varsigma\": \"ς\",\n  \"varsubsetneq\": \"⊊︀\",\n  \"varsubsetneqq\": \"⫋︀\",\n  \"varsupsetneq\": \"⊋︀\",\n  \"varsupsetneqq\": \"⫌︀\",\n  \"vartheta\": \"ϑ\",\n  \"vartriangleleft\": \"⊲\",\n  \"vartriangleright\": \"⊳\",\n  \"vcy\": \"в\",\n  \"vdash\": \"⊢\",\n  \"vee\": \"∨\",\n  \"veebar\": \"⊻\",\n  \"veeeq\": \"≚\",\n  \"vellip\": \"⋮\",\n  \"verbar\": \"|\",\n  \"vert\": \"|\",\n  \"vfr\": \"𝔳\",\n  \"vltri\": \"⊲\",\n  \"vnsub\": \"⊂⃒\",\n  \"vnsup\": \"⊃⃒\",\n  \"vopf\": \"𝕧\",\n  \"vprop\": \"∝\",\n  \"vrtri\": \"⊳\",\n  \"vscr\": \"𝓋\",\n  \"vsubnE\": \"⫋︀\",\n  \"vsubne\": \"⊊︀\",\n  \"vsupnE\": \"⫌︀\",\n  \"vsupne\": \"⊋︀\",\n  \"vzigzag\": \"⦚\",\n  \"wcirc\": \"ŵ\",\n  \"wedbar\": \"⩟\",\n  \"wedge\": \"∧\",\n  \"wedgeq\": \"≙\",\n  \"weierp\": \"℘\",\n  \"wfr\": \"𝔴\",\n  \"wopf\": \"𝕨\",\n  \"wp\": \"℘\",\n  \"wr\": \"≀\",\n  \"wreath\": \"≀\",\n  \"wscr\": \"𝓌\",\n  \"xcap\": \"⋂\",\n  \"xcirc\": \"◯\",\n  \"xcup\": \"⋃\",\n  \"xdtri\": \"▽\",\n  \"xfr\": \"𝔵\",\n  \"xhArr\": \"⟺\",\n  \"xharr\": \"⟷\",\n  \"xi\": \"ξ\",\n  \"xlArr\": \"⟸\",\n  \"xlarr\": \"⟵\",\n  \"xmap\": \"⟼\",\n  \"xnis\": \"⋻\",\n  \"xodot\": \"⨀\",\n  \"xopf\": \"𝕩\",\n  \"xoplus\": \"⨁\",\n  \"xotime\": \"⨂\",\n  \"xrArr\": \"⟹\",\n  \"xrarr\": \"⟶\",\n  \"xscr\": \"𝓍\",\n  \"xsqcup\": \"⨆\",\n  \"xuplus\": \"⨄\",\n  \"xutri\": \"△\",\n  \"xvee\": \"⋁\",\n  \"xwedge\": \"⋀\",\n  \"yacute\": \"ý\",\n  \"yacy\": \"я\",\n  \"ycirc\": \"ŷ\",\n  \"ycy\": \"ы\",\n  \"yen\": \"¥\",\n  \"yfr\": \"𝔶\",\n  \"yicy\": \"ї\",\n  \"yopf\": \"𝕪\",\n  \"yscr\": \"𝓎\",\n  \"yucy\": \"ю\",\n  \"yuml\": \"ÿ\",\n  \"zacute\": \"ź\",\n  \"zcaron\": \"ž\",\n  \"zcy\": \"з\",\n  \"zdot\": \"ż\",\n  \"zeetrf\": \"ℨ\",\n  \"zeta\": \"ζ\",\n  \"zfr\": \"𝔷\",\n  \"zhcy\": \"ж\",\n  \"zigrarr\": \"⇝\",\n  \"zopf\": \"𝕫\",\n  \"zscr\": \"𝓏\",\n  \"zwj\": \"‍\",\n  \"zwnj\": \"‌\"\n}\n","/**\n * @author Titus Wormer\n * @copyright 2015 Titus Wormer\n * @license MIT\n * @module character-entities\n * @fileoverview HTML character entity information.\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\n/*\n * Expose.\n */\n\nmodule.exports = require('./index.json');\n","module.exports={\n  \"0\": \"�\",\n  \"128\": \"€\",\n  \"130\": \"‚\",\n  \"131\": \"ƒ\",\n  \"132\": \"„\",\n  \"133\": \"…\",\n  \"134\": \"†\",\n  \"135\": \"‡\",\n  \"136\": \"ˆ\",\n  \"137\": \"‰\",\n  \"138\": \"Š\",\n  \"139\": \"‹\",\n  \"140\": \"Œ\",\n  \"142\": \"Ž\",\n  \"145\": \"‘\",\n  \"146\": \"’\",\n  \"147\": \"“\",\n  \"148\": \"”\",\n  \"149\": \"•\",\n  \"150\": \"–\",\n  \"151\": \"—\",\n  \"152\": \"˜\",\n  \"153\": \"™\",\n  \"154\": \"š\",\n  \"155\": \"›\",\n  \"156\": \"œ\",\n  \"158\": \"ž\",\n  \"159\": \"Ÿ\"\n}\n","/**\n * @author Titus Wormer\n * @copyright 2015 Titus Wormer\n * @license MIT\n * @module character-reference-invalid\n * @fileoverview HTML invalid numeric character reference information.\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\n/*\n * Expose.\n */\n\nmodule.exports = require('./index.json');\n","var _require = require //fool browserify\nmodule.exports = _require('chloridedown/build/Release/sodium')\n","\nmodule.exports = require('sodium-browserify')\n","\nif(process.env.CHLORIDE_JS)\n  return module.exports = require('./browser')\n\ntry {\n  module.exports = require('./bindings')\n} catch (err) {\n  console.error('error loading sodium bindings:', err.message)\n  console.error('falling back to javascript version.')\n  module.exports = require('./browser')\n}\n\n","var Transform = require('stream').Transform\nvar inherits = require('inherits')\nvar StringDecoder = require('string_decoder').StringDecoder\nmodule.exports = CipherBase\ninherits(CipherBase, Transform)\nfunction CipherBase (hashMode) {\n  Transform.call(this)\n  this.hashMode = typeof hashMode === 'string'\n  if (this.hashMode) {\n    this[hashMode] = this._finalOrDigest\n  } else {\n    this.final = this._finalOrDigest\n  }\n  this._decoder = null\n  this._encoding = null\n}\nCipherBase.prototype.update = function (data, inputEnc, outputEnc) {\n  if (typeof data === 'string') {\n    data = new Buffer(data, inputEnc)\n  }\n  var outData = this._update(data)\n  if (this.hashMode) {\n    return this\n  }\n  if (outputEnc) {\n    outData = this._toString(outData, outputEnc)\n  }\n  return outData\n}\n\nCipherBase.prototype.setAutoPadding = function () {}\n\nCipherBase.prototype.getAuthTag = function () {\n  throw new Error('trying to get auth tag in unsupported state')\n}\n\nCipherBase.prototype.setAuthTag = function () {\n  throw new Error('trying to set auth tag in unsupported state')\n}\n\nCipherBase.prototype.setAAD = function () {\n  throw new Error('trying to set aad in unsupported state')\n}\n\nCipherBase.prototype._transform = function (data, _, next) {\n  var err\n  try {\n    if (this.hashMode) {\n      this._update(data)\n    } else {\n      this.push(this._update(data))\n    }\n  } catch (e) {\n    err = e\n  } finally {\n    next(err)\n  }\n}\nCipherBase.prototype._flush = function (done) {\n  var err\n  try {\n    this.push(this._final())\n  } catch (e) {\n    err = e\n  } finally {\n    done(err)\n  }\n}\nCipherBase.prototype._finalOrDigest = function (outputEnc) {\n  var outData = this._final() || new Buffer('')\n  if (outputEnc) {\n    outData = this._toString(outData, outputEnc, true)\n  }\n  return outData\n}\n\nCipherBase.prototype._toString = function (value, enc, final) {\n  if (!this._decoder) {\n    this._decoder = new StringDecoder(enc)\n    this._encoding = enc\n  }\n  if (this._encoding !== enc) {\n    throw new Error('can\\'t switch encodings')\n  }\n  var out = this._decoder.write(value)\n  if (final) {\n    out += this._decoder.end()\n  }\n  return out\n}\n","var clone = (function() {\n'use strict';\n\n/**\n * Clones (copies) an Object using deep copying.\n *\n * This function supports circular references by default, but if you are certain\n * there are no circular references in your object, you can save some CPU time\n * by calling clone(obj, false).\n *\n * Caution: if `circular` is false and `parent` contains circular references,\n * your program may enter an infinite loop and crash.\n *\n * @param `parent` - the object to be cloned\n * @param `circular` - set to true if the object to be cloned may contain\n *    circular references. (optional - true by default)\n * @param `depth` - set to a number if the object is only to be cloned to\n *    a particular depth. (optional - defaults to Infinity)\n * @param `prototype` - sets the prototype to be used when cloning an object.\n *    (optional - defaults to parent prototype).\n*/\nfunction clone(parent, circular, depth, prototype) {\n  var filter;\n  if (typeof circular === 'object') {\n    depth = circular.depth;\n    prototype = circular.prototype;\n    filter = circular.filter;\n    circular = circular.circular\n  }\n  // maintain two arrays for circular references, where corresponding parents\n  // and children have the same index\n  var allParents = [];\n  var allChildren = [];\n\n  var useBuffer = typeof Buffer != 'undefined';\n\n  if (typeof circular == 'undefined')\n    circular = true;\n\n  if (typeof depth == 'undefined')\n    depth = Infinity;\n\n  // recurse this function so we don't reset allParents and allChildren\n  function _clone(parent, depth) {\n    // cloning null always returns null\n    if (parent === null)\n      return null;\n\n    if (depth == 0)\n      return parent;\n\n    var child;\n    var proto;\n    if (typeof parent != 'object') {\n      return parent;\n    }\n\n    if (clone.__isArray(parent)) {\n      child = [];\n    } else if (clone.__isRegExp(parent)) {\n      child = new RegExp(parent.source, __getRegExpFlags(parent));\n      if (parent.lastIndex) child.lastIndex = parent.lastIndex;\n    } else if (clone.__isDate(parent)) {\n      child = new Date(parent.getTime());\n    } else if (useBuffer && Buffer.isBuffer(parent)) {\n      child = new Buffer(parent.length);\n      parent.copy(child);\n      return child;\n    } else {\n      if (typeof prototype == 'undefined') {\n        proto = Object.getPrototypeOf(parent);\n        child = Object.create(proto);\n      }\n      else {\n        child = Object.create(prototype);\n        proto = prototype;\n      }\n    }\n\n    if (circular) {\n      var index = allParents.indexOf(parent);\n\n      if (index != -1) {\n        return allChildren[index];\n      }\n      allParents.push(parent);\n      allChildren.push(child);\n    }\n\n    for (var i in parent) {\n      var attrs;\n      if (proto) {\n        attrs = Object.getOwnPropertyDescriptor(proto, i);\n      }\n\n      if (attrs && attrs.set == null) {\n        continue;\n      }\n      child[i] = _clone(parent[i], depth - 1);\n    }\n\n    return child;\n  }\n\n  return _clone(parent, depth);\n}\n\n/**\n * Simple flat clone using prototype, accepts only objects, usefull for property\n * override on FLAT configuration object (no nested props).\n *\n * USE WITH CAUTION! This may not behave as you wish if you do not know how this\n * works.\n */\nclone.clonePrototype = function clonePrototype(parent) {\n  if (parent === null)\n    return null;\n\n  var c = function () {};\n  c.prototype = parent;\n  return new c();\n};\n\n// private utility functions\n\nfunction __objToStr(o) {\n  return Object.prototype.toString.call(o);\n};\nclone.__objToStr = __objToStr;\n\nfunction __isDate(o) {\n  return typeof o === 'object' && __objToStr(o) === '[object Date]';\n};\nclone.__isDate = __isDate;\n\nfunction __isArray(o) {\n  return typeof o === 'object' && __objToStr(o) === '[object Array]';\n};\nclone.__isArray = __isArray;\n\nfunction __isRegExp(o) {\n  return typeof o === 'object' && __objToStr(o) === '[object RegExp]';\n};\nclone.__isRegExp = __isRegExp;\n\nfunction __getRegExpFlags(re) {\n  var flags = '';\n  if (re.global) flags += 'g';\n  if (re.ignoreCase) flags += 'i';\n  if (re.multiline) flags += 'm';\n  return flags;\n};\nclone.__getRegExpFlags = __getRegExpFlags;\n\nreturn clone;\n})();\n\nif (typeof module === 'object' && module.exports) {\n  module.exports = clone;\n}\n","\n/**\n * slice() reference.\n */\n\nvar slice = Array.prototype.slice;\n\n/**\n * Expose `co`.\n */\n\nmodule.exports = co;\n\n/**\n * Wrap the given generator `fn` and\n * return a thunk.\n *\n * @param {Function} fn\n * @return {Function}\n * @api public\n */\n\nfunction co(fn) {\n  var isGenFun = isGeneratorFunction(fn);\n\n  return function (done) {\n    var ctx = this;\n\n    // in toThunk() below we invoke co()\n    // with a generator, so optimize for\n    // this case\n    var gen = fn;\n\n    // we only need to parse the arguments\n    // if gen is a generator function.\n    if (isGenFun) {\n      var args = slice.call(arguments), len = args.length;\n      var hasCallback = len && 'function' == typeof args[len - 1];\n      done = hasCallback ? args.pop() : error;\n      gen = fn.apply(this, args);\n    } else {\n      done = done || error;\n    }\n\n    next();\n\n    // #92\n    // wrap the callback in a setImmediate\n    // so that any of its errors aren't caught by `co`\n    function exit(err, res) {\n      setImmediate(function(){\n        done.call(ctx, err, res);\n      });\n    }\n\n    function next(err, res) {\n      var ret;\n\n      // multiple args\n      if (arguments.length > 2) res = slice.call(arguments, 1);\n\n      // error\n      if (err) {\n        try {\n          ret = gen.throw(err);\n        } catch (e) {\n          return exit(e);\n        }\n      }\n\n      // ok\n      if (!err) {\n        try {\n          ret = gen.next(res);\n        } catch (e) {\n          return exit(e);\n        }\n      }\n\n      // done\n      if (ret.done) return exit(null, ret.value);\n\n      // normalize\n      ret.value = toThunk(ret.value, ctx);\n\n      // run\n      if ('function' == typeof ret.value) {\n        var called = false;\n        try {\n          ret.value.call(ctx, function(){\n            if (called) return;\n            called = true;\n            next.apply(ctx, arguments);\n          });\n        } catch (e) {\n          setImmediate(function(){\n            if (called) return;\n            called = true;\n            next(e);\n          });\n        }\n        return;\n      }\n\n      // invalid\n      next(new TypeError('You may only yield a function, promise, generator, array, or object, '\n        + 'but the following was passed: \"' + String(ret.value) + '\"'));\n    }\n  }\n}\n\n/**\n * Convert `obj` into a normalized thunk.\n *\n * @param {Mixed} obj\n * @param {Mixed} ctx\n * @return {Function}\n * @api private\n */\n\nfunction toThunk(obj, ctx) {\n\n  if (isGeneratorFunction(obj)) {\n    return co(obj.call(ctx));\n  }\n\n  if (isGenerator(obj)) {\n    return co(obj);\n  }\n\n  if (isPromise(obj)) {\n    return promiseToThunk(obj);\n  }\n\n  if ('function' == typeof obj) {\n    return obj;\n  }\n\n  if (isObject(obj) || Array.isArray(obj)) {\n    return objectToThunk.call(ctx, obj);\n  }\n\n  return obj;\n}\n\n/**\n * Convert an object of yieldables to a thunk.\n *\n * @param {Object} obj\n * @return {Function}\n * @api private\n */\n\nfunction objectToThunk(obj){\n  var ctx = this;\n  var isArray = Array.isArray(obj);\n\n  return function(done){\n    var keys = Object.keys(obj);\n    var pending = keys.length;\n    var results = isArray\n      ? new Array(pending) // predefine the array length\n      : new obj.constructor();\n    var finished;\n\n    if (!pending) {\n      setImmediate(function(){\n        done(null, results)\n      });\n      return;\n    }\n\n    // prepopulate object keys to preserve key ordering\n    if (!isArray) {\n      for (var i = 0; i < pending; i++) {\n        results[keys[i]] = undefined;\n      }\n    }\n\n    for (var i = 0; i < keys.length; i++) {\n      run(obj[keys[i]], keys[i]);\n    }\n\n    function run(fn, key) {\n      if (finished) return;\n      try {\n        fn = toThunk(fn, ctx);\n\n        if ('function' != typeof fn) {\n          results[key] = fn;\n          return --pending || done(null, results);\n        }\n\n        fn.call(ctx, function(err, res){\n          if (finished) return;\n\n          if (err) {\n            finished = true;\n            return done(err);\n          }\n\n          results[key] = res;\n          --pending || done(null, results);\n        });\n      } catch (err) {\n        finished = true;\n        done(err);\n      }\n    }\n  }\n}\n\n/**\n * Convert `promise` to a thunk.\n *\n * @param {Object} promise\n * @return {Function}\n * @api private\n */\n\nfunction promiseToThunk(promise) {\n  return function(fn){\n    promise.then(function(res) {\n      fn(null, res);\n    }, fn);\n  }\n}\n\n/**\n * Check if `obj` is a promise.\n *\n * @param {Object} obj\n * @return {Boolean}\n * @api private\n */\n\nfunction isPromise(obj) {\n  return obj && 'function' == typeof obj.then;\n}\n\n/**\n * Check if `obj` is a generator.\n *\n * @param {Mixed} obj\n * @return {Boolean}\n * @api private\n */\n\nfunction isGenerator(obj) {\n  return obj && 'function' == typeof obj.next && 'function' == typeof obj.throw;\n}\n\n/**\n * Check if `obj` is a generator function.\n *\n * @param {Mixed} obj\n * @return {Boolean}\n * @api private\n */\n\nfunction isGeneratorFunction(obj) {\n  return obj && obj.constructor && 'GeneratorFunction' == obj.constructor.name;\n}\n\n/**\n * Check for plain object.\n *\n * @param {Mixed} val\n * @return {Boolean}\n * @api private\n */\n\nfunction isObject(val) {\n  return val && Object == val.constructor;\n}\n\n/**\n * Throw `err` in a new stack.\n *\n * This is used when co() is invoked\n * without supplying a callback, which\n * should only be for demonstrational\n * purposes.\n *\n * @param {Error} err\n * @api private\n */\n\nfunction error(err) {\n  if (!err) return;\n  setImmediate(function(){\n    throw err;\n  });\n}\n","'use strict';\n\n/*\n * Constants.\n */\n\nvar WHITE_SPACE_COLLAPSABLE = /\\s+/g;\nvar SPACE = ' ';\n\n/**\n * Replace multiple white-space characters with a single space.\n *\n * @example\n *   collapse(' \\t\\nbar \\nbaz\\t'); // ' bar baz '\n *\n * @param {string} value - Value with uncollapsed white-space,\n *   coerced to string.\n * @return {string} - Value with collapsed white-space.\n */\nfunction collapse(value) {\n    return String(value).replace(WHITE_SPACE_COLLAPSABLE, SPACE);\n}\n\n/*\n * Expose.\n */\n\nmodule.exports = collapse;\n","module.exports = function (xs, fn) {\n    var res = [];\n    for (var i = 0; i < xs.length; i++) {\n        var x = fn(xs[i], i);\n        if (isArray(x)) res.push.apply(res, x);\n        else res.push(x);\n    }\n    return res;\n};\n\nvar isArray = Array.isArray || function (xs) {\n    return Object.prototype.toString.call(xs) === '[object Array]';\n};\n","var cont = require('continuable')\n\nexports = module.exports = function (fun) {\n  return cont.to(fun)\n}\n\nfor(var k in cont)\n  exports[k] = cont[k]\n\nexports.para = require('continuable-para')\nexports.series = require('continuable-series')\n","var maybeCallback = require(\"continuable/maybe-callback\")\n\nmodule.exports = maybeCallback(hash)\n\n//  hash := (tasks:Object<String, Continuable<T>>)\n//      => Continuable<Object<String, T>>\nfunction hash(tasks) {\n    return function continuable(callback) {\n        var keys = Object.keys(tasks)\n        var count = 0\n        var result = {}\n\n        if (keys.length === 0) {\n            return callback(null, result)\n        }\n\n        keys.forEach(function (key) {\n            tasks[key](function (err, value) {\n                if (err && result) {\n                    result = null\n                    callback(err)\n                } else if (!err && result) {\n                    result[key] = value\n                    if (++count === keys.length) {\n                        callback(null, result)\n                    }\n                }\n            })\n        })\n    }\n}\n","var slice = Array.prototype.slice\n\n/* Given a function that takes n arguments and returns a continuable\n    return a function that takes n arguments and maybe a n+1th argument\n    which is a callback or takes n arguments and returns a continuable\n\nThis basically means that you can do this:\n\n```js\nvar readFile = maybeCallback(function (uri) {\n    return function (cb) { fs.readFile(uri, cb) }\n})\n\nreadFile(\"./foo\")(cb)\nreadFile(\"./foo\", cb)\n```\n\nBe warned this breaks if the last argument is a function\n\n*/\nmodule.exports = maybeCallback\n\n//  maybeCallback := (fn: (Any, ...) => Continuable<T>) =>\n//      (Any, ..., Callback<T>?) => Continuable<T>\nfunction maybeCallback(fn) {\n    return function maybeContinuable() {\n        var args = slice.call(arguments)\n        var callback = args[args.length - 1]\n\n        if (typeof callback === \"function\") {\n            args.pop()\n        }\n\n        var continuable = fn.apply(null, args)\n\n        if (typeof callback === \"function\") {\n            continuable(callback)\n        } else {\n            return continuable\n        }\n    }\n}\n","var maybeCallback = require(\"continuable/maybe-callback\")\n\nmodule.exports = maybeCallback(list)\n\n//  list := (tasks:Array<Continuable<T>>)\n//      => Continuable<Array<T>>\nfunction list(tasks) {\n    return function continuable(callback) {\n        var result = []\n        var count = 0\n\n        if (tasks.length === 0) {\n            return callback(null, result)\n        }\n\n        tasks.forEach(function invokeSource(source, index) {\n            source(function continuation(err, value) {\n                if (err && result) {\n                    result = null\n                    callback(err)\n                } else if (!err && result) {\n                    result[index] = value\n                    if (++count === tasks.length) {\n                        callback(null, result)\n                    }\n                }\n            })\n        })\n    }\n}\n","var list = require('continuable-list')\nvar hash = require('continuable-hash')\n\nmodule.exports = function (obj, cb) {\n  if(Array.isArray(obj))\n    return list(obj, cb)\n  else if('object' === typeof obj)\n    return hash(obj, cb)\n  else\n    return list([].slice.call(arguments))\n}\n","module.exports = function series (continuables, callback) {\n  if('function' === typeof continuables)\n    return series([].slice.call(arguments))\n\n  if (callback) {\n    next(callback)\n  } else {\n    return next\n  }\n\n  function next (callback) {\n    continuables.shift() (function (err, value) {\n      if (err || !continuables.length)\n        return callback(err, value)\n      next (callback)\n    })\n  }\n}\n","// both := (Continuable) => Continuable<[Error, Any]>\nmodule.exports = both\n\nfunction both(source) {\n    return function continuable(callback) {\n        source(function (err, value) {\n            callback(null, [err || null, value])\n        })\n    }\n}\n","module.exports = chain\n\n// chain := (Continuable<A>, lambda:(A) => Continuable<B>) => Continuable<B>\nfunction chain(source, lambda) {\n    return function continuable(callback) {\n        source(function continuation(err, value) {\n            if (err) {\n                return callback(err)\n            }\n\n            lambda(value)(callback)\n        })\n    }\n}\n","var of = require(\"./of\")\n\nmodule.exports = either\n\n//  either := (source: Continuable<A>,\n//             left: (Error, cb?: Callback<B>) => Continuable<B>,\n//             right?: (A) => Continuable<B>)\n//      => Continuable<B>\nfunction either(cont, left, right) {\n    right = right || of\n\n    return function continuable(callback) {\n        cont(function (err, value) {\n            if (!err) {\n                return right(value)(callback)\n            }\n\n            // the left function takes either a callback or\n            // it returns a continuable. Both are valid\n            var cont = left(err, callback)\n\n            if (cont) {\n                cont(callback)\n            }\n        })\n    }\n}\n","module.exports = error\n\n// error := (Error) => Continuable<void>\nfunction error(err) {\n    return function continuable(callback) {\n        callback(err)\n    }\n}\n","var maybeCallback = require(\"./maybe-callback.js\")\nmaybeCallback.both = require(\"./both.js\")\nmaybeCallback.chain = require(\"./chain.js\")\nmaybeCallback.either = require(\"./either.js\")\nmaybeCallback.error = require(\"./error.js\")\nmaybeCallback.join = require(\"./join.js\")\nmaybeCallback.mapAsync = require(\"./map-async.js\")\nmaybeCallback.map = require(\"./map.js\")\nmaybeCallback.of = require(\"./of.js\")\nmaybeCallback.to = require(\"./to.js\")\n\nmodule.exports = maybeCallback\n\n","module.exports = join\n\n// join := (Continuable<Continuable<T>>) => Continuable<T>\nfunction join(source) {\n    return function continuable(callback) {\n        source(function continuation(err, next) {\n            if (err) {\n                return callback(err)\n            }\n\n            next(callback)\n        })\n    }\n}\n","module.exports = mapAsync\n\n// mapAsync := (Continuable<A>, lambda: (A, Callback<B>)) => Continuable<B>\nfunction mapAsync(source, lambda) {\n    return function continuable(callback) {\n        source(function continuation(err, value) {\n            if (err) {\n                return callback(err)\n            }\n\n            lambda(value, callback)\n        })\n    }\n}\n","module.exports = map\n\n// map := (Continuable<A>, (A) => B) => Continuable<B>\nfunction map(source, lambda) {\n    return function continuable(callback) {\n        source(function continuation(err, value) {\n            if (err) {\n                return callback(err)\n            }\n\n            callback(null, lambda(value))\n        })\n    }\n}\n","module.exports = of\n\n// of := (Value) => Continuable<Value>\nfunction of(value) {\n    return function continuable(callback) {\n        callback(null, value)\n    }\n}\n","var slice = Array.prototype.slice\n\nmodule.exports = to\n\nfunction to(asyncFn) {\n    return function () {\n        var args = slice.call(arguments)\n        var callback = args[args.length - 1]\n        var self = this\n\n        if (typeof callback === \"function\") {\n            return asyncFn.apply(this, args)\n        }\n\n        return function continuable(callback) {\n            var _args = args.slice()\n            _args.push(callback)\n            return asyncFn.apply(self, _args)\n        }\n    }\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\n\nfunction isArray(arg) {\n  if (Array.isArray) {\n    return Array.isArray(arg);\n  }\n  return objectToString(arg) === '[object Array]';\n}\nexports.isArray = isArray;\n\nfunction isBoolean(arg) {\n  return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\n\nfunction isNull(arg) {\n  return arg === null;\n}\nexports.isNull = isNull;\n\nfunction isNullOrUndefined(arg) {\n  return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n\nfunction isNumber(arg) {\n  return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\n\nfunction isString(arg) {\n  return typeof arg === 'string';\n}\nexports.isString = isString;\n\nfunction isSymbol(arg) {\n  return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\n\nfunction isUndefined(arg) {\n  return arg === void 0;\n}\nexports.isUndefined = isUndefined;\n\nfunction isRegExp(re) {\n  return objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\n\nfunction isObject(arg) {\n  return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\n\nfunction isDate(d) {\n  return objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\n\nfunction isError(e) {\n  return (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\n\nfunction isFunction(arg) {\n  return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\n\nfunction isPrimitive(arg) {\n  return arg === null ||\n         typeof arg === 'boolean' ||\n         typeof arg === 'number' ||\n         typeof arg === 'string' ||\n         typeof arg === 'symbol' ||  // ES6 symbol\n         typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\n\nexports.isBuffer = Buffer.isBuffer;\n\nfunction objectToString(o) {\n  return Object.prototype.toString.call(o);\n}\n","var elliptic = require('elliptic');\nvar BN = require('bn.js');\n\nmodule.exports = function createECDH(curve) {\n\treturn new ECDH(curve);\n};\n\nvar aliases = {\n\tsecp256k1: {\n\t\tname: 'secp256k1',\n\t\tbyteLength: 32\n\t},\n\tsecp224r1: {\n\t\tname: 'p224',\n\t\tbyteLength: 28\n\t},\n\tprime256v1: {\n\t\tname: 'p256',\n\t\tbyteLength: 32\n\t},\n\tprime192v1: {\n\t\tname: 'p192',\n\t\tbyteLength: 24\n\t},\n\ted25519: {\n\t\tname: 'ed25519',\n\t\tbyteLength: 32\n\t},\n\tsecp384r1: {\n\t\tname: 'p384',\n\t\tbyteLength: 48\n\t},\n\tsecp521r1: {\n\t\tname: 'p521',\n\t\tbyteLength: 66\n\t}\n};\n\naliases.p224 = aliases.secp224r1;\naliases.p256 = aliases.secp256r1 = aliases.prime256v1;\naliases.p192 = aliases.secp192r1 = aliases.prime192v1;\naliases.p384 = aliases.secp384r1;\naliases.p521 = aliases.secp521r1;\n\nfunction ECDH(curve) {\n\tthis.curveType = aliases[curve];\n\tif (!this.curveType ) {\n\t\tthis.curveType = {\n\t\t\tname: curve\n\t\t};\n\t}\n\tthis.curve = new elliptic.ec(this.curveType.name);\n\tthis.keys = void 0;\n}\n\nECDH.prototype.generateKeys = function (enc, format) {\n\tthis.keys = this.curve.genKeyPair();\n\treturn this.getPublicKey(enc, format);\n};\n\nECDH.prototype.computeSecret = function (other, inenc, enc) {\n\tinenc = inenc || 'utf8';\n\tif (!Buffer.isBuffer(other)) {\n\t\tother = new Buffer(other, inenc);\n\t}\n\tvar otherPub = this.curve.keyFromPublic(other).getPublic();\n\tvar out = otherPub.mul(this.keys.getPrivate()).getX();\n\treturn formatReturnValue(out, enc, this.curveType.byteLength);\n};\n\nECDH.prototype.getPublicKey = function (enc, format) {\n\tvar key = this.keys.getPublic(format === 'compressed', true);\n\tif (format === 'hybrid') {\n\t\tif (key[key.length - 1] % 2) {\n\t\t\tkey[0] = 7;\n\t\t} else {\n\t\t\tkey [0] = 6;\n\t\t}\n\t}\n\treturn formatReturnValue(key, enc);\n};\n\nECDH.prototype.getPrivateKey = function (enc) {\n\treturn formatReturnValue(this.keys.getPrivate(), enc);\n};\n\nECDH.prototype.setPublicKey = function (pub, enc) {\n\tenc = enc || 'utf8';\n\tif (!Buffer.isBuffer(pub)) {\n\t\tpub = new Buffer(pub, enc);\n\t}\n\tthis.keys._importPublic(pub);\n\treturn this;\n};\n\nECDH.prototype.setPrivateKey = function (priv, enc) {\n\tenc = enc || 'utf8';\n\tif (!Buffer.isBuffer(priv)) {\n\t\tpriv = new Buffer(priv, enc);\n\t}\n\tvar _priv = new BN(priv);\n\t_priv = _priv.toString(16);\n\tthis.keys._importPrivate(_priv);\n\treturn this;\n};\n\nfunction formatReturnValue(bn, enc, len) {\n\tif (!Array.isArray(bn)) {\n\t\tbn = bn.toArray();\n\t}\n\tvar buf = new Buffer(bn);\n\tif (len && buf.length < len) {\n\t\tvar zeros = new Buffer(len - buf.length);\n\t\tzeros.fill(0);\n\t\tbuf = Buffer.concat([zeros, buf]);\n\t}\n\tif (!enc) {\n\t\treturn buf;\n\t} else {\n\t\treturn buf.toString(enc);\n\t}\n}\n","'use strict';\nvar inherits = require('inherits')\nvar md5 = require('./md5')\nvar rmd160 = require('ripemd160')\nvar sha = require('sha.js')\n\nvar Base = require('cipher-base')\n\nfunction HashNoConstructor(hash) {\n  Base.call(this, 'digest')\n\n  this._hash = hash\n  this.buffers = []\n}\n\ninherits(HashNoConstructor, Base)\n\nHashNoConstructor.prototype._update = function (data) {\n  this.buffers.push(data)\n}\n\nHashNoConstructor.prototype._final = function () {\n  var buf = Buffer.concat(this.buffers)\n  var r = this._hash(buf)\n  this.buffers = null\n\n  return r\n}\n\nfunction Hash(hash) {\n  Base.call(this, 'digest')\n\n  this._hash = hash\n}\n\ninherits(Hash, Base)\n\nHash.prototype._update = function (data) {\n  this._hash.update(data)\n}\n\nHash.prototype._final = function () {\n  return this._hash.digest()\n}\n\nmodule.exports = function createHash (alg) {\n  alg = alg.toLowerCase()\n  if ('md5' === alg) return new HashNoConstructor(md5)\n  if ('rmd160' === alg || 'ripemd160' === alg) return new HashNoConstructor(rmd160)\n\n  return new Hash(sha(alg))\n}\n","'use strict';\nvar intSize = 4;\nvar zeroBuffer = new Buffer(intSize); zeroBuffer.fill(0);\nvar chrsz = 8;\n\nfunction toArray(buf, bigEndian) {\n  if ((buf.length % intSize) !== 0) {\n    var len = buf.length + (intSize - (buf.length % intSize));\n    buf = Buffer.concat([buf, zeroBuffer], len);\n  }\n\n  var arr = [];\n  var fn = bigEndian ? buf.readInt32BE : buf.readInt32LE;\n  for (var i = 0; i < buf.length; i += intSize) {\n    arr.push(fn.call(buf, i));\n  }\n  return arr;\n}\n\nfunction toBuffer(arr, size, bigEndian) {\n  var buf = new Buffer(size);\n  var fn = bigEndian ? buf.writeInt32BE : buf.writeInt32LE;\n  for (var i = 0; i < arr.length; i++) {\n    fn.call(buf, arr[i], i * 4, true);\n  }\n  return buf;\n}\n\nfunction hash(buf, fn, hashSize, bigEndian) {\n  if (!Buffer.isBuffer(buf)) buf = new Buffer(buf);\n  var arr = fn(toArray(buf, bigEndian), buf.length * chrsz);\n  return toBuffer(arr, hashSize, bigEndian);\n}\nexports.hash = hash;","'use strict';\n/*\n * A JavaScript implementation of the RSA Data Security, Inc. MD5 Message\n * Digest Algorithm, as defined in RFC 1321.\n * Version 2.1 Copyright (C) Paul Johnston 1999 - 2002.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n * Distributed under the BSD License\n * See http://pajhome.org.uk/crypt/md5 for more info.\n */\n\nvar helpers = require('./helpers');\n\n/*\n * Calculate the MD5 of an array of little-endian words, and a bit length\n */\nfunction core_md5(x, len)\n{\n  /* append padding */\n  x[len >> 5] |= 0x80 << ((len) % 32);\n  x[(((len + 64) >>> 9) << 4) + 14] = len;\n\n  var a =  1732584193;\n  var b = -271733879;\n  var c = -1732584194;\n  var d =  271733878;\n\n  for(var i = 0; i < x.length; i += 16)\n  {\n    var olda = a;\n    var oldb = b;\n    var oldc = c;\n    var oldd = d;\n\n    a = md5_ff(a, b, c, d, x[i+ 0], 7 , -680876936);\n    d = md5_ff(d, a, b, c, x[i+ 1], 12, -389564586);\n    c = md5_ff(c, d, a, b, x[i+ 2], 17,  606105819);\n    b = md5_ff(b, c, d, a, x[i+ 3], 22, -1044525330);\n    a = md5_ff(a, b, c, d, x[i+ 4], 7 , -176418897);\n    d = md5_ff(d, a, b, c, x[i+ 5], 12,  1200080426);\n    c = md5_ff(c, d, a, b, x[i+ 6], 17, -1473231341);\n    b = md5_ff(b, c, d, a, x[i+ 7], 22, -45705983);\n    a = md5_ff(a, b, c, d, x[i+ 8], 7 ,  1770035416);\n    d = md5_ff(d, a, b, c, x[i+ 9], 12, -1958414417);\n    c = md5_ff(c, d, a, b, x[i+10], 17, -42063);\n    b = md5_ff(b, c, d, a, x[i+11], 22, -1990404162);\n    a = md5_ff(a, b, c, d, x[i+12], 7 ,  1804603682);\n    d = md5_ff(d, a, b, c, x[i+13], 12, -40341101);\n    c = md5_ff(c, d, a, b, x[i+14], 17, -1502002290);\n    b = md5_ff(b, c, d, a, x[i+15], 22,  1236535329);\n\n    a = md5_gg(a, b, c, d, x[i+ 1], 5 , -165796510);\n    d = md5_gg(d, a, b, c, x[i+ 6], 9 , -1069501632);\n    c = md5_gg(c, d, a, b, x[i+11], 14,  643717713);\n    b = md5_gg(b, c, d, a, x[i+ 0], 20, -373897302);\n    a = md5_gg(a, b, c, d, x[i+ 5], 5 , -701558691);\n    d = md5_gg(d, a, b, c, x[i+10], 9 ,  38016083);\n    c = md5_gg(c, d, a, b, x[i+15], 14, -660478335);\n    b = md5_gg(b, c, d, a, x[i+ 4], 20, -405537848);\n    a = md5_gg(a, b, c, d, x[i+ 9], 5 ,  568446438);\n    d = md5_gg(d, a, b, c, x[i+14], 9 , -1019803690);\n    c = md5_gg(c, d, a, b, x[i+ 3], 14, -187363961);\n    b = md5_gg(b, c, d, a, x[i+ 8], 20,  1163531501);\n    a = md5_gg(a, b, c, d, x[i+13], 5 , -1444681467);\n    d = md5_gg(d, a, b, c, x[i+ 2], 9 , -51403784);\n    c = md5_gg(c, d, a, b, x[i+ 7], 14,  1735328473);\n    b = md5_gg(b, c, d, a, x[i+12], 20, -1926607734);\n\n    a = md5_hh(a, b, c, d, x[i+ 5], 4 , -378558);\n    d = md5_hh(d, a, b, c, x[i+ 8], 11, -2022574463);\n    c = md5_hh(c, d, a, b, x[i+11], 16,  1839030562);\n    b = md5_hh(b, c, d, a, x[i+14], 23, -35309556);\n    a = md5_hh(a, b, c, d, x[i+ 1], 4 , -1530992060);\n    d = md5_hh(d, a, b, c, x[i+ 4], 11,  1272893353);\n    c = md5_hh(c, d, a, b, x[i+ 7], 16, -155497632);\n    b = md5_hh(b, c, d, a, x[i+10], 23, -1094730640);\n    a = md5_hh(a, b, c, d, x[i+13], 4 ,  681279174);\n    d = md5_hh(d, a, b, c, x[i+ 0], 11, -358537222);\n    c = md5_hh(c, d, a, b, x[i+ 3], 16, -722521979);\n    b = md5_hh(b, c, d, a, x[i+ 6], 23,  76029189);\n    a = md5_hh(a, b, c, d, x[i+ 9], 4 , -640364487);\n    d = md5_hh(d, a, b, c, x[i+12], 11, -421815835);\n    c = md5_hh(c, d, a, b, x[i+15], 16,  530742520);\n    b = md5_hh(b, c, d, a, x[i+ 2], 23, -995338651);\n\n    a = md5_ii(a, b, c, d, x[i+ 0], 6 , -198630844);\n    d = md5_ii(d, a, b, c, x[i+ 7], 10,  1126891415);\n    c = md5_ii(c, d, a, b, x[i+14], 15, -1416354905);\n    b = md5_ii(b, c, d, a, x[i+ 5], 21, -57434055);\n    a = md5_ii(a, b, c, d, x[i+12], 6 ,  1700485571);\n    d = md5_ii(d, a, b, c, x[i+ 3], 10, -1894986606);\n    c = md5_ii(c, d, a, b, x[i+10], 15, -1051523);\n    b = md5_ii(b, c, d, a, x[i+ 1], 21, -2054922799);\n    a = md5_ii(a, b, c, d, x[i+ 8], 6 ,  1873313359);\n    d = md5_ii(d, a, b, c, x[i+15], 10, -30611744);\n    c = md5_ii(c, d, a, b, x[i+ 6], 15, -1560198380);\n    b = md5_ii(b, c, d, a, x[i+13], 21,  1309151649);\n    a = md5_ii(a, b, c, d, x[i+ 4], 6 , -145523070);\n    d = md5_ii(d, a, b, c, x[i+11], 10, -1120210379);\n    c = md5_ii(c, d, a, b, x[i+ 2], 15,  718787259);\n    b = md5_ii(b, c, d, a, x[i+ 9], 21, -343485551);\n\n    a = safe_add(a, olda);\n    b = safe_add(b, oldb);\n    c = safe_add(c, oldc);\n    d = safe_add(d, oldd);\n  }\n  return Array(a, b, c, d);\n\n}\n\n/*\n * These functions implement the four basic operations the algorithm uses.\n */\nfunction md5_cmn(q, a, b, x, s, t)\n{\n  return safe_add(bit_rol(safe_add(safe_add(a, q), safe_add(x, t)), s),b);\n}\nfunction md5_ff(a, b, c, d, x, s, t)\n{\n  return md5_cmn((b & c) | ((~b) & d), a, b, x, s, t);\n}\nfunction md5_gg(a, b, c, d, x, s, t)\n{\n  return md5_cmn((b & d) | (c & (~d)), a, b, x, s, t);\n}\nfunction md5_hh(a, b, c, d, x, s, t)\n{\n  return md5_cmn(b ^ c ^ d, a, b, x, s, t);\n}\nfunction md5_ii(a, b, c, d, x, s, t)\n{\n  return md5_cmn(c ^ (b | (~d)), a, b, x, s, t);\n}\n\n/*\n * Add integers, wrapping at 2^32. This uses 16-bit operations internally\n * to work around bugs in some JS interpreters.\n */\nfunction safe_add(x, y)\n{\n  var lsw = (x & 0xFFFF) + (y & 0xFFFF);\n  var msw = (x >> 16) + (y >> 16) + (lsw >> 16);\n  return (msw << 16) | (lsw & 0xFFFF);\n}\n\n/*\n * Bitwise rotate a 32-bit number to the left.\n */\nfunction bit_rol(num, cnt)\n{\n  return (num << cnt) | (num >>> (32 - cnt));\n}\n\nmodule.exports = function md5(buf) {\n  return helpers.hash(buf, core_md5, 16);\n};","'use strict';\nvar createHash = require('create-hash/browser');\nvar inherits = require('inherits')\n\nvar Transform = require('stream').Transform\n\nvar ZEROS = new Buffer(128)\nZEROS.fill(0)\n\nfunction Hmac(alg, key) {\n  Transform.call(this)\n  alg = alg.toLowerCase()\n  if (typeof key === 'string') {\n    key = new Buffer(key)\n  }\n\n  var blocksize = (alg === 'sha512' || alg === 'sha384') ? 128 : 64\n\n  this._alg = alg\n  this._key = key\n\n  if (key.length > blocksize) {\n    key = createHash(alg).update(key).digest()\n\n  } else if (key.length < blocksize) {\n    key = Buffer.concat([key, ZEROS], blocksize)\n  }\n\n  var ipad = this._ipad = new Buffer(blocksize)\n  var opad = this._opad = new Buffer(blocksize)\n\n  for (var i = 0; i < blocksize; i++) {\n    ipad[i] = key[i] ^ 0x36\n    opad[i] = key[i] ^ 0x5C\n  }\n\n  this._hash = createHash(alg).update(ipad)\n}\n\ninherits(Hmac, Transform)\n\nHmac.prototype.update = function (data, enc) {\n  this._hash.update(data, enc)\n\n  return this\n}\n\nHmac.prototype._transform = function (data, _, next) {\n  this._hash.update(data)\n\n  next()\n}\n\nHmac.prototype._flush = function (next) {\n  this.push(this.digest())\n\n  next()\n}\n\nHmac.prototype.digest = function (enc) {\n  var h = this._hash.digest()\n\n  return createHash(this._alg).update(this._opad).update(h).digest(enc)\n}\n\nmodule.exports = function createHmac(alg, key) {\n  return new Hmac(alg, key)\n}\n","'use strict'\n\nexports.randomBytes = exports.rng = exports.pseudoRandomBytes = exports.prng = require('randombytes')\nexports.createHash = exports.Hash = require('create-hash')\nexports.createHmac = exports.Hmac = require('create-hmac')\n\nvar hashes = ['sha1', 'sha224', 'sha256', 'sha384', 'sha512', 'md5', 'rmd160'].concat(Object.keys(require('browserify-sign/algos')))\nexports.getHashes = function () {\n  return hashes\n}\n\nvar p = require('pbkdf2')\nexports.pbkdf2 = p.pbkdf2\nexports.pbkdf2Sync = p.pbkdf2Sync\n\nvar aes = require('browserify-cipher')\n;[\n  'Cipher',\n  'createCipher',\n  'Cipheriv',\n  'createCipheriv',\n  'Decipher',\n  'createDecipher',\n  'Decipheriv',\n  'createDecipheriv',\n  'getCiphers',\n  'listCiphers'\n].forEach(function (key) {\n  exports[key] = aes[key]\n})\n\nvar dh = require('diffie-hellman')\n;[\n  'DiffieHellmanGroup',\n  'createDiffieHellmanGroup',\n  'getDiffieHellman',\n  'createDiffieHellman',\n  'DiffieHellman'\n].forEach(function (key) {\n  exports[key] = dh[key]\n})\n\nvar sign = require('browserify-sign')\n;[\n  'createSign',\n  'Sign',\n  'createVerify',\n  'Verify'\n].forEach(function (key) {\n  exports[key] = sign[key]\n})\n\nexports.createECDH = require('create-ecdh')\n\nvar publicEncrypt = require('public-encrypt')\n\n;[\n  'publicEncrypt',\n  'privateEncrypt',\n  'publicDecrypt',\n  'privateDecrypt'\n].forEach(function (key) {\n  exports[key] = publicEncrypt[key]\n})\n\n// the least I can do is make error messages for the rest of the node.js/crypto api.\n;[\n  'createCredentials'\n].forEach(function (name) {\n  exports[name] = function () {\n    throw new Error([\n      'sorry, ' + name + ' is not implemented yet',\n      'we accept pull requests',\n      'https://github.com/crypto-browserify/crypto-browserify'\n    ].join('\\n'))\n  }\n})\n","/*!\n * @description Recursive object extending\n * @author Viacheslav Lotsmanov <lotsmanov89@gmail.com>\n * @license MIT\n *\n * The MIT License (MIT)\n *\n * Copyright (c) 2013-2015 Viacheslav Lotsmanov\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy of\n * this software and associated documentation files (the \"Software\"), to deal in\n * the Software without restriction, including without limitation the rights to\n * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of\n * the Software, and to permit persons to whom the Software is furnished to do so,\n * subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in all\n * copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS\n * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR\n * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER\n * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN\n * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n */\n\n'use strict';\n\nfunction isSpecificValue(val) {\n\treturn (\n\t\tval instanceof Buffer\n\t\t|| val instanceof Date\n\t\t|| val instanceof RegExp\n\t) ? true : false;\n}\n\nfunction cloneSpecificValue(val) {\n\tif (val instanceof Buffer) {\n\t\tvar x = new Buffer(val.length);\n\t\tval.copy(x);\n\t\treturn x;\n\t} else if (val instanceof Date) {\n\t\treturn new Date(val.getTime());\n\t} else if (val instanceof RegExp) {\n\t\treturn new RegExp(val);\n\t} else {\n\t\tthrow new Error('Unexpected situation');\n\t}\n}\n\n/**\n * Recursive cloning array.\n */\nfunction deepCloneArray(arr) {\n\tvar clone = [];\n\tarr.forEach(function (item, index) {\n\t\tif (typeof item === 'object' && item !== null) {\n\t\t\tif (Array.isArray(item)) {\n\t\t\t\tclone[index] = deepCloneArray(item);\n\t\t\t} else if (isSpecificValue(item)) {\n\t\t\t\tclone[index] = cloneSpecificValue(item);\n\t\t\t} else {\n\t\t\t\tclone[index] = deepExtend({}, item);\n\t\t\t}\n\t\t} else {\n\t\t\tclone[index] = item;\n\t\t}\n\t});\n\treturn clone;\n}\n\n/**\n * Extening object that entered in first argument.\n *\n * Returns extended object or false if have no target object or incorrect type.\n *\n * If you wish to clone source object (without modify it), just use empty new\n * object as first argument, like this:\n *   deepExtend({}, yourObj_1, [yourObj_N]);\n */\nvar deepExtend = module.exports = function (/*obj_1, [obj_2], [obj_N]*/) {\n\tif (arguments.length < 1 || typeof arguments[0] !== 'object') {\n\t\treturn false;\n\t}\n\n\tif (arguments.length < 2) {\n\t\treturn arguments[0];\n\t}\n\n\tvar target = arguments[0];\n\n\t// convert arguments to array and cut off target object\n\tvar args = Array.prototype.slice.call(arguments, 1);\n\n\tvar val, src, clone;\n\n\targs.forEach(function (obj) {\n\t\t// skip argument if it is array or isn't object\n\t\tif (typeof obj !== 'object' || Array.isArray(obj)) {\n\t\t\treturn;\n\t\t}\n\n\t\tObject.keys(obj).forEach(function (key) {\n\t\t\tsrc = target[key]; // source value\n\t\t\tval = obj[key]; // new value\n\n\t\t\t// recursion prevention\n\t\t\tif (val === target) {\n\t\t\t\treturn;\n\n\t\t\t/**\n\t\t\t * if new value isn't object then just overwrite by new value\n\t\t\t * instead of extending.\n\t\t\t */\n\t\t\t} else if (typeof val !== 'object' || val === null) {\n\t\t\t\ttarget[key] = val;\n\t\t\t\treturn;\n\n\t\t\t// just clone arrays (and recursive clone objects inside)\n\t\t\t} else if (Array.isArray(val)) {\n\t\t\t\ttarget[key] = deepCloneArray(val);\n\t\t\t\treturn;\n\n\t\t\t// custom cloning and overwrite for specific objects\n\t\t\t} else if (isSpecificValue(val)) {\n\t\t\t\ttarget[key] = cloneSpecificValue(val);\n\t\t\t\treturn;\n\n\t\t\t// overwrite by new value if source isn't object or array\n\t\t\t} else if (typeof src !== 'object' || src === null || Array.isArray(src)) {\n\t\t\t\ttarget[key] = deepExtend({}, val);\n\t\t\t\treturn;\n\n\t\t\t// source value and new value is objects both, extending...\n\t\t\t} else {\n\t\t\t\ttarget[key] = deepExtend(src, val);\n\t\t\t\treturn;\n\t\t\t}\n\t\t});\n\t});\n\n\treturn target;\n}\n","module.exports = function () {\n    for (var i = 0; i < arguments.length; i++) {\n        if (arguments[i] !== undefined) return arguments[i];\n    }\n};\n","'use strict';\n\nexports.utils = require('./des/utils');\nexports.Cipher = require('./des/cipher');\nexports.DES = require('./des/des');\nexports.CBC = require('./des/cbc');\nexports.EDE = require('./des/ede');\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nvar proto = {};\n\nfunction CBCState(iv) {\n  assert.equal(iv.length, 8, 'Invalid IV length');\n\n  this.iv = new Array(8);\n  for (var i = 0; i < this.iv.length; i++)\n    this.iv[i] = iv[i];\n}\n\nfunction instantiate(Base) {\n  function CBC(options) {\n    Base.call(this, options);\n    this._cbcInit();\n  }\n  inherits(CBC, Base);\n\n  var keys = Object.keys(proto);\n  for (var i = 0; i < keys.length; i++) {\n    var key = keys[i];\n    CBC.prototype[key] = proto[key];\n  }\n\n  CBC.create = function create(options) {\n    return new CBC(options);\n  };\n\n  return CBC;\n}\n\nexports.instantiate = instantiate;\n\nproto._cbcInit = function _cbcInit() {\n  var state = new CBCState(this.options.iv);\n  this._cbcState = state;\n};\n\nproto._update = function _update(inp, inOff, out, outOff) {\n  var state = this._cbcState;\n  var superProto = this.constructor.super_.prototype;\n\n  var iv = state.iv;\n  if (this.type === 'encrypt') {\n    for (var i = 0; i < this.blockSize; i++)\n      iv[i] ^= inp[inOff + i];\n\n    superProto._update.call(this, iv, 0, out, outOff);\n\n    for (var i = 0; i < this.blockSize; i++)\n      iv[i] = out[outOff + i];\n  } else {\n    superProto._update.call(this, inp, inOff, out, outOff);\n\n    for (var i = 0; i < this.blockSize; i++)\n      out[outOff + i] ^= iv[i];\n\n    for (var i = 0; i < this.blockSize; i++)\n      iv[i] = inp[inOff + i];\n  }\n};\n","'use strict';\n\nvar assert = require('minimalistic-assert');\n\nfunction Cipher(options) {\n  this.options = options;\n\n  this.type = this.options.type;\n  this.blockSize = 8;\n  this._init();\n\n  this.buffer = new Array(this.blockSize);\n  this.bufferOff = 0;\n}\nmodule.exports = Cipher;\n\nCipher.prototype._init = function _init() {\n  // Might be overrided\n};\n\nCipher.prototype.update = function update(data) {\n  if (data.length === 0)\n    return [];\n\n  if (this.type === 'decrypt')\n    return this._updateDecrypt(data);\n  else\n    return this._updateEncrypt(data);\n};\n\nCipher.prototype._buffer = function _buffer(data, off) {\n  // Append data to buffer\n  var min = Math.min(this.buffer.length - this.bufferOff, data.length - off);\n  for (var i = 0; i < min; i++)\n    this.buffer[this.bufferOff + i] = data[off + i];\n  this.bufferOff += min;\n\n  // Shift next\n  return min;\n};\n\nCipher.prototype._flushBuffer = function _flushBuffer(out, off) {\n  this._update(this.buffer, 0, out, off);\n  this.bufferOff = 0;\n  return this.blockSize;\n};\n\nCipher.prototype._updateEncrypt = function _updateEncrypt(data) {\n  var inputOff = 0;\n  var outputOff = 0;\n\n  var count = ((this.bufferOff + data.length) / this.blockSize) | 0;\n  var out = new Array(count * this.blockSize);\n\n  if (this.bufferOff !== 0) {\n    inputOff += this._buffer(data, inputOff);\n\n    if (this.bufferOff === this.buffer.length)\n      outputOff += this._flushBuffer(out, outputOff);\n  }\n\n  // Write blocks\n  var max = data.length - ((data.length - inputOff) % this.blockSize);\n  for (; inputOff < max; inputOff += this.blockSize) {\n    this._update(data, inputOff, out, outputOff);\n    outputOff += this.blockSize;\n  }\n\n  // Queue rest\n  for (; inputOff < data.length; inputOff++, this.bufferOff++)\n    this.buffer[this.bufferOff] = data[inputOff];\n\n  return out;\n};\n\nCipher.prototype._updateDecrypt = function _updateDecrypt(data) {\n  var inputOff = 0;\n  var outputOff = 0;\n\n  var count = Math.ceil((this.bufferOff + data.length) / this.blockSize) - 1;\n  var out = new Array(count * this.blockSize);\n\n  // TODO(indutny): optimize it, this is far from optimal\n  for (; count > 0; count--) {\n    inputOff += this._buffer(data, inputOff);\n    outputOff += this._flushBuffer(out, outputOff);\n  }\n\n  // Buffer rest of the input\n  inputOff += this._buffer(data, inputOff);\n\n  return out;\n};\n\nCipher.prototype.final = function final(buffer) {\n  var first;\n  if (buffer)\n    first = this.update(buffer);\n\n  var last;\n  if (this.type === 'encrypt')\n    last = this._finalEncrypt();\n  else\n    last = this._finalDecrypt();\n\n  if (first)\n    return first.concat(last);\n  else\n    return last;\n};\n\nCipher.prototype._pad = function _pad(buffer, off) {\n  if (off === 0)\n    return false;\n\n  while (off < buffer.length)\n    buffer[off++] = 0;\n\n  return true;\n};\n\nCipher.prototype._finalEncrypt = function _finalEncrypt() {\n  if (!this._pad(this.buffer, this.bufferOff))\n    return [];\n\n  var out = new Array(this.blockSize);\n  this._update(this.buffer, 0, out, 0);\n  return out;\n};\n\nCipher.prototype._unpad = function _unpad(buffer) {\n  return buffer;\n};\n\nCipher.prototype._finalDecrypt = function _finalDecrypt() {\n  assert.equal(this.bufferOff, this.blockSize, 'Not enough data to decrypt');\n  var out = new Array(this.blockSize);\n  this._flushBuffer(out, 0);\n\n  return this._unpad(out);\n};\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nvar des = require('../des');\nvar utils = des.utils;\nvar Cipher = des.Cipher;\n\nfunction DESState() {\n  this.tmp = new Array(2);\n  this.keys = null;\n}\n\nfunction DES(options) {\n  Cipher.call(this, options);\n\n  var state = new DESState();\n  this._desState = state;\n\n  this.deriveKeys(state, options.key);\n}\ninherits(DES, Cipher);\nmodule.exports = DES;\n\nDES.create = function create(options) {\n  return new DES(options);\n};\n\nvar shiftTable = [\n  1, 1, 2, 2, 2, 2, 2, 2,\n  1, 2, 2, 2, 2, 2, 2, 1\n];\n\nDES.prototype.deriveKeys = function deriveKeys(state, key) {\n  state.keys = new Array(16 * 2);\n\n  assert.equal(key.length, this.blockSize, 'Invalid key length');\n\n  var kL = utils.readUInt32BE(key, 0);\n  var kR = utils.readUInt32BE(key, 4);\n\n  utils.pc1(kL, kR, state.tmp, 0);\n  kL = state.tmp[0];\n  kR = state.tmp[1];\n  for (var i = 0; i < state.keys.length; i += 2) {\n    var shift = shiftTable[i >>> 1];\n    kL = utils.r28shl(kL, shift);\n    kR = utils.r28shl(kR, shift);\n    utils.pc2(kL, kR, state.keys, i);\n  }\n};\n\nDES.prototype._update = function _update(inp, inOff, out, outOff) {\n  var state = this._desState;\n\n  var l = utils.readUInt32BE(inp, inOff);\n  var r = utils.readUInt32BE(inp, inOff + 4);\n\n  // Initial Permutation\n  utils.ip(l, r, state.tmp, 0);\n  l = state.tmp[0];\n  r = state.tmp[1];\n\n  if (this.type === 'encrypt')\n    this._encrypt(state, l, r, state.tmp, 0);\n  else\n    this._decrypt(state, l, r, state.tmp, 0);\n\n  l = state.tmp[0];\n  r = state.tmp[1];\n\n  utils.writeUInt32BE(out, l, outOff);\n  utils.writeUInt32BE(out, r, outOff + 4);\n};\n\nDES.prototype._pad = function _pad(buffer, off) {\n  var value = buffer.length - off;\n  for (var i = off; i < buffer.length; i++)\n    buffer[i] = value;\n\n  return true;\n};\n\nDES.prototype._unpad = function _unpad(buffer) {\n  var pad = buffer[buffer.length - 1];\n  for (var i = buffer.length - pad; i < buffer.length; i++)\n    assert.equal(buffer[i], pad);\n\n  return buffer.slice(0, buffer.length - pad);\n};\n\nDES.prototype._encrypt = function _encrypt(state, lStart, rStart, out, off) {\n  var l = lStart;\n  var r = rStart;\n\n  // Apply f() x16 times\n  for (var i = 0; i < state.keys.length; i += 2) {\n    var keyL = state.keys[i];\n    var keyR = state.keys[i + 1];\n\n    // f(r, k)\n    utils.expand(r, state.tmp, 0);\n\n    keyL ^= state.tmp[0];\n    keyR ^= state.tmp[1];\n    var s = utils.substitute(keyL, keyR);\n    var f = utils.permute(s);\n\n    var t = r;\n    r = (l ^ f) >>> 0;\n    l = t;\n  }\n\n  // Reverse Initial Permutation\n  utils.rip(r, l, out, off);\n};\n\nDES.prototype._decrypt = function _decrypt(state, lStart, rStart, out, off) {\n  var l = rStart;\n  var r = lStart;\n\n  // Apply f() x16 times\n  for (var i = state.keys.length - 2; i >= 0; i -= 2) {\n    var keyL = state.keys[i];\n    var keyR = state.keys[i + 1];\n\n    // f(r, k)\n    utils.expand(l, state.tmp, 0);\n\n    keyL ^= state.tmp[0];\n    keyR ^= state.tmp[1];\n    var s = utils.substitute(keyL, keyR);\n    var f = utils.permute(s);\n\n    var t = l;\n    l = (r ^ f) >>> 0;\n    r = t;\n  }\n\n  // Reverse Initial Permutation\n  utils.rip(l, r, out, off);\n};\n","'use strict';\n\nvar assert = require('minimalistic-assert');\nvar inherits = require('inherits');\n\nvar des = require('../des');\nvar Cipher = des.Cipher;\nvar DES = des.DES;\n\nfunction EDEState(type, key) {\n  assert.equal(key.length, 24, 'Invalid key length');\n\n  var k1 = key.slice(0, 8);\n  var k2 = key.slice(8, 16);\n  var k3 = key.slice(16, 24);\n\n  if (type === 'encrypt') {\n    this.ciphers = [\n      DES.create({ type: 'encrypt', key: k1 }),\n      DES.create({ type: 'decrypt', key: k2 }),\n      DES.create({ type: 'encrypt', key: k3 })\n    ];\n  } else {\n    this.ciphers = [\n      DES.create({ type: 'decrypt', key: k3 }),\n      DES.create({ type: 'encrypt', key: k2 }),\n      DES.create({ type: 'decrypt', key: k1 })\n    ];\n  }\n}\n\nfunction EDE(options) {\n  Cipher.call(this, options);\n\n  var state = new EDEState(this.type, this.options.key);\n  this._edeState = state;\n}\ninherits(EDE, Cipher);\n\nmodule.exports = EDE;\n\nEDE.create = function create(options) {\n  return new EDE(options);\n};\n\nEDE.prototype._update = function _update(inp, inOff, out, outOff) {\n  var state = this._edeState;\n\n  state.ciphers[0]._update(inp, inOff, out, outOff);\n  state.ciphers[1]._update(out, outOff, out, outOff);\n  state.ciphers[2]._update(out, outOff, out, outOff);\n};\n\nEDE.prototype._pad = DES.prototype._pad;\nEDE.prototype._unpad = DES.prototype._unpad;\n","'use strict';\n\nexports.readUInt32BE = function readUInt32BE(bytes, off) {\n  var res =  (bytes[0 + off] << 24) |\n             (bytes[1 + off] << 16) |\n             (bytes[2 + off] << 8) |\n             bytes[3 + off];\n  return res >>> 0;\n};\n\nexports.writeUInt32BE = function writeUInt32BE(bytes, value, off) {\n  bytes[0 + off] = value >>> 24;\n  bytes[1 + off] = (value >>> 16) & 0xff;\n  bytes[2 + off] = (value >>> 8) & 0xff;\n  bytes[3 + off] = value & 0xff;\n};\n\nexports.ip = function ip(inL, inR, out, off) {\n  var outL = 0;\n  var outR = 0;\n\n  for (var i = 6; i >= 0; i -= 2) {\n    for (var j = 0; j <= 24; j += 8) {\n      outL <<= 1;\n      outL |= (inR >>> (j + i)) & 1;\n    }\n    for (var j = 0; j <= 24; j += 8) {\n      outL <<= 1;\n      outL |= (inL >>> (j + i)) & 1;\n    }\n  }\n\n  for (var i = 6; i >= 0; i -= 2) {\n    for (var j = 1; j <= 25; j += 8) {\n      outR <<= 1;\n      outR |= (inR >>> (j + i)) & 1;\n    }\n    for (var j = 1; j <= 25; j += 8) {\n      outR <<= 1;\n      outR |= (inL >>> (j + i)) & 1;\n    }\n  }\n\n  out[off + 0] = outL >>> 0;\n  out[off + 1] = outR >>> 0;\n};\n\nexports.rip = function rip(inL, inR, out, off) {\n  var outL = 0;\n  var outR = 0;\n\n  for (var i = 0; i < 4; i++) {\n    for (var j = 24; j >= 0; j -= 8) {\n      outL <<= 1;\n      outL |= (inR >>> (j + i)) & 1;\n      outL <<= 1;\n      outL |= (inL >>> (j + i)) & 1;\n    }\n  }\n  for (var i = 4; i < 8; i++) {\n    for (var j = 24; j >= 0; j -= 8) {\n      outR <<= 1;\n      outR |= (inR >>> (j + i)) & 1;\n      outR <<= 1;\n      outR |= (inL >>> (j + i)) & 1;\n    }\n  }\n\n  out[off + 0] = outL >>> 0;\n  out[off + 1] = outR >>> 0;\n};\n\nexports.pc1 = function pc1(inL, inR, out, off) {\n  var outL = 0;\n  var outR = 0;\n\n  // 7, 15, 23, 31, 39, 47, 55, 63\n  // 6, 14, 22, 30, 39, 47, 55, 63\n  // 5, 13, 21, 29, 39, 47, 55, 63\n  // 4, 12, 20, 28\n  for (var i = 7; i >= 5; i--) {\n    for (var j = 0; j <= 24; j += 8) {\n      outL <<= 1;\n      outL |= (inR >> (j + i)) & 1;\n    }\n    for (var j = 0; j <= 24; j += 8) {\n      outL <<= 1;\n      outL |= (inL >> (j + i)) & 1;\n    }\n  }\n  for (var j = 0; j <= 24; j += 8) {\n    outL <<= 1;\n    outL |= (inR >> (j + i)) & 1;\n  }\n\n  // 1, 9, 17, 25, 33, 41, 49, 57\n  // 2, 10, 18, 26, 34, 42, 50, 58\n  // 3, 11, 19, 27, 35, 43, 51, 59\n  // 36, 44, 52, 60\n  for (var i = 1; i <= 3; i++) {\n    for (var j = 0; j <= 24; j += 8) {\n      outR <<= 1;\n      outR |= (inR >> (j + i)) & 1;\n    }\n    for (var j = 0; j <= 24; j += 8) {\n      outR <<= 1;\n      outR |= (inL >> (j + i)) & 1;\n    }\n  }\n  for (var j = 0; j <= 24; j += 8) {\n    outR <<= 1;\n    outR |= (inL >> (j + i)) & 1;\n  }\n\n  out[off + 0] = outL >>> 0;\n  out[off + 1] = outR >>> 0;\n};\n\nexports.r28shl = function r28shl(num, shift) {\n  return ((num << shift) & 0xfffffff) | (num >>> (28 - shift));\n};\n\nvar pc2table = [\n  // inL => outL\n  14, 11, 17, 4, 27, 23, 25, 0,\n  13, 22, 7, 18, 5, 9, 16, 24,\n  2, 20, 12, 21, 1, 8, 15, 26,\n\n  // inR => outR\n  15, 4, 25, 19, 9, 1, 26, 16,\n  5, 11, 23, 8, 12, 7, 17, 0,\n  22, 3, 10, 14, 6, 20, 27, 24\n];\n\nexports.pc2 = function pc2(inL, inR, out, off) {\n  var outL = 0;\n  var outR = 0;\n\n  var len = pc2table.length >>> 1;\n  for (var i = 0; i < len; i++) {\n    outL <<= 1;\n    outL |= (inL >>> pc2table[i]) & 0x1;\n  }\n  for (var i = len; i < pc2table.length; i++) {\n    outR <<= 1;\n    outR |= (inR >>> pc2table[i]) & 0x1;\n  }\n\n  out[off + 0] = outL >>> 0;\n  out[off + 1] = outR >>> 0;\n};\n\nexports.expand = function expand(r, out, off) {\n  var outL = 0;\n  var outR = 0;\n\n  outL = ((r & 1) << 5) | (r >>> 27);\n  for (var i = 23; i >= 15; i -= 4) {\n    outL <<= 6;\n    outL |= (r >>> i) & 0x3f;\n  }\n  for (var i = 11; i >= 3; i -= 4) {\n    outR |= (r >>> i) & 0x3f;\n    outR <<= 6;\n  }\n  outR |= ((r & 0x1f) << 1) | (r >>> 31);\n\n  out[off + 0] = outL >>> 0;\n  out[off + 1] = outR >>> 0;\n};\n\nvar sTable = [\n  14, 0, 4, 15, 13, 7, 1, 4, 2, 14, 15, 2, 11, 13, 8, 1,\n  3, 10, 10, 6, 6, 12, 12, 11, 5, 9, 9, 5, 0, 3, 7, 8,\n  4, 15, 1, 12, 14, 8, 8, 2, 13, 4, 6, 9, 2, 1, 11, 7,\n  15, 5, 12, 11, 9, 3, 7, 14, 3, 10, 10, 0, 5, 6, 0, 13,\n\n  15, 3, 1, 13, 8, 4, 14, 7, 6, 15, 11, 2, 3, 8, 4, 14,\n  9, 12, 7, 0, 2, 1, 13, 10, 12, 6, 0, 9, 5, 11, 10, 5,\n  0, 13, 14, 8, 7, 10, 11, 1, 10, 3, 4, 15, 13, 4, 1, 2,\n  5, 11, 8, 6, 12, 7, 6, 12, 9, 0, 3, 5, 2, 14, 15, 9,\n\n  10, 13, 0, 7, 9, 0, 14, 9, 6, 3, 3, 4, 15, 6, 5, 10,\n  1, 2, 13, 8, 12, 5, 7, 14, 11, 12, 4, 11, 2, 15, 8, 1,\n  13, 1, 6, 10, 4, 13, 9, 0, 8, 6, 15, 9, 3, 8, 0, 7,\n  11, 4, 1, 15, 2, 14, 12, 3, 5, 11, 10, 5, 14, 2, 7, 12,\n\n  7, 13, 13, 8, 14, 11, 3, 5, 0, 6, 6, 15, 9, 0, 10, 3,\n  1, 4, 2, 7, 8, 2, 5, 12, 11, 1, 12, 10, 4, 14, 15, 9,\n  10, 3, 6, 15, 9, 0, 0, 6, 12, 10, 11, 1, 7, 13, 13, 8,\n  15, 9, 1, 4, 3, 5, 14, 11, 5, 12, 2, 7, 8, 2, 4, 14,\n\n  2, 14, 12, 11, 4, 2, 1, 12, 7, 4, 10, 7, 11, 13, 6, 1,\n  8, 5, 5, 0, 3, 15, 15, 10, 13, 3, 0, 9, 14, 8, 9, 6,\n  4, 11, 2, 8, 1, 12, 11, 7, 10, 1, 13, 14, 7, 2, 8, 13,\n  15, 6, 9, 15, 12, 0, 5, 9, 6, 10, 3, 4, 0, 5, 14, 3,\n\n  12, 10, 1, 15, 10, 4, 15, 2, 9, 7, 2, 12, 6, 9, 8, 5,\n  0, 6, 13, 1, 3, 13, 4, 14, 14, 0, 7, 11, 5, 3, 11, 8,\n  9, 4, 14, 3, 15, 2, 5, 12, 2, 9, 8, 5, 12, 15, 3, 10,\n  7, 11, 0, 14, 4, 1, 10, 7, 1, 6, 13, 0, 11, 8, 6, 13,\n\n  4, 13, 11, 0, 2, 11, 14, 7, 15, 4, 0, 9, 8, 1, 13, 10,\n  3, 14, 12, 3, 9, 5, 7, 12, 5, 2, 10, 15, 6, 8, 1, 6,\n  1, 6, 4, 11, 11, 13, 13, 8, 12, 1, 3, 4, 7, 10, 14, 7,\n  10, 9, 15, 5, 6, 0, 8, 15, 0, 14, 5, 2, 9, 3, 2, 12,\n\n  13, 1, 2, 15, 8, 13, 4, 8, 6, 10, 15, 3, 11, 7, 1, 4,\n  10, 12, 9, 5, 3, 6, 14, 11, 5, 0, 0, 14, 12, 9, 7, 2,\n  7, 2, 11, 1, 4, 14, 1, 7, 9, 4, 12, 10, 14, 8, 2, 13,\n  0, 15, 6, 12, 10, 9, 13, 0, 15, 3, 3, 5, 5, 6, 8, 11\n];\n\nexports.substitute = function substitute(inL, inR) {\n  var out = 0;\n  for (var i = 0; i < 4; i++) {\n    var b = (inL >>> (18 - i * 6)) & 0x3f;\n    var sb = sTable[i * 0x40 + b];\n\n    out <<= 4;\n    out |= sb;\n  }\n  for (var i = 0; i < 4; i++) {\n    var b = (inR >>> (18 - i * 6)) & 0x3f;\n    var sb = sTable[4 * 0x40 + i * 0x40 + b];\n\n    out <<= 4;\n    out |= sb;\n  }\n  return out >>> 0;\n};\n\nvar permuteTable = [\n  16, 25, 12, 11, 3, 20, 4, 15, 31, 17, 9, 6, 27, 14, 1, 22,\n  30, 24, 8, 18, 0, 5, 29, 23, 13, 19, 2, 26, 10, 21, 28, 7\n];\n\nexports.permute = function permute(num) {\n  var out = 0;\n  for (var i = 0; i < permuteTable.length; i++) {\n    out <<= 1;\n    out |= (num >>> permuteTable[i]) & 0x1;\n  }\n  return out >>> 0;\n};\n\nexports.padSplit = function padSplit(num, size, group) {\n  var str = num.toString(2);\n  while (str.length < size)\n    str = '0' + str;\n\n  var out = [];\n  for (var i = 0; i < size; i += group)\n    out.push(str.slice(i, i + group));\n  return out.join(' ');\n};\n","'use strict';\n\n/*\n * Dependencies.\n */\n\nvar repeat = require('repeat-string');\n\n/*\n * Constants.\n */\n\nvar TAB = '\\t';\nvar NEWLINE = '\\n';\nvar SPACE = ' ';\n\n/**\n * Replace tabs with spaces, being smart about which\n * column the tab is at and which size should be used.\n *\n * @example\n *   detab('\\tfoo\\nbar\\tbaz'); // '    foo\\nbar baz'\n *   detab('\\tfoo\\nbar\\tbaz', 2); // '  foo\\nbar baz'\n *   detab('\\tfoo\\nbar\\tbaz', 8); // '        foo\\nbar     baz'\n *\n * @param {string} value - Value with tabs.\n * @param {number?} [size=4] - Tab-size.\n * @return {string} - Value without tabs.\n */\nfunction detab(value, size) {\n    var string = typeof value === 'string';\n    var length = string && value.length;\n    var index = -1;\n    var column = -1;\n    var tabSize = size || 4;\n    var result = '';\n    var character;\n    var add;\n\n    if (!string) {\n        throw new Error('detab expected string');\n    }\n\n    while (++index < length) {\n        character = value.charAt(index);\n\n        if (character === TAB) {\n            add = tabSize - ((column + 1) % tabSize);\n            result += repeat(SPACE, add);\n            column += add;\n            continue;\n        }\n\n        if (character === NEWLINE) {\n            column = -1;\n        } else {\n            column++;\n        }\n\n        result += character;\n    }\n\n    return result;\n}\n\n/*\n * Expose.\n */\n\nmodule.exports = detab;\n","var generatePrime = require('./lib/generatePrime')\nvar primes = require('./lib/primes.json')\n\nvar DH = require('./lib/dh')\n\nfunction getDiffieHellman (mod) {\n  var prime = new Buffer(primes[mod].prime, 'hex')\n  var gen = new Buffer(primes[mod].gen, 'hex')\n\n  return new DH(prime, gen)\n}\n\nvar ENCODINGS = {\n  'binary': true, 'hex': true, 'base64': true\n}\n\nfunction createDiffieHellman (prime, enc, generator, genc) {\n  if (Buffer.isBuffer(enc) || ENCODINGS[enc] === undefined) {\n    return createDiffieHellman(prime, 'binary', enc, generator)\n  }\n\n  enc = enc || 'binary'\n  genc = genc || 'binary'\n  generator = generator || new Buffer([2])\n\n  if (!Buffer.isBuffer(generator)) {\n    generator = new Buffer(generator, genc)\n  }\n\n  if (typeof prime === 'number') {\n    return new DH(generatePrime(prime, generator), generator, true)\n  }\n\n  if (!Buffer.isBuffer(prime)) {\n    prime = new Buffer(prime, enc)\n  }\n\n  return new DH(prime, generator, true)\n}\n\nexports.DiffieHellmanGroup = exports.createDiffieHellmanGroup = exports.getDiffieHellman = getDiffieHellman\nexports.createDiffieHellman = exports.DiffieHellman = createDiffieHellman\n","var BN = require('bn.js');\nvar MillerRabin = require('miller-rabin');\nvar millerRabin = new MillerRabin();\nvar TWENTYFOUR = new BN(24);\nvar ELEVEN = new BN(11);\nvar TEN = new BN(10);\nvar THREE = new BN(3);\nvar SEVEN = new BN(7);\nvar primes = require('./generatePrime');\nvar randomBytes = require('randombytes');\nmodule.exports = DH;\n\nfunction setPublicKey(pub, enc) {\n  enc = enc || 'utf8';\n  if (!Buffer.isBuffer(pub)) {\n    pub = new Buffer(pub, enc);\n  }\n  this._pub = new BN(pub);\n  return this;\n}\n\nfunction setPrivateKey(priv, enc) {\n  enc = enc || 'utf8';\n  if (!Buffer.isBuffer(priv)) {\n    priv = new Buffer(priv, enc);\n  }\n  this._priv = new BN(priv);\n  return this;\n}\n\nvar primeCache = {};\nfunction checkPrime(prime, generator) {\n  var gen = generator.toString('hex');\n  var hex = [gen, prime.toString(16)].join('_');\n  if (hex in primeCache) {\n    return primeCache[hex];\n  }\n  var error = 0;\n\n  if (prime.isEven() ||\n    !primes.simpleSieve ||\n    !primes.fermatTest(prime) ||\n    !millerRabin.test(prime)) {\n    //not a prime so +1\n    error += 1;\n\n    if (gen === '02' || gen === '05') {\n      // we'd be able to check the generator\n      // it would fail so +8\n      error += 8;\n    } else {\n      //we wouldn't be able to test the generator\n      // so +4\n      error += 4;\n    }\n    primeCache[hex] = error;\n    return error;\n  }\n  if (!millerRabin.test(prime.shrn(1))) {\n    //not a safe prime\n    error += 2;\n  }\n  var rem;\n  switch (gen) {\n    case '02':\n      if (prime.mod(TWENTYFOUR).cmp(ELEVEN)) {\n        // unsuidable generator\n        error += 8;\n      }\n      break;\n    case '05':\n      rem = prime.mod(TEN);\n      if (rem.cmp(THREE) && rem.cmp(SEVEN)) {\n        // prime mod 10 needs to equal 3 or 7\n        error += 8;\n      }\n      break;\n    default:\n      error += 4;\n  }\n  primeCache[hex] = error;\n  return error;\n}\n\nfunction DH(prime, generator, malleable) {\n  this.setGenerator(generator);\n  this.__prime = new BN(prime);\n  this._prime = BN.mont(this.__prime);\n  this._primeLen = prime.length;\n  this._pub = undefined;\n  this._priv = undefined;\n  this._primeCode = undefined;\n  if (malleable) {\n    this.setPublicKey = setPublicKey;\n    this.setPrivateKey = setPrivateKey;\n  } else {\n    this._primeCode = 8;\n  }\n}\nObject.defineProperty(DH.prototype, 'verifyError', {\n  enumerable: true,\n  get: function () {\n    if (typeof this._primeCode !== 'number') {\n      this._primeCode = checkPrime(this.__prime, this.__gen);\n    }\n    return this._primeCode;\n  }\n});\nDH.prototype.generateKeys = function () {\n  if (!this._priv) {\n    this._priv = new BN(randomBytes(this._primeLen));\n  }\n  this._pub = this._gen.toRed(this._prime).redPow(this._priv).fromRed();\n  return this.getPublicKey();\n};\n\nDH.prototype.computeSecret = function (other) {\n  other = new BN(other);\n  other = other.toRed(this._prime);\n  var secret = other.redPow(this._priv).fromRed();\n  var out = new Buffer(secret.toArray());\n  var prime = this.getPrime();\n  if (out.length < prime.length) {\n    var front = new Buffer(prime.length - out.length);\n    front.fill(0);\n    out = Buffer.concat([front, out]);\n  }\n  return out;\n};\n\nDH.prototype.getPublicKey = function getPublicKey(enc) {\n  return formatReturnValue(this._pub, enc);\n};\n\nDH.prototype.getPrivateKey = function getPrivateKey(enc) {\n  return formatReturnValue(this._priv, enc);\n};\n\nDH.prototype.getPrime = function (enc) {\n  return formatReturnValue(this.__prime, enc);\n};\n\nDH.prototype.getGenerator = function (enc) {\n  return formatReturnValue(this._gen, enc);\n};\n\nDH.prototype.setGenerator = function (gen, enc) {\n  enc = enc || 'utf8';\n  if (!Buffer.isBuffer(gen)) {\n    gen = new Buffer(gen, enc);\n  }\n  this.__gen = gen;\n  this._gen = new BN(gen);\n  return this;\n};\n\nfunction formatReturnValue(bn, enc) {\n  var buf = new Buffer(bn.toArray());\n  if (!enc) {\n    return buf;\n  } else {\n    return buf.toString(enc);\n  }\n}\n","var randomBytes = require('randombytes');\nmodule.exports = findPrime;\nfindPrime.simpleSieve = simpleSieve;\nfindPrime.fermatTest = fermatTest;\nvar BN = require('bn.js');\nvar TWENTYFOUR = new BN(24);\nvar MillerRabin = require('miller-rabin');\nvar millerRabin = new MillerRabin();\nvar ONE = new BN(1);\nvar TWO = new BN(2);\nvar FIVE = new BN(5);\nvar SIXTEEN = new BN(16);\nvar EIGHT = new BN(8);\nvar TEN = new BN(10);\nvar THREE = new BN(3);\nvar SEVEN = new BN(7);\nvar ELEVEN = new BN(11);\nvar FOUR = new BN(4);\nvar TWELVE = new BN(12);\nvar primes = null;\n\nfunction _getPrimes() {\n  if (primes !== null)\n    return primes;\n\n  var limit = 0x100000;\n  var res = [];\n  res[0] = 2;\n  for (var i = 1, k = 3; k < limit; k += 2) {\n    var sqrt = Math.ceil(Math.sqrt(k));\n    for (var j = 0; j < i && res[j] <= sqrt; j++)\n      if (k % res[j] === 0)\n        break;\n\n    if (i !== j && res[j] <= sqrt)\n      continue;\n\n    res[i++] = k;\n  }\n  primes = res;\n  return res;\n}\n\nfunction simpleSieve(p) {\n  var primes = _getPrimes();\n\n  for (var i = 0; i < primes.length; i++)\n    if (p.modn(primes[i]) === 0) {\n      if (p.cmpn(primes[i]) === 0) {\n        return true;\n      } else {\n        return false;\n      }\n    }\n\n  return true;\n}\n\nfunction fermatTest(p) {\n  var red = BN.mont(p);\n  return TWO.toRed(red).redPow(p.subn(1)).fromRed().cmpn(1) === 0;\n}\n\nfunction findPrime(bits, gen) {\n  if (bits < 16) {\n    // this is what openssl does\n    if (gen === 2 || gen === 5) {\n      return new BN([0x8c, 0x7b]);\n    } else {\n      return new BN([0x8c, 0x27]);\n    }\n  }\n  gen = new BN(gen);\n\n  var num, n2;\n\n  while (true) {\n    num = new BN(randomBytes(Math.ceil(bits / 8)));\n    while (num.bitLength() > bits) {\n      num.ishrn(1);\n    }\n    if (num.isEven()) {\n      num.iadd(ONE);\n    }\n    if (!num.testn(1)) {\n      num.iadd(TWO);\n    }\n    if (!gen.cmp(TWO)) {\n      while (num.mod(TWENTYFOUR).cmp(ELEVEN)) {\n        num.iadd(FOUR);\n      }\n    } else if (!gen.cmp(FIVE)) {\n      while (num.mod(TEN).cmp(THREE)) {\n        num.iadd(FOUR);\n      }\n    }\n    n2 = num.shrn(1);\n    if (simpleSieve(n2) && simpleSieve(num) &&\n      fermatTest(n2) && fermatTest(num) &&\n      millerRabin.test(n2) && millerRabin.test(num)) {\n      return num;\n    }\n  }\n\n}\n","module.exports={\n    \"modp1\": {\n        \"gen\": \"02\",\n        \"prime\": \"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a63a3620ffffffffffffffff\"\n    },\n    \"modp2\": {\n        \"gen\": \"02\",\n        \"prime\": \"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece65381ffffffffffffffff\"\n    },\n    \"modp5\": {\n        \"gen\": \"02\",\n        \"prime\": \"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca237327ffffffffffffffff\"\n    },\n    \"modp14\": {\n        \"gen\": \"02\",\n        \"prime\": \"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aacaa68ffffffffffffffff\"\n    },\n    \"modp15\": {\n        \"gen\": \"02\",\n        \"prime\": \"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a93ad2caffffffffffffffff\"\n    },\n    \"modp16\": {\n        \"gen\": \"02\",\n        \"prime\": \"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a92108011a723c12a787e6d788719a10bdba5b2699c327186af4e23c1a946834b6150bda2583e9ca2ad44ce8dbbbc2db04de8ef92e8efc141fbecaa6287c59474e6bc05d99b2964fa090c3a2233ba186515be7ed1f612970cee2d7afb81bdd762170481cd0069127d5b05aa993b4ea988d8fddc186ffb7dc90a6c08f4df435c934063199ffffffffffffffff\"\n    },\n    \"modp17\": {\n        \"gen\": \"02\",\n        \"prime\": \"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a92108011a723c12a787e6d788719a10bdba5b2699c327186af4e23c1a946834b6150bda2583e9ca2ad44ce8dbbbc2db04de8ef92e8efc141fbecaa6287c59474e6bc05d99b2964fa090c3a2233ba186515be7ed1f612970cee2d7afb81bdd762170481cd0069127d5b05aa993b4ea988d8fddc186ffb7dc90a6c08f4df435c93402849236c3fab4d27c7026c1d4dcb2602646dec9751e763dba37bdf8ff9406ad9e530ee5db382f413001aeb06a53ed9027d831179727b0865a8918da3edbebcf9b14ed44ce6cbaced4bb1bdb7f1447e6cc254b332051512bd7af426fb8f401378cd2bf5983ca01c64b92ecf032ea15d1721d03f482d7ce6e74fef6d55e702f46980c82b5a84031900b1c9e59e7c97fbec7e8f323a97a7e36cc88be0f1d45b7ff585ac54bd407b22b4154aacc8f6d7ebf48e1d814cc5ed20f8037e0a79715eef29be32806a1d58bb7c5da76f550aa3d8a1fbff0eb19ccb1a313d55cda56c9ec2ef29632387fe8d76e3c0468043e8f663f4860ee12bf2d5b0b7474d6e694f91e6dcc4024ffffffffffffffff\"\n    },\n    \"modp18\": {\n        \"gen\": \"02\",\n        \"prime\": \"ffffffffffffffffc90fdaa22168c234c4c6628b80dc1cd129024e088a67cc74020bbea63b139b22514a08798e3404ddef9519b3cd3a431b302b0a6df25f14374fe1356d6d51c245e485b576625e7ec6f44c42e9a637ed6b0bff5cb6f406b7edee386bfb5a899fa5ae9f24117c4b1fe649286651ece45b3dc2007cb8a163bf0598da48361c55d39a69163fa8fd24cf5f83655d23dca3ad961c62f356208552bb9ed529077096966d670c354e4abc9804f1746c08ca18217c32905e462e36ce3be39e772c180e86039b2783a2ec07a28fb5c55df06f4c52c9de2bcbf6955817183995497cea956ae515d2261898fa051015728e5a8aaac42dad33170d04507a33a85521abdf1cba64ecfb850458dbef0a8aea71575d060c7db3970f85a6e1e4c7abf5ae8cdb0933d71e8c94e04a25619dcee3d2261ad2ee6bf12ffa06d98a0864d87602733ec86a64521f2b18177b200cbbe117577a615d6c770988c0bad946e208e24fa074e5ab3143db5bfce0fd108e4b82d120a92108011a723c12a787e6d788719a10bdba5b2699c327186af4e23c1a946834b6150bda2583e9ca2ad44ce8dbbbc2db04de8ef92e8efc141fbecaa6287c59474e6bc05d99b2964fa090c3a2233ba186515be7ed1f612970cee2d7afb81bdd762170481cd0069127d5b05aa993b4ea988d8fddc186ffb7dc90a6c08f4df435c93402849236c3fab4d27c7026c1d4dcb2602646dec9751e763dba37bdf8ff9406ad9e530ee5db382f413001aeb06a53ed9027d831179727b0865a8918da3edbebcf9b14ed44ce6cbaced4bb1bdb7f1447e6cc254b332051512bd7af426fb8f401378cd2bf5983ca01c64b92ecf032ea15d1721d03f482d7ce6e74fef6d55e702f46980c82b5a84031900b1c9e59e7c97fbec7e8f323a97a7e36cc88be0f1d45b7ff585ac54bd407b22b4154aacc8f6d7ebf48e1d814cc5ed20f8037e0a79715eef29be32806a1d58bb7c5da76f550aa3d8a1fbff0eb19ccb1a313d55cda56c9ec2ef29632387fe8d76e3c0468043e8f663f4860ee12bf2d5b0b7474d6e694f91e6dbe115974a3926f12fee5e438777cb6a932df8cd8bec4d073b931ba3bc832b68d9dd300741fa7bf8afc47ed2576f6936ba424663aab639c5ae4f5683423b4742bf1c978238f16cbe39d652de3fdb8befc848ad922222e04a4037c0713eb57a81a23f0c73473fc646cea306b4bcbc8862f8385ddfa9d4b7fa2c087e879683303ed5bdd3a062b3cf5b3a278a66d2a13f83f44f82ddf310ee074ab6a364597e899a0255dc164f31cc50846851df9ab48195ded7ea1b1d510bd7ee74d73faf36bc31ecfa268359046f4eb879f924009438b481c6cd7889a002ed5ee382bc9190da6fc026e479558e4475677e9aa9e3050e2765694dfc81f56e880b96e7160c980dd98edd3dfffffffffffffffff\"\n    }\n}","// Simple wrapper around SJCL's ECC Implementation - v0.3.0 - https://github.com/jpillora/eccjs\n// Jaime Pillora <dev@jpillora.com> - MIT/BSD(sljc) Copyright 2014\n(function(window,undefined) {/** @fileOverview Javascript cryptography implementation.\n *\n * Crush to remove comments, shorten variable names and\n * generally reduce transmission size.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n\"use strict\";\n/*jslint indent: 2, bitwise: false, nomen: false, plusplus: false, white: false, regexp: false */\n/*global document, window, escape, unescape, module, require, Uint32Array */\n\n/** @namespace The Stanford Javascript Crypto Library, top-level namespace. */\nvar sjcl = {\n  /** @namespace Symmetric ciphers. */\n  cipher: {},\n\n  /** @namespace Hash functions.  Right now only SHA256 is implemented. */\n  hash: {},\n\n  /** @namespace Key exchange functions.  Right now only SRP is implemented. */\n  keyexchange: {},\n  \n  /** @namespace Block cipher modes of operation. */\n  mode: {},\n\n  /** @namespace Miscellaneous.  HMAC and PBKDF2. */\n  misc: {},\n  \n  /**\n   * @namespace Bit array encoders and decoders.\n   *\n   * @description\n   * The members of this namespace are functions which translate between\n   * SJCL's bitArrays and other objects (usually strings).  Because it\n   * isn't always clear which direction is encoding and which is decoding,\n   * the method names are \"fromBits\" and \"toBits\".\n   */\n  codec: {},\n  \n  /** @namespace Exceptions. */\n  exception: {\n    /** @constructor Ciphertext is corrupt. */\n    corrupt: function(message) {\n      this.toString = function() { return \"CORRUPT: \"+this.message; };\n      this.message = message;\n    },\n    \n    /** @constructor Invalid parameter. */\n    invalid: function(message) {\n      this.toString = function() { return \"INVALID: \"+this.message; };\n      this.message = message;\n    },\n    \n    /** @constructor Bug or missing feature in SJCL. @constructor */\n    bug: function(message) {\n      this.toString = function() { return \"BUG: \"+this.message; };\n      this.message = message;\n    },\n\n    /** @constructor Something isn't ready. */\n    notReady: function(message) {\n      this.toString = function() { return \"NOT READY: \"+this.message; };\n      this.message = message;\n    }\n  }\n};\n\n/** @fileOverview Low-level AES implementation.\n *\n * This file contains a low-level implementation of AES, optimized for\n * size and for efficiency on several browsers.  It is based on\n * OpenSSL's aes_core.c, a public-domain implementation by Vincent\n * Rijmen, Antoon Bosselaers and Paulo Barreto.\n *\n * An older version of this implementation is available in the public\n * domain, but this one is (c) Emily Stark, Mike Hamburg, Dan Boneh,\n * Stanford University 2008-2010 and BSD-licensed for liability\n * reasons.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/**\n * Schedule out an AES key for both encryption and decryption.  This\n * is a low-level class.  Use a cipher mode to do bulk encryption.\n *\n * @constructor\n * @param {Array} key The key as an array of 4, 6 or 8 words.\n *\n * @class Advanced Encryption Standard (low-level interface)\n */\nsjcl.cipher.aes = function (key) {\n  if (!this._tables[0][0][0]) {\n    this._precompute();\n  }\n  \n  var i, j, tmp,\n    encKey, decKey,\n    sbox = this._tables[0][4], decTable = this._tables[1],\n    keyLen = key.length, rcon = 1;\n  \n  if (keyLen !== 4 && keyLen !== 6 && keyLen !== 8) {\n    throw new sjcl.exception.invalid(\"invalid aes key size\");\n  }\n  \n  this._key = [encKey = key.slice(0), decKey = []];\n  \n  // schedule encryption keys\n  for (i = keyLen; i < 4 * keyLen + 28; i++) {\n    tmp = encKey[i-1];\n    \n    // apply sbox\n    if (i%keyLen === 0 || (keyLen === 8 && i%keyLen === 4)) {\n      tmp = sbox[tmp>>>24]<<24 ^ sbox[tmp>>16&255]<<16 ^ sbox[tmp>>8&255]<<8 ^ sbox[tmp&255];\n      \n      // shift rows and add rcon\n      if (i%keyLen === 0) {\n        tmp = tmp<<8 ^ tmp>>>24 ^ rcon<<24;\n        rcon = rcon<<1 ^ (rcon>>7)*283;\n      }\n    }\n    \n    encKey[i] = encKey[i-keyLen] ^ tmp;\n  }\n  \n  // schedule decryption keys\n  for (j = 0; i; j++, i--) {\n    tmp = encKey[j&3 ? i : i - 4];\n    if (i<=4 || j<4) {\n      decKey[j] = tmp;\n    } else {\n      decKey[j] = decTable[0][sbox[tmp>>>24      ]] ^\n                  decTable[1][sbox[tmp>>16  & 255]] ^\n                  decTable[2][sbox[tmp>>8   & 255]] ^\n                  decTable[3][sbox[tmp      & 255]];\n    }\n  }\n};\n\nsjcl.cipher.aes.prototype = {\n  // public\n  /* Something like this might appear here eventually\n  name: \"AES\",\n  blockSize: 4,\n  keySizes: [4,6,8],\n  */\n  \n  /**\n   * Encrypt an array of 4 big-endian words.\n   * @param {Array} data The plaintext.\n   * @return {Array} The ciphertext.\n   */\n  encrypt:function (data) { return this._crypt(data,0); },\n  \n  /**\n   * Decrypt an array of 4 big-endian words.\n   * @param {Array} data The ciphertext.\n   * @return {Array} The plaintext.\n   */\n  decrypt:function (data) { return this._crypt(data,1); },\n  \n  /**\n   * The expanded S-box and inverse S-box tables.  These will be computed\n   * on the client so that we don't have to send them down the wire.\n   *\n   * There are two tables, _tables[0] is for encryption and\n   * _tables[1] is for decryption.\n   *\n   * The first 4 sub-tables are the expanded S-box with MixColumns.  The\n   * last (_tables[01][4]) is the S-box itself.\n   *\n   * @private\n   */\n  _tables: [[[],[],[],[],[]],[[],[],[],[],[]]],\n\n  /**\n   * Expand the S-box tables.\n   *\n   * @private\n   */\n  _precompute: function () {\n   var encTable = this._tables[0], decTable = this._tables[1],\n       sbox = encTable[4], sboxInv = decTable[4],\n       i, x, xInv, d=[], th=[], x2, x4, x8, s, tEnc, tDec;\n\n    // Compute double and third tables\n   for (i = 0; i < 256; i++) {\n     th[( d[i] = i<<1 ^ (i>>7)*283 )^i]=i;\n   }\n   \n   for (x = xInv = 0; !sbox[x]; x ^= x2 || 1, xInv = th[xInv] || 1) {\n     // Compute sbox\n     s = xInv ^ xInv<<1 ^ xInv<<2 ^ xInv<<3 ^ xInv<<4;\n     s = s>>8 ^ s&255 ^ 99;\n     sbox[x] = s;\n     sboxInv[s] = x;\n     \n     // Compute MixColumns\n     x8 = d[x4 = d[x2 = d[x]]];\n     tDec = x8*0x1010101 ^ x4*0x10001 ^ x2*0x101 ^ x*0x1010100;\n     tEnc = d[s]*0x101 ^ s*0x1010100;\n     \n     for (i = 0; i < 4; i++) {\n       encTable[i][x] = tEnc = tEnc<<24 ^ tEnc>>>8;\n       decTable[i][s] = tDec = tDec<<24 ^ tDec>>>8;\n     }\n   }\n   \n   // Compactify.  Considerable speedup on Firefox.\n   for (i = 0; i < 5; i++) {\n     encTable[i] = encTable[i].slice(0);\n     decTable[i] = decTable[i].slice(0);\n   }\n  },\n  \n  /**\n   * Encryption and decryption core.\n   * @param {Array} input Four words to be encrypted or decrypted.\n   * @param dir The direction, 0 for encrypt and 1 for decrypt.\n   * @return {Array} The four encrypted or decrypted words.\n   * @private\n   */\n  _crypt:function (input, dir) {\n    if (input.length !== 4) {\n      throw new sjcl.exception.invalid(\"invalid aes block size\");\n    }\n    \n    var key = this._key[dir],\n        // state variables a,b,c,d are loaded with pre-whitened data\n        a = input[0]           ^ key[0],\n        b = input[dir ? 3 : 1] ^ key[1],\n        c = input[2]           ^ key[2],\n        d = input[dir ? 1 : 3] ^ key[3],\n        a2, b2, c2,\n        \n        nInnerRounds = key.length/4 - 2,\n        i,\n        kIndex = 4,\n        out = [0,0,0,0],\n        table = this._tables[dir],\n        \n        // load up the tables\n        t0    = table[0],\n        t1    = table[1],\n        t2    = table[2],\n        t3    = table[3],\n        sbox  = table[4];\n \n    // Inner rounds.  Cribbed from OpenSSL.\n    for (i = 0; i < nInnerRounds; i++) {\n      a2 = t0[a>>>24] ^ t1[b>>16 & 255] ^ t2[c>>8 & 255] ^ t3[d & 255] ^ key[kIndex];\n      b2 = t0[b>>>24] ^ t1[c>>16 & 255] ^ t2[d>>8 & 255] ^ t3[a & 255] ^ key[kIndex + 1];\n      c2 = t0[c>>>24] ^ t1[d>>16 & 255] ^ t2[a>>8 & 255] ^ t3[b & 255] ^ key[kIndex + 2];\n      d  = t0[d>>>24] ^ t1[a>>16 & 255] ^ t2[b>>8 & 255] ^ t3[c & 255] ^ key[kIndex + 3];\n      kIndex += 4;\n      a=a2; b=b2; c=c2;\n    }\n        \n    // Last round.\n    for (i = 0; i < 4; i++) {\n      out[dir ? 3&-i : i] =\n        sbox[a>>>24      ]<<24 ^ \n        sbox[b>>16  & 255]<<16 ^\n        sbox[c>>8   & 255]<<8  ^\n        sbox[d      & 255]     ^\n        key[kIndex++];\n      a2=a; a=b; b=c; c=d; d=a2;\n    }\n    \n    return out;\n  }\n};\n\n/** @fileOverview Arrays of bits, encoded as arrays of Numbers.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/** @namespace Arrays of bits, encoded as arrays of Numbers.\n *\n * @description\n * <p>\n * These objects are the currency accepted by SJCL's crypto functions.\n * </p>\n *\n * <p>\n * Most of our crypto primitives operate on arrays of 4-byte words internally,\n * but many of them can take arguments that are not a multiple of 4 bytes.\n * This library encodes arrays of bits (whose size need not be a multiple of 8\n * bits) as arrays of 32-bit words.  The bits are packed, big-endian, into an\n * array of words, 32 bits at a time.  Since the words are double-precision\n * floating point numbers, they fit some extra data.  We use this (in a private,\n * possibly-changing manner) to encode the number of bits actually  present\n * in the last word of the array.\n * </p>\n *\n * <p>\n * Because bitwise ops clear this out-of-band data, these arrays can be passed\n * to ciphers like AES which want arrays of words.\n * </p>\n */\nsjcl.bitArray = {\n  /**\n   * Array slices in units of bits.\n   * @param {bitArray} a The array to slice.\n   * @param {Number} bstart The offset to the start of the slice, in bits.\n   * @param {Number} bend The offset to the end of the slice, in bits.  If this is undefined,\n   * slice until the end of the array.\n   * @return {bitArray} The requested slice.\n   */\n  bitSlice: function (a, bstart, bend) {\n    a = sjcl.bitArray._shiftRight(a.slice(bstart/32), 32 - (bstart & 31)).slice(1);\n    return (bend === undefined) ? a : sjcl.bitArray.clamp(a, bend-bstart);\n  },\n\n  /**\n   * Extract a number packed into a bit array.\n   * @param {bitArray} a The array to slice.\n   * @param {Number} bstart The offset to the start of the slice, in bits.\n   * @param {Number} length The length of the number to extract.\n   * @return {Number} The requested slice.\n   */\n  extract: function(a, bstart, blength) {\n    // FIXME: this Math.floor is not necessary at all, but for some reason\n    // seems to suppress a bug in the Chromium JIT.\n    var x, sh = Math.floor((-bstart-blength) & 31);\n    if ((bstart + blength - 1 ^ bstart) & -32) {\n      // it crosses a boundary\n      x = (a[bstart/32|0] << (32 - sh)) ^ (a[bstart/32+1|0] >>> sh);\n    } else {\n      // within a single word\n      x = a[bstart/32|0] >>> sh;\n    }\n    return x & ((1<<blength) - 1);\n  },\n\n  /**\n   * Concatenate two bit arrays.\n   * @param {bitArray} a1 The first array.\n   * @param {bitArray} a2 The second array.\n   * @return {bitArray} The concatenation of a1 and a2.\n   */\n  concat: function (a1, a2) {\n    if (a1.length === 0 || a2.length === 0) {\n      return a1.concat(a2);\n    }\n    \n    var out, i, last = a1[a1.length-1], shift = sjcl.bitArray.getPartial(last);\n    if (shift === 32) {\n      return a1.concat(a2);\n    } else {\n      return sjcl.bitArray._shiftRight(a2, shift, last|0, a1.slice(0,a1.length-1));\n    }\n  },\n\n  /**\n   * Find the length of an array of bits.\n   * @param {bitArray} a The array.\n   * @return {Number} The length of a, in bits.\n   */\n  bitLength: function (a) {\n    var l = a.length, x;\n    if (l === 0) { return 0; }\n    x = a[l - 1];\n    return (l-1) * 32 + sjcl.bitArray.getPartial(x);\n  },\n\n  /**\n   * Truncate an array.\n   * @param {bitArray} a The array.\n   * @param {Number} len The length to truncate to, in bits.\n   * @return {bitArray} A new array, truncated to len bits.\n   */\n  clamp: function (a, len) {\n    if (a.length * 32 < len) { return a; }\n    a = a.slice(0, Math.ceil(len / 32));\n    var l = a.length;\n    len = len & 31;\n    if (l > 0 && len) {\n      a[l-1] = sjcl.bitArray.partial(len, a[l-1] & 0x80000000 >> (len-1), 1);\n    }\n    return a;\n  },\n\n  /**\n   * Make a partial word for a bit array.\n   * @param {Number} len The number of bits in the word.\n   * @param {Number} x The bits.\n   * @param {Number} [0] _end Pass 1 if x has already been shifted to the high side.\n   * @return {Number} The partial word.\n   */\n  partial: function (len, x, _end) {\n    if (len === 32) { return x; }\n    return (_end ? x|0 : x << (32-len)) + len * 0x10000000000;\n  },\n\n  /**\n   * Get the number of bits used by a partial word.\n   * @param {Number} x The partial word.\n   * @return {Number} The number of bits used by the partial word.\n   */\n  getPartial: function (x) {\n    return Math.round(x/0x10000000000) || 32;\n  },\n\n  /**\n   * Compare two arrays for equality in a predictable amount of time.\n   * @param {bitArray} a The first array.\n   * @param {bitArray} b The second array.\n   * @return {boolean} true if a == b; false otherwise.\n   */\n  equal: function (a, b) {\n    if (sjcl.bitArray.bitLength(a) !== sjcl.bitArray.bitLength(b)) {\n      return false;\n    }\n    var x = 0, i;\n    for (i=0; i<a.length; i++) {\n      x |= a[i]^b[i];\n    }\n    return (x === 0);\n  },\n\n  /** Shift an array right.\n   * @param {bitArray} a The array to shift.\n   * @param {Number} shift The number of bits to shift.\n   * @param {Number} [carry=0] A byte to carry in\n   * @param {bitArray} [out=[]] An array to prepend to the output.\n   * @private\n   */\n  _shiftRight: function (a, shift, carry, out) {\n    var i, last2=0, shift2;\n    if (out === undefined) { out = []; }\n    \n    for (; shift >= 32; shift -= 32) {\n      out.push(carry);\n      carry = 0;\n    }\n    if (shift === 0) {\n      return out.concat(a);\n    }\n    \n    for (i=0; i<a.length; i++) {\n      out.push(carry | a[i]>>>shift);\n      carry = a[i] << (32-shift);\n    }\n    last2 = a.length ? a[a.length-1] : 0;\n    shift2 = sjcl.bitArray.getPartial(last2);\n    out.push(sjcl.bitArray.partial(shift+shift2 & 31, (shift + shift2 > 32) ? carry : out.pop(),1));\n    return out;\n  },\n  \n  /** xor a block of 4 words together.\n   * @private\n   */\n  _xor4: function(x,y) {\n    return [x[0]^y[0],x[1]^y[1],x[2]^y[2],x[3]^y[3]];\n  }\n};\n/** @fileOverview Bit array codec implementations.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n \n/** @namespace UTF-8 strings */\nsjcl.codec.utf8String = {\n  /** Convert from a bitArray to a UTF-8 string. */\n  fromBits: function (arr) {\n    var out = \"\", bl = sjcl.bitArray.bitLength(arr), i, tmp;\n    for (i=0; i<bl/8; i++) {\n      if ((i&3) === 0) {\n        tmp = arr[i/4];\n      }\n      out += String.fromCharCode(tmp >>> 24);\n      tmp <<= 8;\n    }\n    return decodeURIComponent(escape(out));\n  },\n  \n  /** Convert from a UTF-8 string to a bitArray. */\n  toBits: function (str) {\n    str = unescape(encodeURIComponent(str));\n    var out = [], i, tmp=0;\n    for (i=0; i<str.length; i++) {\n      tmp = tmp << 8 | str.charCodeAt(i);\n      if ((i&3) === 3) {\n        out.push(tmp);\n        tmp = 0;\n      }\n    }\n    if (i&3) {\n      out.push(sjcl.bitArray.partial(8*(i&3), tmp));\n    }\n    return out;\n  }\n};\n/** @fileOverview Bit array codec implementations.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/** @namespace Hexadecimal */\nsjcl.codec.hex = {\n  /** Convert from a bitArray to a hex string. */\n  fromBits: function (arr) {\n    var out = \"\", i, x;\n    for (i=0; i<arr.length; i++) {\n      out += ((arr[i]|0)+0xF00000000000).toString(16).substr(4);\n    }\n    return out.substr(0, sjcl.bitArray.bitLength(arr)/4);//.replace(/(.{8})/g, \"$1 \");\n  },\n  /** Convert from a hex string to a bitArray. */\n  toBits: function (str) {\n    var i, out=[], len;\n    str = str.replace(/\\s|0x/g, \"\");\n    len = str.length;\n    str = str + \"00000000\";\n    for (i=0; i<str.length; i+=8) {\n      out.push(parseInt(str.substr(i,8),16)^0);\n    }\n    return sjcl.bitArray.clamp(out, len*4);\n  }\n};\n\n/** @fileOverview Bit array codec implementations.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/** @namespace Base64 encoding/decoding */\nsjcl.codec.base64 = {\n  /** The base64 alphabet.\n   * @private\n   */\n  _chars: \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\",\n  \n  /** Convert from a bitArray to a base64 string. */\n  fromBits: function (arr, _noEquals, _url) {\n    var out = \"\", i, bits=0, c = sjcl.codec.base64._chars, ta=0, bl = sjcl.bitArray.bitLength(arr);\n    if (_url) {\n      c = c.substr(0,62) + '-_';\n    }\n    for (i=0; out.length * 6 < bl; ) {\n      out += c.charAt((ta ^ arr[i]>>>bits) >>> 26);\n      if (bits < 6) {\n        ta = arr[i] << (6-bits);\n        bits += 26;\n        i++;\n      } else {\n        ta <<= 6;\n        bits -= 6;\n      }\n    }\n    while ((out.length & 3) && !_noEquals) { out += \"=\"; }\n    return out;\n  },\n  \n  /** Convert from a base64 string to a bitArray */\n  toBits: function(str, _url) {\n    str = str.replace(/\\s|=/g,'');\n    var out = [], i, bits=0, c = sjcl.codec.base64._chars, ta=0, x;\n    if (_url) {\n      c = c.substr(0,62) + '-_';\n    }\n    for (i=0; i<str.length; i++) {\n      x = c.indexOf(str.charAt(i));\n      if (x < 0) {\n        throw new sjcl.exception.invalid(\"this isn't base64!\");\n      }\n      if (bits > 26) {\n        bits -= 26;\n        out.push(ta ^ x>>>bits);\n        ta  = x << (32-bits);\n      } else {\n        bits += 6;\n        ta ^= x << (32-bits);\n      }\n    }\n    if (bits&56) {\n      out.push(sjcl.bitArray.partial(bits&56, ta, 1));\n    }\n    return out;\n  }\n};\n\nsjcl.codec.base64url = {\n  fromBits: function (arr) { return sjcl.codec.base64.fromBits(arr,1,1); },\n  toBits: function (str) { return sjcl.codec.base64.toBits(str,1); }\n};\n/** @fileOverview Javascript SHA-256 implementation.\n *\n * An older version of this implementation is available in the public\n * domain, but this one is (c) Emily Stark, Mike Hamburg, Dan Boneh,\n * Stanford University 2008-2010 and BSD-licensed for liability\n * reasons.\n *\n * Special thanks to Aldo Cortesi for pointing out several bugs in\n * this code.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/**\n * Context for a SHA-256 operation in progress.\n * @constructor\n * @class Secure Hash Algorithm, 256 bits.\n */\nsjcl.hash.sha256 = function (hash) {\n  if (!this._key[0]) { this._precompute(); }\n  if (hash) {\n    this._h = hash._h.slice(0);\n    this._buffer = hash._buffer.slice(0);\n    this._length = hash._length;\n  } else {\n    this.reset();\n  }\n};\n\n/**\n * Hash a string or an array of words.\n * @static\n * @param {bitArray|String} data the data to hash.\n * @return {bitArray} The hash value, an array of 16 big-endian words.\n */\nsjcl.hash.sha256.hash = function (data) {\n  return (new sjcl.hash.sha256()).update(data).finalize();\n};\n\nsjcl.hash.sha256.prototype = {\n  /**\n   * The hash's block size, in bits.\n   * @constant\n   */\n  blockSize: 512,\n   \n  /**\n   * Reset the hash state.\n   * @return this\n   */\n  reset:function () {\n    this._h = this._init.slice(0);\n    this._buffer = [];\n    this._length = 0;\n    return this;\n  },\n  \n  /**\n   * Input several words to the hash.\n   * @param {bitArray|String} data the data to hash.\n   * @return this\n   */\n  update: function (data) {\n    if (typeof data === \"string\") {\n      data = sjcl.codec.utf8String.toBits(data);\n    }\n    var i, b = this._buffer = sjcl.bitArray.concat(this._buffer, data),\n        ol = this._length,\n        nl = this._length = ol + sjcl.bitArray.bitLength(data);\n    for (i = 512+ol & -512; i <= nl; i+= 512) {\n      this._block(b.splice(0,16));\n    }\n    return this;\n  },\n  \n  /**\n   * Complete hashing and output the hash value.\n   * @return {bitArray} The hash value, an array of 8 big-endian words.\n   */\n  finalize:function () {\n    var i, b = this._buffer, h = this._h;\n\n    // Round out and push the buffer\n    b = sjcl.bitArray.concat(b, [sjcl.bitArray.partial(1,1)]);\n    \n    // Round out the buffer to a multiple of 16 words, less the 2 length words.\n    for (i = b.length + 2; i & 15; i++) {\n      b.push(0);\n    }\n    \n    // append the length\n    b.push(Math.floor(this._length / 0x100000000));\n    b.push(this._length | 0);\n\n    while (b.length) {\n      this._block(b.splice(0,16));\n    }\n\n    this.reset();\n    return h;\n  },\n\n  /**\n   * The SHA-256 initialization vector, to be precomputed.\n   * @private\n   */\n  _init:[],\n  /*\n  _init:[0x6a09e667,0xbb67ae85,0x3c6ef372,0xa54ff53a,0x510e527f,0x9b05688c,0x1f83d9ab,0x5be0cd19],\n  */\n  \n  /**\n   * The SHA-256 hash key, to be precomputed.\n   * @private\n   */\n  _key:[],\n  /*\n  _key:\n    [0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5, 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5,\n     0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3, 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174,\n     0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc, 0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da,\n     0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7, 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967,\n     0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13, 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85,\n     0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3, 0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070,\n     0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5, 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3,\n     0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208, 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2],\n  */\n\n\n  /**\n   * Function to precompute _init and _key.\n   * @private\n   */\n  _precompute: function () {\n    var i = 0, prime = 2, factor;\n\n    function frac(x) { return (x-Math.floor(x)) * 0x100000000 | 0; }\n\n    outer: for (; i<64; prime++) {\n      for (factor=2; factor*factor <= prime; factor++) {\n        if (prime % factor === 0) {\n          // not a prime\n          continue outer;\n        }\n      }\n      \n      if (i<8) {\n        this._init[i] = frac(Math.pow(prime, 1/2));\n      }\n      this._key[i] = frac(Math.pow(prime, 1/3));\n      i++;\n    }\n  },\n  \n  /**\n   * Perform one cycle of SHA-256.\n   * @param {bitArray} words one block of words.\n   * @private\n   */\n  _block:function (words) {  \n    var i, tmp, a, b,\n      w = words.slice(0),\n      h = this._h,\n      k = this._key,\n      h0 = h[0], h1 = h[1], h2 = h[2], h3 = h[3],\n      h4 = h[4], h5 = h[5], h6 = h[6], h7 = h[7];\n\n    /* Rationale for placement of |0 :\n     * If a value can overflow is original 32 bits by a factor of more than a few\n     * million (2^23 ish), there is a possibility that it might overflow the\n     * 53-bit mantissa and lose precision.\n     *\n     * To avoid this, we clamp back to 32 bits by |'ing with 0 on any value that\n     * propagates around the loop, and on the hash state h[].  I don't believe\n     * that the clamps on h4 and on h0 are strictly necessary, but it's close\n     * (for h4 anyway), and better safe than sorry.\n     *\n     * The clamps on h[] are necessary for the output to be correct even in the\n     * common case and for short inputs.\n     */\n    for (i=0; i<64; i++) {\n      // load up the input word for this round\n      if (i<16) {\n        tmp = w[i];\n      } else {\n        a   = w[(i+1 ) & 15];\n        b   = w[(i+14) & 15];\n        tmp = w[i&15] = ((a>>>7  ^ a>>>18 ^ a>>>3  ^ a<<25 ^ a<<14) + \n                         (b>>>17 ^ b>>>19 ^ b>>>10 ^ b<<15 ^ b<<13) +\n                         w[i&15] + w[(i+9) & 15]) | 0;\n      }\n      \n      tmp = (tmp + h7 + (h4>>>6 ^ h4>>>11 ^ h4>>>25 ^ h4<<26 ^ h4<<21 ^ h4<<7) +  (h6 ^ h4&(h5^h6)) + k[i]); // | 0;\n      \n      // shift register\n      h7 = h6; h6 = h5; h5 = h4;\n      h4 = h3 + tmp | 0;\n      h3 = h2; h2 = h1; h1 = h0;\n\n      h0 = (tmp +  ((h1&h2) ^ (h3&(h1^h2))) + (h1>>>2 ^ h1>>>13 ^ h1>>>22 ^ h1<<30 ^ h1<<19 ^ h1<<10)) | 0;\n    }\n\n    h[0] = h[0]+h0 | 0;\n    h[1] = h[1]+h1 | 0;\n    h[2] = h[2]+h2 | 0;\n    h[3] = h[3]+h3 | 0;\n    h[4] = h[4]+h4 | 0;\n    h[5] = h[5]+h5 | 0;\n    h[6] = h[6]+h6 | 0;\n    h[7] = h[7]+h7 | 0;\n  }\n};\n\n\n/** @fileOverview CCM mode implementation.\n *\n * Special thanks to Roy Nicholson for pointing out a bug in our\n * implementation.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/** @namespace CTR mode with CBC MAC. */\nsjcl.mode.ccm = {\n  /** The name of the mode.\n   * @constant\n   */\n  name: \"ccm\",\n  \n  /** Encrypt in CCM mode.\n   * @static\n   * @param {Object} prf The pseudorandom function.  It must have a block size of 16 bytes.\n   * @param {bitArray} plaintext The plaintext data.\n   * @param {bitArray} iv The initialization value.\n   * @param {bitArray} [adata=[]] The authenticated data.\n   * @param {Number} [tlen=64] the desired tag length, in bits.\n   * @return {bitArray} The encrypted data, an array of bytes.\n   */\n  encrypt: function(prf, plaintext, iv, adata, tlen) {\n    var L, i, out = plaintext.slice(0), tag, w=sjcl.bitArray, ivl = w.bitLength(iv) / 8, ol = w.bitLength(out) / 8;\n    tlen = tlen || 64;\n    adata = adata || [];\n    \n    if (ivl < 7) {\n      throw new sjcl.exception.invalid(\"ccm: iv must be at least 7 bytes\");\n    }\n    \n    // compute the length of the length\n    for (L=2; L<4 && ol >>> 8*L; L++) {}\n    if (L < 15 - ivl) { L = 15-ivl; }\n    iv = w.clamp(iv,8*(15-L));\n    \n    // compute the tag\n    tag = sjcl.mode.ccm._computeTag(prf, plaintext, iv, adata, tlen, L);\n    \n    // encrypt\n    out = sjcl.mode.ccm._ctrMode(prf, out, iv, tag, tlen, L);\n    \n    return w.concat(out.data, out.tag);\n  },\n  \n  /** Decrypt in CCM mode.\n   * @static\n   * @param {Object} prf The pseudorandom function.  It must have a block size of 16 bytes.\n   * @param {bitArray} ciphertext The ciphertext data.\n   * @param {bitArray} iv The initialization value.\n   * @param {bitArray} [[]] adata The authenticated data.\n   * @param {Number} [64] tlen the desired tag length, in bits.\n   * @return {bitArray} The decrypted data.\n   */\n  decrypt: function(prf, ciphertext, iv, adata, tlen) {\n    tlen = tlen || 64;\n    adata = adata || [];\n    var L, i, \n        w=sjcl.bitArray,\n        ivl = w.bitLength(iv) / 8,\n        ol = w.bitLength(ciphertext), \n        out = w.clamp(ciphertext, ol - tlen),\n        tag = w.bitSlice(ciphertext, ol - tlen), tag2;\n    \n\n    ol = (ol - tlen) / 8;\n        \n    if (ivl < 7) {\n      throw new sjcl.exception.invalid(\"ccm: iv must be at least 7 bytes\");\n    }\n    \n    // compute the length of the length\n    for (L=2; L<4 && ol >>> 8*L; L++) {}\n    if (L < 15 - ivl) { L = 15-ivl; }\n    iv = w.clamp(iv,8*(15-L));\n    \n    // decrypt\n    out = sjcl.mode.ccm._ctrMode(prf, out, iv, tag, tlen, L);\n    \n    // check the tag\n    tag2 = sjcl.mode.ccm._computeTag(prf, out.data, iv, adata, tlen, L);\n    if (!w.equal(out.tag, tag2)) {\n      throw new sjcl.exception.corrupt(\"ccm: tag doesn't match\");\n    }\n    \n    return out.data;\n  },\n\n  /* Compute the (unencrypted) authentication tag, according to the CCM specification\n   * @param {Object} prf The pseudorandom function.\n   * @param {bitArray} plaintext The plaintext data.\n   * @param {bitArray} iv The initialization value.\n   * @param {bitArray} adata The authenticated data.\n   * @param {Number} tlen the desired tag length, in bits.\n   * @return {bitArray} The tag, but not yet encrypted.\n   * @private\n   */\n  _computeTag: function(prf, plaintext, iv, adata, tlen, L) {\n    // compute B[0]\n    var q, mac, field = 0, offset = 24, tmp, i, macData = [], w=sjcl.bitArray, xor = w._xor4;\n\n    tlen /= 8;\n  \n    // check tag length and message length\n    if (tlen % 2 || tlen < 4 || tlen > 16) {\n      throw new sjcl.exception.invalid(\"ccm: invalid tag length\");\n    }\n  \n    if (adata.length > 0xFFFFFFFF || plaintext.length > 0xFFFFFFFF) {\n      // I don't want to deal with extracting high words from doubles.\n      throw new sjcl.exception.bug(\"ccm: can't deal with 4GiB or more data\");\n    }\n\n    // mac the flags\n    mac = [w.partial(8, (adata.length ? 1<<6 : 0) | (tlen-2) << 2 | L-1)];\n\n    // mac the iv and length\n    mac = w.concat(mac, iv);\n    mac[3] |= w.bitLength(plaintext)/8;\n    mac = prf.encrypt(mac);\n    \n  \n    if (adata.length) {\n      // mac the associated data.  start with its length...\n      tmp = w.bitLength(adata)/8;\n      if (tmp <= 0xFEFF) {\n        macData = [w.partial(16, tmp)];\n      } else if (tmp <= 0xFFFFFFFF) {\n        macData = w.concat([w.partial(16,0xFFFE)], [tmp]);\n      } // else ...\n    \n      // mac the data itself\n      macData = w.concat(macData, adata);\n      for (i=0; i<macData.length; i += 4) {\n        mac = prf.encrypt(xor(mac, macData.slice(i,i+4).concat([0,0,0])));\n      }\n    }\n  \n    // mac the plaintext\n    for (i=0; i<plaintext.length; i+=4) {\n      mac = prf.encrypt(xor(mac, plaintext.slice(i,i+4).concat([0,0,0])));\n    }\n\n    return w.clamp(mac, tlen * 8);\n  },\n\n  /** CCM CTR mode.\n   * Encrypt or decrypt data and tag with the prf in CCM-style CTR mode.\n   * May mutate its arguments.\n   * @param {Object} prf The PRF.\n   * @param {bitArray} data The data to be encrypted or decrypted.\n   * @param {bitArray} iv The initialization vector.\n   * @param {bitArray} tag The authentication tag.\n   * @param {Number} tlen The length of th etag, in bits.\n   * @param {Number} L The CCM L value.\n   * @return {Object} An object with data and tag, the en/decryption of data and tag values.\n   * @private\n   */\n  _ctrMode: function(prf, data, iv, tag, tlen, L) {\n    var enc, i, w=sjcl.bitArray, xor = w._xor4, ctr, b, l = data.length, bl=w.bitLength(data);\n\n    // start the ctr\n    ctr = w.concat([w.partial(8,L-1)],iv).concat([0,0,0]).slice(0,4);\n    \n    // en/decrypt the tag\n    tag = w.bitSlice(xor(tag,prf.encrypt(ctr)), 0, tlen);\n  \n    // en/decrypt the data\n    if (!l) { return {tag:tag, data:[]}; }\n    \n    for (i=0; i<l; i+=4) {\n      ctr[3]++;\n      enc = prf.encrypt(ctr);\n      data[i]   ^= enc[0];\n      data[i+1] ^= enc[1];\n      data[i+2] ^= enc[2];\n      data[i+3] ^= enc[3];\n    }\n    return { tag:tag, data:w.clamp(data,bl) };\n  }\n};\n/** @fileOverview OCB 2.0 implementation\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/** @namespace\n * Phil Rogaway's Offset CodeBook mode, version 2.0.\n * May be covered by US and international patents.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\nsjcl.mode.ocb2 = {\n  /** The name of the mode.\n   * @constant\n   */\n  name: \"ocb2\",\n  \n  /** Encrypt in OCB mode, version 2.0.\n   * @param {Object} prp The block cipher.  It must have a block size of 16 bytes.\n   * @param {bitArray} plaintext The plaintext data.\n   * @param {bitArray} iv The initialization value.\n   * @param {bitArray} [adata=[]] The authenticated data.\n   * @param {Number} [tlen=64] the desired tag length, in bits.\n   * @param [false] premac 1 if the authentication data is pre-macced with PMAC.\n   * @return The encrypted data, an array of bytes.\n   * @throws {sjcl.exception.invalid} if the IV isn't exactly 128 bits.\n   */\n  encrypt: function(prp, plaintext, iv, adata, tlen, premac) {\n    if (sjcl.bitArray.bitLength(iv) !== 128) {\n      throw new sjcl.exception.invalid(\"ocb iv must be 128 bits\");\n    }\n    var i,\n        times2 = sjcl.mode.ocb2._times2,\n        w = sjcl.bitArray,\n        xor = w._xor4,\n        checksum = [0,0,0,0],\n        delta = times2(prp.encrypt(iv)),\n        bi, bl,\n        output = [],\n        pad;\n        \n    adata = adata || [];\n    tlen  = tlen || 64;\n  \n    for (i=0; i+4 < plaintext.length; i+=4) {\n      /* Encrypt a non-final block */\n      bi = plaintext.slice(i,i+4);\n      checksum = xor(checksum, bi);\n      output = output.concat(xor(delta,prp.encrypt(xor(delta, bi))));\n      delta = times2(delta);\n    }\n    \n    /* Chop out the final block */\n    bi = plaintext.slice(i);\n    bl = w.bitLength(bi);\n    pad = prp.encrypt(xor(delta,[0,0,0,bl]));\n    bi = w.clamp(xor(bi.concat([0,0,0]),pad), bl);\n    \n    /* Checksum the final block, and finalize the checksum */\n    checksum = xor(checksum,xor(bi.concat([0,0,0]),pad));\n    checksum = prp.encrypt(xor(checksum,xor(delta,times2(delta))));\n    \n    /* MAC the header */\n    if (adata.length) {\n      checksum = xor(checksum, premac ? adata : sjcl.mode.ocb2.pmac(prp, adata));\n    }\n    \n    return output.concat(w.concat(bi, w.clamp(checksum, tlen)));\n  },\n  \n  /** Decrypt in OCB mode.\n   * @param {Object} prp The block cipher.  It must have a block size of 16 bytes.\n   * @param {bitArray} ciphertext The ciphertext data.\n   * @param {bitArray} iv The initialization value.\n   * @param {bitArray} [adata=[]] The authenticated data.\n   * @param {Number} [tlen=64] the desired tag length, in bits.\n   * @param {boolean} [premac=false] true if the authentication data is pre-macced with PMAC.\n   * @return The decrypted data, an array of bytes.\n   * @throws {sjcl.exception.invalid} if the IV isn't exactly 128 bits.\n   * @throws {sjcl.exception.corrupt} if if the message is corrupt.\n   */\n  decrypt: function(prp, ciphertext, iv, adata, tlen, premac) {\n    if (sjcl.bitArray.bitLength(iv) !== 128) {\n      throw new sjcl.exception.invalid(\"ocb iv must be 128 bits\");\n    }\n    tlen  = tlen || 64;\n    var i,\n        times2 = sjcl.mode.ocb2._times2,\n        w = sjcl.bitArray,\n        xor = w._xor4,\n        checksum = [0,0,0,0],\n        delta = times2(prp.encrypt(iv)),\n        bi, bl,\n        len = sjcl.bitArray.bitLength(ciphertext) - tlen,\n        output = [],\n        pad;\n        \n    adata = adata || [];\n  \n    for (i=0; i+4 < len/32; i+=4) {\n      /* Decrypt a non-final block */\n      bi = xor(delta, prp.decrypt(xor(delta, ciphertext.slice(i,i+4))));\n      checksum = xor(checksum, bi);\n      output = output.concat(bi);\n      delta = times2(delta);\n    }\n    \n    /* Chop out and decrypt the final block */\n    bl = len-i*32;\n    pad = prp.encrypt(xor(delta,[0,0,0,bl]));\n    bi = xor(pad, w.clamp(ciphertext.slice(i),bl).concat([0,0,0]));\n    \n    /* Checksum the final block, and finalize the checksum */\n    checksum = xor(checksum, bi);\n    checksum = prp.encrypt(xor(checksum, xor(delta, times2(delta))));\n    \n    /* MAC the header */\n    if (adata.length) {\n      checksum = xor(checksum, premac ? adata : sjcl.mode.ocb2.pmac(prp, adata));\n    }\n    \n    if (!w.equal(w.clamp(checksum, tlen), w.bitSlice(ciphertext, len))) {\n      throw new sjcl.exception.corrupt(\"ocb: tag doesn't match\");\n    }\n    \n    return output.concat(w.clamp(bi,bl));\n  },\n  \n  /** PMAC authentication for OCB associated data.\n   * @param {Object} prp The block cipher.  It must have a block size of 16 bytes.\n   * @param {bitArray} adata The authenticated data.\n   */\n  pmac: function(prp, adata) {\n    var i,\n        times2 = sjcl.mode.ocb2._times2,\n        w = sjcl.bitArray,\n        xor = w._xor4,\n        checksum = [0,0,0,0],\n        delta = prp.encrypt([0,0,0,0]),\n        bi;\n        \n    delta = xor(delta,times2(times2(delta)));\n \n    for (i=0; i+4<adata.length; i+=4) {\n      delta = times2(delta);\n      checksum = xor(checksum, prp.encrypt(xor(delta, adata.slice(i,i+4))));\n    }\n    \n    bi = adata.slice(i);\n    if (w.bitLength(bi) < 128) {\n      delta = xor(delta,times2(delta));\n      bi = w.concat(bi,[0x80000000|0,0,0,0]);\n    }\n    checksum = xor(checksum, bi);\n    return prp.encrypt(xor(times2(xor(delta,times2(delta))), checksum));\n  },\n  \n  /** Double a block of words, OCB style.\n   * @private\n   */\n  _times2: function(x) {\n    return [x[0]<<1 ^ x[1]>>>31,\n            x[1]<<1 ^ x[2]>>>31,\n            x[2]<<1 ^ x[3]>>>31,\n            x[3]<<1 ^ (x[0]>>>31)*0x87];\n  }\n};\n/** @fileOverview GCM mode implementation.\n *\n * @author Juho Vähä-Herttua\n */\n\n/** @namespace Galois/Counter mode. */\nsjcl.mode.gcm = {\n  /** The name of the mode.\n   * @constant\n   */\n  name: \"gcm\",\n  \n  /** Encrypt in GCM mode.\n   * @static\n   * @param {Object} prf The pseudorandom function.  It must have a block size of 16 bytes.\n   * @param {bitArray} plaintext The plaintext data.\n   * @param {bitArray} iv The initialization value.\n   * @param {bitArray} [adata=[]] The authenticated data.\n   * @param {Number} [tlen=128] The desired tag length, in bits.\n   * @return {bitArray} The encrypted data, an array of bytes.\n   */\n  encrypt: function (prf, plaintext, iv, adata, tlen) {\n    var out, data = plaintext.slice(0), w=sjcl.bitArray;\n    tlen = tlen || 128;\n    adata = adata || [];\n\n    // encrypt and tag\n    out = sjcl.mode.gcm._ctrMode(true, prf, data, adata, iv, tlen);\n\n    return w.concat(out.data, out.tag);\n  },\n  \n  /** Decrypt in GCM mode.\n   * @static\n   * @param {Object} prf The pseudorandom function.  It must have a block size of 16 bytes.\n   * @param {bitArray} ciphertext The ciphertext data.\n   * @param {bitArray} iv The initialization value.\n   * @param {bitArray} [adata=[]] The authenticated data.\n   * @param {Number} [tlen=128] The desired tag length, in bits.\n   * @return {bitArray} The decrypted data.\n   */\n  decrypt: function (prf, ciphertext, iv, adata, tlen) {\n    var out, data = ciphertext.slice(0), tag, w=sjcl.bitArray, l=w.bitLength(data);\n    tlen = tlen || 128;\n    adata = adata || [];\n\n    // Slice tag out of data\n    if (tlen <= l) {\n      tag = w.bitSlice(data, l-tlen);\n      data = w.bitSlice(data, 0, l-tlen);\n    } else {\n      tag = data;\n      data = [];\n    }\n\n    // decrypt and tag\n    out = sjcl.mode.gcm._ctrMode(false, prf, data, adata, iv, tlen);\n\n    if (!w.equal(out.tag, tag)) {\n      throw new sjcl.exception.corrupt(\"gcm: tag doesn't match\");\n    }\n    return out.data;\n  },\n\n  /* Compute the galois multiplication of X and Y\n   * @private\n   */\n  _galoisMultiply: function (x, y) {\n    var i, j, xi, Zi, Vi, lsb_Vi, w=sjcl.bitArray, xor=w._xor4;\n\n    Zi = [0,0,0,0];\n    Vi = y.slice(0);\n\n    // Block size is 128 bits, run 128 times to get Z_128\n    for (i=0; i<128; i++) {\n      xi = (x[Math.floor(i/32)] & (1 << (31-i%32))) !== 0;\n      if (xi) {\n        // Z_i+1 = Z_i ^ V_i\n        Zi = xor(Zi, Vi);\n      }\n\n      // Store the value of LSB(V_i)\n      lsb_Vi = (Vi[3] & 1) !== 0;\n\n      // V_i+1 = V_i >> 1\n      for (j=3; j>0; j--) {\n        Vi[j] = (Vi[j] >>> 1) | ((Vi[j-1]&1) << 31);\n      }\n      Vi[0] = Vi[0] >>> 1;\n\n      // If LSB(V_i) is 1, V_i+1 = (V_i >> 1) ^ R\n      if (lsb_Vi) {\n        Vi[0] = Vi[0] ^ (0xe1 << 24);\n      }\n    }\n    return Zi;\n  },\n\n  _ghash: function(H, Y0, data) {\n    var Yi, i, l = data.length;\n\n    Yi = Y0.slice(0);\n    for (i=0; i<l; i+=4) {\n      Yi[0] ^= 0xffffffff&data[i];\n      Yi[1] ^= 0xffffffff&data[i+1];\n      Yi[2] ^= 0xffffffff&data[i+2];\n      Yi[3] ^= 0xffffffff&data[i+3];\n      Yi = sjcl.mode.gcm._galoisMultiply(Yi, H);\n    }\n    return Yi;\n  },\n\n  /** GCM CTR mode.\n   * Encrypt or decrypt data and tag with the prf in GCM-style CTR mode.\n   * @param {Boolean} encrypt True if encrypt, false if decrypt.\n   * @param {Object} prf The PRF.\n   * @param {bitArray} data The data to be encrypted or decrypted.\n   * @param {bitArray} iv The initialization vector.\n   * @param {bitArray} adata The associated data to be tagged.\n   * @param {Number} tlen The length of the tag, in bits.\n   */\n  _ctrMode: function(encrypt, prf, data, adata, iv, tlen) {\n    var H, J0, S0, enc, i, ctr, tag, last, l, bl, abl, ivbl, w=sjcl.bitArray, xor=w._xor4;\n\n    // Calculate data lengths\n    l = data.length;\n    bl = w.bitLength(data);\n    abl = w.bitLength(adata);\n    ivbl = w.bitLength(iv);\n\n    // Calculate the parameters\n    H = prf.encrypt([0,0,0,0]);\n    if (ivbl === 96) {\n      J0 = iv.slice(0);\n      J0 = w.concat(J0, [1]);\n    } else {\n      J0 = sjcl.mode.gcm._ghash(H, [0,0,0,0], iv);\n      J0 = sjcl.mode.gcm._ghash(H, J0, [0,0,Math.floor(ivbl/0x100000000),ivbl&0xffffffff]);\n    }\n    S0 = sjcl.mode.gcm._ghash(H, [0,0,0,0], adata);\n\n    // Initialize ctr and tag\n    ctr = J0.slice(0);\n    tag = S0.slice(0);\n\n    // If decrypting, calculate hash\n    if (!encrypt) {\n      tag = sjcl.mode.gcm._ghash(H, S0, data);\n    }\n\n    // Encrypt all the data\n    for (i=0; i<l; i+=4) {\n       ctr[3]++;\n       enc = prf.encrypt(ctr);\n       data[i]   ^= enc[0];\n       data[i+1] ^= enc[1];\n       data[i+2] ^= enc[2];\n       data[i+3] ^= enc[3];\n    }\n    data = w.clamp(data, bl);\n\n    // If encrypting, calculate hash\n    if (encrypt) {\n      tag = sjcl.mode.gcm._ghash(H, S0, data);\n    }\n\n    // Calculate last block from bit lengths, ugly because bitwise operations are 32-bit\n    last = [\n      Math.floor(abl/0x100000000), abl&0xffffffff,\n      Math.floor(bl/0x100000000), bl&0xffffffff\n    ];\n\n    // Calculate the final tag block\n    tag = sjcl.mode.gcm._ghash(H, tag, last);\n    enc = prf.encrypt(J0);\n    tag[0] ^= enc[0];\n    tag[1] ^= enc[1];\n    tag[2] ^= enc[2];\n    tag[3] ^= enc[3];\n\n    return { tag:w.bitSlice(tag, 0, tlen), data:data };\n  }\n};\n/** @fileOverview HMAC implementation.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/** HMAC with the specified hash function.\n * @constructor\n * @param {bitArray} key the key for HMAC.\n * @param {Object} [hash=sjcl.hash.sha256] The hash function to use.\n */\nsjcl.misc.hmac = function (key, Hash) {\n  this._hash = Hash = Hash || sjcl.hash.sha256;\n  var exKey = [[],[]], i,\n      bs = Hash.prototype.blockSize / 32;\n  this._baseHash = [new Hash(), new Hash()];\n\n  if (key.length > bs) {\n    key = Hash.hash(key);\n  }\n  \n  for (i=0; i<bs; i++) {\n    exKey[0][i] = key[i]^0x36363636;\n    exKey[1][i] = key[i]^0x5C5C5C5C;\n  }\n  \n  this._baseHash[0].update(exKey[0]);\n  this._baseHash[1].update(exKey[1]);\n  this._resultHash = new Hash(this._baseHash[0]);\n};\n\n/** HMAC with the specified hash function.  Also called encrypt since it's a prf.\n * @param {bitArray|String} data The data to mac.\n */\nsjcl.misc.hmac.prototype.encrypt = sjcl.misc.hmac.prototype.mac = function (data) {\n  if (!this._updated) {\n    this.update(data);\n    return this.digest(data);\n  } else {\n    throw new sjcl.exception.invalid(\"encrypt on already updated hmac called!\");\n  }\n};\n\nsjcl.misc.hmac.prototype.reset = function () {\n  this._resultHash = new this._hash(this._baseHash[0]);\n  this._updated = false;\n};\n\nsjcl.misc.hmac.prototype.update = function (data) {\n  this._updated = true;\n  this._resultHash.update(data);\n};\n\nsjcl.misc.hmac.prototype.digest = function () {\n  var w = this._resultHash.finalize(), result = new (this._hash)(this._baseHash[1]).update(w).finalize();\n\n  this.reset();\n\n  return result;\n};/** @fileOverview Password-based key-derivation function, version 2.0.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n\n/** Password-Based Key-Derivation Function, version 2.0.\n *\n * Generate keys from passwords using PBKDF2-HMAC-SHA256.\n *\n * This is the method specified by RSA's PKCS #5 standard.\n *\n * @param {bitArray|String} password  The password.\n * @param {bitArray|String} salt The salt.  Should have lots of entropy.\n * @param {Number} [count=1000] The number of iterations.  Higher numbers make the function slower but more secure.\n * @param {Number} [length] The length of the derived key.  Defaults to the\n                            output size of the hash function.\n * @param {Object} [Prff=sjcl.misc.hmac] The pseudorandom function family.\n * @return {bitArray} the derived key.\n */\nsjcl.misc.pbkdf2 = function (password, salt, count, length, Prff) {\n  count = count || 1000;\n  \n  if (length < 0 || count < 0) {\n    throw sjcl.exception.invalid(\"invalid params to pbkdf2\");\n  }\n  \n  if (typeof password === \"string\") {\n    password = sjcl.codec.utf8String.toBits(password);\n  }\n  \n  if (typeof salt === \"string\") {\n    salt = sjcl.codec.utf8String.toBits(salt);\n  }\n  \n  Prff = Prff || sjcl.misc.hmac;\n  \n  var prf = new Prff(password),\n      u, ui, i, j, k, out = [], b = sjcl.bitArray;\n\n  for (k = 1; 32 * out.length < (length || 1); k++) {\n    u = ui = prf.encrypt(b.concat(salt,[k]));\n    \n    for (i=1; i<count; i++) {\n      ui = prf.encrypt(ui);\n      for (j=0; j<ui.length; j++) {\n        u[j] ^= ui[j];\n      }\n    }\n    \n    out = out.concat(u);\n  }\n\n  if (length) { out = b.clamp(out, length); }\n\n  return out;\n};\n/** @fileOverview Random number generator.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n * @author Michael Brooks\n */\n\n/** @constructor\n * @class Random number generator\n * @description\n * <b>Use sjcl.random as a singleton for this class!</b>\n * <p>\n * This random number generator is a derivative of Ferguson and Schneier's\n * generator Fortuna.  It collects entropy from various events into several\n * pools, implemented by streaming SHA-256 instances.  It differs from\n * ordinary Fortuna in a few ways, though.\n * </p>\n *\n * <p>\n * Most importantly, it has an entropy estimator.  This is present because\n * there is a strong conflict here between making the generator available\n * as soon as possible, and making sure that it doesn't \"run on empty\".\n * In Fortuna, there is a saved state file, and the system is likely to have\n * time to warm up.\n * </p>\n *\n * <p>\n * Second, because users are unlikely to stay on the page for very long,\n * and to speed startup time, the number of pools increases logarithmically:\n * a new pool is created when the previous one is actually used for a reseed.\n * This gives the same asymptotic guarantees as Fortuna, but gives more\n * entropy to early reseeds.\n * </p>\n *\n * <p>\n * The entire mechanism here feels pretty klunky.  Furthermore, there are\n * several improvements that should be made, including support for\n * dedicated cryptographic functions that may be present in some browsers;\n * state files in local storage; cookies containing randomness; etc.  So\n * look for improvements in future versions.\n * </p>\n */\nsjcl.prng = function(defaultParanoia) {\n  \n  /* private */\n  this._pools                   = [new sjcl.hash.sha256()];\n  this._poolEntropy             = [0];\n  this._reseedCount             = 0;\n  this._robins                  = {};\n  this._eventId                 = 0;\n  \n  this._collectorIds            = {};\n  this._collectorIdNext         = 0;\n  \n  this._strength                = 0;\n  this._poolStrength            = 0;\n  this._nextReseed              = 0;\n  this._key                     = [0,0,0,0,0,0,0,0];\n  this._counter                 = [0,0,0,0];\n  this._cipher                  = undefined;\n  this._defaultParanoia         = defaultParanoia;\n  \n  /* event listener stuff */\n  this._collectorsStarted       = false;\n  this._callbacks               = {progress: {}, seeded: {}};\n  this._callbackI               = 0;\n  \n  /* constants */\n  this._NOT_READY               = 0;\n  this._READY                   = 1;\n  this._REQUIRES_RESEED         = 2;\n\n  this._MAX_WORDS_PER_BURST     = 65536;\n  this._PARANOIA_LEVELS         = [0,48,64,96,128,192,256,384,512,768,1024];\n  this._MILLISECONDS_PER_RESEED = 30000;\n  this._BITS_PER_RESEED         = 80;\n};\n \nsjcl.prng.prototype = {\n  /** Generate several random words, and return them in an array.\n   * A word consists of 32 bits (4 bytes)\n   * @param {Number} nwords The number of words to generate.\n   */\n  randomWords: function (nwords, paranoia) {\n    var out = [], i, readiness = this.isReady(paranoia), g;\n  \n    if (readiness === this._NOT_READY) {\n      throw new sjcl.exception.notReady(\"generator isn't seeded\");\n    } else if (readiness & this._REQUIRES_RESEED) {\n      this._reseedFromPools(!(readiness & this._READY));\n    }\n  \n    for (i=0; i<nwords; i+= 4) {\n      if ((i+1) % this._MAX_WORDS_PER_BURST === 0) {\n        this._gate();\n      }\n   \n      g = this._gen4words();\n      out.push(g[0],g[1],g[2],g[3]);\n    }\n    this._gate();\n  \n    return out.slice(0,nwords);\n  },\n  \n  setDefaultParanoia: function (paranoia, allowZeroParanoia) {\n    if (paranoia === 0 && allowZeroParanoia !== \"Setting paranoia=0 will ruin your security; use it only for testing\") {\n      throw \"Setting paranoia=0 will ruin your security; use it only for testing\";\n    }\n\n    this._defaultParanoia = paranoia;\n  },\n  \n  /**\n   * Add entropy to the pools.\n   * @param data The entropic value.  Should be a 32-bit integer, array of 32-bit integers, or string\n   * @param {Number} estimatedEntropy The estimated entropy of data, in bits\n   * @param {String} source The source of the entropy, eg \"mouse\"\n   */\n  addEntropy: function (data, estimatedEntropy, source) {\n    source = source || \"user\";\n  \n    var id,\n      i, tmp,\n      t = (new Date()).valueOf(),\n      robin = this._robins[source],\n      oldReady = this.isReady(), err = 0, objName;\n      \n    id = this._collectorIds[source];\n    if (id === undefined) { id = this._collectorIds[source] = this._collectorIdNext ++; }\n      \n    if (robin === undefined) { robin = this._robins[source] = 0; }\n    this._robins[source] = ( this._robins[source] + 1 ) % this._pools.length;\n  \n    switch(typeof(data)) {\n      \n    case \"number\":\n      if (estimatedEntropy === undefined) {\n        estimatedEntropy = 1;\n      }\n      this._pools[robin].update([id,this._eventId++,1,estimatedEntropy,t,1,data|0]);\n      break;\n      \n    case \"object\":\n      objName = Object.prototype.toString.call(data);\n      if (objName === \"[object Uint32Array]\") {\n        tmp = [];\n        for (i = 0; i < data.length; i++) {\n          tmp.push(data[i]);\n        }\n        data = tmp;\n      } else {\n        if (typeof data.length !== \"number\") {\n          err = 1;\n        }\n        for (i=0; i<data.length && !err; i++) {\n          if (typeof(data[i]) !== \"number\") {\n            err = 1;\n          }\n        }\n      }\n      if (!err) {\n        if (estimatedEntropy === undefined) {\n          /* horrible entropy estimator */\n          estimatedEntropy = 0;\n          for (i=0; i<data.length; i++) {\n            tmp= data[i];\n            while (tmp>0) {\n              estimatedEntropy++;\n              tmp = tmp >>> 1;\n            }\n          }\n        }\n        this._pools[robin].update([id,this._eventId++,2,estimatedEntropy,t,data.length].concat(data));\n      }\n      break;\n      \n    case \"string\":\n      if (estimatedEntropy === undefined) {\n       /* English text has just over 1 bit per character of entropy.\n        * But this might be HTML or something, and have far less\n        * entropy than English...  Oh well, let's just say one bit.\n        */\n       estimatedEntropy = data.length;\n      }\n      this._pools[robin].update([id,this._eventId++,3,estimatedEntropy,t,data.length]);\n      this._pools[robin].update(data);\n      break;\n      \n    default:\n      err=1;\n    }\n    if (err) {\n      throw new sjcl.exception.bug(\"random: addEntropy only supports number, array of numbers or string\");\n    }\n  \n    /* record the new strength */\n    this._poolEntropy[robin] += estimatedEntropy;\n    this._poolStrength += estimatedEntropy;\n  \n    /* fire off events */\n    if (oldReady === this._NOT_READY) {\n      if (this.isReady() !== this._NOT_READY) {\n        this._fireEvent(\"seeded\", Math.max(this._strength, this._poolStrength));\n      }\n      this._fireEvent(\"progress\", this.getProgress());\n    }\n  },\n  \n  /** Is the generator ready? */\n  isReady: function (paranoia) {\n    var entropyRequired = this._PARANOIA_LEVELS[ (paranoia !== undefined) ? paranoia : this._defaultParanoia ];\n  \n    if (this._strength && this._strength >= entropyRequired) {\n      return (this._poolEntropy[0] > this._BITS_PER_RESEED && (new Date()).valueOf() > this._nextReseed) ?\n        this._REQUIRES_RESEED | this._READY :\n        this._READY;\n    } else {\n      return (this._poolStrength >= entropyRequired) ?\n        this._REQUIRES_RESEED | this._NOT_READY :\n        this._NOT_READY;\n    }\n  },\n  \n  /** Get the generator's progress toward readiness, as a fraction */\n  getProgress: function (paranoia) {\n    var entropyRequired = this._PARANOIA_LEVELS[ paranoia ? paranoia : this._defaultParanoia ];\n  \n    if (this._strength >= entropyRequired) {\n      return 1.0;\n    } else {\n      return (this._poolStrength > entropyRequired) ?\n        1.0 :\n        this._poolStrength / entropyRequired;\n    }\n  },\n  \n  /** start the built-in entropy collectors */\n  startCollectors: function () {\n    if (this._collectorsStarted) { return; }\n  \n    this._eventListener = {\n      loadTimeCollector: this._bind(this._loadTimeCollector),\n      mouseCollector: this._bind(this._mouseCollector),\n      keyboardCollector: this._bind(this._keyboardCollector),\n      accelerometerCollector: this._bind(this._accelerometerCollector)\n    }\n\n    if (window.addEventListener) {\n      window.addEventListener(\"load\", this._eventListener.loadTimeCollector, false);\n      window.addEventListener(\"mousemove\", this._eventListener.mouseCollector, false);\n      window.addEventListener(\"keypress\", this._eventListener.keyboardCollector, false);\n      window.addEventListener(\"devicemotion\", this._eventListener.accelerometerCollector, false);\n    } else if (document.attachEvent) {\n      document.attachEvent(\"onload\", this._eventListener.loadTimeCollector);\n      document.attachEvent(\"onmousemove\", this._eventListener.mouseCollector);\n      document.attachEvent(\"keypress\", this._eventListener.keyboardCollector);\n    } else {\n      throw new sjcl.exception.bug(\"can't attach event\");\n    }\n  \n    this._collectorsStarted = true;\n  },\n  \n  /** stop the built-in entropy collectors */\n  stopCollectors: function () {\n    if (!this._collectorsStarted) { return; }\n  \n    if (window.removeEventListener) {\n      window.removeEventListener(\"load\", this._eventListener.loadTimeCollector, false);\n      window.removeEventListener(\"mousemove\", this._eventListener.mouseCollector, false);\n      window.removeEventListener(\"keypress\", this._eventListener.keyboardCollector, false);\n      window.removeEventListener(\"devicemotion\", this._eventListener.accelerometerCollector, false);\n    } else if (document.detachEvent) {\n      document.detachEvent(\"onload\", this._eventListener.loadTimeCollector);\n      document.detachEvent(\"onmousemove\", this._eventListener.mouseCollector);\n      document.detachEvent(\"keypress\", this._eventListener.keyboardCollector);\n    }\n\n    this._collectorsStarted = false;\n  },\n  \n  /* use a cookie to store entropy.\n  useCookie: function (all_cookies) {\n      throw new sjcl.exception.bug(\"random: useCookie is unimplemented\");\n  },*/\n  \n  /** add an event listener for progress or seeded-ness. */\n  addEventListener: function (name, callback) {\n    this._callbacks[name][this._callbackI++] = callback;\n  },\n  \n  /** remove an event listener for progress or seeded-ness */\n  removeEventListener: function (name, cb) {\n    var i, j, cbs=this._callbacks[name], jsTemp=[];\n\n    /* I'm not sure if this is necessary; in C++, iterating over a\n     * collection and modifying it at the same time is a no-no.\n     */\n\n    for (j in cbs) {\n      if (cbs.hasOwnProperty(j) && cbs[j] === cb) {\n        jsTemp.push(j);\n      }\n    }\n\n    for (i=0; i<jsTemp.length; i++) {\n      j = jsTemp[i];\n      delete cbs[j];\n    }\n  },\n  \n  _bind: function (func) {\n    var that = this;\n    return function () {\n      func.apply(that, arguments);\n    };\n  },\n\n  /** Generate 4 random words, no reseed, no gate.\n   * @private\n   */\n  _gen4words: function () {\n    for (var i=0; i<4; i++) {\n      this._counter[i] = this._counter[i]+1 | 0;\n      if (this._counter[i]) { break; }\n    }\n    return this._cipher.encrypt(this._counter);\n  },\n  \n  /* Rekey the AES instance with itself after a request, or every _MAX_WORDS_PER_BURST words.\n   * @private\n   */\n  _gate: function () {\n    this._key = this._gen4words().concat(this._gen4words());\n    this._cipher = new sjcl.cipher.aes(this._key);\n  },\n  \n  /** Reseed the generator with the given words\n   * @private\n   */\n  _reseed: function (seedWords) {\n    this._key = sjcl.hash.sha256.hash(this._key.concat(seedWords));\n    this._cipher = new sjcl.cipher.aes(this._key);\n    for (var i=0; i<4; i++) {\n      this._counter[i] = this._counter[i]+1 | 0;\n      if (this._counter[i]) { break; }\n    }\n  },\n  \n  /** reseed the data from the entropy pools\n   * @param full If set, use all the entropy pools in the reseed.\n   */\n  _reseedFromPools: function (full) {\n    var reseedData = [], strength = 0, i;\n  \n    this._nextReseed = reseedData[0] =\n      (new Date()).valueOf() + this._MILLISECONDS_PER_RESEED;\n    \n    for (i=0; i<16; i++) {\n      /* On some browsers, this is cryptographically random.  So we might\n       * as well toss it in the pot and stir...\n       */\n      reseedData.push(Math.random()*0x100000000|0);\n    }\n    \n    for (i=0; i<this._pools.length; i++) {\n     reseedData = reseedData.concat(this._pools[i].finalize());\n     strength += this._poolEntropy[i];\n     this._poolEntropy[i] = 0;\n   \n     if (!full && (this._reseedCount & (1<<i))) { break; }\n    }\n  \n    /* if we used the last pool, push a new one onto the stack */\n    if (this._reseedCount >= 1 << this._pools.length) {\n     this._pools.push(new sjcl.hash.sha256());\n     this._poolEntropy.push(0);\n    }\n  \n    /* how strong was this reseed? */\n    this._poolStrength -= strength;\n    if (strength > this._strength) {\n      this._strength = strength;\n    }\n  \n    this._reseedCount ++;\n    this._reseed(reseedData);\n  },\n  \n  _keyboardCollector: function () {\n    this._addCurrentTimeToEntropy(1);\n  },\n  \n  _mouseCollector: function (ev) {\n    var x = ev.x || ev.clientX || ev.offsetX || 0, y = ev.y || ev.clientY || ev.offsetY || 0;\n    sjcl.random.addEntropy([x,y], 2, \"mouse\");\n    this._addCurrentTimeToEntropy(0);\n  },\n  \n  _loadTimeCollector: function () {\n    this._addCurrentTimeToEntropy(2);\n  },\n\n  _addCurrentTimeToEntropy: function (estimatedEntropy) {\n    if (window && window.performance && typeof window.performance.now === \"function\") {\n      //how much entropy do we want to add here?\n      sjcl.random.addEntropy(window.performance.now(), estimatedEntropy, \"loadtime\");\n    } else {\n      sjcl.random.addEntropy((new Date()).valueOf(), estimatedEntropy, \"loadtime\");\n    }\n  },\n  _accelerometerCollector: function (ev) {\n    var ac = ev.accelerationIncludingGravity.x||ev.accelerationIncludingGravity.y||ev.accelerationIncludingGravity.z;\n    var or = \"\";\n    if(window.orientation){\n      or = window.orientation;\n    }\n    sjcl.random.addEntropy([ac,or], 3, \"accelerometer\");\n    this._addCurrentTimeToEntropy(0);\n  },\n\n  _fireEvent: function (name, arg) {\n    var j, cbs=sjcl.random._callbacks[name], cbsTemp=[];\n    /* TODO: there is a race condition between removing collectors and firing them */\n\n    /* I'm not sure if this is necessary; in C++, iterating over a\n     * collection and modifying it at the same time is a no-no.\n     */\n\n    for (j in cbs) {\n      if (cbs.hasOwnProperty(j)) {\n        cbsTemp.push(cbs[j]);\n      }\n    }\n\n    for (j=0; j<cbsTemp.length; j++) {\n      cbsTemp[j](arg);\n    }\n  }\n};\n\n/** an instance for the prng.\n* @see sjcl.prng\n*/\nsjcl.random = new sjcl.prng(6);\n\n(function(){\n  try {\n    var buf, crypt, getRandomValues, ab;\n\n\n\n\n    // get cryptographically strong entropy depending on runtime environment\n    if (typeof module !== 'undefined' && module.exports && (crypt = require('crypto')) && crypt.randomBytes) {\n      buf = crypt.randomBytes(1024/8);\n\n      sjcl.random.addEntropy(buf.slice(), 1024, \"crypto.randomBytes\");\n\n    } else if (window && Uint32Array) {\n      ab = new Uint32Array(32);\n      if (window.crypto && window.crypto.getRandomValues) {\n        window.crypto.getRandomValues(ab);\n      } else if (window.msCrypto && window.msCrypto.getRandomValues) {\n        window.msCrypto.getRandomValues(ab);\n      } else {\n        return;\n      }\n\n      // get cryptographically strong entropy in Webkit\n      sjcl.random.addEntropy(ab, 1024, \"crypto.getRandomValues\");\n\n    } else {\n      // no getRandomValues :-(\n    }\n  } catch (e) {\n    console.log(\"There was an error collecting entropy from the browser:\");\n    console.log(e);\n    //we do not want the library to fail due to randomness not being maintained.\n  }\n}());\n/** @fileOverview Convenince functions centered around JSON encapsulation.\n *\n * @author Emily Stark\n * @author Mike Hamburg\n * @author Dan Boneh\n */\n \n /** @namespace JSON encapsulation */\n sjcl.json = {\n  /** Default values for encryption */\n  defaults: { v:1, iter:1000, ks:128, ts:64, mode:\"ccm\", adata:\"\", cipher:\"aes\" },\n\n  /** Simple encryption function.\n   * @param {String|bitArray} password The password or key.\n   * @param {String} plaintext The data to encrypt.\n   * @param {Object} [params] The parameters including tag, iv and salt.\n   * @param {Object} [rp] A returned version with filled-in parameters.\n   * @return {Object} The cipher raw data.\n   * @throws {sjcl.exception.invalid} if a parameter is invalid.\n   */\n  _encrypt: function (password, plaintext, params, rp) {\n    params = params || {};\n    rp = rp || {};\n\n    var j = sjcl.json, p = j._add({ iv: sjcl.random.randomWords(4,0) },\n                                  j.defaults), tmp, prp, adata;\n    j._add(p, params);\n    adata = p.adata;\n    if (typeof p.salt === \"string\") {\n      p.salt = sjcl.codec.base64.toBits(p.salt);\n    }\n    if (typeof p.iv === \"string\") {\n      p.iv = sjcl.codec.base64.toBits(p.iv);\n    }\n\n    if (!sjcl.mode[p.mode] ||\n        !sjcl.cipher[p.cipher] ||\n        (typeof password === \"string\" && p.iter <= 100) ||\n        (p.ts !== 64 && p.ts !== 96 && p.ts !== 128) ||\n        (p.ks !== 128 && p.ks !== 192 && p.ks !== 256) ||\n        (p.iv.length < 2 || p.iv.length > 4)) {\n      throw new sjcl.exception.invalid(\"json encrypt: invalid parameters\");\n    }\n\n    if (typeof password === \"string\") {\n      tmp = sjcl.misc.cachedPbkdf2(password, p);\n      password = tmp.key.slice(0,p.ks/32);\n      p.salt = tmp.salt;\n    } else if (sjcl.ecc && password instanceof sjcl.ecc.elGamal.publicKey) {\n      tmp = password.kem();\n      p.kemtag = tmp.tag;\n      password = tmp.key.slice(0,p.ks/32);\n    }\n    if (typeof plaintext === \"string\") {\n      plaintext = sjcl.codec.utf8String.toBits(plaintext);\n    }\n    if (typeof adata === \"string\") {\n      adata = sjcl.codec.utf8String.toBits(adata);\n    }\n    prp = new sjcl.cipher[p.cipher](password);\n\n    /* return the json data */\n    j._add(rp, p);\n    rp.key = password;\n\n    /* do the encryption */\n    p.ct = sjcl.mode[p.mode].encrypt(prp, plaintext, p.iv, adata, p.ts);\n\n    //return j.encode(j._subtract(p, j.defaults));\n    return p;\n  },\n\n  /** Simple encryption function.\n   * @param {String|bitArray} password The password or key.\n   * @param {String} plaintext The data to encrypt.\n   * @param {Object} [params] The parameters including tag, iv and salt.\n   * @param {Object} [rp] A returned version with filled-in parameters.\n   * @return {String} The ciphertext serialized data.\n   * @throws {sjcl.exception.invalid} if a parameter is invalid.\n   */\n  encrypt: function (password, plaintext, params, rp) {\n    var j = sjcl.json, p = j._encrypt.apply(j, arguments);\n    return j.encode(p);\n  },\n\n  /** Simple decryption function.\n   * @param {String|bitArray} password The password or key.\n   * @param {Object} ciphertext The cipher raw data to decrypt.\n   * @param {Object} [params] Additional non-default parameters.\n   * @param {Object} [rp] A returned object with filled parameters.\n   * @return {String} The plaintext.\n   * @throws {sjcl.exception.invalid} if a parameter is invalid.\n   * @throws {sjcl.exception.corrupt} if the ciphertext is corrupt.\n   */\n  _decrypt: function (password, ciphertext, params, rp) {\n    params = params || {};\n    rp = rp || {};\n\n    var j = sjcl.json, p = j._add(j._add(j._add({},j.defaults),ciphertext), params, true), ct, tmp, prp, adata=p.adata;\n    if (typeof p.salt === \"string\") {\n      p.salt = sjcl.codec.base64.toBits(p.salt);\n    }\n    if (typeof p.iv === \"string\") {\n      p.iv = sjcl.codec.base64.toBits(p.iv);\n    }\n\n    if (!sjcl.mode[p.mode] ||\n        !sjcl.cipher[p.cipher] ||\n        (typeof password === \"string\" && p.iter <= 100) ||\n        (p.ts !== 64 && p.ts !== 96 && p.ts !== 128) ||\n        (p.ks !== 128 && p.ks !== 192 && p.ks !== 256) ||\n        (!p.iv) ||\n        (p.iv.length < 2 || p.iv.length > 4)) {\n      throw new sjcl.exception.invalid(\"json decrypt: invalid parameters\");\n    }\n\n    if (typeof password === \"string\") {\n      tmp = sjcl.misc.cachedPbkdf2(password, p);\n      password = tmp.key.slice(0,p.ks/32);\n      p.salt  = tmp.salt;\n    } else if (sjcl.ecc && password instanceof sjcl.ecc.elGamal.secretKey) {\n      password = password.unkem(sjcl.codec.base64.toBits(p.kemtag)).slice(0,p.ks/32);\n    }\n    if (typeof adata === \"string\") {\n      adata = sjcl.codec.utf8String.toBits(adata);\n    }\n    prp = new sjcl.cipher[p.cipher](password);\n\n    /* do the decryption */\n    ct = sjcl.mode[p.mode].decrypt(prp, p.ct, p.iv, adata, p.ts);\n\n    /* return the json data */\n    j._add(rp, p);\n    rp.key = password;\n\n    return sjcl.codec.utf8String.fromBits(ct);\n  },\n\n  /** Simple decryption function.\n   * @param {String|bitArray} password The password or key.\n   * @param {String} ciphertext The ciphertext to decrypt.\n   * @param {Object} [params] Additional non-default parameters.\n   * @param {Object} [rp] A returned object with filled parameters.\n   * @return {String} The plaintext.\n   * @throws {sjcl.exception.invalid} if a parameter is invalid.\n   * @throws {sjcl.exception.corrupt} if the ciphertext is corrupt.\n   */\n  decrypt: function (password, ciphertext, params, rp) {\n    var j = sjcl.json;\n    return j._decrypt(password, j.decode(ciphertext), params, rp);\n  },\n  \n  /** Encode a flat structure into a JSON string.\n   * @param {Object} obj The structure to encode.\n   * @return {String} A JSON string.\n   * @throws {sjcl.exception.invalid} if obj has a non-alphanumeric property.\n   * @throws {sjcl.exception.bug} if a parameter has an unsupported type.\n   */\n  encode: function (obj) {\n    var i, out='{', comma='';\n    for (i in obj) {\n      if (obj.hasOwnProperty(i)) {\n        if (!i.match(/^[a-z0-9]+$/i)) {\n          throw new sjcl.exception.invalid(\"json encode: invalid property name\");\n        }\n        out += comma + '\"' + i + '\":';\n        comma = ',';\n\n        switch (typeof obj[i]) {\n          case 'number':\n          case 'boolean':\n            out += obj[i];\n            break;\n\n          case 'string':\n            out += '\"' + escape(obj[i]) + '\"';\n            break;\n\n          case 'object':\n            out += '\"' + sjcl.codec.base64.fromBits(obj[i],0) + '\"';\n            break;\n\n          default:\n            throw new sjcl.exception.bug(\"json encode: unsupported type\");\n        }\n      }\n    }\n    return out+'}';\n  },\n  \n  /** Decode a simple (flat) JSON string into a structure.  The ciphertext,\n   * adata, salt and iv will be base64-decoded.\n   * @param {String} str The string.\n   * @return {Object} The decoded structure.\n   * @throws {sjcl.exception.invalid} if str isn't (simple) JSON.\n   */\n  decode: function (str) {\n    str = str.replace(/\\s/g,'');\n    if (!str.match(/^\\{.*\\}$/)) { \n      throw new sjcl.exception.invalid(\"json decode: this isn't json!\");\n    }\n    var a = str.replace(/^\\{|\\}$/g, '').split(/,/), out={}, i, m;\n    for (i=0; i<a.length; i++) {\n      if (!(m=a[i].match(/^(?:([\"']?)([a-z][a-z0-9]*)\\1):(?:(\\d+)|\"([a-z0-9+\\/%*_.@=\\-]*)\")$/i))) {\n        throw new sjcl.exception.invalid(\"json decode: this isn't json!\");\n      }\n      if (m[3]) {\n        out[m[2]] = parseInt(m[3],10);\n      } else {\n        out[m[2]] = m[2].match(/^(ct|salt|iv)$/) ? sjcl.codec.base64.toBits(m[4]) : unescape(m[4]);\n      }\n    }\n    return out;\n  },\n  \n  /** Insert all elements of src into target, modifying and returning target.\n   * @param {Object} target The object to be modified.\n   * @param {Object} src The object to pull data from.\n   * @param {boolean} [requireSame=false] If true, throw an exception if any field of target differs from corresponding field of src.\n   * @return {Object} target.\n   * @private\n   */\n  _add: function (target, src, requireSame) {\n    if (target === undefined) { target = {}; }\n    if (src === undefined) { return target; }\n    var i;\n    for (i in src) {\n      if (src.hasOwnProperty(i)) {\n        if (requireSame && target[i] !== undefined && target[i] !== src[i]) {\n          throw new sjcl.exception.invalid(\"required parameter overridden\");\n        }\n        target[i] = src[i];\n      }\n    }\n    return target;\n  },\n  \n  /** Remove all elements of minus from plus.  Does not modify plus.\n   * @private\n   */\n  _subtract: function (plus, minus) {\n    var out = {}, i;\n\n    for (i in plus) {\n      if (plus.hasOwnProperty(i) && plus[i] !== minus[i]) {\n        out[i] = plus[i];\n      }\n    }\n\n    return out;\n  },\n  \n  /** Return only the specified elements of src.\n   * @private\n   */\n  _filter: function (src, filter) {\n    var out = {}, i;\n    for (i=0; i<filter.length; i++) {\n      if (src[filter[i]] !== undefined) {\n        out[filter[i]] = src[filter[i]];\n      }\n    }\n    return out;\n  }\n};\n\n/** Simple encryption function; convenient shorthand for sjcl.json.encrypt.\n * @param {String|bitArray} password The password or key.\n * @param {String} plaintext The data to encrypt.\n * @param {Object} [params] The parameters including tag, iv and salt.\n * @param {Object} [rp] A returned version with filled-in parameters.\n * @return {String} The ciphertext.\n */\nsjcl.encrypt = sjcl.json.encrypt;\n\n/** Simple decryption function; convenient shorthand for sjcl.json.decrypt.\n * @param {String|bitArray} password The password or key.\n * @param {String} ciphertext The ciphertext to decrypt.\n * @param {Object} [params] Additional non-default parameters.\n * @param {Object} [rp] A returned object with filled parameters.\n * @return {String} The plaintext.\n */\nsjcl.decrypt = sjcl.json.decrypt;\n\n/** The cache for cachedPbkdf2.\n * @private\n */\nsjcl.misc._pbkdf2Cache = {};\n\n/** Cached PBKDF2 key derivation.\n * @param {String} password The password.\n * @param {Object} [obj] The derivation params (iteration count and optional salt).\n * @return {Object} The derived data in key, the salt in salt.\n */\nsjcl.misc.cachedPbkdf2 = function (password, obj) {\n  var cache = sjcl.misc._pbkdf2Cache, c, cp, str, salt, iter;\n  \n  obj = obj || {};\n  iter = obj.iter || 1000;\n  \n  /* open the cache for this password and iteration count */\n  cp = cache[password] = cache[password] || {};\n  c = cp[iter] = cp[iter] || { firstSalt: (obj.salt && obj.salt.length) ?\n                     obj.salt.slice(0) : sjcl.random.randomWords(2,0) };\n          \n  salt = (obj.salt === undefined) ? c.firstSalt : obj.salt;\n  \n  c[salt] = c[salt] || sjcl.misc.pbkdf2(password, salt, obj.iter);\n  return { key: c[salt].slice(0), salt:salt.slice(0) };\n};\n\n\n/**\n * @constructor\n * Constructs a new bignum from another bignum, a number or a hex string.\n */\nsjcl.bn = function(it) {\n  this.initWith(it);\n};\n\nsjcl.bn.prototype = {\n  radix: 24,\n  maxMul: 8,\n  _class: sjcl.bn,\n  \n  copy: function() {\n    return new this._class(this);\n  },\n\n  /**\n   * Initializes this with it, either as a bn, a number, or a hex string.\n   */\n  initWith: function(it) {\n    var i=0, k, n, l;\n    switch(typeof it) {\n    case \"object\":\n      this.limbs = it.limbs.slice(0);\n      break;\n      \n    case \"number\":\n      this.limbs = [it];\n      this.normalize();\n      break;\n      \n    case \"string\":\n      it = it.replace(/^0x/, '');\n      this.limbs = [];\n      // hack\n      k = this.radix / 4;\n      for (i=0; i < it.length; i+=k) {\n        this.limbs.push(parseInt(it.substring(Math.max(it.length - i - k, 0), it.length - i),16));\n      }\n      break;\n\n    default:\n      this.limbs = [0];\n    }\n    return this;\n  },\n\n  /**\n   * Returns true if \"this\" and \"that\" are equal.  Calls fullReduce().\n   * Equality test is in constant time.\n   */\n  equals: function(that) {\n    if (typeof that === \"number\") { that = new this._class(that); }\n    var difference = 0, i;\n    this.fullReduce();\n    that.fullReduce();\n    for (i = 0; i < this.limbs.length || i < that.limbs.length; i++) {\n      difference |= this.getLimb(i) ^ that.getLimb(i);\n    }\n    return (difference === 0);\n  },\n  \n  /**\n   * Get the i'th limb of this, zero if i is too large.\n   */\n  getLimb: function(i) {\n    return (i >= this.limbs.length) ? 0 : this.limbs[i];\n  },\n  \n  /**\n   * Constant time comparison function.\n   * Returns 1 if this >= that, or zero otherwise.\n   */\n  greaterEquals: function(that) {\n    if (typeof that === \"number\") { that = new this._class(that); }\n    var less = 0, greater = 0, i, a, b;\n    i = Math.max(this.limbs.length, that.limbs.length) - 1;\n    for (; i>= 0; i--) {\n      a = this.getLimb(i);\n      b = that.getLimb(i);\n      greater |= (b - a) & ~less;\n      less |= (a - b) & ~greater;\n    }\n    return (greater | ~less) >>> 31;\n  },\n  \n  /**\n   * Convert to a hex string.\n   */\n  toString: function() {\n    this.fullReduce();\n    var out=\"\", i, s, l = this.limbs;\n    for (i=0; i < this.limbs.length; i++) {\n      s = l[i].toString(16);\n      while (i < this.limbs.length - 1 && s.length < 6) {\n        s = \"0\" + s;\n      }\n      out = s + out;\n    }\n    return \"0x\"+out;\n  },\n  \n  /** this += that.  Does not normalize. */\n  addM: function(that) {\n    if (typeof(that) !== \"object\") { that = new this._class(that); }\n    var i, l=this.limbs, ll=that.limbs;\n    for (i=l.length; i<ll.length; i++) {\n      l[i] = 0;\n    }\n    for (i=0; i<ll.length; i++) {\n      l[i] += ll[i];\n    }\n    return this;\n  },\n  \n  /** this *= 2.  Requires normalized; ends up normalized. */\n  doubleM: function() {\n    var i, carry=0, tmp, r=this.radix, m=this.radixMask, l=this.limbs;\n    for (i=0; i<l.length; i++) {\n      tmp = l[i];\n      tmp = tmp+tmp+carry;\n      l[i] = tmp & m;\n      carry = tmp >> r;\n    }\n    if (carry) {\n      l.push(carry);\n    }\n    return this;\n  },\n  \n  /** this /= 2, rounded down.  Requires normalized; ends up normalized. */\n  halveM: function() {\n    var i, carry=0, tmp, r=this.radix, l=this.limbs;\n    for (i=l.length-1; i>=0; i--) {\n      tmp = l[i];\n      l[i] = (tmp+carry)>>1;\n      carry = (tmp&1) << r;\n    }\n    if (!l[l.length-1]) {\n      l.pop();\n    }\n    return this;\n  },\n\n  /** this -= that.  Does not normalize. */\n  subM: function(that) {\n    if (typeof(that) !== \"object\") { that = new this._class(that); }\n    var i, l=this.limbs, ll=that.limbs;\n    for (i=l.length; i<ll.length; i++) {\n      l[i] = 0;\n    }\n    for (i=0; i<ll.length; i++) {\n      l[i] -= ll[i];\n    }\n    return this;\n  },\n  \n  mod: function(that) {\n    var neg = !this.greaterEquals(new sjcl.bn(0));\n    \n    that = new sjcl.bn(that).normalize(); // copy before we begin\n    var out = new sjcl.bn(this).normalize(), ci=0;\n    \n    if (neg) out = (new sjcl.bn(0)).subM(out).normalize();\n    \n    for (; out.greaterEquals(that); ci++) {\n      that.doubleM();\n    }\n    \n    if (neg) out = that.sub(out).normalize();\n    \n    for (; ci > 0; ci--) {\n      that.halveM();\n      if (out.greaterEquals(that)) {\n        out.subM(that).normalize();\n      }\n    }\n    return out.trim();\n  },\n  \n  /** return inverse mod prime p.  p must be odd. Binary extended Euclidean algorithm mod p. */\n  inverseMod: function(p) {\n    var a = new sjcl.bn(1), b = new sjcl.bn(0), x = new sjcl.bn(this), y = new sjcl.bn(p), tmp, i, nz=1;\n    \n    if (!(p.limbs[0] & 1)) {\n      throw (new sjcl.exception.invalid(\"inverseMod: p must be odd\"));\n    }\n    \n    // invariant: y is odd\n    do {\n      if (x.limbs[0] & 1) {\n        if (!x.greaterEquals(y)) {\n          // x < y; swap everything\n          tmp = x; x = y; y = tmp;\n          tmp = a; a = b; b = tmp;\n        }\n        x.subM(y);\n        x.normalize();\n        \n        if (!a.greaterEquals(b)) {\n          a.addM(p);\n        }\n        a.subM(b);\n      }\n      \n      // cut everything in half\n      x.halveM();\n      if (a.limbs[0] & 1) {\n        a.addM(p);\n      }\n      a.normalize();\n      a.halveM();\n      \n      // check for termination: x ?= 0\n      for (i=nz=0; i<x.limbs.length; i++) {\n        nz |= x.limbs[i];\n      }\n    } while(nz);\n    \n    if (!y.equals(1)) {\n      throw (new sjcl.exception.invalid(\"inverseMod: p and x must be relatively prime\"));\n    }\n    \n    return b;\n  },\n  \n  /** this + that.  Does not normalize. */\n  add: function(that) {\n    return this.copy().addM(that);\n  },\n\n  /** this - that.  Does not normalize. */\n  sub: function(that) {\n    return this.copy().subM(that);\n  },\n  \n  /** this * that.  Normalizes and reduces. */\n  mul: function(that) {\n    if (typeof(that) === \"number\") { that = new this._class(that); }\n    var i, j, a = this.limbs, b = that.limbs, al = a.length, bl = b.length, out = new this._class(), c = out.limbs, ai, ii=this.maxMul;\n\n    for (i=0; i < this.limbs.length + that.limbs.length + 1; i++) {\n      c[i] = 0;\n    }\n    for (i=0; i<al; i++) {\n      ai = a[i];\n      for (j=0; j<bl; j++) {\n        c[i+j] += ai * b[j];\n      }\n     \n      if (!--ii) {\n        ii = this.maxMul;\n        out.cnormalize();\n      }\n    }\n    return out.cnormalize().reduce();\n  },\n\n  /** this ^ 2.  Normalizes and reduces. */\n  square: function() {\n    return this.mul(this);\n  },\n\n  /** this ^ n.  Uses square-and-multiply.  Normalizes and reduces. */\n  power: function(l) {\n    if (typeof(l) === \"number\") {\n      l = [l];\n    } else if (l.limbs !== undefined) {\n      l = l.normalize().limbs;\n    }\n    var i, j, out = new this._class(1), pow = this;\n\n    for (i=0; i<l.length; i++) {\n      for (j=0; j<this.radix; j++) {\n        if (l[i] & (1<<j)) {\n          out = out.mul(pow);\n        }\n        pow = pow.square();\n      }\n    }\n    \n    return out;\n  },\n\n  /** this * that mod N */\n  mulmod: function(that, N) {\n    return this.mod(N).mul(that.mod(N)).mod(N);\n  },\n\n  /** this ^ x mod N */\n  powermod: function(x, N) {\n    var result = new sjcl.bn(1), a = new sjcl.bn(this), k = new sjcl.bn(x);\n    while (true) {\n      if (k.limbs[0] & 1) { result = result.mulmod(a, N); }\n      k.halveM();\n      if (k.equals(0)) { break; }\n      a = a.mulmod(a, N);\n    }\n    return result.normalize().reduce();\n  },\n\n  trim: function() {\n    var l = this.limbs, p;\n    do {\n      p = l.pop();\n    } while (l.length && p === 0);\n    l.push(p);\n    return this;\n  },\n  \n  /** Reduce mod a modulus.  Stubbed for subclassing. */\n  reduce: function() {\n    return this;\n  },\n\n  /** Reduce and normalize. */\n  fullReduce: function() {\n    return this.normalize();\n  },\n  \n  /** Propagate carries. */\n  normalize: function() {\n    var carry=0, i, pv = this.placeVal, ipv = this.ipv, l, m, limbs = this.limbs, ll = limbs.length, mask = this.radixMask;\n    for (i=0; i < ll || (carry !== 0 && carry !== -1); i++) {\n      l = (limbs[i]||0) + carry;\n      m = limbs[i] = l & mask;\n      carry = (l-m)*ipv;\n    }\n    if (carry === -1) {\n      limbs[i-1] -= this.placeVal;\n    }\n    return this;\n  },\n\n  /** Constant-time normalize. Does not allocate additional space. */\n  cnormalize: function() {\n    var carry=0, i, ipv = this.ipv, l, m, limbs = this.limbs, ll = limbs.length, mask = this.radixMask;\n    for (i=0; i < ll-1; i++) {\n      l = limbs[i] + carry;\n      m = limbs[i] = l & mask;\n      carry = (l-m)*ipv;\n    }\n    limbs[i] += carry;\n    return this;\n  },\n  \n  /** Serialize to a bit array */\n  toBits: function(len) {\n    this.fullReduce();\n    len = len || this.exponent || this.bitLength();\n    var i = Math.floor((len-1)/24), w=sjcl.bitArray, e = (len + 7 & -8) % this.radix || this.radix,\n        out = [w.partial(e, this.getLimb(i))];\n    for (i--; i >= 0; i--) {\n      out = w.concat(out, [w.partial(Math.min(this.radix,len), this.getLimb(i))]);\n      len -= this.radix;\n    }\n    return out;\n  },\n  \n  /** Return the length in bits, rounded up to the nearest byte. */\n  bitLength: function() {\n    this.fullReduce();\n    var out = this.radix * (this.limbs.length - 1),\n        b = this.limbs[this.limbs.length - 1];\n    for (; b; b >>>= 1) {\n      out ++;\n    }\n    return out+7 & -8;\n  }\n};\n\n/** @memberOf sjcl.bn\n* @this { sjcl.bn }\n*/\nsjcl.bn.fromBits = function(bits) {\n  var Class = this, out = new Class(), words=[], w=sjcl.bitArray, t = this.prototype,\n      l = Math.min(this.bitLength || 0x100000000, w.bitLength(bits)), e = l % t.radix || t.radix;\n  \n  words[0] = w.extract(bits, 0, e);\n  for (; e < l; e += t.radix) {\n    words.unshift(w.extract(bits, e, t.radix));\n  }\n\n  out.limbs = words;\n  return out;\n};\n\n\n\nsjcl.bn.prototype.ipv = 1 / (sjcl.bn.prototype.placeVal = Math.pow(2,sjcl.bn.prototype.radix));\nsjcl.bn.prototype.radixMask = (1 << sjcl.bn.prototype.radix) - 1;\n\n/**\n * Creates a new subclass of bn, based on reduction modulo a pseudo-Mersenne prime,\n * i.e. a prime of the form 2^e + sum(a * 2^b),where the sum is negative and sparse.\n */\nsjcl.bn.pseudoMersennePrime = function(exponent, coeff) {\n  /** @constructor \n  * @private\n  */\n  function p(it) {\n    this.initWith(it);\n    /*if (this.limbs[this.modOffset]) {\n      this.reduce();\n    }*/\n  }\n\n  var ppr = p.prototype = new sjcl.bn(), i, tmp, mo;\n  mo = ppr.modOffset = Math.ceil(tmp = exponent / ppr.radix);\n  ppr.exponent = exponent;\n  ppr.offset = [];\n  ppr.factor = [];\n  ppr.minOffset = mo;\n  ppr.fullMask = 0;\n  ppr.fullOffset = [];\n  ppr.fullFactor = [];\n  ppr.modulus = p.modulus = new sjcl.bn(Math.pow(2,exponent));\n  \n  ppr.fullMask = 0|-Math.pow(2, exponent % ppr.radix);\n\n  for (i=0; i<coeff.length; i++) {\n    ppr.offset[i] = Math.floor(coeff[i][0] / ppr.radix - tmp);\n    ppr.fullOffset[i] = Math.ceil(coeff[i][0] / ppr.radix - tmp);\n    ppr.factor[i] = coeff[i][1] * Math.pow(1/2, exponent - coeff[i][0] + ppr.offset[i] * ppr.radix);\n    ppr.fullFactor[i] = coeff[i][1] * Math.pow(1/2, exponent - coeff[i][0] + ppr.fullOffset[i] * ppr.radix);\n    ppr.modulus.addM(new sjcl.bn(Math.pow(2,coeff[i][0])*coeff[i][1]));\n    ppr.minOffset = Math.min(ppr.minOffset, -ppr.offset[i]); // conservative\n  }\n  ppr._class = p;\n  ppr.modulus.cnormalize();\n\n  /** Approximate reduction mod p.  May leave a number which is negative or slightly larger than p.\n   * @memberof sjcl.bn\n   * @this { sjcl.bn }\n   */\n  ppr.reduce = function() {\n    var i, k, l, mo = this.modOffset, limbs = this.limbs, aff, off = this.offset, ol = this.offset.length, fac = this.factor, ll;\n\n    i = this.minOffset;\n    while (limbs.length > mo) {\n      l = limbs.pop();\n      ll = limbs.length;\n      for (k=0; k<ol; k++) {\n        limbs[ll+off[k]] -= fac[k] * l;\n      }\n      \n      i--;\n      if (!i) {\n        limbs.push(0);\n        this.cnormalize();\n        i = this.minOffset;\n      }\n    }\n    this.cnormalize();\n\n    return this;\n  };\n  \n  /** @memberof sjcl.bn\n  * @this { sjcl.bn }\n  */\n  ppr._strongReduce = (ppr.fullMask === -1) ? ppr.reduce : function() {\n    var limbs = this.limbs, i = limbs.length - 1, k, l;\n    this.reduce();\n    if (i === this.modOffset - 1) {\n      l = limbs[i] & this.fullMask;\n      limbs[i] -= l;\n      for (k=0; k<this.fullOffset.length; k++) {\n        limbs[i+this.fullOffset[k]] -= this.fullFactor[k] * l;\n      }\n      this.normalize();\n    }\n  };\n\n  /** mostly constant-time, very expensive full reduction.\n   * @memberof sjcl.bn\n   * @this { sjcl.bn }\n   */\n  ppr.fullReduce = function() {\n    var greater, i;\n    // massively above the modulus, may be negative\n    \n    this._strongReduce();\n    // less than twice the modulus, may be negative\n\n    this.addM(this.modulus);\n    this.addM(this.modulus);\n    this.normalize();\n    // probably 2-3x the modulus\n    \n    this._strongReduce();\n    // less than the power of 2.  still may be more than\n    // the modulus\n\n    // HACK: pad out to this length\n    for (i=this.limbs.length; i<this.modOffset; i++) {\n      this.limbs[i] = 0;\n    }\n    \n    // constant-time subtract modulus\n    greater = this.greaterEquals(this.modulus);\n    for (i=0; i<this.limbs.length; i++) {\n      this.limbs[i] -= this.modulus.limbs[i] * greater;\n    }\n    this.cnormalize();\n\n    return this;\n  };\n\n\n  /** @memberof sjcl.bn\n  * @this { sjcl.bn }\n  */\n  ppr.inverse = function() {\n    return (this.power(this.modulus.sub(2)));\n  };\n\n  p.fromBits = sjcl.bn.fromBits;\n\n  return p;\n};\n\n// a small Mersenne prime\nvar sbp = sjcl.bn.pseudoMersennePrime;\nsjcl.bn.prime = {\n  p127: sbp(127, [[0,-1]]),\n\n  // Bernstein's prime for Curve25519\n  p25519: sbp(255, [[0,-19]]),\n\n  // Koblitz primes\n  p192k: sbp(192, [[32,-1],[12,-1],[8,-1],[7,-1],[6,-1],[3,-1],[0,-1]]),\n  p224k: sbp(224, [[32,-1],[12,-1],[11,-1],[9,-1],[7,-1],[4,-1],[1,-1],[0,-1]]),\n  p256k: sbp(256, [[32,-1],[9,-1],[8,-1],[7,-1],[6,-1],[4,-1],[0,-1]]),\n\n  // NIST primes\n  p192: sbp(192, [[0,-1],[64,-1]]),\n  p224: sbp(224, [[0,1],[96,-1]]),\n  p256: sbp(256, [[0,-1],[96,1],[192,1],[224,-1]]),\n  p384: sbp(384, [[0,-1],[32,1],[96,-1],[128,-1]]),\n  p521: sbp(521, [[0,-1]])\n};\n\nsjcl.bn.random = function(modulus, paranoia) {\n  if (typeof modulus !== \"object\") { modulus = new sjcl.bn(modulus); }\n  var words, i, l = modulus.limbs.length, m = modulus.limbs[l-1]+1, out = new sjcl.bn();\n  while (true) {\n    // get a sequence whose first digits make sense\n    do {\n      words = sjcl.random.randomWords(l, paranoia);\n      if (words[l-1] < 0) { words[l-1] += 0x100000000; }\n    } while (Math.floor(words[l-1] / m) === Math.floor(0x100000000 / m));\n    words[l-1] %= m;\n\n    // mask off all the limbs\n    for (i=0; i<l-1; i++) {\n      words[i] &= modulus.radixMask;\n    }\n\n    // check the rest of the digitssj\n    out.limbs = words;\n    if (!out.greaterEquals(modulus)) {\n      return out;\n    }\n  }\n};\n\n/**\n * base class for all ecc operations.\n */\nsjcl.ecc = {};\n\n/**\n * Represents a point on a curve in affine coordinates.\n * @constructor\n * @param {sjcl.ecc.curve} curve The curve that this point lies on.\n * @param {bigInt} x The x coordinate.\n * @param {bigInt} y The y coordinate.\n */\nsjcl.ecc.point = function(curve,x,y) {\n  if (x === undefined) {\n    this.isIdentity = true;\n  } else {\n    this.x = x;\n    this.y = y;\n    this.isIdentity = false;\n  }\n  this.curve = curve;\n};\n\n\n\nsjcl.ecc.point.prototype = {\n  toJac: function() {\n    return new sjcl.ecc.pointJac(this.curve, this.x, this.y, new this.curve.field(1));\n  },\n\n  mult: function(k) {\n    return this.toJac().mult(k, this).toAffine();\n  },\n  \n  /**\n   * Multiply this point by k, added to affine2*k2, and return the answer in Jacobian coordinates.\n   * @param {bigInt} k The coefficient to multiply this by.\n   * @param {bigInt} k2 The coefficient to multiply affine2 this by.\n   * @param {sjcl.ecc.point} affine The other point in affine coordinates.\n   * @return {sjcl.ecc.pointJac} The result of the multiplication and addition, in Jacobian coordinates.\n   */\n  mult2: function(k, k2, affine2) {\n    return this.toJac().mult2(k, this, k2, affine2).toAffine();\n  },\n  \n  multiples: function() {\n    var m, i, j;\n    if (this._multiples === undefined) {\n      j = this.toJac().doubl();\n      m = this._multiples = [new sjcl.ecc.point(this.curve), this, j.toAffine()];\n      for (i=3; i<16; i++) {\n        j = j.add(this);\n        m.push(j.toAffine());\n      }\n    }\n    return this._multiples;\n  },\n\n  isValid: function() {\n    return this.y.square().equals(this.curve.b.add(this.x.mul(this.curve.a.add(this.x.square()))));\n  },\n\n  toBits: function() {\n    return sjcl.bitArray.concat(this.x.toBits(), this.y.toBits());\n  }\n};\n\n/**\n * Represents a point on a curve in Jacobian coordinates. Coordinates can be specified as bigInts or strings (which\n * will be converted to bigInts).\n *\n * @constructor\n * @param {bigInt/string} x The x coordinate.\n * @param {bigInt/string} y The y coordinate.\n * @param {bigInt/string} z The z coordinate.\n * @param {sjcl.ecc.curve} curve The curve that this point lies on.\n */\nsjcl.ecc.pointJac = function(curve, x, y, z) {\n  if (x === undefined) {\n    this.isIdentity = true;\n  } else {\n    this.x = x;\n    this.y = y;\n    this.z = z;\n    this.isIdentity = false;\n  }\n  this.curve = curve;\n};\n\nsjcl.ecc.pointJac.prototype = {\n  /**\n   * Adds S and T and returns the result in Jacobian coordinates. Note that S must be in Jacobian coordinates and T must be in affine coordinates.\n   * @param {sjcl.ecc.pointJac} S One of the points to add, in Jacobian coordinates.\n   * @param {sjcl.ecc.point} T The other point to add, in affine coordinates.\n   * @return {sjcl.ecc.pointJac} The sum of the two points, in Jacobian coordinates. \n   */\n  add: function(T) {\n    var S = this, sz2, c, d, c2, x1, x2, x, y1, y2, y, z;\n    if (S.curve !== T.curve) {\n      throw(\"sjcl.ecc.add(): Points must be on the same curve to add them!\");\n    }\n\n    if (S.isIdentity) {\n      return T.toJac();\n    } else if (T.isIdentity) {\n      return S;\n    }\n\n    sz2 = S.z.square();\n    c = T.x.mul(sz2).subM(S.x);\n\n    if (c.equals(0)) {\n      if (S.y.equals(T.y.mul(sz2.mul(S.z)))) {\n        // same point\n        return S.doubl();\n      } else {\n        // inverses\n        return new sjcl.ecc.pointJac(S.curve);\n      }\n    }\n    \n    d = T.y.mul(sz2.mul(S.z)).subM(S.y);\n    c2 = c.square();\n\n    x1 = d.square();\n    x2 = c.square().mul(c).addM( S.x.add(S.x).mul(c2) );\n    x  = x1.subM(x2);\n\n    y1 = S.x.mul(c2).subM(x).mul(d);\n    y2 = S.y.mul(c.square().mul(c));\n    y  = y1.subM(y2);\n\n    z  = S.z.mul(c);\n\n    return new sjcl.ecc.pointJac(this.curve,x,y,z);\n  },\n  \n  /**\n   * doubles this point.\n   * @return {sjcl.ecc.pointJac} The doubled point.\n   */\n  doubl: function() {\n    if (this.isIdentity) { return this; }\n\n    var\n      y2 = this.y.square(),\n      a  = y2.mul(this.x.mul(4)),\n      b  = y2.square().mul(8),\n      z2 = this.z.square(),\n      c  = this.curve.a.toString() == (new sjcl.bn(-3)).toString() ?\n                this.x.sub(z2).mul(3).mul(this.x.add(z2)) :\n                this.x.square().mul(3).add(z2.square().mul(this.curve.a)),\n      x  = c.square().subM(a).subM(a),\n      y  = a.sub(x).mul(c).subM(b),\n      z  = this.y.add(this.y).mul(this.z);\n    return new sjcl.ecc.pointJac(this.curve, x, y, z);\n  },\n\n  /**\n   * Returns a copy of this point converted to affine coordinates.\n   * @return {sjcl.ecc.point} The converted point.\n   */\n  toAffine: function() {\n    if (this.isIdentity || this.z.equals(0)) {\n      return new sjcl.ecc.point(this.curve);\n    }\n    var zi = this.z.inverse(), zi2 = zi.square();\n    return new sjcl.ecc.point(this.curve, this.x.mul(zi2).fullReduce(), this.y.mul(zi2.mul(zi)).fullReduce());\n  },\n  \n  /**\n   * Multiply this point by k and return the answer in Jacobian coordinates.\n   * @param {bigInt} k The coefficient to multiply by.\n   * @param {sjcl.ecc.point} affine This point in affine coordinates.\n   * @return {sjcl.ecc.pointJac} The result of the multiplication, in Jacobian coordinates.\n   */\n  mult: function(k, affine) {\n    if (typeof(k) === \"number\") {\n      k = [k];\n    } else if (k.limbs !== undefined) {\n      k = k.normalize().limbs;\n    }\n    \n    var i, j, out = new sjcl.ecc.point(this.curve).toJac(), multiples = affine.multiples();\n\n    for (i=k.length-1; i>=0; i--) {\n      for (j=sjcl.bn.prototype.radix-4; j>=0; j-=4) {\n        out = out.doubl().doubl().doubl().doubl().add(multiples[k[i]>>j & 0xF]);\n      }\n    }\n    \n    return out;\n  },\n  \n  /**\n   * Multiply this point by k, added to affine2*k2, and return the answer in Jacobian coordinates.\n   * @param {bigInt} k The coefficient to multiply this by.\n   * @param {sjcl.ecc.point} affine This point in affine coordinates.\n   * @param {bigInt} k2 The coefficient to multiply affine2 this by.\n   * @param {sjcl.ecc.point} affine The other point in affine coordinates.\n   * @return {sjcl.ecc.pointJac} The result of the multiplication and addition, in Jacobian coordinates.\n   */\n  mult2: function(k1, affine, k2, affine2) {\n    if (typeof(k1) === \"number\") {\n      k1 = [k1];\n    } else if (k1.limbs !== undefined) {\n      k1 = k1.normalize().limbs;\n    }\n    \n    if (typeof(k2) === \"number\") {\n      k2 = [k2];\n    } else if (k2.limbs !== undefined) {\n      k2 = k2.normalize().limbs;\n    }\n    \n    var i, j, out = new sjcl.ecc.point(this.curve).toJac(), m1 = affine.multiples(),\n        m2 = affine2.multiples(), l1, l2;\n\n    for (i=Math.max(k1.length,k2.length)-1; i>=0; i--) {\n      l1 = k1[i] | 0;\n      l2 = k2[i] | 0;\n      for (j=sjcl.bn.prototype.radix-4; j>=0; j-=4) {\n        out = out.doubl().doubl().doubl().doubl().add(m1[l1>>j & 0xF]).add(m2[l2>>j & 0xF]);\n      }\n    }\n    \n    return out;\n  },\n\n  isValid: function() {\n    var z2 = this.z.square(), z4 = z2.square(), z6 = z4.mul(z2);\n    return this.y.square().equals(\n             this.curve.b.mul(z6).add(this.x.mul(\n               this.curve.a.mul(z4).add(this.x.square()))));\n  }\n};\n\n/**\n * Construct an elliptic curve. Most users will not use this and instead start with one of the NIST curves defined below.\n *\n * @constructor\n * @param {bigInt} p The prime modulus.\n * @param {bigInt} r The prime order of the curve.\n * @param {bigInt} a The constant a in the equation of the curve y^2 = x^3 + ax + b (for NIST curves, a is always -3).\n * @param {bigInt} x The x coordinate of a base point of the curve.\n * @param {bigInt} y The y coordinate of a base point of the curve.\n */\nsjcl.ecc.curve = function(Field, r, a, b, x, y) {\n  this.field = Field;\n  this.r = new sjcl.bn(r);\n  this.a = new Field(a);\n  this.b = new Field(b);\n  this.G = new sjcl.ecc.point(this, new Field(x), new Field(y));\n};\n\nsjcl.ecc.curve.prototype.fromBits = function (bits) {\n  var w = sjcl.bitArray, l = this.field.prototype.exponent + 7 & -8,\n      p = new sjcl.ecc.point(this, this.field.fromBits(w.bitSlice(bits, 0, l)),\n                             this.field.fromBits(w.bitSlice(bits, l, 2*l)));\n  if (!p.isValid()) {\n    throw new sjcl.exception.corrupt(\"not on the curve!\");\n  }\n  return p;\n};\n\nsjcl.ecc.curves = {\n  c192: new sjcl.ecc.curve(\n    sjcl.bn.prime.p192,\n    \"0xffffffffffffffffffffffff99def836146bc9b1b4d22831\",\n    -3,\n    \"0x64210519e59c80e70fa7e9ab72243049feb8deecc146b9b1\",\n    \"0x188da80eb03090f67cbf20eb43a18800f4ff0afd82ff1012\",\n    \"0x07192b95ffc8da78631011ed6b24cdd573f977a11e794811\"),\n\n  c224: new sjcl.ecc.curve(\n    sjcl.bn.prime.p224,\n    \"0xffffffffffffffffffffffffffff16a2e0b8f03e13dd29455c5c2a3d\",\n    -3,\n    \"0xb4050a850c04b3abf54132565044b0b7d7bfd8ba270b39432355ffb4\",\n    \"0xb70e0cbd6bb4bf7f321390b94a03c1d356c21122343280d6115c1d21\",\n    \"0xbd376388b5f723fb4c22dfe6cd4375a05a07476444d5819985007e34\"),\n\n  c256: new sjcl.ecc.curve(\n    sjcl.bn.prime.p256,\n    \"0xffffffff00000000ffffffffffffffffbce6faada7179e84f3b9cac2fc632551\",\n    -3,\n    \"0x5ac635d8aa3a93e7b3ebbd55769886bc651d06b0cc53b0f63bce3c3e27d2604b\",\n    \"0x6b17d1f2e12c4247f8bce6e563a440f277037d812deb33a0f4a13945d898c296\",\n    \"0x4fe342e2fe1a7f9b8ee7eb4a7c0f9e162bce33576b315ececbb6406837bf51f5\"),\n\n  c384: new sjcl.ecc.curve(\n    sjcl.bn.prime.p384,\n    \"0xffffffffffffffffffffffffffffffffffffffffffffffffc7634d81f4372ddf581a0db248b0a77aecec196accc52973\",\n    -3,\n    \"0xb3312fa7e23ee7e4988e056be3f82d19181d9c6efe8141120314088f5013875ac656398d8a2ed19d2a85c8edd3ec2aef\",\n    \"0xaa87ca22be8b05378eb1c71ef320ad746e1d3b628ba79b9859f741e082542a385502f25dbf55296c3a545e3872760ab7\",\n    \"0x3617de4a96262c6f5d9e98bf9292dc29f8f41dbd289a147ce9da3113b5f0b8c00a60b1ce1d7e819d7a431d7c90ea0e5f\"),\n\n  k192: new sjcl.ecc.curve(\n    sjcl.bn.prime.p192k,\n    \"0xfffffffffffffffffffffffe26f2fc170f69466a74defd8d\",\n    0,\n    3,\n    \"0xdb4ff10ec057e9ae26b07d0280b7f4341da5d1b1eae06c7d\",\n    \"0x9b2f2f6d9c5628a7844163d015be86344082aa88d95e2f9d\"),\n\n  k224: new sjcl.ecc.curve(\n    sjcl.bn.prime.p224k,\n    \"0x010000000000000000000000000001dce8d2ec6184caf0a971769fb1f7\",\n    0,\n    5,\n    \"0xa1455b334df099df30fc28a169a467e9e47075a90f7e650eb6b7a45c\",\n    \"0x7e089fed7fba344282cafbd6f7e319f7c0b0bd59e2ca4bdb556d61a5\"),\n\n  k256: new sjcl.ecc.curve(\n    sjcl.bn.prime.p256k,\n    \"0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141\",\n    0,\n    7,\n    \"0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798\",\n    \"0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8\")\n\n};\n\n/** our basicKey classes\n*/\nsjcl.ecc.basicKey = {\n  /** ecc publicKey. \n  * @constructor\n  * @param {curve} curve the elliptic curve\n  * @param {point} point the point on the curve\n  */\n  publicKey: function(curve, point) {\n    this._curve = curve;\n    this._curveBitLength = curve.r.bitLength();\n    if (point instanceof Array) {\n      this._point = curve.fromBits(point);\n    } else {\n      this._point = point;\n    }\n\n    /** get this keys point data\n    * @return x and y as bitArrays\n    */\n    this.get = function() {\n      var pointbits = this._point.toBits();\n      var len = sjcl.bitArray.bitLength(pointbits);\n      var x = sjcl.bitArray.bitSlice(pointbits, 0, len/2);\n      var y = sjcl.bitArray.bitSlice(pointbits, len/2);\n      return { x: x, y: y };\n    };\n  },\n\n  /** ecc secretKey\n  * @constructor\n  * @param {curve} curve the elliptic curve\n  * @param exponent\n  */\n  secretKey: function(curve, exponent) {\n    this._curve = curve;\n    this._curveBitLength = curve.r.bitLength();\n    this._exponent = exponent;\n\n    /** get this keys exponent data\n    * @return {bitArray} exponent\n    */\n    this.get = function () {\n      return this._exponent.toBits();\n    };\n  }\n};\n\n/** @private */\nsjcl.ecc.basicKey.generateKeys = function(cn) {\n  return function generateKeys(curve, paranoia, sec) {\n    curve = curve || 256;\n    paranoia = paranoia || 0;\n\n    if (typeof curve === \"number\") {\n      curve = sjcl.ecc.curves['c'+curve];\n      if (curve === undefined) {\n        throw new sjcl.exception.invalid(\"no such curve\");\n      }\n    }\n    sec = sec || sjcl.bn.random(curve.r, paranoia);\n\n    var pub = curve.G.mult(sec);\n    return { pub: new sjcl.ecc[cn].publicKey(curve, pub),\n             sec: new sjcl.ecc[cn].secretKey(curve, sec) };\n  };\n};\n\n/** elGamal keys */\nsjcl.ecc.elGamal = {\n  /** generate keys\n  * @function\n  * @param curve\n  * @param {int} paranoia Paranoia for generation (default 6)\n  * @param {secretKey} sec secret Key to use. used to get the publicKey for ones secretKey\n  */\n  generateKeys: sjcl.ecc.basicKey.generateKeys(\"elGamal\"),\n  /** elGamal publicKey. \n  * @constructor\n  * @augments sjcl.ecc.basicKey.publicKey\n  */\n  publicKey: function (curve, point) {\n    sjcl.ecc.basicKey.publicKey.apply(this, arguments);\n  },\n  /** elGamal secretKey\n  * @constructor\n  * @augments sjcl.ecc.basicKey.secretKey\n  */\n  secretKey: function (curve, exponent) {\n    sjcl.ecc.basicKey.secretKey.apply(this, arguments);\n  }\n};\n\nsjcl.ecc.elGamal.publicKey.prototype = {\n  /** Kem function of elGamal Public Key\n  * @param paranoia paranoia to use for randomization.\n  * @return {object} key and tag. unkem(tag) with the corresponding secret key results in the key returned.\n  */\n  kem: function(paranoia) {\n    var sec = sjcl.bn.random(this._curve.r, paranoia),\n        tag = this._curve.G.mult(sec).toBits(),\n        key = sjcl.hash.sha256.hash(this._point.mult(sec).toBits());\n    return { key: key, tag: tag };\n  }\n};\n\nsjcl.ecc.elGamal.secretKey.prototype = {\n  /** UnKem function of elGamal Secret Key\n  * @param {bitArray} tag The Tag to decrypt.\n  * @return {bitArray} decrypted key.\n  */\n  unkem: function(tag) {\n    return sjcl.hash.sha256.hash(this._curve.fromBits(tag).mult(this._exponent).toBits());\n  },\n\n  /** Diffie-Hellmann function\n  * @param {elGamal.publicKey} pk The Public Key to do Diffie-Hellmann with\n  * @return {bitArray} diffie-hellmann result for this key combination.\n  */\n  dh: function(pk) {\n    return sjcl.hash.sha256.hash(pk._point.mult(this._exponent).toBits());\n  }\n};\n\n/** ecdsa keys */\nsjcl.ecc.ecdsa = {\n  /** generate keys\n  * @function\n  * @param curve\n  * @param {int} paranoia Paranoia for generation (default 6)\n  * @param {secretKey} sec secret Key to use. used to get the publicKey for ones secretKey\n  */\n  generateKeys: sjcl.ecc.basicKey.generateKeys(\"ecdsa\")\n};\n\n/** ecdsa publicKey. \n* @constructor\n* @augments sjcl.ecc.basicKey.publicKey\n*/\nsjcl.ecc.ecdsa.publicKey = function (curve, point) {\n  sjcl.ecc.basicKey.publicKey.apply(this, arguments);\n};\n\n/** specific functions for ecdsa publicKey. */\nsjcl.ecc.ecdsa.publicKey.prototype = {\n  /** Diffie-Hellmann function\n  * @param {bitArray} hash hash to verify. \n  * @param {bitArray} rs signature bitArray.\n  * @param {boolean}  fakeLegacyVersion use old legacy version\n  */\n  verify: function(hash, rs, fakeLegacyVersion) {\n    if (sjcl.bitArray.bitLength(hash) > this._curveBitLength) {\n      hash = sjcl.bitArray.clamp(hash, this._curveBitLength);\n    }\n    var w = sjcl.bitArray,\n        R = this._curve.r,\n        l = this._curveBitLength,\n        r = sjcl.bn.fromBits(w.bitSlice(rs,0,l)),\n        ss = sjcl.bn.fromBits(w.bitSlice(rs,l,2*l)),\n        s = fakeLegacyVersion ? ss : ss.inverseMod(R),\n        hG = sjcl.bn.fromBits(hash).mul(s).mod(R),\n        hA = r.mul(s).mod(R),\n        r2 = this._curve.G.mult2(hG, hA, this._point).x;\n    if (r.equals(0) || ss.equals(0) || r.greaterEquals(R) || ss.greaterEquals(R) || !r2.equals(r)) {\n      if (fakeLegacyVersion === undefined) {\n        return this.verify(hash, rs, true);\n      } else {\n        throw (new sjcl.exception.corrupt(\"signature didn't check out\"));\n      }\n    }\n    return true;\n  }\n};\n\n/** ecdsa secretKey\n* @constructor\n* @augments sjcl.ecc.basicKey.publicKey\n*/\nsjcl.ecc.ecdsa.secretKey = function (curve, exponent) {\n  sjcl.ecc.basicKey.secretKey.apply(this, arguments);\n};\n\n/** specific functions for ecdsa secretKey. */\nsjcl.ecc.ecdsa.secretKey.prototype = {\n  /** Diffie-Hellmann function\n  * @param {bitArray} hash hash to sign. \n  * @param {int} paranoia paranoia for random number generation\n  * @param {boolean} fakeLegacyVersion use old legacy version\n  */\n  sign: function(hash, paranoia, fakeLegacyVersion, fixedKForTesting) {\n    if (sjcl.bitArray.bitLength(hash) > this._curveBitLength) {\n      hash = sjcl.bitArray.clamp(hash, this._curveBitLength);\n    }\n    var R  = this._curve.r,\n        l  = R.bitLength(),\n        k  = fixedKForTesting || sjcl.bn.random(R.sub(1), paranoia).add(1),\n        r  = this._curve.G.mult(k).x.mod(R),\n        ss = sjcl.bn.fromBits(hash).add(r.mul(this._exponent)),\n        s  = fakeLegacyVersion ? ss.inverseMod(R).mul(k).mod(R)\n             : ss.mul(k.inverseMod(R)).mod(R);\n    return sjcl.bitArray.concat(r.toBits(l), s.toBits(l));\n  }\n};\n\nvar ecc = {},\n    DEFAULT_CURVE = 192,\n    ENC_DEC = ecc.ENC_DEC = {},\n    SIG_VER = ecc.SIG_VER = {},\n    elg = eccAPI('elGamal'),\n    dsa = eccAPI('ecdsa'),\n    sha256 = hashAPI('sha256');\n\necc.sjcl = sjcl;\n\necc.generate = function(type, curve) {\n  if(!curve)\n    curve = DEFAULT_CURVE;\n  var keys, pub, sec;\n  if(type === ENC_DEC) {\n    pub = 'enc';\n    sec = 'dec';\n    keys = elg.generate(curve);\n  } else if(type === SIG_VER) {\n    pub = 'ver';\n    sec = 'sig';\n    keys = dsa.generate(curve);\n  } else\n    throw \"eccjs: generate: Unknown type\";\n\n  var newkeys = {};\n  newkeys[pub] = exportPublic(keys.pub);\n  newkeys[sec] = exportSecret(keys.sec);\n  return newkeys;\n};\n\nvar cache = {\n  enc: {}, dec: {}, sig: {}, ver: {}\n};\n\necc.encrypt = function(enckey, plaintext) {\n  var kem = cache.enc[enckey];\n\n  if(!kem) {\n    kem = cache.enc[enckey] = elg.importPublic(enckey).kem();\n    kem.tagHex = sjcl.codec.hex.fromBits(kem.tag);\n  }\n\n  var obj = sjcl.json._encrypt(kem.key, plaintext);\n  obj.tag = kem.tagHex;\n  return JSON.stringify(obj);\n};\n\n\necc.decrypt = function(deckey, ciphertext) {\n  var obj = JSON.parse(ciphertext);\n\n  var kem = cache.dec[deckey];\n  if(!kem) {\n    kem = cache.dec[deckey] = elg.importSecret(deckey);\n    kem.$keys = {};\n  }\n\n  var key = kem.$keys[obj.tag];\n  if(!key)\n    key = kem.$keys[obj.tag] = kem.unkem(sjcl.codec.hex.toBits(obj.tag));\n\n  return sjcl.json._decrypt(key, obj);\n};\n\necc.sign = function(sigkey, text, hash) {\n  var key = cache.sig[sigkey];\n  if(!key)\n    key = cache.sig[sigkey] = dsa.importSecret(sigkey);\n\n  //hash first\n  if(hash !== false)\n    text = sha256.hash(text);\n\n  return key.sign(text);\n};\n\necc.verify = function(verkey, signature, text, hash) {\n  var key = cache.ver[verkey];\n  if(!key)\n    key = cache.ver[verkey] = dsa.importPublic(verkey);\n\n  //hash first\n  if(hash !== false)\n    text = sha256.hash(text);\n\n  try {\n    return key.verify(text, signature);\n  } catch(e) {\n    return false;\n  }\n};\n\n\n//ecc algorithm helpers\nfunction eccAPI(algoName) {\n  var algo = sjcl.ecc[algoName];\n  if(!algo)\n    throw new Error(\"Missing ECC algorithm: \" + algoName);\n  return {\n    generate: function(curve) {\n      var keys = algo.generateKeys(curve, 1);\n      keys.pub.$curve = curve;\n      keys.sec.$curve = curve;\n      return keys;\n    },\n    importPublic: function(keyStr) {\n      var key = extract(keyStr);\n      return new algo.publicKey(key.curve, sjcl.codec.hex.toBits(key.hex));\n    },\n    importSecret: function(keyStr) {\n      var key = extract(keyStr);\n      return new algo.secretKey(key.curve, new sjcl.bn(key.hex));\n    }\n  };\n}\n\nfunction extract(str) {\n  return {\n    curve: sjcl.ecc.curves['c'+str.substr(0, 3)],\n    hex: str.substr(3)\n  };\n}\n\nfunction exportPublic(keyObj) {\n  var obj = keyObj.get();\n  return keyObj.$curve +\n         sjcl.codec.hex.fromBits(obj.x) +\n         sjcl.codec.hex.fromBits(obj.y);\n}\nfunction exportSecret(keyObj) {\n  return keyObj.$curve + sjcl.codec.hex.fromBits(keyObj.get());\n}\n\n//hash algorithm helpers\nfunction hashAPI(algoName) {\n  var algo = sjcl.hash[algoName];\n  if(!algo)\n    throw new Error(\"Missing hash algorithm: \" + algoName);\n  return {\n    hash: function(input) {\n      return algo.hash(input);\n    }\n  };\n}\n\n//publicise\nif(typeof module !== 'undefined' && module.exports)\n  module.exports = ecc;\nelse\n  window.ecc = ecc;\n\n\n}(this));","'use strict';\n\nvar elliptic = exports;\n\nelliptic.version = require('../package.json').version;\nelliptic.utils = require('./elliptic/utils');\nelliptic.rand = require('brorand');\nelliptic.hmacDRBG = require('./elliptic/hmac-drbg');\nelliptic.curve = require('./elliptic/curve');\nelliptic.curves = require('./elliptic/curves');\n\n// Protocols\nelliptic.ec = require('./elliptic/ec');\nelliptic.eddsa = require('./elliptic/eddsa');\n","'use strict';\n\nvar BN = require('bn.js');\nvar elliptic = require('../../elliptic');\nvar utils = elliptic.utils;\nvar getNAF = utils.getNAF;\nvar getJSF = utils.getJSF;\nvar assert = utils.assert;\n\nfunction BaseCurve(type, conf) {\n  this.type = type;\n  this.p = new BN(conf.p, 16);\n\n  // Use Montgomery, when there is no fast reduction for the prime\n  this.red = conf.prime ? BN.red(conf.prime) : BN.mont(this.p);\n\n  // Useful for many curves\n  this.zero = new BN(0).toRed(this.red);\n  this.one = new BN(1).toRed(this.red);\n  this.two = new BN(2).toRed(this.red);\n\n  // Curve configuration, optional\n  this.n = conf.n && new BN(conf.n, 16);\n  this.g = conf.g && this.pointFromJSON(conf.g, conf.gRed);\n\n  // Temporary arrays\n  this._wnafT1 = new Array(4);\n  this._wnafT2 = new Array(4);\n  this._wnafT3 = new Array(4);\n  this._wnafT4 = new Array(4);\n}\nmodule.exports = BaseCurve;\n\nBaseCurve.prototype.point = function point() {\n  throw new Error('Not implemented');\n};\n\nBaseCurve.prototype.validate = function validate() {\n  throw new Error('Not implemented');\n};\n\nBaseCurve.prototype._fixedNafMul = function _fixedNafMul(p, k) {\n  assert(p.precomputed);\n  var doubles = p._getDoubles();\n\n  var naf = getNAF(k, 1);\n  var I = (1 << (doubles.step + 1)) - (doubles.step % 2 === 0 ? 2 : 1);\n  I /= 3;\n\n  // Translate into more windowed form\n  var repr = [];\n  for (var j = 0; j < naf.length; j += doubles.step) {\n    var nafW = 0;\n    for (var k = j + doubles.step - 1; k >= j; k--)\n      nafW = (nafW << 1) + naf[k];\n    repr.push(nafW);\n  }\n\n  var a = this.jpoint(null, null, null);\n  var b = this.jpoint(null, null, null);\n  for (var i = I; i > 0; i--) {\n    for (var j = 0; j < repr.length; j++) {\n      var nafW = repr[j];\n      if (nafW === i)\n        b = b.mixedAdd(doubles.points[j]);\n      else if (nafW === -i)\n        b = b.mixedAdd(doubles.points[j].neg());\n    }\n    a = a.add(b);\n  }\n  return a.toP();\n};\n\nBaseCurve.prototype._wnafMul = function _wnafMul(p, k) {\n  var w = 4;\n\n  // Precompute window\n  var nafPoints = p._getNAFPoints(w);\n  w = nafPoints.wnd;\n  var wnd = nafPoints.points;\n\n  // Get NAF form\n  var naf = getNAF(k, w);\n\n  // Add `this`*(N+1) for every w-NAF index\n  var acc = this.jpoint(null, null, null);\n  for (var i = naf.length - 1; i >= 0; i--) {\n    // Count zeroes\n    for (var k = 0; i >= 0 && naf[i] === 0; i--)\n      k++;\n    if (i >= 0)\n      k++;\n    acc = acc.dblp(k);\n\n    if (i < 0)\n      break;\n    var z = naf[i];\n    assert(z !== 0);\n    if (p.type === 'affine') {\n      // J +- P\n      if (z > 0)\n        acc = acc.mixedAdd(wnd[(z - 1) >> 1]);\n      else\n        acc = acc.mixedAdd(wnd[(-z - 1) >> 1].neg());\n    } else {\n      // J +- J\n      if (z > 0)\n        acc = acc.add(wnd[(z - 1) >> 1]);\n      else\n        acc = acc.add(wnd[(-z - 1) >> 1].neg());\n    }\n  }\n  return p.type === 'affine' ? acc.toP() : acc;\n};\n\nBaseCurve.prototype._wnafMulAdd = function _wnafMulAdd(defW,\n                                                       points,\n                                                       coeffs,\n                                                       len) {\n  var wndWidth = this._wnafT1;\n  var wnd = this._wnafT2;\n  var naf = this._wnafT3;\n\n  // Fill all arrays\n  var max = 0;\n  for (var i = 0; i < len; i++) {\n    var p = points[i];\n    var nafPoints = p._getNAFPoints(defW);\n    wndWidth[i] = nafPoints.wnd;\n    wnd[i] = nafPoints.points;\n  }\n\n  // Comb small window NAFs\n  for (var i = len - 1; i >= 1; i -= 2) {\n    var a = i - 1;\n    var b = i;\n    if (wndWidth[a] !== 1 || wndWidth[b] !== 1) {\n      naf[a] = getNAF(coeffs[a], wndWidth[a]);\n      naf[b] = getNAF(coeffs[b], wndWidth[b]);\n      max = Math.max(naf[a].length, max);\n      max = Math.max(naf[b].length, max);\n      continue;\n    }\n\n    var comb = [\n      points[a], /* 1 */\n      null, /* 3 */\n      null, /* 5 */\n      points[b] /* 7 */\n    ];\n\n    // Try to avoid Projective points, if possible\n    if (points[a].y.cmp(points[b].y) === 0) {\n      comb[1] = points[a].add(points[b]);\n      comb[2] = points[a].toJ().mixedAdd(points[b].neg());\n    } else if (points[a].y.cmp(points[b].y.redNeg()) === 0) {\n      comb[1] = points[a].toJ().mixedAdd(points[b]);\n      comb[2] = points[a].add(points[b].neg());\n    } else {\n      comb[1] = points[a].toJ().mixedAdd(points[b]);\n      comb[2] = points[a].toJ().mixedAdd(points[b].neg());\n    }\n\n    var index = [\n      -3, /* -1 -1 */\n      -1, /* -1 0 */\n      -5, /* -1 1 */\n      -7, /* 0 -1 */\n      0, /* 0 0 */\n      7, /* 0 1 */\n      5, /* 1 -1 */\n      1, /* 1 0 */\n      3  /* 1 1 */\n    ];\n\n    var jsf = getJSF(coeffs[a], coeffs[b]);\n    max = Math.max(jsf[0].length, max);\n    naf[a] = new Array(max);\n    naf[b] = new Array(max);\n    for (var j = 0; j < max; j++) {\n      var ja = jsf[0][j] | 0;\n      var jb = jsf[1][j] | 0;\n\n      naf[a][j] = index[(ja + 1) * 3 + (jb + 1)];\n      naf[b][j] = 0;\n      wnd[a] = comb;\n    }\n  }\n\n  var acc = this.jpoint(null, null, null);\n  var tmp = this._wnafT4;\n  for (var i = max; i >= 0; i--) {\n    var k = 0;\n\n    while (i >= 0) {\n      var zero = true;\n      for (var j = 0; j < len; j++) {\n        tmp[j] = naf[j][i] | 0;\n        if (tmp[j] !== 0)\n          zero = false;\n      }\n      if (!zero)\n        break;\n      k++;\n      i--;\n    }\n    if (i >= 0)\n      k++;\n    acc = acc.dblp(k);\n    if (i < 0)\n      break;\n\n    for (var j = 0; j < len; j++) {\n      var z = tmp[j];\n      var p;\n      if (z === 0)\n        continue;\n      else if (z > 0)\n        p = wnd[j][(z - 1) >> 1];\n      else if (z < 0)\n        p = wnd[j][(-z - 1) >> 1].neg();\n\n      if (p.type === 'affine')\n        acc = acc.mixedAdd(p);\n      else\n        acc = acc.add(p);\n    }\n  }\n  // Zeroify references\n  for (var i = 0; i < len; i++)\n    wnd[i] = null;\n  return acc.toP();\n};\n\nfunction BasePoint(curve, type) {\n  this.curve = curve;\n  this.type = type;\n  this.precomputed = null;\n}\nBaseCurve.BasePoint = BasePoint;\n\nBasePoint.prototype.eq = function eq(/*other*/) {\n  throw new Error('Not implemented');\n};\n\nBasePoint.prototype.validate = function validate() {\n  return this.curve.validate(this);\n};\n\nBaseCurve.prototype.decodePoint = function decodePoint(bytes, enc) {\n  bytes = utils.toArray(bytes, enc);\n\n  var len = this.p.byteLength();\n  if (bytes[0] === 0x04 && bytes.length - 1 === 2 * len) {\n    return this.point(bytes.slice(1, 1 + len),\n                      bytes.slice(1 + len, 1 + 2 * len));\n  } else if ((bytes[0] === 0x02 || bytes[0] === 0x03) &&\n              bytes.length - 1 === len) {\n    return this.pointFromX(bytes.slice(1, 1 + len), bytes[0] === 0x03);\n  }\n  throw new Error('Unknown point format');\n};\n\nBasePoint.prototype.encodeCompressed = function encodeCompressed(enc) {\n  return this.encode(enc, true);\n};\n\nBasePoint.prototype._encode = function _encode(compact) {\n  var len = this.curve.p.byteLength();\n  var x = this.getX().toArray('be', len);\n\n  if (compact)\n    return [ this.getY().isEven() ? 0x02 : 0x03 ].concat(x);\n\n  return [ 0x04 ].concat(x, this.getY().toArray('be', len)) ;\n};\n\nBasePoint.prototype.encode = function encode(enc, compact) {\n  return utils.encode(this._encode(compact), enc);\n};\n\nBasePoint.prototype.precompute = function precompute(power) {\n  if (this.precomputed)\n    return this;\n\n  var precomputed = {\n    doubles: null,\n    naf: null,\n    beta: null\n  };\n  precomputed.naf = this._getNAFPoints(8);\n  precomputed.doubles = this._getDoubles(4, power);\n  precomputed.beta = this._getBeta();\n  this.precomputed = precomputed;\n\n  return this;\n};\n\nBasePoint.prototype._hasDoubles = function _hasDoubles(k) {\n  if (!this.precomputed)\n    return false;\n\n  var doubles = this.precomputed.doubles;\n  if (!doubles)\n    return false;\n\n  return doubles.points.length >= Math.ceil((k.bitLength() + 1) / doubles.step);\n};\n\nBasePoint.prototype._getDoubles = function _getDoubles(step, power) {\n  if (this.precomputed && this.precomputed.doubles)\n    return this.precomputed.doubles;\n\n  var doubles = [ this ];\n  var acc = this;\n  for (var i = 0; i < power; i += step) {\n    for (var j = 0; j < step; j++)\n      acc = acc.dbl();\n    doubles.push(acc);\n  }\n  return {\n    step: step,\n    points: doubles\n  };\n};\n\nBasePoint.prototype._getNAFPoints = function _getNAFPoints(wnd) {\n  if (this.precomputed && this.precomputed.naf)\n    return this.precomputed.naf;\n\n  var res = [ this ];\n  var max = (1 << wnd) - 1;\n  var dbl = max === 1 ? null : this.dbl();\n  for (var i = 1; i < max; i++)\n    res[i] = res[i - 1].add(dbl);\n  return {\n    wnd: wnd,\n    points: res\n  };\n};\n\nBasePoint.prototype._getBeta = function _getBeta() {\n  return null;\n};\n\nBasePoint.prototype.dblp = function dblp(k) {\n  var r = this;\n  for (var i = 0; i < k; i++)\n    r = r.dbl();\n  return r;\n};\n","'use strict';\n\nvar curve = require('../curve');\nvar elliptic = require('../../elliptic');\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = curve.base;\n\nvar assert = elliptic.utils.assert;\n\nfunction EdwardsCurve(conf) {\n  // NOTE: Important as we are creating point in Base.call()\n  this.twisted = (conf.a | 0) !== 1;\n  this.mOneA = this.twisted && (conf.a | 0) === -1;\n  this.extended = this.mOneA;\n\n  Base.call(this, 'edwards', conf);\n\n  this.a = new BN(conf.a, 16).umod(this.red.m);\n  this.a = this.a.toRed(this.red);\n  this.c = new BN(conf.c, 16).toRed(this.red);\n  this.c2 = this.c.redSqr();\n  this.d = new BN(conf.d, 16).toRed(this.red);\n  this.dd = this.d.redAdd(this.d);\n\n  assert(!this.twisted || this.c.fromRed().cmpn(1) === 0);\n  this.oneC = (conf.c | 0) === 1;\n}\ninherits(EdwardsCurve, Base);\nmodule.exports = EdwardsCurve;\n\nEdwardsCurve.prototype._mulA = function _mulA(num) {\n  if (this.mOneA)\n    return num.redNeg();\n  else\n    return this.a.redMul(num);\n};\n\nEdwardsCurve.prototype._mulC = function _mulC(num) {\n  if (this.oneC)\n    return num;\n  else\n    return this.c.redMul(num);\n};\n\n// Just for compatibility with Short curve\nEdwardsCurve.prototype.jpoint = function jpoint(x, y, z, t) {\n  return this.point(x, y, z, t);\n};\n\nEdwardsCurve.prototype.pointFromX = function pointFromX(x, odd) {\n  x = new BN(x, 16);\n  if (!x.red)\n    x = x.toRed(this.red);\n\n  var x2 = x.redSqr();\n  var rhs = this.c2.redSub(this.a.redMul(x2));\n  var lhs = this.one.redSub(this.c2.redMul(this.d).redMul(x2));\n\n  var y2 = rhs.redMul(lhs.redInvm());\n  var y = y2.redSqrt();\n  if (y.redSqr().redSub(y2).cmp(this.zero) !== 0)\n    throw new Error('invalid point');\n\n  var isOdd = y.fromRed().isOdd();\n  if (odd && !isOdd || !odd && isOdd)\n    y = y.redNeg();\n\n  return this.point(x, y);\n};\n\nEdwardsCurve.prototype.pointFromY = function pointFromY(y, odd) {\n  y = new BN(y, 16);\n  if (!y.red)\n    y = y.toRed(this.red);\n\n  // x^2 = (y^2 - 1) / (d y^2 + 1)\n  var y2 = y.redSqr();\n  var lhs = y2.redSub(this.one);\n  var rhs = y2.redMul(this.d).redAdd(this.one);\n  var x2 = lhs.redMul(rhs.redInvm());\n\n  if (x2.cmp(this.zero) === 0) {\n    if (odd)\n      throw new Error('invalid point');\n    else\n      return this.point(this.zero, y);\n  }\n\n  var x = x2.redSqrt();\n  if (x.redSqr().redSub(x2).cmp(this.zero) !== 0)\n    throw new Error('invalid point');\n\n  if (x.isOdd() !== odd)\n    x = x.redNeg();\n\n  return this.point(x, y);\n};\n\nEdwardsCurve.prototype.validate = function validate(point) {\n  if (point.isInfinity())\n    return true;\n\n  // Curve: A * X^2 + Y^2 = C^2 * (1 + D * X^2 * Y^2)\n  point.normalize();\n\n  var x2 = point.x.redSqr();\n  var y2 = point.y.redSqr();\n  var lhs = x2.redMul(this.a).redAdd(y2);\n  var rhs = this.c2.redMul(this.one.redAdd(this.d.redMul(x2).redMul(y2)));\n\n  return lhs.cmp(rhs) === 0;\n};\n\nfunction Point(curve, x, y, z, t) {\n  Base.BasePoint.call(this, curve, 'projective');\n  if (x === null && y === null && z === null) {\n    this.x = this.curve.zero;\n    this.y = this.curve.one;\n    this.z = this.curve.one;\n    this.t = this.curve.zero;\n    this.zOne = true;\n  } else {\n    this.x = new BN(x, 16);\n    this.y = new BN(y, 16);\n    this.z = z ? new BN(z, 16) : this.curve.one;\n    this.t = t && new BN(t, 16);\n    if (!this.x.red)\n      this.x = this.x.toRed(this.curve.red);\n    if (!this.y.red)\n      this.y = this.y.toRed(this.curve.red);\n    if (!this.z.red)\n      this.z = this.z.toRed(this.curve.red);\n    if (this.t && !this.t.red)\n      this.t = this.t.toRed(this.curve.red);\n    this.zOne = this.z === this.curve.one;\n\n    // Use extended coordinates\n    if (this.curve.extended && !this.t) {\n      this.t = this.x.redMul(this.y);\n      if (!this.zOne)\n        this.t = this.t.redMul(this.z.redInvm());\n    }\n  }\n}\ninherits(Point, Base.BasePoint);\n\nEdwardsCurve.prototype.pointFromJSON = function pointFromJSON(obj) {\n  return Point.fromJSON(this, obj);\n};\n\nEdwardsCurve.prototype.point = function point(x, y, z, t) {\n  return new Point(this, x, y, z, t);\n};\n\nPoint.fromJSON = function fromJSON(curve, obj) {\n  return new Point(curve, obj[0], obj[1], obj[2]);\n};\n\nPoint.prototype.inspect = function inspect() {\n  if (this.isInfinity())\n    return '<EC Point Infinity>';\n  return '<EC Point x: ' + this.x.fromRed().toString(16, 2) +\n      ' y: ' + this.y.fromRed().toString(16, 2) +\n      ' z: ' + this.z.fromRed().toString(16, 2) + '>';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n  // XXX This code assumes that zero is always zero in red\n  return this.x.cmpn(0) === 0 &&\n         this.y.cmp(this.z) === 0;\n};\n\nPoint.prototype._extDbl = function _extDbl() {\n  // hyperelliptic.org/EFD/g1p/auto-twisted-extended-1.html\n  //     #doubling-dbl-2008-hwcd\n  // 4M + 4S\n\n  // A = X1^2\n  var a = this.x.redSqr();\n  // B = Y1^2\n  var b = this.y.redSqr();\n  // C = 2 * Z1^2\n  var c = this.z.redSqr();\n  c = c.redIAdd(c);\n  // D = a * A\n  var d = this.curve._mulA(a);\n  // E = (X1 + Y1)^2 - A - B\n  var e = this.x.redAdd(this.y).redSqr().redISub(a).redISub(b);\n  // G = D + B\n  var g = d.redAdd(b);\n  // F = G - C\n  var f = g.redSub(c);\n  // H = D - B\n  var h = d.redSub(b);\n  // X3 = E * F\n  var nx = e.redMul(f);\n  // Y3 = G * H\n  var ny = g.redMul(h);\n  // T3 = E * H\n  var nt = e.redMul(h);\n  // Z3 = F * G\n  var nz = f.redMul(g);\n  return this.curve.point(nx, ny, nz, nt);\n};\n\nPoint.prototype._projDbl = function _projDbl() {\n  // hyperelliptic.org/EFD/g1p/auto-twisted-projective.html\n  //     #doubling-dbl-2008-bbjlp\n  //     #doubling-dbl-2007-bl\n  // and others\n  // Generally 3M + 4S or 2M + 4S\n\n  // B = (X1 + Y1)^2\n  var b = this.x.redAdd(this.y).redSqr();\n  // C = X1^2\n  var c = this.x.redSqr();\n  // D = Y1^2\n  var d = this.y.redSqr();\n\n  var nx;\n  var ny;\n  var nz;\n  if (this.curve.twisted) {\n    // E = a * C\n    var e = this.curve._mulA(c);\n    // F = E + D\n    var f = e.redAdd(d);\n    if (this.zOne) {\n      // X3 = (B - C - D) * (F - 2)\n      nx = b.redSub(c).redSub(d).redMul(f.redSub(this.curve.two));\n      // Y3 = F * (E - D)\n      ny = f.redMul(e.redSub(d));\n      // Z3 = F^2 - 2 * F\n      nz = f.redSqr().redSub(f).redSub(f);\n    } else {\n      // H = Z1^2\n      var h = this.z.redSqr();\n      // J = F - 2 * H\n      var j = f.redSub(h).redISub(h);\n      // X3 = (B-C-D)*J\n      nx = b.redSub(c).redISub(d).redMul(j);\n      // Y3 = F * (E - D)\n      ny = f.redMul(e.redSub(d));\n      // Z3 = F * J\n      nz = f.redMul(j);\n    }\n  } else {\n    // E = C + D\n    var e = c.redAdd(d);\n    // H = (c * Z1)^2\n    var h = this.curve._mulC(this.c.redMul(this.z)).redSqr();\n    // J = E - 2 * H\n    var j = e.redSub(h).redSub(h);\n    // X3 = c * (B - E) * J\n    nx = this.curve._mulC(b.redISub(e)).redMul(j);\n    // Y3 = c * E * (C - D)\n    ny = this.curve._mulC(e).redMul(c.redISub(d));\n    // Z3 = E * J\n    nz = e.redMul(j);\n  }\n  return this.curve.point(nx, ny, nz);\n};\n\nPoint.prototype.dbl = function dbl() {\n  if (this.isInfinity())\n    return this;\n\n  // Double in extended coordinates\n  if (this.curve.extended)\n    return this._extDbl();\n  else\n    return this._projDbl();\n};\n\nPoint.prototype._extAdd = function _extAdd(p) {\n  // hyperelliptic.org/EFD/g1p/auto-twisted-extended-1.html\n  //     #addition-add-2008-hwcd-3\n  // 8M\n\n  // A = (Y1 - X1) * (Y2 - X2)\n  var a = this.y.redSub(this.x).redMul(p.y.redSub(p.x));\n  // B = (Y1 + X1) * (Y2 + X2)\n  var b = this.y.redAdd(this.x).redMul(p.y.redAdd(p.x));\n  // C = T1 * k * T2\n  var c = this.t.redMul(this.curve.dd).redMul(p.t);\n  // D = Z1 * 2 * Z2\n  var d = this.z.redMul(p.z.redAdd(p.z));\n  // E = B - A\n  var e = b.redSub(a);\n  // F = D - C\n  var f = d.redSub(c);\n  // G = D + C\n  var g = d.redAdd(c);\n  // H = B + A\n  var h = b.redAdd(a);\n  // X3 = E * F\n  var nx = e.redMul(f);\n  // Y3 = G * H\n  var ny = g.redMul(h);\n  // T3 = E * H\n  var nt = e.redMul(h);\n  // Z3 = F * G\n  var nz = f.redMul(g);\n  return this.curve.point(nx, ny, nz, nt);\n};\n\nPoint.prototype._projAdd = function _projAdd(p) {\n  // hyperelliptic.org/EFD/g1p/auto-twisted-projective.html\n  //     #addition-add-2008-bbjlp\n  //     #addition-add-2007-bl\n  // 10M + 1S\n\n  // A = Z1 * Z2\n  var a = this.z.redMul(p.z);\n  // B = A^2\n  var b = a.redSqr();\n  // C = X1 * X2\n  var c = this.x.redMul(p.x);\n  // D = Y1 * Y2\n  var d = this.y.redMul(p.y);\n  // E = d * C * D\n  var e = this.curve.d.redMul(c).redMul(d);\n  // F = B - E\n  var f = b.redSub(e);\n  // G = B + E\n  var g = b.redAdd(e);\n  // X3 = A * F * ((X1 + Y1) * (X2 + Y2) - C - D)\n  var tmp = this.x.redAdd(this.y).redMul(p.x.redAdd(p.y)).redISub(c).redISub(d);\n  var nx = a.redMul(f).redMul(tmp);\n  var ny;\n  var nz;\n  if (this.curve.twisted) {\n    // Y3 = A * G * (D - a * C)\n    ny = a.redMul(g).redMul(d.redSub(this.curve._mulA(c)));\n    // Z3 = F * G\n    nz = f.redMul(g);\n  } else {\n    // Y3 = A * G * (D - C)\n    ny = a.redMul(g).redMul(d.redSub(c));\n    // Z3 = c * F * G\n    nz = this.curve._mulC(f).redMul(g);\n  }\n  return this.curve.point(nx, ny, nz);\n};\n\nPoint.prototype.add = function add(p) {\n  if (this.isInfinity())\n    return p;\n  if (p.isInfinity())\n    return this;\n\n  if (this.curve.extended)\n    return this._extAdd(p);\n  else\n    return this._projAdd(p);\n};\n\nPoint.prototype.mul = function mul(k) {\n  if (this._hasDoubles(k))\n    return this.curve._fixedNafMul(this, k);\n  else\n    return this.curve._wnafMul(this, k);\n};\n\nPoint.prototype.mulAdd = function mulAdd(k1, p, k2) {\n  return this.curve._wnafMulAdd(1, [ this, p ], [ k1, k2 ], 2);\n};\n\nPoint.prototype.normalize = function normalize() {\n  if (this.zOne)\n    return this;\n\n  // Normalize coordinates\n  var zi = this.z.redInvm();\n  this.x = this.x.redMul(zi);\n  this.y = this.y.redMul(zi);\n  if (this.t)\n    this.t = this.t.redMul(zi);\n  this.z = this.curve.one;\n  this.zOne = true;\n  return this;\n};\n\nPoint.prototype.neg = function neg() {\n  return this.curve.point(this.x.redNeg(),\n                          this.y,\n                          this.z,\n                          this.t && this.t.redNeg());\n};\n\nPoint.prototype.getX = function getX() {\n  this.normalize();\n  return this.x.fromRed();\n};\n\nPoint.prototype.getY = function getY() {\n  this.normalize();\n  return this.y.fromRed();\n};\n\nPoint.prototype.eq = function eq(other) {\n  return this === other ||\n         this.getX().cmp(other.getX()) === 0 &&\n         this.getY().cmp(other.getY()) === 0;\n};\n\n// Compatibility with BaseCurve\nPoint.prototype.toP = Point.prototype.normalize;\nPoint.prototype.mixedAdd = Point.prototype.add;\n","'use strict';\n\nvar curve = exports;\n\ncurve.base = require('./base');\ncurve.short = require('./short');\ncurve.mont = require('./mont');\ncurve.edwards = require('./edwards');\n","'use strict';\n\nvar curve = require('../curve');\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = curve.base;\n\nvar elliptic = require('../../elliptic');\nvar utils = elliptic.utils;\n\nfunction MontCurve(conf) {\n  Base.call(this, 'mont', conf);\n\n  this.a = new BN(conf.a, 16).toRed(this.red);\n  this.b = new BN(conf.b, 16).toRed(this.red);\n  this.i4 = new BN(4).toRed(this.red).redInvm();\n  this.two = new BN(2).toRed(this.red);\n  this.a24 = this.i4.redMul(this.a.redAdd(this.two));\n}\ninherits(MontCurve, Base);\nmodule.exports = MontCurve;\n\nMontCurve.prototype.validate = function validate(point) {\n  var x = point.normalize().x;\n  var x2 = x.redSqr();\n  var rhs = x2.redMul(x).redAdd(x2.redMul(this.a)).redAdd(x);\n  var y = rhs.redSqrt();\n\n  return y.redSqr().cmp(rhs) === 0;\n};\n\nfunction Point(curve, x, z) {\n  Base.BasePoint.call(this, curve, 'projective');\n  if (x === null && z === null) {\n    this.x = this.curve.one;\n    this.z = this.curve.zero;\n  } else {\n    this.x = new BN(x, 16);\n    this.z = new BN(z, 16);\n    if (!this.x.red)\n      this.x = this.x.toRed(this.curve.red);\n    if (!this.z.red)\n      this.z = this.z.toRed(this.curve.red);\n  }\n}\ninherits(Point, Base.BasePoint);\n\nMontCurve.prototype.decodePoint = function decodePoint(bytes, enc) {\n  return this.point(utils.toArray(bytes, enc), 1);\n};\n\nMontCurve.prototype.point = function point(x, z) {\n  return new Point(this, x, z);\n};\n\nMontCurve.prototype.pointFromJSON = function pointFromJSON(obj) {\n  return Point.fromJSON(this, obj);\n};\n\nPoint.prototype.precompute = function precompute() {\n  // No-op\n};\n\nPoint.prototype._encode = function _encode() {\n  return this.getX().toArray('be', this.curve.p.byteLength());\n};\n\nPoint.fromJSON = function fromJSON(curve, obj) {\n  return new Point(curve, obj[0], obj[1] || curve.one);\n};\n\nPoint.prototype.inspect = function inspect() {\n  if (this.isInfinity())\n    return '<EC Point Infinity>';\n  return '<EC Point x: ' + this.x.fromRed().toString(16, 2) +\n      ' z: ' + this.z.fromRed().toString(16, 2) + '>';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n  // XXX This code assumes that zero is always zero in red\n  return this.z.cmpn(0) === 0;\n};\n\nPoint.prototype.dbl = function dbl() {\n  // http://hyperelliptic.org/EFD/g1p/auto-montgom-xz.html#doubling-dbl-1987-m-3\n  // 2M + 2S + 4A\n\n  // A = X1 + Z1\n  var a = this.x.redAdd(this.z);\n  // AA = A^2\n  var aa = a.redSqr();\n  // B = X1 - Z1\n  var b = this.x.redSub(this.z);\n  // BB = B^2\n  var bb = b.redSqr();\n  // C = AA - BB\n  var c = aa.redSub(bb);\n  // X3 = AA * BB\n  var nx = aa.redMul(bb);\n  // Z3 = C * (BB + A24 * C)\n  var nz = c.redMul(bb.redAdd(this.curve.a24.redMul(c)));\n  return this.curve.point(nx, nz);\n};\n\nPoint.prototype.add = function add() {\n  throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.diffAdd = function diffAdd(p, diff) {\n  // http://hyperelliptic.org/EFD/g1p/auto-montgom-xz.html#diffadd-dadd-1987-m-3\n  // 4M + 2S + 6A\n\n  // A = X2 + Z2\n  var a = this.x.redAdd(this.z);\n  // B = X2 - Z2\n  var b = this.x.redSub(this.z);\n  // C = X3 + Z3\n  var c = p.x.redAdd(p.z);\n  // D = X3 - Z3\n  var d = p.x.redSub(p.z);\n  // DA = D * A\n  var da = d.redMul(a);\n  // CB = C * B\n  var cb = c.redMul(b);\n  // X5 = Z1 * (DA + CB)^2\n  var nx = diff.z.redMul(da.redAdd(cb).redSqr());\n  // Z5 = X1 * (DA - CB)^2\n  var nz = diff.x.redMul(da.redISub(cb).redSqr());\n  return this.curve.point(nx, nz);\n};\n\nPoint.prototype.mul = function mul(k) {\n  var t = k.clone();\n  var a = this; // (N / 2) * Q + Q\n  var b = this.curve.point(null, null); // (N / 2) * Q\n  var c = this; // Q\n\n  for (var bits = []; t.cmpn(0) !== 0; t.iushrn(1))\n    bits.push(t.andln(1));\n\n  for (var i = bits.length - 1; i >= 0; i--) {\n    if (bits[i] === 0) {\n      // N * Q + Q = ((N / 2) * Q + Q)) + (N / 2) * Q\n      a = a.diffAdd(b, c);\n      // N * Q = 2 * ((N / 2) * Q + Q))\n      b = b.dbl();\n    } else {\n      // N * Q = ((N / 2) * Q + Q) + ((N / 2) * Q)\n      b = a.diffAdd(b, c);\n      // N * Q + Q = 2 * ((N / 2) * Q + Q)\n      a = a.dbl();\n    }\n  }\n  return b;\n};\n\nPoint.prototype.mulAdd = function mulAdd() {\n  throw new Error('Not supported on Montgomery curve');\n};\n\nPoint.prototype.eq = function eq(other) {\n  return this.getX().cmp(other.getX()) === 0;\n};\n\nPoint.prototype.normalize = function normalize() {\n  this.x = this.x.redMul(this.z.redInvm());\n  this.z = this.curve.one;\n  return this;\n};\n\nPoint.prototype.getX = function getX() {\n  // Normalize coordinates\n  this.normalize();\n\n  return this.x.fromRed();\n};\n","'use strict';\n\nvar curve = require('../curve');\nvar elliptic = require('../../elliptic');\nvar BN = require('bn.js');\nvar inherits = require('inherits');\nvar Base = curve.base;\n\nvar assert = elliptic.utils.assert;\n\nfunction ShortCurve(conf) {\n  Base.call(this, 'short', conf);\n\n  this.a = new BN(conf.a, 16).toRed(this.red);\n  this.b = new BN(conf.b, 16).toRed(this.red);\n  this.tinv = this.two.redInvm();\n\n  this.zeroA = this.a.fromRed().cmpn(0) === 0;\n  this.threeA = this.a.fromRed().sub(this.p).cmpn(-3) === 0;\n\n  // If the curve is endomorphic, precalculate beta and lambda\n  this.endo = this._getEndomorphism(conf);\n  this._endoWnafT1 = new Array(4);\n  this._endoWnafT2 = new Array(4);\n}\ninherits(ShortCurve, Base);\nmodule.exports = ShortCurve;\n\nShortCurve.prototype._getEndomorphism = function _getEndomorphism(conf) {\n  // No efficient endomorphism\n  if (!this.zeroA || !this.g || !this.n || this.p.modn(3) !== 1)\n    return;\n\n  // Compute beta and lambda, that lambda * P = (beta * Px; Py)\n  var beta;\n  var lambda;\n  if (conf.beta) {\n    beta = new BN(conf.beta, 16).toRed(this.red);\n  } else {\n    var betas = this._getEndoRoots(this.p);\n    // Choose the smallest beta\n    beta = betas[0].cmp(betas[1]) < 0 ? betas[0] : betas[1];\n    beta = beta.toRed(this.red);\n  }\n  if (conf.lambda) {\n    lambda = new BN(conf.lambda, 16);\n  } else {\n    // Choose the lambda that is matching selected beta\n    var lambdas = this._getEndoRoots(this.n);\n    if (this.g.mul(lambdas[0]).x.cmp(this.g.x.redMul(beta)) === 0) {\n      lambda = lambdas[0];\n    } else {\n      lambda = lambdas[1];\n      assert(this.g.mul(lambda).x.cmp(this.g.x.redMul(beta)) === 0);\n    }\n  }\n\n  // Get basis vectors, used for balanced length-two representation\n  var basis;\n  if (conf.basis) {\n    basis = conf.basis.map(function(vec) {\n      return {\n        a: new BN(vec.a, 16),\n        b: new BN(vec.b, 16)\n      };\n    });\n  } else {\n    basis = this._getEndoBasis(lambda);\n  }\n\n  return {\n    beta: beta,\n    lambda: lambda,\n    basis: basis\n  };\n};\n\nShortCurve.prototype._getEndoRoots = function _getEndoRoots(num) {\n  // Find roots of for x^2 + x + 1 in F\n  // Root = (-1 +- Sqrt(-3)) / 2\n  //\n  var red = num === this.p ? this.red : BN.mont(num);\n  var tinv = new BN(2).toRed(red).redInvm();\n  var ntinv = tinv.redNeg();\n\n  var s = new BN(3).toRed(red).redNeg().redSqrt().redMul(tinv);\n\n  var l1 = ntinv.redAdd(s).fromRed();\n  var l2 = ntinv.redSub(s).fromRed();\n  return [ l1, l2 ];\n};\n\nShortCurve.prototype._getEndoBasis = function _getEndoBasis(lambda) {\n  // aprxSqrt >= sqrt(this.n)\n  var aprxSqrt = this.n.ushrn(Math.floor(this.n.bitLength() / 2));\n\n  // 3.74\n  // Run EGCD, until r(L + 1) < aprxSqrt\n  var u = lambda;\n  var v = this.n.clone();\n  var x1 = new BN(1);\n  var y1 = new BN(0);\n  var x2 = new BN(0);\n  var y2 = new BN(1);\n\n  // NOTE: all vectors are roots of: a + b * lambda = 0 (mod n)\n  var a0;\n  var b0;\n  // First vector\n  var a1;\n  var b1;\n  // Second vector\n  var a2;\n  var b2;\n\n  var prevR;\n  var i = 0;\n  var r;\n  var x;\n  while (u.cmpn(0) !== 0) {\n    var q = v.div(u);\n    r = v.sub(q.mul(u));\n    x = x2.sub(q.mul(x1));\n    var y = y2.sub(q.mul(y1));\n\n    if (!a1 && r.cmp(aprxSqrt) < 0) {\n      a0 = prevR.neg();\n      b0 = x1;\n      a1 = r.neg();\n      b1 = x;\n    } else if (a1 && ++i === 2) {\n      break;\n    }\n    prevR = r;\n\n    v = u;\n    u = r;\n    x2 = x1;\n    x1 = x;\n    y2 = y1;\n    y1 = y;\n  }\n  a2 = r.neg();\n  b2 = x;\n\n  var len1 = a1.sqr().add(b1.sqr());\n  var len2 = a2.sqr().add(b2.sqr());\n  if (len2.cmp(len1) >= 0) {\n    a2 = a0;\n    b2 = b0;\n  }\n\n  // Normalize signs\n  if (a1.negative) {\n    a1 = a1.neg();\n    b1 = b1.neg();\n  }\n  if (a2.negative) {\n    a2 = a2.neg();\n    b2 = b2.neg();\n  }\n\n  return [\n    { a: a1, b: b1 },\n    { a: a2, b: b2 }\n  ];\n};\n\nShortCurve.prototype._endoSplit = function _endoSplit(k) {\n  var basis = this.endo.basis;\n  var v1 = basis[0];\n  var v2 = basis[1];\n\n  var c1 = v2.b.mul(k).divRound(this.n);\n  var c2 = v1.b.neg().mul(k).divRound(this.n);\n\n  var p1 = c1.mul(v1.a);\n  var p2 = c2.mul(v2.a);\n  var q1 = c1.mul(v1.b);\n  var q2 = c2.mul(v2.b);\n\n  // Calculate answer\n  var k1 = k.sub(p1).sub(p2);\n  var k2 = q1.add(q2).neg();\n  return { k1: k1, k2: k2 };\n};\n\nShortCurve.prototype.pointFromX = function pointFromX(x, odd) {\n  x = new BN(x, 16);\n  if (!x.red)\n    x = x.toRed(this.red);\n\n  var y2 = x.redSqr().redMul(x).redIAdd(x.redMul(this.a)).redIAdd(this.b);\n  var y = y2.redSqrt();\n  if (y.redSqr().redSub(y2).cmp(this.zero) !== 0)\n    throw new Error('invalid point');\n\n  // XXX Is there any way to tell if the number is odd without converting it\n  // to non-red form?\n  var isOdd = y.fromRed().isOdd();\n  if (odd && !isOdd || !odd && isOdd)\n    y = y.redNeg();\n\n  return this.point(x, y);\n};\n\nShortCurve.prototype.validate = function validate(point) {\n  if (point.inf)\n    return true;\n\n  var x = point.x;\n  var y = point.y;\n\n  var ax = this.a.redMul(x);\n  var rhs = x.redSqr().redMul(x).redIAdd(ax).redIAdd(this.b);\n  return y.redSqr().redISub(rhs).cmpn(0) === 0;\n};\n\nShortCurve.prototype._endoWnafMulAdd =\n    function _endoWnafMulAdd(points, coeffs) {\n  var npoints = this._endoWnafT1;\n  var ncoeffs = this._endoWnafT2;\n  for (var i = 0; i < points.length; i++) {\n    var split = this._endoSplit(coeffs[i]);\n    var p = points[i];\n    var beta = p._getBeta();\n\n    if (split.k1.negative) {\n      split.k1.ineg();\n      p = p.neg(true);\n    }\n    if (split.k2.negative) {\n      split.k2.ineg();\n      beta = beta.neg(true);\n    }\n\n    npoints[i * 2] = p;\n    npoints[i * 2 + 1] = beta;\n    ncoeffs[i * 2] = split.k1;\n    ncoeffs[i * 2 + 1] = split.k2;\n  }\n  var res = this._wnafMulAdd(1, npoints, ncoeffs, i * 2);\n\n  // Clean-up references to points and coefficients\n  for (var j = 0; j < i * 2; j++) {\n    npoints[j] = null;\n    ncoeffs[j] = null;\n  }\n  return res;\n};\n\nfunction Point(curve, x, y, isRed) {\n  Base.BasePoint.call(this, curve, 'affine');\n  if (x === null && y === null) {\n    this.x = null;\n    this.y = null;\n    this.inf = true;\n  } else {\n    this.x = new BN(x, 16);\n    this.y = new BN(y, 16);\n    // Force redgomery representation when loading from JSON\n    if (isRed) {\n      this.x.forceRed(this.curve.red);\n      this.y.forceRed(this.curve.red);\n    }\n    if (!this.x.red)\n      this.x = this.x.toRed(this.curve.red);\n    if (!this.y.red)\n      this.y = this.y.toRed(this.curve.red);\n    this.inf = false;\n  }\n}\ninherits(Point, Base.BasePoint);\n\nShortCurve.prototype.point = function point(x, y, isRed) {\n  return new Point(this, x, y, isRed);\n};\n\nShortCurve.prototype.pointFromJSON = function pointFromJSON(obj, red) {\n  return Point.fromJSON(this, obj, red);\n};\n\nPoint.prototype._getBeta = function _getBeta() {\n  if (!this.curve.endo)\n    return;\n\n  var pre = this.precomputed;\n  if (pre && pre.beta)\n    return pre.beta;\n\n  var beta = this.curve.point(this.x.redMul(this.curve.endo.beta), this.y);\n  if (pre) {\n    var curve = this.curve;\n    var endoMul = function(p) {\n      return curve.point(p.x.redMul(curve.endo.beta), p.y);\n    };\n    pre.beta = beta;\n    beta.precomputed = {\n      beta: null,\n      naf: pre.naf && {\n        wnd: pre.naf.wnd,\n        points: pre.naf.points.map(endoMul)\n      },\n      doubles: pre.doubles && {\n        step: pre.doubles.step,\n        points: pre.doubles.points.map(endoMul)\n      }\n    };\n  }\n  return beta;\n};\n\nPoint.prototype.toJSON = function toJSON() {\n  if (!this.precomputed)\n    return [ this.x, this.y ];\n\n  return [ this.x, this.y, this.precomputed && {\n    doubles: this.precomputed.doubles && {\n      step: this.precomputed.doubles.step,\n      points: this.precomputed.doubles.points.slice(1)\n    },\n    naf: this.precomputed.naf && {\n      wnd: this.precomputed.naf.wnd,\n      points: this.precomputed.naf.points.slice(1)\n    }\n  } ];\n};\n\nPoint.fromJSON = function fromJSON(curve, obj, red) {\n  if (typeof obj === 'string')\n    obj = JSON.parse(obj);\n  var res = curve.point(obj[0], obj[1], red);\n  if (!obj[2])\n    return res;\n\n  function obj2point(obj) {\n    return curve.point(obj[0], obj[1], red);\n  }\n\n  var pre = obj[2];\n  res.precomputed = {\n    beta: null,\n    doubles: pre.doubles && {\n      step: pre.doubles.step,\n      points: [ res ].concat(pre.doubles.points.map(obj2point))\n    },\n    naf: pre.naf && {\n      wnd: pre.naf.wnd,\n      points: [ res ].concat(pre.naf.points.map(obj2point))\n    }\n  };\n  return res;\n};\n\nPoint.prototype.inspect = function inspect() {\n  if (this.isInfinity())\n    return '<EC Point Infinity>';\n  return '<EC Point x: ' + this.x.fromRed().toString(16, 2) +\n      ' y: ' + this.y.fromRed().toString(16, 2) + '>';\n};\n\nPoint.prototype.isInfinity = function isInfinity() {\n  return this.inf;\n};\n\nPoint.prototype.add = function add(p) {\n  // O + P = P\n  if (this.inf)\n    return p;\n\n  // P + O = P\n  if (p.inf)\n    return this;\n\n  // P + P = 2P\n  if (this.eq(p))\n    return this.dbl();\n\n  // P + (-P) = O\n  if (this.neg().eq(p))\n    return this.curve.point(null, null);\n\n  // P + Q = O\n  if (this.x.cmp(p.x) === 0)\n    return this.curve.point(null, null);\n\n  var c = this.y.redSub(p.y);\n  if (c.cmpn(0) !== 0)\n    c = c.redMul(this.x.redSub(p.x).redInvm());\n  var nx = c.redSqr().redISub(this.x).redISub(p.x);\n  var ny = c.redMul(this.x.redSub(nx)).redISub(this.y);\n  return this.curve.point(nx, ny);\n};\n\nPoint.prototype.dbl = function dbl() {\n  if (this.inf)\n    return this;\n\n  // 2P = O\n  var ys1 = this.y.redAdd(this.y);\n  if (ys1.cmpn(0) === 0)\n    return this.curve.point(null, null);\n\n  var a = this.curve.a;\n\n  var x2 = this.x.redSqr();\n  var dyinv = ys1.redInvm();\n  var c = x2.redAdd(x2).redIAdd(x2).redIAdd(a).redMul(dyinv);\n\n  var nx = c.redSqr().redISub(this.x.redAdd(this.x));\n  var ny = c.redMul(this.x.redSub(nx)).redISub(this.y);\n  return this.curve.point(nx, ny);\n};\n\nPoint.prototype.getX = function getX() {\n  return this.x.fromRed();\n};\n\nPoint.prototype.getY = function getY() {\n  return this.y.fromRed();\n};\n\nPoint.prototype.mul = function mul(k) {\n  k = new BN(k, 16);\n\n  if (this._hasDoubles(k))\n    return this.curve._fixedNafMul(this, k);\n  else if (this.curve.endo)\n    return this.curve._endoWnafMulAdd([ this ], [ k ]);\n  else\n    return this.curve._wnafMul(this, k);\n};\n\nPoint.prototype.mulAdd = function mulAdd(k1, p2, k2) {\n  var points = [ this, p2 ];\n  var coeffs = [ k1, k2 ];\n  if (this.curve.endo)\n    return this.curve._endoWnafMulAdd(points, coeffs);\n  else\n    return this.curve._wnafMulAdd(1, points, coeffs, 2);\n};\n\nPoint.prototype.eq = function eq(p) {\n  return this === p ||\n         this.inf === p.inf &&\n             (this.inf || this.x.cmp(p.x) === 0 && this.y.cmp(p.y) === 0);\n};\n\nPoint.prototype.neg = function neg(_precompute) {\n  if (this.inf)\n    return this;\n\n  var res = this.curve.point(this.x, this.y.redNeg());\n  if (_precompute && this.precomputed) {\n    var pre = this.precomputed;\n    var negate = function(p) {\n      return p.neg();\n    };\n    res.precomputed = {\n      naf: pre.naf && {\n        wnd: pre.naf.wnd,\n        points: pre.naf.points.map(negate)\n      },\n      doubles: pre.doubles && {\n        step: pre.doubles.step,\n        points: pre.doubles.points.map(negate)\n      }\n    };\n  }\n  return res;\n};\n\nPoint.prototype.toJ = function toJ() {\n  if (this.inf)\n    return this.curve.jpoint(null, null, null);\n\n  var res = this.curve.jpoint(this.x, this.y, this.curve.one);\n  return res;\n};\n\nfunction JPoint(curve, x, y, z) {\n  Base.BasePoint.call(this, curve, 'jacobian');\n  if (x === null && y === null && z === null) {\n    this.x = this.curve.one;\n    this.y = this.curve.one;\n    this.z = new BN(0);\n  } else {\n    this.x = new BN(x, 16);\n    this.y = new BN(y, 16);\n    this.z = new BN(z, 16);\n  }\n  if (!this.x.red)\n    this.x = this.x.toRed(this.curve.red);\n  if (!this.y.red)\n    this.y = this.y.toRed(this.curve.red);\n  if (!this.z.red)\n    this.z = this.z.toRed(this.curve.red);\n\n  this.zOne = this.z === this.curve.one;\n}\ninherits(JPoint, Base.BasePoint);\n\nShortCurve.prototype.jpoint = function jpoint(x, y, z) {\n  return new JPoint(this, x, y, z);\n};\n\nJPoint.prototype.toP = function toP() {\n  if (this.isInfinity())\n    return this.curve.point(null, null);\n\n  var zinv = this.z.redInvm();\n  var zinv2 = zinv.redSqr();\n  var ax = this.x.redMul(zinv2);\n  var ay = this.y.redMul(zinv2).redMul(zinv);\n\n  return this.curve.point(ax, ay);\n};\n\nJPoint.prototype.neg = function neg() {\n  return this.curve.jpoint(this.x, this.y.redNeg(), this.z);\n};\n\nJPoint.prototype.add = function add(p) {\n  // O + P = P\n  if (this.isInfinity())\n    return p;\n\n  // P + O = P\n  if (p.isInfinity())\n    return this;\n\n  // 12M + 4S + 7A\n  var pz2 = p.z.redSqr();\n  var z2 = this.z.redSqr();\n  var u1 = this.x.redMul(pz2);\n  var u2 = p.x.redMul(z2);\n  var s1 = this.y.redMul(pz2.redMul(p.z));\n  var s2 = p.y.redMul(z2.redMul(this.z));\n\n  var h = u1.redSub(u2);\n  var r = s1.redSub(s2);\n  if (h.cmpn(0) === 0) {\n    if (r.cmpn(0) !== 0)\n      return this.curve.jpoint(null, null, null);\n    else\n      return this.dbl();\n  }\n\n  var h2 = h.redSqr();\n  var h3 = h2.redMul(h);\n  var v = u1.redMul(h2);\n\n  var nx = r.redSqr().redIAdd(h3).redISub(v).redISub(v);\n  var ny = r.redMul(v.redISub(nx)).redISub(s1.redMul(h3));\n  var nz = this.z.redMul(p.z).redMul(h);\n\n  return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.mixedAdd = function mixedAdd(p) {\n  // O + P = P\n  if (this.isInfinity())\n    return p.toJ();\n\n  // P + O = P\n  if (p.isInfinity())\n    return this;\n\n  // 8M + 3S + 7A\n  var z2 = this.z.redSqr();\n  var u1 = this.x;\n  var u2 = p.x.redMul(z2);\n  var s1 = this.y;\n  var s2 = p.y.redMul(z2).redMul(this.z);\n\n  var h = u1.redSub(u2);\n  var r = s1.redSub(s2);\n  if (h.cmpn(0) === 0) {\n    if (r.cmpn(0) !== 0)\n      return this.curve.jpoint(null, null, null);\n    else\n      return this.dbl();\n  }\n\n  var h2 = h.redSqr();\n  var h3 = h2.redMul(h);\n  var v = u1.redMul(h2);\n\n  var nx = r.redSqr().redIAdd(h3).redISub(v).redISub(v);\n  var ny = r.redMul(v.redISub(nx)).redISub(s1.redMul(h3));\n  var nz = this.z.redMul(h);\n\n  return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.dblp = function dblp(pow) {\n  if (pow === 0)\n    return this;\n  if (this.isInfinity())\n    return this;\n  if (!pow)\n    return this.dbl();\n\n  if (this.curve.zeroA || this.curve.threeA) {\n    var r = this;\n    for (var i = 0; i < pow; i++)\n      r = r.dbl();\n    return r;\n  }\n\n  // 1M + 2S + 1A + N * (4S + 5M + 8A)\n  // N = 1 => 6M + 6S + 9A\n  var a = this.curve.a;\n  var tinv = this.curve.tinv;\n\n  var jx = this.x;\n  var jy = this.y;\n  var jz = this.z;\n  var jz4 = jz.redSqr().redSqr();\n\n  // Reuse results\n  var jyd = jy.redAdd(jy);\n  for (var i = 0; i < pow; i++) {\n    var jx2 = jx.redSqr();\n    var jyd2 = jyd.redSqr();\n    var jyd4 = jyd2.redSqr();\n    var c = jx2.redAdd(jx2).redIAdd(jx2).redIAdd(a.redMul(jz4));\n\n    var t1 = jx.redMul(jyd2);\n    var nx = c.redSqr().redISub(t1.redAdd(t1));\n    var t2 = t1.redISub(nx);\n    var dny = c.redMul(t2);\n    dny = dny.redIAdd(dny).redISub(jyd4);\n    var nz = jyd.redMul(jz);\n    if (i + 1 < pow)\n      jz4 = jz4.redMul(jyd4);\n\n    jx = nx;\n    jz = nz;\n    jyd = dny;\n  }\n\n  return this.curve.jpoint(jx, jyd.redMul(tinv), jz);\n};\n\nJPoint.prototype.dbl = function dbl() {\n  if (this.isInfinity())\n    return this;\n\n  if (this.curve.zeroA)\n    return this._zeroDbl();\n  else if (this.curve.threeA)\n    return this._threeDbl();\n  else\n    return this._dbl();\n};\n\nJPoint.prototype._zeroDbl = function _zeroDbl() {\n  var nx;\n  var ny;\n  var nz;\n  // Z = 1\n  if (this.zOne) {\n    // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html\n    //     #doubling-mdbl-2007-bl\n    // 1M + 5S + 14A\n\n    // XX = X1^2\n    var xx = this.x.redSqr();\n    // YY = Y1^2\n    var yy = this.y.redSqr();\n    // YYYY = YY^2\n    var yyyy = yy.redSqr();\n    // S = 2 * ((X1 + YY)^2 - XX - YYYY)\n    var s = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n    s = s.redIAdd(s);\n    // M = 3 * XX + a; a = 0\n    var m = xx.redAdd(xx).redIAdd(xx);\n    // T = M ^ 2 - 2*S\n    var t = m.redSqr().redISub(s).redISub(s);\n\n    // 8 * YYYY\n    var yyyy8 = yyyy.redIAdd(yyyy);\n    yyyy8 = yyyy8.redIAdd(yyyy8);\n    yyyy8 = yyyy8.redIAdd(yyyy8);\n\n    // X3 = T\n    nx = t;\n    // Y3 = M * (S - T) - 8 * YYYY\n    ny = m.redMul(s.redISub(t)).redISub(yyyy8);\n    // Z3 = 2*Y1\n    nz = this.y.redAdd(this.y);\n  } else {\n    // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html\n    //     #doubling-dbl-2009-l\n    // 2M + 5S + 13A\n\n    // A = X1^2\n    var a = this.x.redSqr();\n    // B = Y1^2\n    var b = this.y.redSqr();\n    // C = B^2\n    var c = b.redSqr();\n    // D = 2 * ((X1 + B)^2 - A - C)\n    var d = this.x.redAdd(b).redSqr().redISub(a).redISub(c);\n    d = d.redIAdd(d);\n    // E = 3 * A\n    var e = a.redAdd(a).redIAdd(a);\n    // F = E^2\n    var f = e.redSqr();\n\n    // 8 * C\n    var c8 = c.redIAdd(c);\n    c8 = c8.redIAdd(c8);\n    c8 = c8.redIAdd(c8);\n\n    // X3 = F - 2 * D\n    nx = f.redISub(d).redISub(d);\n    // Y3 = E * (D - X3) - 8 * C\n    ny = e.redMul(d.redISub(nx)).redISub(c8);\n    // Z3 = 2 * Y1 * Z1\n    nz = this.y.redMul(this.z);\n    nz = nz.redIAdd(nz);\n  }\n\n  return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype._threeDbl = function _threeDbl() {\n  var nx;\n  var ny;\n  var nz;\n  // Z = 1\n  if (this.zOne) {\n    // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-3.html\n    //     #doubling-mdbl-2007-bl\n    // 1M + 5S + 15A\n\n    // XX = X1^2\n    var xx = this.x.redSqr();\n    // YY = Y1^2\n    var yy = this.y.redSqr();\n    // YYYY = YY^2\n    var yyyy = yy.redSqr();\n    // S = 2 * ((X1 + YY)^2 - XX - YYYY)\n    var s = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n    s = s.redIAdd(s);\n    // M = 3 * XX + a\n    var m = xx.redAdd(xx).redIAdd(xx).redIAdd(this.curve.a);\n    // T = M^2 - 2 * S\n    var t = m.redSqr().redISub(s).redISub(s);\n    // X3 = T\n    nx = t;\n    // Y3 = M * (S - T) - 8 * YYYY\n    var yyyy8 = yyyy.redIAdd(yyyy);\n    yyyy8 = yyyy8.redIAdd(yyyy8);\n    yyyy8 = yyyy8.redIAdd(yyyy8);\n    ny = m.redMul(s.redISub(t)).redISub(yyyy8);\n    // Z3 = 2 * Y1\n    nz = this.y.redAdd(this.y);\n  } else {\n    // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-3.html#doubling-dbl-2001-b\n    // 3M + 5S\n\n    // delta = Z1^2\n    var delta = this.z.redSqr();\n    // gamma = Y1^2\n    var gamma = this.y.redSqr();\n    // beta = X1 * gamma\n    var beta = this.x.redMul(gamma);\n    // alpha = 3 * (X1 - delta) * (X1 + delta)\n    var alpha = this.x.redSub(delta).redMul(this.x.redAdd(delta));\n    alpha = alpha.redAdd(alpha).redIAdd(alpha);\n    // X3 = alpha^2 - 8 * beta\n    var beta4 = beta.redIAdd(beta);\n    beta4 = beta4.redIAdd(beta4);\n    var beta8 = beta4.redAdd(beta4);\n    nx = alpha.redSqr().redISub(beta8);\n    // Z3 = (Y1 + Z1)^2 - gamma - delta\n    nz = this.y.redAdd(this.z).redSqr().redISub(gamma).redISub(delta);\n    // Y3 = alpha * (4 * beta - X3) - 8 * gamma^2\n    var ggamma8 = gamma.redSqr();\n    ggamma8 = ggamma8.redIAdd(ggamma8);\n    ggamma8 = ggamma8.redIAdd(ggamma8);\n    ggamma8 = ggamma8.redIAdd(ggamma8);\n    ny = alpha.redMul(beta4.redISub(nx)).redISub(ggamma8);\n  }\n\n  return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype._dbl = function _dbl() {\n  var a = this.curve.a;\n\n  // 4M + 6S + 10A\n  var jx = this.x;\n  var jy = this.y;\n  var jz = this.z;\n  var jz4 = jz.redSqr().redSqr();\n\n  var jx2 = jx.redSqr();\n  var jy2 = jy.redSqr();\n\n  var c = jx2.redAdd(jx2).redIAdd(jx2).redIAdd(a.redMul(jz4));\n\n  var jxd4 = jx.redAdd(jx);\n  jxd4 = jxd4.redIAdd(jxd4);\n  var t1 = jxd4.redMul(jy2);\n  var nx = c.redSqr().redISub(t1.redAdd(t1));\n  var t2 = t1.redISub(nx);\n\n  var jyd8 = jy2.redSqr();\n  jyd8 = jyd8.redIAdd(jyd8);\n  jyd8 = jyd8.redIAdd(jyd8);\n  jyd8 = jyd8.redIAdd(jyd8);\n  var ny = c.redMul(t2).redISub(jyd8);\n  var nz = jy.redAdd(jy).redMul(jz);\n\n  return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.trpl = function trpl() {\n  if (!this.curve.zeroA)\n    return this.dbl().add(this);\n\n  // hyperelliptic.org/EFD/g1p/auto-shortw-jacobian-0.html#tripling-tpl-2007-bl\n  // 5M + 10S + ...\n\n  // XX = X1^2\n  var xx = this.x.redSqr();\n  // YY = Y1^2\n  var yy = this.y.redSqr();\n  // ZZ = Z1^2\n  var zz = this.z.redSqr();\n  // YYYY = YY^2\n  var yyyy = yy.redSqr();\n  // M = 3 * XX + a * ZZ2; a = 0\n  var m = xx.redAdd(xx).redIAdd(xx);\n  // MM = M^2\n  var mm = m.redSqr();\n  // E = 6 * ((X1 + YY)^2 - XX - YYYY) - MM\n  var e = this.x.redAdd(yy).redSqr().redISub(xx).redISub(yyyy);\n  e = e.redIAdd(e);\n  e = e.redAdd(e).redIAdd(e);\n  e = e.redISub(mm);\n  // EE = E^2\n  var ee = e.redSqr();\n  // T = 16*YYYY\n  var t = yyyy.redIAdd(yyyy);\n  t = t.redIAdd(t);\n  t = t.redIAdd(t);\n  t = t.redIAdd(t);\n  // U = (M + E)^2 - MM - EE - T\n  var u = m.redIAdd(e).redSqr().redISub(mm).redISub(ee).redISub(t);\n  // X3 = 4 * (X1 * EE - 4 * YY * U)\n  var yyu4 = yy.redMul(u);\n  yyu4 = yyu4.redIAdd(yyu4);\n  yyu4 = yyu4.redIAdd(yyu4);\n  var nx = this.x.redMul(ee).redISub(yyu4);\n  nx = nx.redIAdd(nx);\n  nx = nx.redIAdd(nx);\n  // Y3 = 8 * Y1 * (U * (T - U) - E * EE)\n  var ny = this.y.redMul(u.redMul(t.redISub(u)).redISub(e.redMul(ee)));\n  ny = ny.redIAdd(ny);\n  ny = ny.redIAdd(ny);\n  ny = ny.redIAdd(ny);\n  // Z3 = (Z1 + E)^2 - ZZ - EE\n  var nz = this.z.redAdd(e).redSqr().redISub(zz).redISub(ee);\n\n  return this.curve.jpoint(nx, ny, nz);\n};\n\nJPoint.prototype.mul = function mul(k, kbase) {\n  k = new BN(k, kbase);\n\n  return this.curve._wnafMul(this, k);\n};\n\nJPoint.prototype.eq = function eq(p) {\n  if (p.type === 'affine')\n    return this.eq(p.toJ());\n\n  if (this === p)\n    return true;\n\n  // x1 * z2^2 == x2 * z1^2\n  var z2 = this.z.redSqr();\n  var pz2 = p.z.redSqr();\n  if (this.x.redMul(pz2).redISub(p.x.redMul(z2)).cmpn(0) !== 0)\n    return false;\n\n  // y1 * z2^3 == y2 * z1^3\n  var z3 = z2.redMul(this.z);\n  var pz3 = pz2.redMul(p.z);\n  return this.y.redMul(pz3).redISub(p.y.redMul(z3)).cmpn(0) === 0;\n};\n\nJPoint.prototype.inspect = function inspect() {\n  if (this.isInfinity())\n    return '<EC JPoint Infinity>';\n  return '<EC JPoint x: ' + this.x.toString(16, 2) +\n      ' y: ' + this.y.toString(16, 2) +\n      ' z: ' + this.z.toString(16, 2) + '>';\n};\n\nJPoint.prototype.isInfinity = function isInfinity() {\n  // XXX This code assumes that zero is always zero in red\n  return this.z.cmpn(0) === 0;\n};\n","'use strict';\n\nvar curves = exports;\n\nvar hash = require('hash.js');\nvar elliptic = require('../elliptic');\n\nvar assert = elliptic.utils.assert;\n\nfunction PresetCurve(options) {\n  if (options.type === 'short')\n    this.curve = new elliptic.curve.short(options);\n  else if (options.type === 'edwards')\n    this.curve = new elliptic.curve.edwards(options);\n  else\n    this.curve = new elliptic.curve.mont(options);\n  this.g = this.curve.g;\n  this.n = this.curve.n;\n  this.hash = options.hash;\n\n  assert(this.g.validate(), 'Invalid curve');\n  assert(this.g.mul(this.n).isInfinity(), 'Invalid curve, G*N != O');\n}\ncurves.PresetCurve = PresetCurve;\n\nfunction defineCurve(name, options) {\n  Object.defineProperty(curves, name, {\n    configurable: true,\n    enumerable: true,\n    get: function() {\n      var curve = new PresetCurve(options);\n      Object.defineProperty(curves, name, {\n        configurable: true,\n        enumerable: true,\n        value: curve\n      });\n      return curve;\n    }\n  });\n}\n\ndefineCurve('p192', {\n  type: 'short',\n  prime: 'p192',\n  p: 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff',\n  a: 'ffffffff ffffffff ffffffff fffffffe ffffffff fffffffc',\n  b: '64210519 e59c80e7 0fa7e9ab 72243049 feb8deec c146b9b1',\n  n: 'ffffffff ffffffff ffffffff 99def836 146bc9b1 b4d22831',\n  hash: hash.sha256,\n  gRed: false,\n  g: [\n    '188da80e b03090f6 7cbf20eb 43a18800 f4ff0afd 82ff1012',\n    '07192b95 ffc8da78 631011ed 6b24cdd5 73f977a1 1e794811'\n  ]\n});\n\ndefineCurve('p224', {\n  type: 'short',\n  prime: 'p224',\n  p: 'ffffffff ffffffff ffffffff ffffffff 00000000 00000000 00000001',\n  a: 'ffffffff ffffffff ffffffff fffffffe ffffffff ffffffff fffffffe',\n  b: 'b4050a85 0c04b3ab f5413256 5044b0b7 d7bfd8ba 270b3943 2355ffb4',\n  n: 'ffffffff ffffffff ffffffff ffff16a2 e0b8f03e 13dd2945 5c5c2a3d',\n  hash: hash.sha256,\n  gRed: false,\n  g: [\n    'b70e0cbd 6bb4bf7f 321390b9 4a03c1d3 56c21122 343280d6 115c1d21',\n    'bd376388 b5f723fb 4c22dfe6 cd4375a0 5a074764 44d58199 85007e34'\n  ]\n});\n\ndefineCurve('p256', {\n  type: 'short',\n  prime: null,\n  p: 'ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff ffffffff',\n  a: 'ffffffff 00000001 00000000 00000000 00000000 ffffffff ffffffff fffffffc',\n  b: '5ac635d8 aa3a93e7 b3ebbd55 769886bc 651d06b0 cc53b0f6 3bce3c3e 27d2604b',\n  n: 'ffffffff 00000000 ffffffff ffffffff bce6faad a7179e84 f3b9cac2 fc632551',\n  hash: hash.sha256,\n  gRed: false,\n  g: [\n    '6b17d1f2 e12c4247 f8bce6e5 63a440f2 77037d81 2deb33a0 f4a13945 d898c296',\n    '4fe342e2 fe1a7f9b 8ee7eb4a 7c0f9e16 2bce3357 6b315ece cbb64068 37bf51f5'\n  ]\n});\n\ndefineCurve('p384', {\n  type: 'short',\n  prime: null,\n  p: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n     'fffffffe ffffffff 00000000 00000000 ffffffff',\n  a: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n     'fffffffe ffffffff 00000000 00000000 fffffffc',\n  b: 'b3312fa7 e23ee7e4 988e056b e3f82d19 181d9c6e fe814112 0314088f ' +\n     '5013875a c656398d 8a2ed19d 2a85c8ed d3ec2aef',\n  n: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff c7634d81 ' +\n     'f4372ddf 581a0db2 48b0a77a ecec196a ccc52973',\n  hash: hash.sha384,\n  gRed: false,\n  g: [\n    'aa87ca22 be8b0537 8eb1c71e f320ad74 6e1d3b62 8ba79b98 59f741e0 82542a38 ' +\n    '5502f25d bf55296c 3a545e38 72760ab7',\n    '3617de4a 96262c6f 5d9e98bf 9292dc29 f8f41dbd 289a147c e9da3113 b5f0b8c0 ' +\n    '0a60b1ce 1d7e819d 7a431d7c 90ea0e5f'\n  ]\n});\n\ndefineCurve('p521', {\n  type: 'short',\n  prime: null,\n  p: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n     'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n     'ffffffff ffffffff ffffffff ffffffff ffffffff',\n  a: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n     'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n     'ffffffff ffffffff ffffffff ffffffff fffffffc',\n  b: '00000051 953eb961 8e1c9a1f 929a21a0 b68540ee a2da725b ' +\n     '99b315f3 b8b48991 8ef109e1 56193951 ec7e937b 1652c0bd ' +\n     '3bb1bf07 3573df88 3d2c34f1 ef451fd4 6b503f00',\n  n: '000001ff ffffffff ffffffff ffffffff ffffffff ffffffff ' +\n     'ffffffff ffffffff fffffffa 51868783 bf2f966b 7fcc0148 ' +\n     'f709a5d0 3bb5c9b8 899c47ae bb6fb71e 91386409',\n  hash: hash.sha512,\n  gRed: false,\n  g: [\n    '000000c6 858e06b7 0404e9cd 9e3ecb66 2395b442 9c648139 ' +\n    '053fb521 f828af60 6b4d3dba a14b5e77 efe75928 fe1dc127 ' +\n    'a2ffa8de 3348b3c1 856a429b f97e7e31 c2e5bd66',\n    '00000118 39296a78 9a3bc004 5c8a5fb4 2c7d1bd9 98f54449 ' +\n    '579b4468 17afbd17 273e662c 97ee7299 5ef42640 c550b901 ' +\n    '3fad0761 353c7086 a272c240 88be9476 9fd16650'\n  ]\n});\n\ndefineCurve('curve25519', {\n  type: 'mont',\n  prime: 'p25519',\n  p: '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed',\n  a: '76d06',\n  b: '0',\n  n: '1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed',\n  hash: hash.sha256,\n  gRed: false,\n  g: [\n    '9'\n  ]\n});\n\ndefineCurve('ed25519', {\n  type: 'edwards',\n  prime: 'p25519',\n  p: '7fffffffffffffff ffffffffffffffff ffffffffffffffff ffffffffffffffed',\n  a: '-1',\n  c: '1',\n  // -121665 * (121666^(-1)) (mod P)\n  d: '52036cee2b6ffe73 8cc740797779e898 00700a4d4141d8ab 75eb4dca135978a3',\n  n: '1000000000000000 0000000000000000 14def9dea2f79cd6 5812631a5cf5d3ed',\n  hash: hash.sha256,\n  gRed: false,\n  g: [\n    '216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a',\n\n    // 4/5\n    '6666666666666666666666666666666666666666666666666666666666666658'\n  ]\n});\n\nvar pre;\ntry {\n  pre = require('./precomputed/secp256k1');\n} catch (e) {\n  pre = undefined;\n}\n\ndefineCurve('secp256k1', {\n  type: 'short',\n  prime: 'k256',\n  p: 'ffffffff ffffffff ffffffff ffffffff ffffffff ffffffff fffffffe fffffc2f',\n  a: '0',\n  b: '7',\n  n: 'ffffffff ffffffff ffffffff fffffffe baaedce6 af48a03b bfd25e8c d0364141',\n  h: '1',\n  hash: hash.sha256,\n\n  // Precomputed endomorphism\n  beta: '7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee',\n  lambda: '5363ad4cc05c30e0a5261c028812645a122e22ea20816678df02967c1b23bd72',\n  basis: [\n    {\n      a: '3086d221a7d46bcde86c90e49284eb15',\n      b: '-e4437ed6010e88286f547fa90abfe4c3'\n    },\n    {\n      a: '114ca50f7a8e2f3f657c1108d9d44cfd8',\n      b: '3086d221a7d46bcde86c90e49284eb15'\n    }\n  ],\n\n  gRed: false,\n  g: [\n    '79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798',\n    '483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8',\n    pre\n  ]\n});\n","'use strict';\n\nvar BN = require('bn.js');\nvar elliptic = require('../../elliptic');\nvar utils = elliptic.utils;\nvar assert = utils.assert;\n\nvar KeyPair = require('./key');\nvar Signature = require('./signature');\n\nfunction EC(options) {\n  if (!(this instanceof EC))\n    return new EC(options);\n\n  // Shortcut `elliptic.ec(curve-name)`\n  if (typeof options === 'string') {\n    assert(elliptic.curves.hasOwnProperty(options), 'Unknown curve ' + options);\n\n    options = elliptic.curves[options];\n  }\n\n  // Shortcut for `elliptic.ec(elliptic.curves.curveName)`\n  if (options instanceof elliptic.curves.PresetCurve)\n    options = { curve: options };\n\n  this.curve = options.curve.curve;\n  this.n = this.curve.n;\n  this.nh = this.n.ushrn(1);\n  this.g = this.curve.g;\n\n  // Point on curve\n  this.g = options.curve.g;\n  this.g.precompute(options.curve.n.bitLength() + 1);\n\n  // Hash for function for DRBG\n  this.hash = options.hash || options.curve.hash;\n}\nmodule.exports = EC;\n\nEC.prototype.keyPair = function keyPair(options) {\n  return new KeyPair(this, options);\n};\n\nEC.prototype.keyFromPrivate = function keyFromPrivate(priv, enc) {\n  return KeyPair.fromPrivate(this, priv, enc);\n};\n\nEC.prototype.keyFromPublic = function keyFromPublic(pub, enc) {\n  return KeyPair.fromPublic(this, pub, enc);\n};\n\nEC.prototype.genKeyPair = function genKeyPair(options) {\n  if (!options)\n    options = {};\n\n  // Instantiate Hmac_DRBG\n  var drbg = new elliptic.hmacDRBG({\n    hash: this.hash,\n    pers: options.pers,\n    entropy: options.entropy || elliptic.rand(this.hash.hmacStrength),\n    nonce: this.n.toArray()\n  });\n\n  var bytes = this.n.byteLength();\n  var ns2 = this.n.sub(new BN(2));\n  do {\n    var priv = new BN(drbg.generate(bytes));\n    if (priv.cmp(ns2) > 0)\n      continue;\n\n    priv.iaddn(1);\n    return this.keyFromPrivate(priv);\n  } while (true);\n};\n\nEC.prototype._truncateToN = function truncateToN(msg, truncOnly) {\n  var delta = msg.byteLength() * 8 - this.n.bitLength();\n  if (delta > 0)\n    msg = msg.ushrn(delta);\n  if (!truncOnly && msg.cmp(this.n) >= 0)\n    return msg.sub(this.n);\n  else\n    return msg;\n};\n\nEC.prototype.sign = function sign(msg, key, enc, options) {\n  if (typeof enc === 'object') {\n    options = enc;\n    enc = null;\n  }\n  if (!options)\n    options = {};\n\n  key = this.keyFromPrivate(key, enc);\n  msg = this._truncateToN(new BN(msg, 16));\n\n  // Zero-extend key to provide enough entropy\n  var bytes = this.n.byteLength();\n  var bkey = key.getPrivate().toArray('be', bytes);\n\n  // Zero-extend nonce to have the same byte size as N\n  var nonce = msg.toArray('be', bytes);\n\n  // Instantiate Hmac_DRBG\n  var drbg = new elliptic.hmacDRBG({\n    hash: this.hash,\n    entropy: bkey,\n    nonce: nonce,\n    pers: options.pers,\n    persEnc: options.persEnc\n  });\n\n  // Number of bytes to generate\n  var ns1 = this.n.sub(new BN(1));\n\n  for (var iter = 0; true; iter++) {\n    var k = options.k ?\n        options.k(iter) :\n        new BN(drbg.generate(this.n.byteLength()));\n    k = this._truncateToN(k, true);\n    if (k.cmpn(1) <= 0 || k.cmp(ns1) >= 0)\n      continue;\n\n    var kp = this.g.mul(k);\n    if (kp.isInfinity())\n      continue;\n\n    var kpX = kp.getX();\n    var r = kpX.umod(this.n);\n    if (r.cmpn(0) === 0)\n      continue;\n\n    var s = k.invm(this.n).mul(r.mul(key.getPrivate()).iadd(msg));\n    s = s.umod(this.n);\n    if (s.cmpn(0) === 0)\n      continue;\n\n    var recoveryParam = (kp.getY().isOdd() ? 1 : 0) |\n                        (kpX.cmp(r) !== 0 ? 2 : 0);\n\n    // Use complement of `s`, if it is > `n / 2`\n    if (options.canonical && s.cmp(this.nh) > 0) {\n      s = this.n.sub(s);\n      recoveryParam ^= 1;\n    }\n\n    return new Signature({ r: r, s: s, recoveryParam: recoveryParam });\n  }\n};\n\nEC.prototype.verify = function verify(msg, signature, key, enc) {\n  msg = this._truncateToN(new BN(msg, 16));\n  key = this.keyFromPublic(key, enc);\n  signature = new Signature(signature, 'hex');\n\n  // Perform primitive values validation\n  var r = signature.r;\n  var s = signature.s;\n  if (r.cmpn(1) < 0 || r.cmp(this.n) >= 0)\n    return false;\n  if (s.cmpn(1) < 0 || s.cmp(this.n) >= 0)\n    return false;\n\n  // Validate signature\n  var sinv = s.invm(this.n);\n  var u1 = sinv.mul(msg).umod(this.n);\n  var u2 = sinv.mul(r).umod(this.n);\n\n  var p = this.g.mulAdd(u1, key.getPublic(), u2);\n  if (p.isInfinity())\n    return false;\n\n  return p.getX().umod(this.n).cmp(r) === 0;\n};\n\nEC.prototype.recoverPubKey = function(msg, signature, j, enc) {\n  assert((3 & j) === j, 'The recovery param is more than two bits');\n  signature = new Signature(signature, enc);\n\n  var n = this.n;\n  var e = new BN(msg);\n  var r = signature.r;\n  var s = signature.s;\n\n  // A set LSB signifies that the y-coordinate is odd\n  var isYOdd = j & 1;\n  var isSecondKey = j >> 1;\n  if (r.cmp(this.curve.p.umod(this.curve.n)) >= 0 && isSecondKey)\n    throw new Error('Unable to find sencond key candinate');\n\n  // 1.1. Let x = r + jn.\n  if (isSecondKey)\n    r = this.curve.pointFromX(r.add(this.curve.n), isYOdd);\n  else\n    r = this.curve.pointFromX(r, isYOdd);\n\n  var eNeg = n.sub(e);\n\n  // 1.6.1 Compute Q = r^-1 (sR -  eG)\n  //               Q = r^-1 (sR + -eG)\n  var rInv = signature.r.invm(n);\n  return this.g.mulAdd(eNeg, r, s).mul(rInv);\n};\n\nEC.prototype.getKeyRecoveryParam = function(e, signature, Q, enc) {\n  signature = new Signature(signature, enc);\n  if (signature.recoveryParam !== null)\n    return signature.recoveryParam;\n\n  for (var i = 0; i < 4; i++) {\n    var Qprime;\n    try {\n      Qprime = this.recoverPubKey(e, signature, i);\n    } catch (e) {\n      continue;\n    }\n\n    if (Qprime.eq(Q))\n      return i;\n  }\n  throw new Error('Unable to find valid recovery factor');\n};\n","'use strict';\n\nvar BN = require('bn.js');\n\nfunction KeyPair(ec, options) {\n  this.ec = ec;\n  this.priv = null;\n  this.pub = null;\n\n  // KeyPair(ec, { priv: ..., pub: ... })\n  if (options.priv)\n    this._importPrivate(options.priv, options.privEnc);\n  if (options.pub)\n    this._importPublic(options.pub, options.pubEnc);\n}\nmodule.exports = KeyPair;\n\nKeyPair.fromPublic = function fromPublic(ec, pub, enc) {\n  if (pub instanceof KeyPair)\n    return pub;\n\n  return new KeyPair(ec, {\n    pub: pub,\n    pubEnc: enc\n  });\n};\n\nKeyPair.fromPrivate = function fromPrivate(ec, priv, enc) {\n  if (priv instanceof KeyPair)\n    return priv;\n\n  return new KeyPair(ec, {\n    priv: priv,\n    privEnc: enc\n  });\n};\n\nKeyPair.prototype.validate = function validate() {\n  var pub = this.getPublic();\n\n  if (pub.isInfinity())\n    return { result: false, reason: 'Invalid public key' };\n  if (!pub.validate())\n    return { result: false, reason: 'Public key is not a point' };\n  if (!pub.mul(this.ec.curve.n).isInfinity())\n    return { result: false, reason: 'Public key * N != O' };\n\n  return { result: true, reason: null };\n};\n\nKeyPair.prototype.getPublic = function getPublic(compact, enc) {\n  // compact is optional argument\n  if (typeof compact === 'string') {\n    enc = compact;\n    compact = null;\n  }\n\n  if (!this.pub)\n    this.pub = this.ec.g.mul(this.priv);\n\n  if (!enc)\n    return this.pub;\n\n  return this.pub.encode(enc, compact);\n};\n\nKeyPair.prototype.getPrivate = function getPrivate(enc) {\n  if (enc === 'hex')\n    return this.priv.toString(16, 2);\n  else\n    return this.priv;\n};\n\nKeyPair.prototype._importPrivate = function _importPrivate(key, enc) {\n  this.priv = new BN(key, enc || 16);\n\n  // Ensure that the priv won't be bigger than n, otherwise we may fail\n  // in fixed multiplication method\n  this.priv = this.priv.umod(this.ec.curve.n);\n};\n\nKeyPair.prototype._importPublic = function _importPublic(key, enc) {\n  if (key.x || key.y) {\n    this.pub = this.ec.curve.point(key.x, key.y);\n    return;\n  }\n  this.pub = this.ec.curve.decodePoint(key, enc);\n};\n\n// ECDH\nKeyPair.prototype.derive = function derive(pub) {\n  return pub.mul(this.priv).getX();\n};\n\n// ECDSA\nKeyPair.prototype.sign = function sign(msg, enc, options) {\n  return this.ec.sign(msg, this, enc, options);\n};\n\nKeyPair.prototype.verify = function verify(msg, signature) {\n  return this.ec.verify(msg, signature, this);\n};\n\nKeyPair.prototype.inspect = function inspect() {\n  return '<Key priv: ' + (this.priv && this.priv.toString(16, 2)) +\n         ' pub: ' + (this.pub && this.pub.inspect()) + ' >';\n};\n","'use strict';\n\nvar BN = require('bn.js');\n\nvar elliptic = require('../../elliptic');\nvar utils = elliptic.utils;\nvar assert = utils.assert;\n\nfunction Signature(options, enc) {\n  if (options instanceof Signature)\n    return options;\n\n  if (this._importDER(options, enc))\n    return;\n\n  assert(options.r && options.s, 'Signature without r or s');\n  this.r = new BN(options.r, 16);\n  this.s = new BN(options.s, 16);\n  if (options.recoveryParam === undefined)\n    this.recoveryParam = null;\n  else\n    this.recoveryParam = options.recoveryParam;\n}\nmodule.exports = Signature;\n\nfunction Position() {\n  this.place = 0;\n}\n\nfunction getLength(buf, p) {\n  var initial = buf[p.place++];\n  if (!(initial & 0x80)) {\n    return initial;\n  }\n  var octetLen = initial & 0xf;\n  var val = 0;\n  for (var i = 0, off = p.place; i < octetLen; i++, off++) {\n    val <<= 8;\n    val |= buf[off];\n  }\n  p.place = off;\n  return val;\n}\n\nfunction rmPadding(buf) {\n  var i = 0;\n  var len = buf.length - 1;\n  while (!buf[i] && !(buf[i + 1] & 0x80) && i < len) {\n    i++;\n  }\n  if (i === 0) {\n    return buf;\n  }\n  return buf.slice(i);\n}\n\nSignature.prototype._importDER = function _importDER(data, enc) {\n  data = utils.toArray(data, enc);\n  var p = new Position();\n  if (data[p.place++] !== 0x30) {\n    return false;\n  }\n  var len = getLength(data, p);\n  if ((len + p.place) !== data.length) {\n    return false;\n  }\n  if (data[p.place++] !== 0x02) {\n    return false;\n  }\n  var rlen = getLength(data, p);\n  var r = data.slice(p.place, rlen + p.place);\n  p.place += rlen;\n  if (data[p.place++] !== 0x02) {\n    return false;\n  }\n  var slen = getLength(data, p);\n  if (data.length !== slen + p.place) {\n    return false;\n  }\n  var s = data.slice(p.place, slen + p.place);\n  if (r[0] === 0 && (r[1] & 0x80)) {\n    r = r.slice(1);\n  }\n  if (s[0] === 0 && (s[1] & 0x80)) {\n    s = s.slice(1);\n  }\n\n  this.r = new BN(r);\n  this.s = new BN(s);\n  this.recoveryParam = null;\n\n  return true;\n};\n\nfunction constructLength(arr, len) {\n  if (len < 0x80) {\n    arr.push(len);\n    return;\n  }\n  var octets = 1 + (Math.log(len) / Math.LN2 >>> 3);\n  arr.push(octets | 0x80);\n  while (--octets) {\n    arr.push((len >>> (octets << 3)) & 0xff);\n  }\n  arr.push(len);\n}\n\nSignature.prototype.toDER = function toDER(enc) {\n  var r = this.r.toArray();\n  var s = this.s.toArray();\n\n  // Pad values\n  if (r[0] & 0x80)\n    r = [ 0 ].concat(r);\n  // Pad values\n  if (s[0] & 0x80)\n    s = [ 0 ].concat(s);\n\n  r = rmPadding(r);\n  s = rmPadding(s);\n\n  while (!s[0] && !(s[1] & 0x80)) {\n    s = s.slice(1);\n  }\n  var arr = [ 0x02 ];\n  constructLength(arr, r.length);\n  arr = arr.concat(r);\n  arr.push(0x02);\n  constructLength(arr, s.length);\n  var backHalf = arr.concat(s);\n  var res = [ 0x30 ];\n  constructLength(res, backHalf.length);\n  res = res.concat(backHalf);\n  return utils.encode(res, enc);\n};\n","'use strict';\n\nvar hash = require('hash.js');\nvar elliptic = require('../../elliptic');\nvar utils = elliptic.utils;\nvar assert = utils.assert;\nvar parseBytes = utils.parseBytes;\nvar KeyPair = require('./key');\nvar Signature = require('./signature');\n\nfunction EDDSA(curve) {\n  assert(curve === 'ed25519', 'only tested with ed25519 so far');\n\n  if (!(this instanceof EDDSA))\n    return new EDDSA(curve);\n\n  var curve = elliptic.curves[curve].curve;\n  this.curve = curve;\n  this.g = curve.g;\n  this.g.precompute(curve.n.bitLength() + 1);\n\n  this.pointClass = curve.point().constructor;\n  this.encodingLength = Math.ceil(curve.n.bitLength() / 8);\n  this.hash = hash.sha512;\n}\n\nmodule.exports = EDDSA;\n\n/**\n* @param {Array|String} message - message bytes\n* @param {Array|String|KeyPair} secret - secret bytes or a keypair\n* @returns {Signature} - signature\n*/\nEDDSA.prototype.sign = function sign(message, secret) {\n  message = parseBytes(message);\n  var key = this.keyFromSecret(secret);\n  var r = this.hashInt(key.messagePrefix(), message);\n  var R = this.g.mul(r);\n  var Rencoded = this.encodePoint(R);\n  var s_ = this.hashInt(Rencoded, key.pubBytes(), message)\n               .mul(key.priv());\n  var S = r.add(s_).umod(this.curve.n);\n  return this.makeSignature({ R: R, S: S, Rencoded: Rencoded });\n};\n\n/**\n* @param {Array} message - message bytes\n* @param {Array|String|Signature} sig - sig bytes\n* @param {Array|String|Point|KeyPair} pub - public key\n* @returns {Boolean} - true if public key matches sig of message\n*/\nEDDSA.prototype.verify = function verify(message, sig, pub) {\n  message = parseBytes(message);\n  sig = this.makeSignature(sig);\n  var key = this.keyFromPublic(pub);\n  var h = this.hashInt(sig.Rencoded(), key.pubBytes(), message);\n  var SG = this.g.mul(sig.S());\n  var RplusAh = sig.R().add(key.pub().mul(h));\n  return RplusAh.eq(SG);\n};\n\nEDDSA.prototype.hashInt = function hashInt() {\n  var hash = this.hash();\n  for (var i = 0; i < arguments.length; i++)\n    hash.update(arguments[i]);\n  return utils.intFromLE(hash.digest()).umod(this.curve.n);\n};\n\nEDDSA.prototype.keyFromPublic = function keyFromPublic(pub) {\n  return KeyPair.fromPublic(this, pub);\n};\n\nEDDSA.prototype.keyFromSecret = function keyFromSecret(secret) {\n  return KeyPair.fromSecret(this, secret);\n};\n\nEDDSA.prototype.makeSignature = function makeSignature(sig) {\n  if (sig instanceof Signature)\n    return sig;\n  return new Signature(this, sig);\n};\n\n/**\n* * https://tools.ietf.org/html/draft-josefsson-eddsa-ed25519-03#section-5.2\n*\n* EDDSA defines methods for encoding and decoding points and integers. These are\n* helper convenience methods, that pass along to utility functions implied\n* parameters.\n*\n*/\nEDDSA.prototype.encodePoint = function encodePoint(point) {\n  var enc = point.getY().toArray('le', this.encodingLength);\n  enc[this.encodingLength - 1] |= point.getX().isOdd() ? 0x80 : 0;\n  return enc;\n};\n\nEDDSA.prototype.decodePoint = function decodePoint(bytes) {\n  bytes = utils.parseBytes(bytes);\n\n  var lastIx = bytes.length - 1;\n  var normed = bytes.slice(0, lastIx).concat(bytes[lastIx] & ~0x80);\n  var xIsOdd = (bytes[lastIx] & 0x80) !== 0;\n\n  var y = utils.intFromLE(normed);\n  return this.curve.pointFromY(y, xIsOdd);\n};\n\nEDDSA.prototype.encodeInt = function encodeInt(num) {\n  return num.toArray('le', this.encodingLength);\n};\n\nEDDSA.prototype.decodeInt = function decodeInt(bytes) {\n  return utils.intFromLE(bytes);\n};\n\nEDDSA.prototype.isPoint = function isPoint(val) {\n  return val instanceof this.pointClass;\n};\n","'use strict';\n\nvar elliptic = require('../../elliptic');\nvar utils = elliptic.utils;\nvar assert = utils.assert;\nvar parseBytes = utils.parseBytes;\nvar cachedProperty = utils.cachedProperty;\n\n/**\n* @param {EDDSA} eddsa - instance\n* @param {Object} params - public/private key parameters\n*\n* @param {Array<Byte>} [params.secret] - secret seed bytes\n* @param {Point} [params.pub] - public key point (aka `A` in eddsa terms)\n* @param {Array<Byte>} [params.pub] - public key point encoded as bytes\n*\n*/\nfunction KeyPair(eddsa, params) {\n  this.eddsa = eddsa;\n  this._secret = parseBytes(params.secret);\n  if (eddsa.isPoint(params.pub))\n    this._pub = params.pub;\n  else\n    this._pubBytes = parseBytes(params.pub);\n}\n\nKeyPair.fromPublic = function fromPublic(eddsa, pub) {\n  if (pub instanceof KeyPair)\n    return pub;\n  return new KeyPair(eddsa, { pub: pub });\n};\n\nKeyPair.fromSecret = function fromSecret(eddsa, secret) {\n  if (secret instanceof KeyPair)\n    return secret;\n  return new KeyPair(eddsa, { secret: secret });\n};\n\nKeyPair.prototype.secret = function secret() {\n  return this._secret;\n};\n\ncachedProperty(KeyPair, function pubBytes() {\n  return this.eddsa.encodePoint(this.pub());\n});\n\ncachedProperty(KeyPair, function pub() {\n  if (this._pubBytes)\n    return this.eddsa.decodePoint(this._pubBytes);\n  return this.eddsa.g.mul(this.priv());\n});\n\ncachedProperty(KeyPair, function privBytes() {\n  var eddsa = this.eddsa;\n  var hash = this.hash();\n  var lastIx = eddsa.encodingLength - 1;\n\n  var a = hash.slice(0, eddsa.encodingLength);\n  a[0] &= 248;\n  a[lastIx] &= 127;\n  a[lastIx] |= 64;\n\n  return a;\n});\n\ncachedProperty(KeyPair, function priv() {\n  return this.eddsa.decodeInt(this.privBytes());\n});\n\ncachedProperty(KeyPair, function hash() {\n  return this.eddsa.hash().update(this.secret()).digest();\n});\n\ncachedProperty(KeyPair, function messagePrefix() {\n  return this.hash().slice(this.eddsa.encodingLength);\n});\n\nKeyPair.prototype.sign = function sign(message) {\n  assert(this._secret, 'KeyPair can only verify');\n  return this.eddsa.sign(message, this);\n};\n\nKeyPair.prototype.verify = function verify(message, sig) {\n  return this.eddsa.verify(message, sig, this);\n};\n\nKeyPair.prototype.getSecret = function getSecret(enc) {\n  assert(this._secret, 'KeyPair is public only');\n  return utils.encode(this.secret(), enc);\n};\n\nKeyPair.prototype.getPublic = function getPublic(enc) {\n  return utils.encode(this.pubBytes(), enc);\n};\n\nmodule.exports = KeyPair;\n","'use strict';\n\nvar BN = require('bn.js');\nvar elliptic = require('../../elliptic');\nvar utils = elliptic.utils;\nvar assert = utils.assert;\nvar cachedProperty = utils.cachedProperty;\nvar parseBytes = utils.parseBytes;\n\n/**\n* @param {EDDSA} eddsa - eddsa instance\n* @param {Array<Bytes>|Object} sig -\n* @param {Array<Bytes>|Point} [sig.R] - R point as Point or bytes\n* @param {Array<Bytes>|bn} [sig.S] - S scalar as bn or bytes\n* @param {Array<Bytes>} [sig.Rencoded] - R point encoded\n* @param {Array<Bytes>} [sig.Sencoded] - S scalar encoded\n*/\nfunction Signature(eddsa, sig) {\n  this.eddsa = eddsa;\n\n  if (typeof sig !== 'object')\n    sig = parseBytes(sig);\n\n  if (Array.isArray(sig)) {\n    sig = {\n      R: sig.slice(0, eddsa.encodingLength),\n      S: sig.slice(eddsa.encodingLength)\n    };\n  }\n\n  assert(sig.R && sig.S, 'Signature without R or S');\n\n  if (eddsa.isPoint(sig.R))\n    this._R = sig.R;\n  if (sig.S instanceof BN)\n    this._S = sig.S;\n\n  this._Rencoded = Array.isArray(sig.R) ? sig.R : sig.Rencoded;\n  this._Sencoded = Array.isArray(sig.S) ? sig.S : sig.Sencoded;\n}\n\ncachedProperty(Signature, function S() {\n  return this.eddsa.decodeInt(this.Sencoded());\n});\n\ncachedProperty(Signature, function R() {\n  return this.eddsa.decodePoint(this.Rencoded());\n});\n\ncachedProperty(Signature, function Rencoded() {\n  return this.eddsa.encodePoint(this.R());\n});\n\ncachedProperty(Signature, function Sencoded() {\n  return this.eddsa.encodeInt(this.S());\n});\n\nSignature.prototype.toBytes = function toBytes() {\n  return this.Rencoded().concat(this.Sencoded());\n};\n\nSignature.prototype.toHex = function toHex() {\n  return utils.encode(this.toBytes(), 'hex').toUpperCase();\n};\n\nmodule.exports = Signature;\n","'use strict';\n\nvar hash = require('hash.js');\nvar elliptic = require('../elliptic');\nvar utils = elliptic.utils;\nvar assert = utils.assert;\n\nfunction HmacDRBG(options) {\n  if (!(this instanceof HmacDRBG))\n    return new HmacDRBG(options);\n  this.hash = options.hash;\n  this.predResist = !!options.predResist;\n\n  this.outLen = this.hash.outSize;\n  this.minEntropy = options.minEntropy || this.hash.hmacStrength;\n\n  this.reseed = null;\n  this.reseedInterval = null;\n  this.K = null;\n  this.V = null;\n\n  var entropy = utils.toArray(options.entropy, options.entropyEnc);\n  var nonce = utils.toArray(options.nonce, options.nonceEnc);\n  var pers = utils.toArray(options.pers, options.persEnc);\n  assert(entropy.length >= (this.minEntropy / 8),\n         'Not enough entropy. Minimum is: ' + this.minEntropy + ' bits');\n  this._init(entropy, nonce, pers);\n}\nmodule.exports = HmacDRBG;\n\nHmacDRBG.prototype._init = function init(entropy, nonce, pers) {\n  var seed = entropy.concat(nonce).concat(pers);\n\n  this.K = new Array(this.outLen / 8);\n  this.V = new Array(this.outLen / 8);\n  for (var i = 0; i < this.V.length; i++) {\n    this.K[i] = 0x00;\n    this.V[i] = 0x01;\n  }\n\n  this._update(seed);\n  this.reseed = 1;\n  this.reseedInterval = 0x1000000000000;  // 2^48\n};\n\nHmacDRBG.prototype._hmac = function hmac() {\n  return new hash.hmac(this.hash, this.K);\n};\n\nHmacDRBG.prototype._update = function update(seed) {\n  var kmac = this._hmac()\n                 .update(this.V)\n                 .update([ 0x00 ]);\n  if (seed)\n    kmac = kmac.update(seed);\n  this.K = kmac.digest();\n  this.V = this._hmac().update(this.V).digest();\n  if (!seed)\n    return;\n\n  this.K = this._hmac()\n               .update(this.V)\n               .update([ 0x01 ])\n               .update(seed)\n               .digest();\n  this.V = this._hmac().update(this.V).digest();\n};\n\nHmacDRBG.prototype.reseed = function reseed(entropy, entropyEnc, add, addEnc) {\n  // Optional entropy enc\n  if (typeof entropyEnc !== 'string') {\n    addEnc = add;\n    add = entropyEnc;\n    entropyEnc = null;\n  }\n\n  entropy = utils.toBuffer(entropy, entropyEnc);\n  add = utils.toBuffer(add, addEnc);\n\n  assert(entropy.length >= (this.minEntropy / 8),\n         'Not enough entropy. Minimum is: ' + this.minEntropy + ' bits');\n\n  this._update(entropy.concat(add || []));\n  this.reseed = 1;\n};\n\nHmacDRBG.prototype.generate = function generate(len, enc, add, addEnc) {\n  if (this.reseed > this.reseedInterval)\n    throw new Error('Reseed is required');\n\n  // Optional encoding\n  if (typeof enc !== 'string') {\n    addEnc = add;\n    add = enc;\n    enc = null;\n  }\n\n  // Optional additional data\n  if (add) {\n    add = utils.toArray(add, addEnc);\n    this._update(add);\n  }\n\n  var temp = [];\n  while (temp.length < len) {\n    this.V = this._hmac().update(this.V).digest();\n    temp = temp.concat(this.V);\n  }\n\n  var res = temp.slice(0, len);\n  this._update(add);\n  this.reseed++;\n  return utils.encode(res, enc);\n};\n","module.exports = {\n  doubles: {\n    step: 4,\n    points: [\n      [\n        'e60fce93b59e9ec53011aabc21c23e97b2a31369b87a5ae9c44ee89e2a6dec0a',\n        'f7e3507399e595929db99f34f57937101296891e44d23f0be1f32cce69616821'\n      ],\n      [\n        '8282263212c609d9ea2a6e3e172de238d8c39cabd5ac1ca10646e23fd5f51508',\n        '11f8a8098557dfe45e8256e830b60ace62d613ac2f7b17bed31b6eaff6e26caf'\n      ],\n      [\n        '175e159f728b865a72f99cc6c6fc846de0b93833fd2222ed73fce5b551e5b739',\n        'd3506e0d9e3c79eba4ef97a51ff71f5eacb5955add24345c6efa6ffee9fed695'\n      ],\n      [\n        '363d90d447b00c9c99ceac05b6262ee053441c7e55552ffe526bad8f83ff4640',\n        '4e273adfc732221953b445397f3363145b9a89008199ecb62003c7f3bee9de9'\n      ],\n      [\n        '8b4b5f165df3c2be8c6244b5b745638843e4a781a15bcd1b69f79a55dffdf80c',\n        '4aad0a6f68d308b4b3fbd7813ab0da04f9e336546162ee56b3eff0c65fd4fd36'\n      ],\n      [\n        '723cbaa6e5db996d6bf771c00bd548c7b700dbffa6c0e77bcb6115925232fcda',\n        '96e867b5595cc498a921137488824d6e2660a0653779494801dc069d9eb39f5f'\n      ],\n      [\n        'eebfa4d493bebf98ba5feec812c2d3b50947961237a919839a533eca0e7dd7fa',\n        '5d9a8ca3970ef0f269ee7edaf178089d9ae4cdc3a711f712ddfd4fdae1de8999'\n      ],\n      [\n        '100f44da696e71672791d0a09b7bde459f1215a29b3c03bfefd7835b39a48db0',\n        'cdd9e13192a00b772ec8f3300c090666b7ff4a18ff5195ac0fbd5cd62bc65a09'\n      ],\n      [\n        'e1031be262c7ed1b1dc9227a4a04c017a77f8d4464f3b3852c8acde6e534fd2d',\n        '9d7061928940405e6bb6a4176597535af292dd419e1ced79a44f18f29456a00d'\n      ],\n      [\n        'feea6cae46d55b530ac2839f143bd7ec5cf8b266a41d6af52d5e688d9094696d',\n        'e57c6b6c97dce1bab06e4e12bf3ecd5c981c8957cc41442d3155debf18090088'\n      ],\n      [\n        'da67a91d91049cdcb367be4be6ffca3cfeed657d808583de33fa978bc1ec6cb1',\n        '9bacaa35481642bc41f463f7ec9780e5dec7adc508f740a17e9ea8e27a68be1d'\n      ],\n      [\n        '53904faa0b334cdda6e000935ef22151ec08d0f7bb11069f57545ccc1a37b7c0',\n        '5bc087d0bc80106d88c9eccac20d3c1c13999981e14434699dcb096b022771c8'\n      ],\n      [\n        '8e7bcd0bd35983a7719cca7764ca906779b53a043a9b8bcaeff959f43ad86047',\n        '10b7770b2a3da4b3940310420ca9514579e88e2e47fd68b3ea10047e8460372a'\n      ],\n      [\n        '385eed34c1cdff21e6d0818689b81bde71a7f4f18397e6690a841e1599c43862',\n        '283bebc3e8ea23f56701de19e9ebf4576b304eec2086dc8cc0458fe5542e5453'\n      ],\n      [\n        '6f9d9b803ecf191637c73a4413dfa180fddf84a5947fbc9c606ed86c3fac3a7',\n        '7c80c68e603059ba69b8e2a30e45c4d47ea4dd2f5c281002d86890603a842160'\n      ],\n      [\n        '3322d401243c4e2582a2147c104d6ecbf774d163db0f5e5313b7e0e742d0e6bd',\n        '56e70797e9664ef5bfb019bc4ddaf9b72805f63ea2873af624f3a2e96c28b2a0'\n      ],\n      [\n        '85672c7d2de0b7da2bd1770d89665868741b3f9af7643397721d74d28134ab83',\n        '7c481b9b5b43b2eb6374049bfa62c2e5e77f17fcc5298f44c8e3094f790313a6'\n      ],\n      [\n        '948bf809b1988a46b06c9f1919413b10f9226c60f668832ffd959af60c82a0a',\n        '53a562856dcb6646dc6b74c5d1c3418c6d4dff08c97cd2bed4cb7f88d8c8e589'\n      ],\n      [\n        '6260ce7f461801c34f067ce0f02873a8f1b0e44dfc69752accecd819f38fd8e8',\n        'bc2da82b6fa5b571a7f09049776a1ef7ecd292238051c198c1a84e95b2b4ae17'\n      ],\n      [\n        'e5037de0afc1d8d43d8348414bbf4103043ec8f575bfdc432953cc8d2037fa2d',\n        '4571534baa94d3b5f9f98d09fb990bddbd5f5b03ec481f10e0e5dc841d755bda'\n      ],\n      [\n        'e06372b0f4a207adf5ea905e8f1771b4e7e8dbd1c6a6c5b725866a0ae4fce725',\n        '7a908974bce18cfe12a27bb2ad5a488cd7484a7787104870b27034f94eee31dd'\n      ],\n      [\n        '213c7a715cd5d45358d0bbf9dc0ce02204b10bdde2a3f58540ad6908d0559754',\n        '4b6dad0b5ae462507013ad06245ba190bb4850f5f36a7eeddff2c27534b458f2'\n      ],\n      [\n        '4e7c272a7af4b34e8dbb9352a5419a87e2838c70adc62cddf0cc3a3b08fbd53c',\n        '17749c766c9d0b18e16fd09f6def681b530b9614bff7dd33e0b3941817dcaae6'\n      ],\n      [\n        'fea74e3dbe778b1b10f238ad61686aa5c76e3db2be43057632427e2840fb27b6',\n        '6e0568db9b0b13297cf674deccb6af93126b596b973f7b77701d3db7f23cb96f'\n      ],\n      [\n        '76e64113f677cf0e10a2570d599968d31544e179b760432952c02a4417bdde39',\n        'c90ddf8dee4e95cf577066d70681f0d35e2a33d2b56d2032b4b1752d1901ac01'\n      ],\n      [\n        'c738c56b03b2abe1e8281baa743f8f9a8f7cc643df26cbee3ab150242bcbb891',\n        '893fb578951ad2537f718f2eacbfbbbb82314eef7880cfe917e735d9699a84c3'\n      ],\n      [\n        'd895626548b65b81e264c7637c972877d1d72e5f3a925014372e9f6588f6c14b',\n        'febfaa38f2bc7eae728ec60818c340eb03428d632bb067e179363ed75d7d991f'\n      ],\n      [\n        'b8da94032a957518eb0f6433571e8761ceffc73693e84edd49150a564f676e03',\n        '2804dfa44805a1e4d7c99cc9762808b092cc584d95ff3b511488e4e74efdf6e7'\n      ],\n      [\n        'e80fea14441fb33a7d8adab9475d7fab2019effb5156a792f1a11778e3c0df5d',\n        'eed1de7f638e00771e89768ca3ca94472d155e80af322ea9fcb4291b6ac9ec78'\n      ],\n      [\n        'a301697bdfcd704313ba48e51d567543f2a182031efd6915ddc07bbcc4e16070',\n        '7370f91cfb67e4f5081809fa25d40f9b1735dbf7c0a11a130c0d1a041e177ea1'\n      ],\n      [\n        '90ad85b389d6b936463f9d0512678de208cc330b11307fffab7ac63e3fb04ed4',\n        'e507a3620a38261affdcbd9427222b839aefabe1582894d991d4d48cb6ef150'\n      ],\n      [\n        '8f68b9d2f63b5f339239c1ad981f162ee88c5678723ea3351b7b444c9ec4c0da',\n        '662a9f2dba063986de1d90c2b6be215dbbea2cfe95510bfdf23cbf79501fff82'\n      ],\n      [\n        'e4f3fb0176af85d65ff99ff9198c36091f48e86503681e3e6686fd5053231e11',\n        '1e63633ad0ef4f1c1661a6d0ea02b7286cc7e74ec951d1c9822c38576feb73bc'\n      ],\n      [\n        '8c00fa9b18ebf331eb961537a45a4266c7034f2f0d4e1d0716fb6eae20eae29e',\n        'efa47267fea521a1a9dc343a3736c974c2fadafa81e36c54e7d2a4c66702414b'\n      ],\n      [\n        'e7a26ce69dd4829f3e10cec0a9e98ed3143d084f308b92c0997fddfc60cb3e41',\n        '2a758e300fa7984b471b006a1aafbb18d0a6b2c0420e83e20e8a9421cf2cfd51'\n      ],\n      [\n        'b6459e0ee3662ec8d23540c223bcbdc571cbcb967d79424f3cf29eb3de6b80ef',\n        '67c876d06f3e06de1dadf16e5661db3c4b3ae6d48e35b2ff30bf0b61a71ba45'\n      ],\n      [\n        'd68a80c8280bb840793234aa118f06231d6f1fc67e73c5a5deda0f5b496943e8',\n        'db8ba9fff4b586d00c4b1f9177b0e28b5b0e7b8f7845295a294c84266b133120'\n      ],\n      [\n        '324aed7df65c804252dc0270907a30b09612aeb973449cea4095980fc28d3d5d',\n        '648a365774b61f2ff130c0c35aec1f4f19213b0c7e332843967224af96ab7c84'\n      ],\n      [\n        '4df9c14919cde61f6d51dfdbe5fee5dceec4143ba8d1ca888e8bd373fd054c96',\n        '35ec51092d8728050974c23a1d85d4b5d506cdc288490192ebac06cad10d5d'\n      ],\n      [\n        '9c3919a84a474870faed8a9c1cc66021523489054d7f0308cbfc99c8ac1f98cd',\n        'ddb84f0f4a4ddd57584f044bf260e641905326f76c64c8e6be7e5e03d4fc599d'\n      ],\n      [\n        '6057170b1dd12fdf8de05f281d8e06bb91e1493a8b91d4cc5a21382120a959e5',\n        '9a1af0b26a6a4807add9a2daf71df262465152bc3ee24c65e899be932385a2a8'\n      ],\n      [\n        'a576df8e23a08411421439a4518da31880cef0fba7d4df12b1a6973eecb94266',\n        '40a6bf20e76640b2c92b97afe58cd82c432e10a7f514d9f3ee8be11ae1b28ec8'\n      ],\n      [\n        '7778a78c28dec3e30a05fe9629de8c38bb30d1f5cf9a3a208f763889be58ad71',\n        '34626d9ab5a5b22ff7098e12f2ff580087b38411ff24ac563b513fc1fd9f43ac'\n      ],\n      [\n        '928955ee637a84463729fd30e7afd2ed5f96274e5ad7e5cb09eda9c06d903ac',\n        'c25621003d3f42a827b78a13093a95eeac3d26efa8a8d83fc5180e935bcd091f'\n      ],\n      [\n        '85d0fef3ec6db109399064f3a0e3b2855645b4a907ad354527aae75163d82751',\n        '1f03648413a38c0be29d496e582cf5663e8751e96877331582c237a24eb1f962'\n      ],\n      [\n        'ff2b0dce97eece97c1c9b6041798b85dfdfb6d8882da20308f5404824526087e',\n        '493d13fef524ba188af4c4dc54d07936c7b7ed6fb90e2ceb2c951e01f0c29907'\n      ],\n      [\n        '827fbbe4b1e880ea9ed2b2e6301b212b57f1ee148cd6dd28780e5e2cf856e241',\n        'c60f9c923c727b0b71bef2c67d1d12687ff7a63186903166d605b68baec293ec'\n      ],\n      [\n        'eaa649f21f51bdbae7be4ae34ce6e5217a58fdce7f47f9aa7f3b58fa2120e2b3',\n        'be3279ed5bbbb03ac69a80f89879aa5a01a6b965f13f7e59d47a5305ba5ad93d'\n      ],\n      [\n        'e4a42d43c5cf169d9391df6decf42ee541b6d8f0c9a137401e23632dda34d24f',\n        '4d9f92e716d1c73526fc99ccfb8ad34ce886eedfa8d8e4f13a7f7131deba9414'\n      ],\n      [\n        '1ec80fef360cbdd954160fadab352b6b92b53576a88fea4947173b9d4300bf19',\n        'aeefe93756b5340d2f3a4958a7abbf5e0146e77f6295a07b671cdc1cc107cefd'\n      ],\n      [\n        '146a778c04670c2f91b00af4680dfa8bce3490717d58ba889ddb5928366642be',\n        'b318e0ec3354028add669827f9d4b2870aaa971d2f7e5ed1d0b297483d83efd0'\n      ],\n      [\n        'fa50c0f61d22e5f07e3acebb1aa07b128d0012209a28b9776d76a8793180eef9',\n        '6b84c6922397eba9b72cd2872281a68a5e683293a57a213b38cd8d7d3f4f2811'\n      ],\n      [\n        'da1d61d0ca721a11b1a5bf6b7d88e8421a288ab5d5bba5220e53d32b5f067ec2',\n        '8157f55a7c99306c79c0766161c91e2966a73899d279b48a655fba0f1ad836f1'\n      ],\n      [\n        'a8e282ff0c9706907215ff98e8fd416615311de0446f1e062a73b0610d064e13',\n        '7f97355b8db81c09abfb7f3c5b2515888b679a3e50dd6bd6cef7c73111f4cc0c'\n      ],\n      [\n        '174a53b9c9a285872d39e56e6913cab15d59b1fa512508c022f382de8319497c',\n        'ccc9dc37abfc9c1657b4155f2c47f9e6646b3a1d8cb9854383da13ac079afa73'\n      ],\n      [\n        '959396981943785c3d3e57edf5018cdbe039e730e4918b3d884fdff09475b7ba',\n        '2e7e552888c331dd8ba0386a4b9cd6849c653f64c8709385e9b8abf87524f2fd'\n      ],\n      [\n        'd2a63a50ae401e56d645a1153b109a8fcca0a43d561fba2dbb51340c9d82b151',\n        'e82d86fb6443fcb7565aee58b2948220a70f750af484ca52d4142174dcf89405'\n      ],\n      [\n        '64587e2335471eb890ee7896d7cfdc866bacbdbd3839317b3436f9b45617e073',\n        'd99fcdd5bf6902e2ae96dd6447c299a185b90a39133aeab358299e5e9faf6589'\n      ],\n      [\n        '8481bde0e4e4d885b3a546d3e549de042f0aa6cea250e7fd358d6c86dd45e458',\n        '38ee7b8cba5404dd84a25bf39cecb2ca900a79c42b262e556d64b1b59779057e'\n      ],\n      [\n        '13464a57a78102aa62b6979ae817f4637ffcfed3c4b1ce30bcd6303f6caf666b',\n        '69be159004614580ef7e433453ccb0ca48f300a81d0942e13f495a907f6ecc27'\n      ],\n      [\n        'bc4a9df5b713fe2e9aef430bcc1dc97a0cd9ccede2f28588cada3a0d2d83f366',\n        'd3a81ca6e785c06383937adf4b798caa6e8a9fbfa547b16d758d666581f33c1'\n      ],\n      [\n        '8c28a97bf8298bc0d23d8c749452a32e694b65e30a9472a3954ab30fe5324caa',\n        '40a30463a3305193378fedf31f7cc0eb7ae784f0451cb9459e71dc73cbef9482'\n      ],\n      [\n        '8ea9666139527a8c1dd94ce4f071fd23c8b350c5a4bb33748c4ba111faccae0',\n        '620efabbc8ee2782e24e7c0cfb95c5d735b783be9cf0f8e955af34a30e62b945'\n      ],\n      [\n        'dd3625faef5ba06074669716bbd3788d89bdde815959968092f76cc4eb9a9787',\n        '7a188fa3520e30d461da2501045731ca941461982883395937f68d00c644a573'\n      ],\n      [\n        'f710d79d9eb962297e4f6232b40e8f7feb2bc63814614d692c12de752408221e',\n        'ea98e67232d3b3295d3b535532115ccac8612c721851617526ae47a9c77bfc82'\n      ]\n    ]\n  },\n  naf: {\n    wnd: 7,\n    points: [\n      [\n        'f9308a019258c31049344f85f89d5229b531c845836f99b08601f113bce036f9',\n        '388f7b0f632de8140fe337e62a37f3566500a99934c2231b6cb9fd7584b8e672'\n      ],\n      [\n        '2f8bde4d1a07209355b4a7250a5c5128e88b84bddc619ab7cba8d569b240efe4',\n        'd8ac222636e5e3d6d4dba9dda6c9c426f788271bab0d6840dca87d3aa6ac62d6'\n      ],\n      [\n        '5cbdf0646e5db4eaa398f365f2ea7a0e3d419b7e0330e39ce92bddedcac4f9bc',\n        '6aebca40ba255960a3178d6d861a54dba813d0b813fde7b5a5082628087264da'\n      ],\n      [\n        'acd484e2f0c7f65309ad178a9f559abde09796974c57e714c35f110dfc27ccbe',\n        'cc338921b0a7d9fd64380971763b61e9add888a4375f8e0f05cc262ac64f9c37'\n      ],\n      [\n        '774ae7f858a9411e5ef4246b70c65aac5649980be5c17891bbec17895da008cb',\n        'd984a032eb6b5e190243dd56d7b7b365372db1e2dff9d6a8301d74c9c953c61b'\n      ],\n      [\n        'f28773c2d975288bc7d1d205c3748651b075fbc6610e58cddeeddf8f19405aa8',\n        'ab0902e8d880a89758212eb65cdaf473a1a06da521fa91f29b5cb52db03ed81'\n      ],\n      [\n        'd7924d4f7d43ea965a465ae3095ff41131e5946f3c85f79e44adbcf8e27e080e',\n        '581e2872a86c72a683842ec228cc6defea40af2bd896d3a5c504dc9ff6a26b58'\n      ],\n      [\n        'defdea4cdb677750a420fee807eacf21eb9898ae79b9768766e4faa04a2d4a34',\n        '4211ab0694635168e997b0ead2a93daeced1f4a04a95c0f6cfb199f69e56eb77'\n      ],\n      [\n        '2b4ea0a797a443d293ef5cff444f4979f06acfebd7e86d277475656138385b6c',\n        '85e89bc037945d93b343083b5a1c86131a01f60c50269763b570c854e5c09b7a'\n      ],\n      [\n        '352bbf4a4cdd12564f93fa332ce333301d9ad40271f8107181340aef25be59d5',\n        '321eb4075348f534d59c18259dda3e1f4a1b3b2e71b1039c67bd3d8bcf81998c'\n      ],\n      [\n        '2fa2104d6b38d11b0230010559879124e42ab8dfeff5ff29dc9cdadd4ecacc3f',\n        '2de1068295dd865b64569335bd5dd80181d70ecfc882648423ba76b532b7d67'\n      ],\n      [\n        '9248279b09b4d68dab21a9b066edda83263c3d84e09572e269ca0cd7f5453714',\n        '73016f7bf234aade5d1aa71bdea2b1ff3fc0de2a887912ffe54a32ce97cb3402'\n      ],\n      [\n        'daed4f2be3a8bf278e70132fb0beb7522f570e144bf615c07e996d443dee8729',\n        'a69dce4a7d6c98e8d4a1aca87ef8d7003f83c230f3afa726ab40e52290be1c55'\n      ],\n      [\n        'c44d12c7065d812e8acf28d7cbb19f9011ecd9e9fdf281b0e6a3b5e87d22e7db',\n        '2119a460ce326cdc76c45926c982fdac0e106e861edf61c5a039063f0e0e6482'\n      ],\n      [\n        '6a245bf6dc698504c89a20cfded60853152b695336c28063b61c65cbd269e6b4',\n        'e022cf42c2bd4a708b3f5126f16a24ad8b33ba48d0423b6efd5e6348100d8a82'\n      ],\n      [\n        '1697ffa6fd9de627c077e3d2fe541084ce13300b0bec1146f95ae57f0d0bd6a5',\n        'b9c398f186806f5d27561506e4557433a2cf15009e498ae7adee9d63d01b2396'\n      ],\n      [\n        '605bdb019981718b986d0f07e834cb0d9deb8360ffb7f61df982345ef27a7479',\n        '2972d2de4f8d20681a78d93ec96fe23c26bfae84fb14db43b01e1e9056b8c49'\n      ],\n      [\n        '62d14dab4150bf497402fdc45a215e10dcb01c354959b10cfe31c7e9d87ff33d',\n        '80fc06bd8cc5b01098088a1950eed0db01aa132967ab472235f5642483b25eaf'\n      ],\n      [\n        '80c60ad0040f27dade5b4b06c408e56b2c50e9f56b9b8b425e555c2f86308b6f',\n        '1c38303f1cc5c30f26e66bad7fe72f70a65eed4cbe7024eb1aa01f56430bd57a'\n      ],\n      [\n        '7a9375ad6167ad54aa74c6348cc54d344cc5dc9487d847049d5eabb0fa03c8fb',\n        'd0e3fa9eca8726909559e0d79269046bdc59ea10c70ce2b02d499ec224dc7f7'\n      ],\n      [\n        'd528ecd9b696b54c907a9ed045447a79bb408ec39b68df504bb51f459bc3ffc9',\n        'eecf41253136e5f99966f21881fd656ebc4345405c520dbc063465b521409933'\n      ],\n      [\n        '49370a4b5f43412ea25f514e8ecdad05266115e4a7ecb1387231808f8b45963',\n        '758f3f41afd6ed428b3081b0512fd62a54c3f3afbb5b6764b653052a12949c9a'\n      ],\n      [\n        '77f230936ee88cbbd73df930d64702ef881d811e0e1498e2f1c13eb1fc345d74',\n        '958ef42a7886b6400a08266e9ba1b37896c95330d97077cbbe8eb3c7671c60d6'\n      ],\n      [\n        'f2dac991cc4ce4b9ea44887e5c7c0bce58c80074ab9d4dbaeb28531b7739f530',\n        'e0dedc9b3b2f8dad4da1f32dec2531df9eb5fbeb0598e4fd1a117dba703a3c37'\n      ],\n      [\n        '463b3d9f662621fb1b4be8fbbe2520125a216cdfc9dae3debcba4850c690d45b',\n        '5ed430d78c296c3543114306dd8622d7c622e27c970a1de31cb377b01af7307e'\n      ],\n      [\n        'f16f804244e46e2a09232d4aff3b59976b98fac14328a2d1a32496b49998f247',\n        'cedabd9b82203f7e13d206fcdf4e33d92a6c53c26e5cce26d6579962c4e31df6'\n      ],\n      [\n        'caf754272dc84563b0352b7a14311af55d245315ace27c65369e15f7151d41d1',\n        'cb474660ef35f5f2a41b643fa5e460575f4fa9b7962232a5c32f908318a04476'\n      ],\n      [\n        '2600ca4b282cb986f85d0f1709979d8b44a09c07cb86d7c124497bc86f082120',\n        '4119b88753c15bd6a693b03fcddbb45d5ac6be74ab5f0ef44b0be9475a7e4b40'\n      ],\n      [\n        '7635ca72d7e8432c338ec53cd12220bc01c48685e24f7dc8c602a7746998e435',\n        '91b649609489d613d1d5e590f78e6d74ecfc061d57048bad9e76f302c5b9c61'\n      ],\n      [\n        '754e3239f325570cdbbf4a87deee8a66b7f2b33479d468fbc1a50743bf56cc18',\n        '673fb86e5bda30fb3cd0ed304ea49a023ee33d0197a695d0c5d98093c536683'\n      ],\n      [\n        'e3e6bd1071a1e96aff57859c82d570f0330800661d1c952f9fe2694691d9b9e8',\n        '59c9e0bba394e76f40c0aa58379a3cb6a5a2283993e90c4167002af4920e37f5'\n      ],\n      [\n        '186b483d056a033826ae73d88f732985c4ccb1f32ba35f4b4cc47fdcf04aa6eb',\n        '3b952d32c67cf77e2e17446e204180ab21fb8090895138b4a4a797f86e80888b'\n      ],\n      [\n        'df9d70a6b9876ce544c98561f4be4f725442e6d2b737d9c91a8321724ce0963f',\n        '55eb2dafd84d6ccd5f862b785dc39d4ab157222720ef9da217b8c45cf2ba2417'\n      ],\n      [\n        '5edd5cc23c51e87a497ca815d5dce0f8ab52554f849ed8995de64c5f34ce7143',\n        'efae9c8dbc14130661e8cec030c89ad0c13c66c0d17a2905cdc706ab7399a868'\n      ],\n      [\n        '290798c2b6476830da12fe02287e9e777aa3fba1c355b17a722d362f84614fba',\n        'e38da76dcd440621988d00bcf79af25d5b29c094db2a23146d003afd41943e7a'\n      ],\n      [\n        'af3c423a95d9f5b3054754efa150ac39cd29552fe360257362dfdecef4053b45',\n        'f98a3fd831eb2b749a93b0e6f35cfb40c8cd5aa667a15581bc2feded498fd9c6'\n      ],\n      [\n        '766dbb24d134e745cccaa28c99bf274906bb66b26dcf98df8d2fed50d884249a',\n        '744b1152eacbe5e38dcc887980da38b897584a65fa06cedd2c924f97cbac5996'\n      ],\n      [\n        '59dbf46f8c94759ba21277c33784f41645f7b44f6c596a58ce92e666191abe3e',\n        'c534ad44175fbc300f4ea6ce648309a042ce739a7919798cd85e216c4a307f6e'\n      ],\n      [\n        'f13ada95103c4537305e691e74e9a4a8dd647e711a95e73cb62dc6018cfd87b8',\n        'e13817b44ee14de663bf4bc808341f326949e21a6a75c2570778419bdaf5733d'\n      ],\n      [\n        '7754b4fa0e8aced06d4167a2c59cca4cda1869c06ebadfb6488550015a88522c',\n        '30e93e864e669d82224b967c3020b8fa8d1e4e350b6cbcc537a48b57841163a2'\n      ],\n      [\n        '948dcadf5990e048aa3874d46abef9d701858f95de8041d2a6828c99e2262519',\n        'e491a42537f6e597d5d28a3224b1bc25df9154efbd2ef1d2cbba2cae5347d57e'\n      ],\n      [\n        '7962414450c76c1689c7b48f8202ec37fb224cf5ac0bfa1570328a8a3d7c77ab',\n        '100b610ec4ffb4760d5c1fc133ef6f6b12507a051f04ac5760afa5b29db83437'\n      ],\n      [\n        '3514087834964b54b15b160644d915485a16977225b8847bb0dd085137ec47ca',\n        'ef0afbb2056205448e1652c48e8127fc6039e77c15c2378b7e7d15a0de293311'\n      ],\n      [\n        'd3cc30ad6b483e4bc79ce2c9dd8bc54993e947eb8df787b442943d3f7b527eaf',\n        '8b378a22d827278d89c5e9be8f9508ae3c2ad46290358630afb34db04eede0a4'\n      ],\n      [\n        '1624d84780732860ce1c78fcbfefe08b2b29823db913f6493975ba0ff4847610',\n        '68651cf9b6da903e0914448c6cd9d4ca896878f5282be4c8cc06e2a404078575'\n      ],\n      [\n        '733ce80da955a8a26902c95633e62a985192474b5af207da6df7b4fd5fc61cd4',\n        'f5435a2bd2badf7d485a4d8b8db9fcce3e1ef8e0201e4578c54673bc1dc5ea1d'\n      ],\n      [\n        '15d9441254945064cf1a1c33bbd3b49f8966c5092171e699ef258dfab81c045c',\n        'd56eb30b69463e7234f5137b73b84177434800bacebfc685fc37bbe9efe4070d'\n      ],\n      [\n        'a1d0fcf2ec9de675b612136e5ce70d271c21417c9d2b8aaaac138599d0717940',\n        'edd77f50bcb5a3cab2e90737309667f2641462a54070f3d519212d39c197a629'\n      ],\n      [\n        'e22fbe15c0af8ccc5780c0735f84dbe9a790badee8245c06c7ca37331cb36980',\n        'a855babad5cd60c88b430a69f53a1a7a38289154964799be43d06d77d31da06'\n      ],\n      [\n        '311091dd9860e8e20ee13473c1155f5f69635e394704eaa74009452246cfa9b3',\n        '66db656f87d1f04fffd1f04788c06830871ec5a64feee685bd80f0b1286d8374'\n      ],\n      [\n        '34c1fd04d301be89b31c0442d3e6ac24883928b45a9340781867d4232ec2dbdf',\n        '9414685e97b1b5954bd46f730174136d57f1ceeb487443dc5321857ba73abee'\n      ],\n      [\n        'f219ea5d6b54701c1c14de5b557eb42a8d13f3abbcd08affcc2a5e6b049b8d63',\n        '4cb95957e83d40b0f73af4544cccf6b1f4b08d3c07b27fb8d8c2962a400766d1'\n      ],\n      [\n        'd7b8740f74a8fbaab1f683db8f45de26543a5490bca627087236912469a0b448',\n        'fa77968128d9c92ee1010f337ad4717eff15db5ed3c049b3411e0315eaa4593b'\n      ],\n      [\n        '32d31c222f8f6f0ef86f7c98d3a3335ead5bcd32abdd94289fe4d3091aa824bf',\n        '5f3032f5892156e39ccd3d7915b9e1da2e6dac9e6f26e961118d14b8462e1661'\n      ],\n      [\n        '7461f371914ab32671045a155d9831ea8793d77cd59592c4340f86cbc18347b5',\n        '8ec0ba238b96bec0cbdddcae0aa442542eee1ff50c986ea6b39847b3cc092ff6'\n      ],\n      [\n        'ee079adb1df1860074356a25aa38206a6d716b2c3e67453d287698bad7b2b2d6',\n        '8dc2412aafe3be5c4c5f37e0ecc5f9f6a446989af04c4e25ebaac479ec1c8c1e'\n      ],\n      [\n        '16ec93e447ec83f0467b18302ee620f7e65de331874c9dc72bfd8616ba9da6b5',\n        '5e4631150e62fb40d0e8c2a7ca5804a39d58186a50e497139626778e25b0674d'\n      ],\n      [\n        'eaa5f980c245f6f038978290afa70b6bd8855897f98b6aa485b96065d537bd99',\n        'f65f5d3e292c2e0819a528391c994624d784869d7e6ea67fb18041024edc07dc'\n      ],\n      [\n        '78c9407544ac132692ee1910a02439958ae04877151342ea96c4b6b35a49f51',\n        'f3e0319169eb9b85d5404795539a5e68fa1fbd583c064d2462b675f194a3ddb4'\n      ],\n      [\n        '494f4be219a1a77016dcd838431aea0001cdc8ae7a6fc688726578d9702857a5',\n        '42242a969283a5f339ba7f075e36ba2af925ce30d767ed6e55f4b031880d562c'\n      ],\n      [\n        'a598a8030da6d86c6bc7f2f5144ea549d28211ea58faa70ebf4c1e665c1fe9b5',\n        '204b5d6f84822c307e4b4a7140737aec23fc63b65b35f86a10026dbd2d864e6b'\n      ],\n      [\n        'c41916365abb2b5d09192f5f2dbeafec208f020f12570a184dbadc3e58595997',\n        '4f14351d0087efa49d245b328984989d5caf9450f34bfc0ed16e96b58fa9913'\n      ],\n      [\n        '841d6063a586fa475a724604da03bc5b92a2e0d2e0a36acfe4c73a5514742881',\n        '73867f59c0659e81904f9a1c7543698e62562d6744c169ce7a36de01a8d6154'\n      ],\n      [\n        '5e95bb399a6971d376026947f89bde2f282b33810928be4ded112ac4d70e20d5',\n        '39f23f366809085beebfc71181313775a99c9aed7d8ba38b161384c746012865'\n      ],\n      [\n        '36e4641a53948fd476c39f8a99fd974e5ec07564b5315d8bf99471bca0ef2f66',\n        'd2424b1b1abe4eb8164227b085c9aa9456ea13493fd563e06fd51cf5694c78fc'\n      ],\n      [\n        '336581ea7bfbbb290c191a2f507a41cf5643842170e914faeab27c2c579f726',\n        'ead12168595fe1be99252129b6e56b3391f7ab1410cd1e0ef3dcdcabd2fda224'\n      ],\n      [\n        '8ab89816dadfd6b6a1f2634fcf00ec8403781025ed6890c4849742706bd43ede',\n        '6fdcef09f2f6d0a044e654aef624136f503d459c3e89845858a47a9129cdd24e'\n      ],\n      [\n        '1e33f1a746c9c5778133344d9299fcaa20b0938e8acff2544bb40284b8c5fb94',\n        '60660257dd11b3aa9c8ed618d24edff2306d320f1d03010e33a7d2057f3b3b6'\n      ],\n      [\n        '85b7c1dcb3cec1b7ee7f30ded79dd20a0ed1f4cc18cbcfcfa410361fd8f08f31',\n        '3d98a9cdd026dd43f39048f25a8847f4fcafad1895d7a633c6fed3c35e999511'\n      ],\n      [\n        '29df9fbd8d9e46509275f4b125d6d45d7fbe9a3b878a7af872a2800661ac5f51',\n        'b4c4fe99c775a606e2d8862179139ffda61dc861c019e55cd2876eb2a27d84b'\n      ],\n      [\n        'a0b1cae06b0a847a3fea6e671aaf8adfdfe58ca2f768105c8082b2e449fce252',\n        'ae434102edde0958ec4b19d917a6a28e6b72da1834aff0e650f049503a296cf2'\n      ],\n      [\n        '4e8ceafb9b3e9a136dc7ff67e840295b499dfb3b2133e4ba113f2e4c0e121e5',\n        'cf2174118c8b6d7a4b48f6d534ce5c79422c086a63460502b827ce62a326683c'\n      ],\n      [\n        'd24a44e047e19b6f5afb81c7ca2f69080a5076689a010919f42725c2b789a33b',\n        '6fb8d5591b466f8fc63db50f1c0f1c69013f996887b8244d2cdec417afea8fa3'\n      ],\n      [\n        'ea01606a7a6c9cdd249fdfcfacb99584001edd28abbab77b5104e98e8e3b35d4',\n        '322af4908c7312b0cfbfe369f7a7b3cdb7d4494bc2823700cfd652188a3ea98d'\n      ],\n      [\n        'af8addbf2b661c8a6c6328655eb96651252007d8c5ea31be4ad196de8ce2131f',\n        '6749e67c029b85f52a034eafd096836b2520818680e26ac8f3dfbcdb71749700'\n      ],\n      [\n        'e3ae1974566ca06cc516d47e0fb165a674a3dabcfca15e722f0e3450f45889',\n        '2aeabe7e4531510116217f07bf4d07300de97e4874f81f533420a72eeb0bd6a4'\n      ],\n      [\n        '591ee355313d99721cf6993ffed1e3e301993ff3ed258802075ea8ced397e246',\n        'b0ea558a113c30bea60fc4775460c7901ff0b053d25ca2bdeee98f1a4be5d196'\n      ],\n      [\n        '11396d55fda54c49f19aa97318d8da61fa8584e47b084945077cf03255b52984',\n        '998c74a8cd45ac01289d5833a7beb4744ff536b01b257be4c5767bea93ea57a4'\n      ],\n      [\n        '3c5d2a1ba39c5a1790000738c9e0c40b8dcdfd5468754b6405540157e017aa7a',\n        'b2284279995a34e2f9d4de7396fc18b80f9b8b9fdd270f6661f79ca4c81bd257'\n      ],\n      [\n        'cc8704b8a60a0defa3a99a7299f2e9c3fbc395afb04ac078425ef8a1793cc030',\n        'bdd46039feed17881d1e0862db347f8cf395b74fc4bcdc4e940b74e3ac1f1b13'\n      ],\n      [\n        'c533e4f7ea8555aacd9777ac5cad29b97dd4defccc53ee7ea204119b2889b197',\n        '6f0a256bc5efdf429a2fb6242f1a43a2d9b925bb4a4b3a26bb8e0f45eb596096'\n      ],\n      [\n        'c14f8f2ccb27d6f109f6d08d03cc96a69ba8c34eec07bbcf566d48e33da6593',\n        'c359d6923bb398f7fd4473e16fe1c28475b740dd098075e6c0e8649113dc3a38'\n      ],\n      [\n        'a6cbc3046bc6a450bac24789fa17115a4c9739ed75f8f21ce441f72e0b90e6ef',\n        '21ae7f4680e889bb130619e2c0f95a360ceb573c70603139862afd617fa9b9f'\n      ],\n      [\n        '347d6d9a02c48927ebfb86c1359b1caf130a3c0267d11ce6344b39f99d43cc38',\n        '60ea7f61a353524d1c987f6ecec92f086d565ab687870cb12689ff1e31c74448'\n      ],\n      [\n        'da6545d2181db8d983f7dcb375ef5866d47c67b1bf31c8cf855ef7437b72656a',\n        '49b96715ab6878a79e78f07ce5680c5d6673051b4935bd897fea824b77dc208a'\n      ],\n      [\n        'c40747cc9d012cb1a13b8148309c6de7ec25d6945d657146b9d5994b8feb1111',\n        '5ca560753be2a12fc6de6caf2cb489565db936156b9514e1bb5e83037e0fa2d4'\n      ],\n      [\n        '4e42c8ec82c99798ccf3a610be870e78338c7f713348bd34c8203ef4037f3502',\n        '7571d74ee5e0fb92a7a8b33a07783341a5492144cc54bcc40a94473693606437'\n      ],\n      [\n        '3775ab7089bc6af823aba2e1af70b236d251cadb0c86743287522a1b3b0dedea',\n        'be52d107bcfa09d8bcb9736a828cfa7fac8db17bf7a76a2c42ad961409018cf7'\n      ],\n      [\n        'cee31cbf7e34ec379d94fb814d3d775ad954595d1314ba8846959e3e82f74e26',\n        '8fd64a14c06b589c26b947ae2bcf6bfa0149ef0be14ed4d80f448a01c43b1c6d'\n      ],\n      [\n        'b4f9eaea09b6917619f6ea6a4eb5464efddb58fd45b1ebefcdc1a01d08b47986',\n        '39e5c9925b5a54b07433a4f18c61726f8bb131c012ca542eb24a8ac07200682a'\n      ],\n      [\n        'd4263dfc3d2df923a0179a48966d30ce84e2515afc3dccc1b77907792ebcc60e',\n        '62dfaf07a0f78feb30e30d6295853ce189e127760ad6cf7fae164e122a208d54'\n      ],\n      [\n        '48457524820fa65a4f8d35eb6930857c0032acc0a4a2de422233eeda897612c4',\n        '25a748ab367979d98733c38a1fa1c2e7dc6cc07db2d60a9ae7a76aaa49bd0f77'\n      ],\n      [\n        'dfeeef1881101f2cb11644f3a2afdfc2045e19919152923f367a1767c11cceda',\n        'ecfb7056cf1de042f9420bab396793c0c390bde74b4bbdff16a83ae09a9a7517'\n      ],\n      [\n        '6d7ef6b17543f8373c573f44e1f389835d89bcbc6062ced36c82df83b8fae859',\n        'cd450ec335438986dfefa10c57fea9bcc521a0959b2d80bbf74b190dca712d10'\n      ],\n      [\n        'e75605d59102a5a2684500d3b991f2e3f3c88b93225547035af25af66e04541f',\n        'f5c54754a8f71ee540b9b48728473e314f729ac5308b06938360990e2bfad125'\n      ],\n      [\n        'eb98660f4c4dfaa06a2be453d5020bc99a0c2e60abe388457dd43fefb1ed620c',\n        '6cb9a8876d9cb8520609af3add26cd20a0a7cd8a9411131ce85f44100099223e'\n      ],\n      [\n        '13e87b027d8514d35939f2e6892b19922154596941888336dc3563e3b8dba942',\n        'fef5a3c68059a6dec5d624114bf1e91aac2b9da568d6abeb2570d55646b8adf1'\n      ],\n      [\n        'ee163026e9fd6fe017c38f06a5be6fc125424b371ce2708e7bf4491691e5764a',\n        '1acb250f255dd61c43d94ccc670d0f58f49ae3fa15b96623e5430da0ad6c62b2'\n      ],\n      [\n        'b268f5ef9ad51e4d78de3a750c2dc89b1e626d43505867999932e5db33af3d80',\n        '5f310d4b3c99b9ebb19f77d41c1dee018cf0d34fd4191614003e945a1216e423'\n      ],\n      [\n        'ff07f3118a9df035e9fad85eb6c7bfe42b02f01ca99ceea3bf7ffdba93c4750d',\n        '438136d603e858a3a5c440c38eccbaddc1d2942114e2eddd4740d098ced1f0d8'\n      ],\n      [\n        '8d8b9855c7c052a34146fd20ffb658bea4b9f69e0d825ebec16e8c3ce2b526a1',\n        'cdb559eedc2d79f926baf44fb84ea4d44bcf50fee51d7ceb30e2e7f463036758'\n      ],\n      [\n        '52db0b5384dfbf05bfa9d472d7ae26dfe4b851ceca91b1eba54263180da32b63',\n        'c3b997d050ee5d423ebaf66a6db9f57b3180c902875679de924b69d84a7b375'\n      ],\n      [\n        'e62f9490d3d51da6395efd24e80919cc7d0f29c3f3fa48c6fff543becbd43352',\n        '6d89ad7ba4876b0b22c2ca280c682862f342c8591f1daf5170e07bfd9ccafa7d'\n      ],\n      [\n        '7f30ea2476b399b4957509c88f77d0191afa2ff5cb7b14fd6d8e7d65aaab1193',\n        'ca5ef7d4b231c94c3b15389a5f6311e9daff7bb67b103e9880ef4bff637acaec'\n      ],\n      [\n        '5098ff1e1d9f14fb46a210fada6c903fef0fb7b4a1dd1d9ac60a0361800b7a00',\n        '9731141d81fc8f8084d37c6e7542006b3ee1b40d60dfe5362a5b132fd17ddc0'\n      ],\n      [\n        '32b78c7de9ee512a72895be6b9cbefa6e2f3c4ccce445c96b9f2c81e2778ad58',\n        'ee1849f513df71e32efc3896ee28260c73bb80547ae2275ba497237794c8753c'\n      ],\n      [\n        'e2cb74fddc8e9fbcd076eef2a7c72b0ce37d50f08269dfc074b581550547a4f7',\n        'd3aa2ed71c9dd2247a62df062736eb0baddea9e36122d2be8641abcb005cc4a4'\n      ],\n      [\n        '8438447566d4d7bedadc299496ab357426009a35f235cb141be0d99cd10ae3a8',\n        'c4e1020916980a4da5d01ac5e6ad330734ef0d7906631c4f2390426b2edd791f'\n      ],\n      [\n        '4162d488b89402039b584c6fc6c308870587d9c46f660b878ab65c82c711d67e',\n        '67163e903236289f776f22c25fb8a3afc1732f2b84b4e95dbda47ae5a0852649'\n      ],\n      [\n        '3fad3fa84caf0f34f0f89bfd2dcf54fc175d767aec3e50684f3ba4a4bf5f683d',\n        'cd1bc7cb6cc407bb2f0ca647c718a730cf71872e7d0d2a53fa20efcdfe61826'\n      ],\n      [\n        '674f2600a3007a00568c1a7ce05d0816c1fb84bf1370798f1c69532faeb1a86b',\n        '299d21f9413f33b3edf43b257004580b70db57da0b182259e09eecc69e0d38a5'\n      ],\n      [\n        'd32f4da54ade74abb81b815ad1fb3b263d82d6c692714bcff87d29bd5ee9f08f',\n        'f9429e738b8e53b968e99016c059707782e14f4535359d582fc416910b3eea87'\n      ],\n      [\n        '30e4e670435385556e593657135845d36fbb6931f72b08cb1ed954f1e3ce3ff6',\n        '462f9bce619898638499350113bbc9b10a878d35da70740dc695a559eb88db7b'\n      ],\n      [\n        'be2062003c51cc3004682904330e4dee7f3dcd10b01e580bf1971b04d4cad297',\n        '62188bc49d61e5428573d48a74e1c655b1c61090905682a0d5558ed72dccb9bc'\n      ],\n      [\n        '93144423ace3451ed29e0fb9ac2af211cb6e84a601df5993c419859fff5df04a',\n        '7c10dfb164c3425f5c71a3f9d7992038f1065224f72bb9d1d902a6d13037b47c'\n      ],\n      [\n        'b015f8044f5fcbdcf21ca26d6c34fb8197829205c7b7d2a7cb66418c157b112c',\n        'ab8c1e086d04e813744a655b2df8d5f83b3cdc6faa3088c1d3aea1454e3a1d5f'\n      ],\n      [\n        'd5e9e1da649d97d89e4868117a465a3a4f8a18de57a140d36b3f2af341a21b52',\n        '4cb04437f391ed73111a13cc1d4dd0db1693465c2240480d8955e8592f27447a'\n      ],\n      [\n        'd3ae41047dd7ca065dbf8ed77b992439983005cd72e16d6f996a5316d36966bb',\n        'bd1aeb21ad22ebb22a10f0303417c6d964f8cdd7df0aca614b10dc14d125ac46'\n      ],\n      [\n        '463e2763d885f958fc66cdd22800f0a487197d0a82e377b49f80af87c897b065',\n        'bfefacdb0e5d0fd7df3a311a94de062b26b80c61fbc97508b79992671ef7ca7f'\n      ],\n      [\n        '7985fdfd127c0567c6f53ec1bb63ec3158e597c40bfe747c83cddfc910641917',\n        '603c12daf3d9862ef2b25fe1de289aed24ed291e0ec6708703a5bd567f32ed03'\n      ],\n      [\n        '74a1ad6b5f76e39db2dd249410eac7f99e74c59cb83d2d0ed5ff1543da7703e9',\n        'cc6157ef18c9c63cd6193d83631bbea0093e0968942e8c33d5737fd790e0db08'\n      ],\n      [\n        '30682a50703375f602d416664ba19b7fc9bab42c72747463a71d0896b22f6da3',\n        '553e04f6b018b4fa6c8f39e7f311d3176290d0e0f19ca73f17714d9977a22ff8'\n      ],\n      [\n        '9e2158f0d7c0d5f26c3791efefa79597654e7a2b2464f52b1ee6c1347769ef57',\n        '712fcdd1b9053f09003a3481fa7762e9ffd7c8ef35a38509e2fbf2629008373'\n      ],\n      [\n        '176e26989a43c9cfeba4029c202538c28172e566e3c4fce7322857f3be327d66',\n        'ed8cc9d04b29eb877d270b4878dc43c19aefd31f4eee09ee7b47834c1fa4b1c3'\n      ],\n      [\n        '75d46efea3771e6e68abb89a13ad747ecf1892393dfc4f1b7004788c50374da8',\n        '9852390a99507679fd0b86fd2b39a868d7efc22151346e1a3ca4726586a6bed8'\n      ],\n      [\n        '809a20c67d64900ffb698c4c825f6d5f2310fb0451c869345b7319f645605721',\n        '9e994980d9917e22b76b061927fa04143d096ccc54963e6a5ebfa5f3f8e286c1'\n      ],\n      [\n        '1b38903a43f7f114ed4500b4eac7083fdefece1cf29c63528d563446f972c180',\n        '4036edc931a60ae889353f77fd53de4a2708b26b6f5da72ad3394119daf408f9'\n      ]\n    ]\n  }\n};\n","'use strict';\n\nvar utils = exports;\nvar BN = require('bn.js');\n\nutils.assert = function assert(val, msg) {\n  if (!val)\n    throw new Error(msg || 'Assertion failed');\n};\n\nfunction toArray(msg, enc) {\n  if (Array.isArray(msg))\n    return msg.slice();\n  if (!msg)\n    return [];\n  var res = [];\n  if (typeof msg !== 'string') {\n    for (var i = 0; i < msg.length; i++)\n      res[i] = msg[i] | 0;\n    return res;\n  }\n  if (!enc) {\n    for (var i = 0; i < msg.length; i++) {\n      var c = msg.charCodeAt(i);\n      var hi = c >> 8;\n      var lo = c & 0xff;\n      if (hi)\n        res.push(hi, lo);\n      else\n        res.push(lo);\n    }\n  } else if (enc === 'hex') {\n    msg = msg.replace(/[^a-z0-9]+/ig, '');\n    if (msg.length % 2 !== 0)\n      msg = '0' + msg;\n    for (var i = 0; i < msg.length; i += 2)\n      res.push(parseInt(msg[i] + msg[i + 1], 16));\n  }\n  return res;\n}\nutils.toArray = toArray;\n\nfunction zero2(word) {\n  if (word.length === 1)\n    return '0' + word;\n  else\n    return word;\n}\nutils.zero2 = zero2;\n\nfunction toHex(msg) {\n  var res = '';\n  for (var i = 0; i < msg.length; i++)\n    res += zero2(msg[i].toString(16));\n  return res;\n}\nutils.toHex = toHex;\n\nutils.encode = function encode(arr, enc) {\n  if (enc === 'hex')\n    return toHex(arr);\n  else\n    return arr;\n};\n\n// Represent num in a w-NAF form\nfunction getNAF(num, w) {\n  var naf = [];\n  var ws = 1 << (w + 1);\n  var k = num.clone();\n  while (k.cmpn(1) >= 0) {\n    var z;\n    if (k.isOdd()) {\n      var mod = k.andln(ws - 1);\n      if (mod > (ws >> 1) - 1)\n        z = (ws >> 1) - mod;\n      else\n        z = mod;\n      k.isubn(z);\n    } else {\n      z = 0;\n    }\n    naf.push(z);\n\n    // Optimization, shift by word if possible\n    var shift = (k.cmpn(0) !== 0 && k.andln(ws - 1) === 0) ? (w + 1) : 1;\n    for (var i = 1; i < shift; i++)\n      naf.push(0);\n    k.iushrn(shift);\n  }\n\n  return naf;\n}\nutils.getNAF = getNAF;\n\n// Represent k1, k2 in a Joint Sparse Form\nfunction getJSF(k1, k2) {\n  var jsf = [\n    [],\n    []\n  ];\n\n  k1 = k1.clone();\n  k2 = k2.clone();\n  var d1 = 0;\n  var d2 = 0;\n  while (k1.cmpn(-d1) > 0 || k2.cmpn(-d2) > 0) {\n\n    // First phase\n    var m14 = (k1.andln(3) + d1) & 3;\n    var m24 = (k2.andln(3) + d2) & 3;\n    if (m14 === 3)\n      m14 = -1;\n    if (m24 === 3)\n      m24 = -1;\n    var u1;\n    if ((m14 & 1) === 0) {\n      u1 = 0;\n    } else {\n      var m8 = (k1.andln(7) + d1) & 7;\n      if ((m8 === 3 || m8 === 5) && m24 === 2)\n        u1 = -m14;\n      else\n        u1 = m14;\n    }\n    jsf[0].push(u1);\n\n    var u2;\n    if ((m24 & 1) === 0) {\n      u2 = 0;\n    } else {\n      var m8 = (k2.andln(7) + d2) & 7;\n      if ((m8 === 3 || m8 === 5) && m14 === 2)\n        u2 = -m24;\n      else\n        u2 = m24;\n    }\n    jsf[1].push(u2);\n\n    // Second phase\n    if (2 * d1 === u1 + 1)\n      d1 = 1 - d1;\n    if (2 * d2 === u2 + 1)\n      d2 = 1 - d2;\n    k1.iushrn(1);\n    k2.iushrn(1);\n  }\n\n  return jsf;\n}\nutils.getJSF = getJSF;\n\nfunction cachedProperty(obj, computer) {\n  var name = computer.name;\n  var key = '_' + name;\n  obj.prototype[name] = function cachedProperty() {\n    return this[key] !== undefined ? this[key] :\n           this[key] = computer.call(this);\n  };\n}\nutils.cachedProperty = cachedProperty;\n\nfunction parseBytes(bytes) {\n  return typeof bytes === 'string' ? utils.toArray(bytes, 'hex') :\n                                     bytes;\n}\nutils.parseBytes = parseBytes;\n\nfunction intFromLE(bytes) {\n  return new BN(bytes, 'hex', 'le');\n}\nutils.intFromLE = intFromLE;\n\n","module.exports={\n  \"_args\": [\n    [\n      \"elliptic@^6.0.0\",\n      \"/Users/joran/Documents/development/patchdeck/node_modules/browserify-sign\"\n    ]\n  ],\n  \"_from\": \"elliptic@>=6.0.0 <7.0.0\",\n  \"_id\": \"elliptic@6.2.3\",\n  \"_inCache\": true,\n  \"_installable\": true,\n  \"_location\": \"/elliptic\",\n  \"_nodeVersion\": \"5.4.1\",\n  \"_npmUser\": {\n    \"email\": \"fedor@indutny.com\",\n    \"name\": \"indutny\"\n  },\n  \"_npmVersion\": \"3.3.12\",\n  \"_phantomChildren\": {},\n  \"_requested\": {\n    \"name\": \"elliptic\",\n    \"raw\": \"elliptic@^6.0.0\",\n    \"rawSpec\": \"^6.0.0\",\n    \"scope\": null,\n    \"spec\": \">=6.0.0 <7.0.0\",\n    \"type\": \"range\"\n  },\n  \"_requiredBy\": [\n    \"/browserify-sign\",\n    \"/create-ecdh\"\n  ],\n  \"_resolved\": \"https://registry.npmjs.org/elliptic/-/elliptic-6.2.3.tgz\",\n  \"_shasum\": \"18e46d7306b0951275a2d42063270a14b74ebe99\",\n  \"_shrinkwrap\": null,\n  \"_spec\": \"elliptic@^6.0.0\",\n  \"_where\": \"/Users/joran/Documents/development/patchdeck/node_modules/browserify-sign\",\n  \"author\": {\n    \"email\": \"fedor@indutny.com\",\n    \"name\": \"Fedor Indutny\"\n  },\n  \"bugs\": {\n    \"url\": \"https://github.com/indutny/elliptic/issues\"\n  },\n  \"dependencies\": {\n    \"bn.js\": \"^4.0.0\",\n    \"brorand\": \"^1.0.1\",\n    \"hash.js\": \"^1.0.0\",\n    \"inherits\": \"^2.0.1\"\n  },\n  \"description\": \"EC cryptography\",\n  \"devDependencies\": {\n    \"coveralls\": \"^2.11.3\",\n    \"istanbul\": \"^0.4.2\",\n    \"jscs\": \"^2.9.0\",\n    \"jshint\": \"^2.6.0\",\n    \"mocha\": \"^2.1.0\"\n  },\n  \"directories\": {},\n  \"dist\": {\n    \"shasum\": \"18e46d7306b0951275a2d42063270a14b74ebe99\",\n    \"tarball\": \"https://registry.npmjs.org/elliptic/-/elliptic-6.2.3.tgz\"\n  },\n  \"files\": [\n    \"lib\"\n  ],\n  \"gitHead\": \"c32f20b22b420eb6af3c6dda28963deb7facf823\",\n  \"homepage\": \"https://github.com/indutny/elliptic\",\n  \"keywords\": [\n    \"Cryptography\",\n    \"EC\",\n    \"Elliptic\",\n    \"curve\"\n  ],\n  \"license\": \"MIT\",\n  \"main\": \"lib/elliptic.js\",\n  \"maintainers\": [\n    {\n      \"name\": \"indutny\",\n      \"email\": \"fedor@indutny.com\"\n    }\n  ],\n  \"name\": \"elliptic\",\n  \"optionalDependencies\": {},\n  \"readme\": \"ERROR: No README data found!\",\n  \"repository\": {\n    \"type\": \"git\",\n    \"url\": \"git+ssh://git@github.com/indutny/elliptic.git\"\n  },\n  \"scripts\": {\n    \"coverage\": \"npm run unit --coverage\",\n    \"coveralls\": \"npm run coverage && cat ./coverage/lcov.info | coveralls\",\n    \"jscs\": \"jscs benchmarks/*.js lib/*.js lib/**/*.js lib/**/**/*.js test/*.js\",\n    \"jshint\": \"jscs benchmarks/*.js lib/*.js lib/**/*.js lib/**/**/*.js test/*.js\",\n    \"lint\": \"npm run jscs && npm run jshint\",\n    \"test\": \"npm run lint && npm run unit\",\n    \"unit\": \"istanbul test _mocha --reporter=spec test/*-test.js\"\n  },\n  \"version\": \"6.2.3\"\n}\n","var prr = require('prr')\n\nfunction init (type, message, cause) {\n  prr(this, {\n      type    : type\n    , name    : type\n      // can be passed just a 'cause'\n    , cause   : typeof message != 'string' ? message : cause\n    , message : !!message && typeof message != 'string' ? message.message : message\n\n  }, 'ewr')\n}\n\n// generic prototype, not intended to be actually used - helpful for `instanceof`\nfunction CustomError (message, cause) {\n  Error.call(this)\n  if (Error.captureStackTrace)\n    Error.captureStackTrace(this, arguments.callee)\n  init.call(this, 'CustomError', message, cause)\n}\n\nCustomError.prototype = new Error()\n\nfunction createError (errno, type, proto) {\n  var err = function (message, cause) {\n    init.call(this, type, message, cause)\n    //TODO: the specificity here is stupid, errno should be available everywhere\n    if (type == 'FilesystemError') {\n      this.code    = this.cause.code\n      this.path    = this.cause.path\n      this.errno   = this.cause.errno\n      this.message =\n        (errno.errno[this.cause.errno]\n          ? errno.errno[this.cause.errno].description\n          : this.cause.message)\n        + (this.cause.path ? ' [' + this.cause.path + ']' : '')\n    }\n    Error.call(this)\n    if (Error.captureStackTrace)\n      Error.captureStackTrace(this, arguments.callee)\n  }\n  err.prototype = !!proto ? new proto() : new CustomError()\n  return err\n}\n\nmodule.exports = function (errno) {\n  var ce = function (type, proto) {\n    return createError(errno, type, proto)\n  }\n  return {\n      CustomError     : CustomError\n    , FilesystemError : ce('FilesystemError')\n    , createError     : ce\n  }\n}\n","var all = module.exports.all = [\n  {\n    errno: -2,\n    code: 'ENOENT',\n    description: 'no such file or directory'\n  },\n  {\n    errno: -1,\n    code: 'UNKNOWN',\n    description: 'unknown error'\n  },\n  {\n    errno: 0,\n    code: 'OK',\n    description: 'success'\n  },\n  {\n    errno: 1,\n    code: 'EOF',\n    description: 'end of file'\n  },\n  {\n    errno: 2,\n    code: 'EADDRINFO',\n    description: 'getaddrinfo error'\n  },\n  {\n    errno: 3,\n    code: 'EACCES',\n    description: 'permission denied'\n  },\n  {\n    errno: 4,\n    code: 'EAGAIN',\n    description: 'resource temporarily unavailable'\n  },\n  {\n    errno: 5,\n    code: 'EADDRINUSE',\n    description: 'address already in use'\n  },\n  {\n    errno: 6,\n    code: 'EADDRNOTAVAIL',\n    description: 'address not available'\n  },\n  {\n    errno: 7,\n    code: 'EAFNOSUPPORT',\n    description: 'address family not supported'\n  },\n  {\n    errno: 8,\n    code: 'EALREADY',\n    description: 'connection already in progress'\n  },\n  {\n    errno: 9,\n    code: 'EBADF',\n    description: 'bad file descriptor'\n  },\n  {\n    errno: 10,\n    code: 'EBUSY',\n    description: 'resource busy or locked'\n  },\n  {\n    errno: 11,\n    code: 'ECONNABORTED',\n    description: 'software caused connection abort'\n  },\n  {\n    errno: 12,\n    code: 'ECONNREFUSED',\n    description: 'connection refused'\n  },\n  {\n    errno: 13,\n    code: 'ECONNRESET',\n    description: 'connection reset by peer'\n  },\n  {\n    errno: 14,\n    code: 'EDESTADDRREQ',\n    description: 'destination address required'\n  },\n  {\n    errno: 15,\n    code: 'EFAULT',\n    description: 'bad address in system call argument'\n  },\n  {\n    errno: 16,\n    code: 'EHOSTUNREACH',\n    description: 'host is unreachable'\n  },\n  {\n    errno: 17,\n    code: 'EINTR',\n    description: 'interrupted system call'\n  },\n  {\n    errno: 18,\n    code: 'EINVAL',\n    description: 'invalid argument'\n  },\n  {\n    errno: 19,\n    code: 'EISCONN',\n    description: 'socket is already connected'\n  },\n  {\n    errno: 20,\n    code: 'EMFILE',\n    description: 'too many open files'\n  },\n  {\n    errno: 21,\n    code: 'EMSGSIZE',\n    description: 'message too long'\n  },\n  {\n    errno: 22,\n    code: 'ENETDOWN',\n    description: 'network is down'\n  },\n  {\n    errno: 23,\n    code: 'ENETUNREACH',\n    description: 'network is unreachable'\n  },\n  {\n    errno: 24,\n    code: 'ENFILE',\n    description: 'file table overflow'\n  },\n  {\n    errno: 25,\n    code: 'ENOBUFS',\n    description: 'no buffer space available'\n  },\n  {\n    errno: 26,\n    code: 'ENOMEM',\n    description: 'not enough memory'\n  },\n  {\n    errno: 27,\n    code: 'ENOTDIR',\n    description: 'not a directory'\n  },\n  {\n    errno: 28,\n    code: 'EISDIR',\n    description: 'illegal operation on a directory'\n  },\n  {\n    errno: 29,\n    code: 'ENONET',\n    description: 'machine is not on the network'\n  },\n  {\n    errno: 31,\n    code: 'ENOTCONN',\n    description: 'socket is not connected'\n  },\n  {\n    errno: 32,\n    code: 'ENOTSOCK',\n    description: 'socket operation on non-socket'\n  },\n  {\n    errno: 33,\n    code: 'ENOTSUP',\n    description: 'operation not supported on socket'\n  },\n  {\n    errno: 34,\n    code: 'ENOENT',\n    description: 'no such file or directory'\n  },\n  {\n    errno: 35,\n    code: 'ENOSYS',\n    description: 'function not implemented'\n  },\n  {\n    errno: 36,\n    code: 'EPIPE',\n    description: 'broken pipe'\n  },\n  {\n    errno: 37,\n    code: 'EPROTO',\n    description: 'protocol error'\n  },\n  {\n    errno: 38,\n    code: 'EPROTONOSUPPORT',\n    description: 'protocol not supported'\n  },\n  {\n    errno: 39,\n    code: 'EPROTOTYPE',\n    description: 'protocol wrong type for socket'\n  },\n  {\n    errno: 40,\n    code: 'ETIMEDOUT',\n    description: 'connection timed out'\n  },\n  {\n    errno: 41,\n    code: 'ECHARSET',\n    description: 'invalid Unicode character'\n  },\n  {\n    errno: 42,\n    code: 'EAIFAMNOSUPPORT',\n    description: 'address family for hostname not supported'\n  },\n  {\n    errno: 44,\n    code: 'EAISERVICE',\n    description: 'servname not supported for ai_socktype'\n  },\n  {\n    errno: 45,\n    code: 'EAISOCKTYPE',\n    description: 'ai_socktype not supported'\n  },\n  {\n    errno: 46,\n    code: 'ESHUTDOWN',\n    description: 'cannot send after transport endpoint shutdown'\n  },\n  {\n    errno: 47,\n    code: 'EEXIST',\n    description: 'file already exists'\n  },\n  {\n    errno: 48,\n    code: 'ESRCH',\n    description: 'no such process'\n  },\n  {\n    errno: 49,\n    code: 'ENAMETOOLONG',\n    description: 'name too long'\n  },\n  {\n    errno: 50,\n    code: 'EPERM',\n    description: 'operation not permitted'\n  },\n  {\n    errno: 51,\n    code: 'ELOOP',\n    description: 'too many symbolic links encountered'\n  },\n  {\n    errno: 52,\n    code: 'EXDEV',\n    description: 'cross-device link not permitted'\n  },\n  {\n    errno: 53,\n    code: 'ENOTEMPTY',\n    description: 'directory not empty'\n  },\n  {\n    errno: 54,\n    code: 'ENOSPC',\n    description: 'no space left on device'\n  },\n  {\n    errno: 55,\n    code: 'EIO',\n    description: 'i/o error'\n  },\n  {\n    errno: 56,\n    code: 'EROFS',\n    description: 'read-only file system'\n  },\n  {\n    errno: 57,\n    code: 'ENODEV',\n    description: 'no such device'\n  },\n  {\n    errno: 58,\n    code: 'ESPIPE',\n    description: 'invalid seek'\n  },\n  {\n    errno: 59,\n    code: 'ECANCELED',\n    description: 'operation canceled'\n  }\n]\n\nmodule.exports.errno = {}\nmodule.exports.code = {}\n\nall.forEach(function (error) {\n  module.exports.errno[error.errno] = error\n  module.exports.code[error.code] = error\n})\n\nmodule.exports.custom = require('./custom')(module.exports)\nmodule.exports.create = module.exports.custom.createError\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nfunction EventEmitter() {\n  this._events = this._events || {};\n  this._maxListeners = this._maxListeners || undefined;\n}\nmodule.exports = EventEmitter;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nEventEmitter.defaultMaxListeners = 10;\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function(n) {\n  if (!isNumber(n) || n < 0 || isNaN(n))\n    throw TypeError('n must be a positive number');\n  this._maxListeners = n;\n  return this;\n};\n\nEventEmitter.prototype.emit = function(type) {\n  var er, handler, len, args, i, listeners;\n\n  if (!this._events)\n    this._events = {};\n\n  // If there is no 'error' event listener then throw.\n  if (type === 'error') {\n    if (!this._events.error ||\n        (isObject(this._events.error) && !this._events.error.length)) {\n      er = arguments[1];\n      if (er instanceof Error) {\n        throw er; // Unhandled 'error' event\n      }\n      throw TypeError('Uncaught, unspecified \"error\" event.');\n    }\n  }\n\n  handler = this._events[type];\n\n  if (isUndefined(handler))\n    return false;\n\n  if (isFunction(handler)) {\n    switch (arguments.length) {\n      // fast cases\n      case 1:\n        handler.call(this);\n        break;\n      case 2:\n        handler.call(this, arguments[1]);\n        break;\n      case 3:\n        handler.call(this, arguments[1], arguments[2]);\n        break;\n      // slower\n      default:\n        args = Array.prototype.slice.call(arguments, 1);\n        handler.apply(this, args);\n    }\n  } else if (isObject(handler)) {\n    args = Array.prototype.slice.call(arguments, 1);\n    listeners = handler.slice();\n    len = listeners.length;\n    for (i = 0; i < len; i++)\n      listeners[i].apply(this, args);\n  }\n\n  return true;\n};\n\nEventEmitter.prototype.addListener = function(type, listener) {\n  var m;\n\n  if (!isFunction(listener))\n    throw TypeError('listener must be a function');\n\n  if (!this._events)\n    this._events = {};\n\n  // To avoid recursion in the case that type === \"newListener\"! Before\n  // adding it to the listeners, first emit \"newListener\".\n  if (this._events.newListener)\n    this.emit('newListener', type,\n              isFunction(listener.listener) ?\n              listener.listener : listener);\n\n  if (!this._events[type])\n    // Optimize the case of one listener. Don't need the extra array object.\n    this._events[type] = listener;\n  else if (isObject(this._events[type]))\n    // If we've already got an array, just append.\n    this._events[type].push(listener);\n  else\n    // Adding the second element, need to change to array.\n    this._events[type] = [this._events[type], listener];\n\n  // Check for listener leak\n  if (isObject(this._events[type]) && !this._events[type].warned) {\n    if (!isUndefined(this._maxListeners)) {\n      m = this._maxListeners;\n    } else {\n      m = EventEmitter.defaultMaxListeners;\n    }\n\n    if (m && m > 0 && this._events[type].length > m) {\n      this._events[type].warned = true;\n      console.error('(node) warning: possible EventEmitter memory ' +\n                    'leak detected. %d listeners added. ' +\n                    'Use emitter.setMaxListeners() to increase limit.',\n                    this._events[type].length);\n      if (typeof console.trace === 'function') {\n        // not supported in IE 10\n        console.trace();\n      }\n    }\n  }\n\n  return this;\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.once = function(type, listener) {\n  if (!isFunction(listener))\n    throw TypeError('listener must be a function');\n\n  var fired = false;\n\n  function g() {\n    this.removeListener(type, g);\n\n    if (!fired) {\n      fired = true;\n      listener.apply(this, arguments);\n    }\n  }\n\n  g.listener = listener;\n  this.on(type, g);\n\n  return this;\n};\n\n// emits a 'removeListener' event iff the listener was removed\nEventEmitter.prototype.removeListener = function(type, listener) {\n  var list, position, length, i;\n\n  if (!isFunction(listener))\n    throw TypeError('listener must be a function');\n\n  if (!this._events || !this._events[type])\n    return this;\n\n  list = this._events[type];\n  length = list.length;\n  position = -1;\n\n  if (list === listener ||\n      (isFunction(list.listener) && list.listener === listener)) {\n    delete this._events[type];\n    if (this._events.removeListener)\n      this.emit('removeListener', type, listener);\n\n  } else if (isObject(list)) {\n    for (i = length; i-- > 0;) {\n      if (list[i] === listener ||\n          (list[i].listener && list[i].listener === listener)) {\n        position = i;\n        break;\n      }\n    }\n\n    if (position < 0)\n      return this;\n\n    if (list.length === 1) {\n      list.length = 0;\n      delete this._events[type];\n    } else {\n      list.splice(position, 1);\n    }\n\n    if (this._events.removeListener)\n      this.emit('removeListener', type, listener);\n  }\n\n  return this;\n};\n\nEventEmitter.prototype.removeAllListeners = function(type) {\n  var key, listeners;\n\n  if (!this._events)\n    return this;\n\n  // not listening for removeListener, no need to emit\n  if (!this._events.removeListener) {\n    if (arguments.length === 0)\n      this._events = {};\n    else if (this._events[type])\n      delete this._events[type];\n    return this;\n  }\n\n  // emit removeListener for all listeners on all events\n  if (arguments.length === 0) {\n    for (key in this._events) {\n      if (key === 'removeListener') continue;\n      this.removeAllListeners(key);\n    }\n    this.removeAllListeners('removeListener');\n    this._events = {};\n    return this;\n  }\n\n  listeners = this._events[type];\n\n  if (isFunction(listeners)) {\n    this.removeListener(type, listeners);\n  } else if (listeners) {\n    // LIFO order\n    while (listeners.length)\n      this.removeListener(type, listeners[listeners.length - 1]);\n  }\n  delete this._events[type];\n\n  return this;\n};\n\nEventEmitter.prototype.listeners = function(type) {\n  var ret;\n  if (!this._events || !this._events[type])\n    ret = [];\n  else if (isFunction(this._events[type]))\n    ret = [this._events[type]];\n  else\n    ret = this._events[type].slice();\n  return ret;\n};\n\nEventEmitter.prototype.listenerCount = function(type) {\n  if (this._events) {\n    var evlistener = this._events[type];\n\n    if (isFunction(evlistener))\n      return 1;\n    else if (evlistener)\n      return evlistener.length;\n  }\n  return 0;\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n  return emitter.listenerCount(type);\n};\n\nfunction isFunction(arg) {\n  return typeof arg === 'function';\n}\n\nfunction isNumber(arg) {\n  return typeof arg === 'number';\n}\n\nfunction isObject(arg) {\n  return typeof arg === 'object' && arg !== null;\n}\n\nfunction isUndefined(arg) {\n  return arg === void 0;\n}\n","var md5 = require('create-hash/md5')\nmodule.exports = EVP_BytesToKey\nfunction EVP_BytesToKey (password, salt, keyLen, ivLen) {\n  if (!Buffer.isBuffer(password)) {\n    password = new Buffer(password, 'binary')\n  }\n  if (salt && !Buffer.isBuffer(salt)) {\n    salt = new Buffer(salt, 'binary')\n  }\n  keyLen = keyLen / 8\n  ivLen = ivLen || 0\n  var ki = 0\n  var ii = 0\n  var key = new Buffer(keyLen)\n  var iv = new Buffer(ivLen)\n  var addmd = 0\n  var md_buf\n  var i\n  var bufs = []\n  while (true) {\n    if (addmd++ > 0) {\n      bufs.push(md_buf)\n    }\n    bufs.push(password)\n    if (salt) {\n      bufs.push(salt)\n    }\n    md_buf = md5(Buffer.concat(bufs))\n    bufs = []\n    i = 0\n    if (keyLen > 0) {\n      while (true) {\n        if (keyLen === 0) {\n          break\n        }\n        if (i === md_buf.length) {\n          break\n        }\n        key[ki++] = md_buf[i]\n        keyLen--\n        i++\n      }\n    }\n    if (ivLen > 0 && i !== md_buf.length) {\n      while (true) {\n        if (ivLen === 0) {\n          break\n        }\n        if (i === md_buf.length) {\n          break\n        }\n        iv[ii++] = md_buf[i]\n        ivLen--\n        i++\n      }\n    }\n    if (keyLen === 0 && ivLen === 0) {\n      break\n    }\n  }\n  for (i = 0; i < md_buf.length; i++) {\n    md_buf[i] = 0\n  }\n  return {\n    key: key,\n    iv: iv\n  }\n}\n","\nfunction getStack(err) {\n  return err.stack.substring(err.name.length + 3 + err.message.length)\n    .split('\\n')\n}\n\nfunction removePrefix (a, b) {\n  return a.filter(function (e) {\n    return !~b.indexOf(e)\n  })\n}\n\nvar explain = module.exports = function (err, message) {\n  var _err = new Error(message)\n  var stack = removePrefix(getStack(_err).slice(1), getStack(err)).join('\\n')\n\n  _err.stack =\n    _err.name + ': ' + _err.message + '\\n' +\n    stack + '\\n  ' + err.stack\n\n  return _err\n}\n\n","/**\n * Extend an object with another.\n *\n * @param {Object, ...} src, ...\n * @return {Object} merged\n * @api private\n */\n\nmodule.exports = function(src) {\n  var objs = [].slice.call(arguments, 1), obj;\n\n  for (var i = 0, len = objs.length; i < len; i++) {\n    obj = objs[i];\n    for (var prop in obj) {\n      src[prop] = obj[prop];\n    }\n  }\n\n  return src;\n}\n","'use strict';\n\nvar hasOwn = Object.prototype.hasOwnProperty;\nvar toStr = Object.prototype.toString;\n\nvar isArray = function isArray(arr) {\n\tif (typeof Array.isArray === 'function') {\n\t\treturn Array.isArray(arr);\n\t}\n\n\treturn toStr.call(arr) === '[object Array]';\n};\n\nvar isPlainObject = function isPlainObject(obj) {\n\tif (!obj || toStr.call(obj) !== '[object Object]') {\n\t\treturn false;\n\t}\n\n\tvar hasOwnConstructor = hasOwn.call(obj, 'constructor');\n\tvar hasIsPrototypeOf = obj.constructor && obj.constructor.prototype && hasOwn.call(obj.constructor.prototype, 'isPrototypeOf');\n\t// Not own constructor property must be Object\n\tif (obj.constructor && !hasOwnConstructor && !hasIsPrototypeOf) {\n\t\treturn false;\n\t}\n\n\t// Own properties are enumerated firstly, so to speed up,\n\t// if last one is own, then all properties are own.\n\tvar key;\n\tfor (key in obj) {/**/}\n\n\treturn typeof key === 'undefined' || hasOwn.call(obj, key);\n};\n\nmodule.exports = function extend() {\n\tvar options, name, src, copy, copyIsArray, clone,\n\t\ttarget = arguments[0],\n\t\ti = 1,\n\t\tlength = arguments.length,\n\t\tdeep = false;\n\n\t// Handle a deep copy situation\n\tif (typeof target === 'boolean') {\n\t\tdeep = target;\n\t\ttarget = arguments[1] || {};\n\t\t// skip the boolean and the target\n\t\ti = 2;\n\t} else if ((typeof target !== 'object' && typeof target !== 'function') || target == null) {\n\t\ttarget = {};\n\t}\n\n\tfor (; i < length; ++i) {\n\t\toptions = arguments[i];\n\t\t// Only deal with non-null/undefined values\n\t\tif (options != null) {\n\t\t\t// Extend the base object\n\t\t\tfor (name in options) {\n\t\t\t\tsrc = target[name];\n\t\t\t\tcopy = options[name];\n\n\t\t\t\t// Prevent never-ending loop\n\t\t\t\tif (target !== copy) {\n\t\t\t\t\t// Recurse if we're merging plain objects or arrays\n\t\t\t\t\tif (deep && copy && (isPlainObject(copy) || (copyIsArray = isArray(copy)))) {\n\t\t\t\t\t\tif (copyIsArray) {\n\t\t\t\t\t\t\tcopyIsArray = false;\n\t\t\t\t\t\t\tclone = src && isArray(src) ? src : [];\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tclone = src && isPlainObject(src) ? src : {};\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Never move original objects, clone them\n\t\t\t\t\t\ttarget[name] = extend(deep, clone, copy);\n\n\t\t\t\t\t// Don't bring in undefined values\n\t\t\t\t\t} else if (typeof copy !== 'undefined') {\n\t\t\t\t\t\ttarget[name] = copy;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// Return the modified object\n\treturn target;\n};\n\n","var LIMIT = process.maxTickDepth / 2\n  , factory = function () {\n      var count = 0\n      return function (callback) {\n        if (count >= LIMIT){\n          global.setImmediate(callback)\n          count = 0\n        } else\n          process.nextTick(callback)\n        count++\n      }\n    }\n\nmodule.exports = global.setImmediate ? factory : function () { return process.nextTick }","exports.alphasort = alphasort\nexports.alphasorti = alphasorti\nexports.setopts = setopts\nexports.ownProp = ownProp\nexports.makeAbs = makeAbs\nexports.finish = finish\nexports.mark = mark\nexports.isIgnored = isIgnored\nexports.childrenIgnored = childrenIgnored\n\nfunction ownProp (obj, field) {\n  return Object.prototype.hasOwnProperty.call(obj, field)\n}\n\nvar path = require(\"path\")\nvar minimatch = require(\"minimatch\")\nvar isAbsolute = require(\"path-is-absolute\")\nvar Minimatch = minimatch.Minimatch\n\nfunction alphasorti (a, b) {\n  return a.toLowerCase().localeCompare(b.toLowerCase())\n}\n\nfunction alphasort (a, b) {\n  return a.localeCompare(b)\n}\n\nfunction setupIgnores (self, options) {\n  self.ignore = options.ignore || []\n\n  if (!Array.isArray(self.ignore))\n    self.ignore = [self.ignore]\n\n  if (self.ignore.length) {\n    self.ignore = self.ignore.map(ignoreMap)\n  }\n}\n\n// ignore patterns are always in dot:true mode.\nfunction ignoreMap (pattern) {\n  var gmatcher = null\n  if (pattern.slice(-3) === '/**') {\n    var gpattern = pattern.replace(/(\\/\\*\\*)+$/, '')\n    gmatcher = new Minimatch(gpattern, { dot: true })\n  }\n\n  return {\n    matcher: new Minimatch(pattern, { dot: true }),\n    gmatcher: gmatcher\n  }\n}\n\nfunction setopts (self, pattern, options) {\n  if (!options)\n    options = {}\n\n  // base-matching: just use globstar for that.\n  if (options.matchBase && -1 === pattern.indexOf(\"/\")) {\n    if (options.noglobstar) {\n      throw new Error(\"base matching requires globstar\")\n    }\n    pattern = \"**/\" + pattern\n  }\n\n  self.silent = !!options.silent\n  self.pattern = pattern\n  self.strict = options.strict !== false\n  self.realpath = !!options.realpath\n  self.realpathCache = options.realpathCache || Object.create(null)\n  self.follow = !!options.follow\n  self.dot = !!options.dot\n  self.mark = !!options.mark\n  self.nodir = !!options.nodir\n  if (self.nodir)\n    self.mark = true\n  self.sync = !!options.sync\n  self.nounique = !!options.nounique\n  self.nonull = !!options.nonull\n  self.nosort = !!options.nosort\n  self.nocase = !!options.nocase\n  self.stat = !!options.stat\n  self.noprocess = !!options.noprocess\n\n  self.maxLength = options.maxLength || Infinity\n  self.cache = options.cache || Object.create(null)\n  self.statCache = options.statCache || Object.create(null)\n  self.symlinks = options.symlinks || Object.create(null)\n\n  setupIgnores(self, options)\n\n  self.changedCwd = false\n  var cwd = process.cwd()\n  if (!ownProp(options, \"cwd\"))\n    self.cwd = cwd\n  else {\n    self.cwd = options.cwd\n    self.changedCwd = path.resolve(options.cwd) !== cwd\n  }\n\n  self.root = options.root || path.resolve(self.cwd, \"/\")\n  self.root = path.resolve(self.root)\n  if (process.platform === \"win32\")\n    self.root = self.root.replace(/\\\\/g, \"/\")\n\n  self.nomount = !!options.nomount\n\n  // disable comments and negation in Minimatch.\n  // Note that they are not supported in Glob itself anyway.\n  options.nonegate = true\n  options.nocomment = true\n\n  self.minimatch = new Minimatch(pattern, options)\n  self.options = self.minimatch.options\n}\n\nfunction finish (self) {\n  var nou = self.nounique\n  var all = nou ? [] : Object.create(null)\n\n  for (var i = 0, l = self.matches.length; i < l; i ++) {\n    var matches = self.matches[i]\n    if (!matches || Object.keys(matches).length === 0) {\n      if (self.nonull) {\n        // do like the shell, and spit out the literal glob\n        var literal = self.minimatch.globSet[i]\n        if (nou)\n          all.push(literal)\n        else\n          all[literal] = true\n      }\n    } else {\n      // had matches\n      var m = Object.keys(matches)\n      if (nou)\n        all.push.apply(all, m)\n      else\n        m.forEach(function (m) {\n          all[m] = true\n        })\n    }\n  }\n\n  if (!nou)\n    all = Object.keys(all)\n\n  if (!self.nosort)\n    all = all.sort(self.nocase ? alphasorti : alphasort)\n\n  // at *some* point we statted all of these\n  if (self.mark) {\n    for (var i = 0; i < all.length; i++) {\n      all[i] = self._mark(all[i])\n    }\n    if (self.nodir) {\n      all = all.filter(function (e) {\n        return !(/\\/$/.test(e))\n      })\n    }\n  }\n\n  if (self.ignore.length)\n    all = all.filter(function(m) {\n      return !isIgnored(self, m)\n    })\n\n  self.found = all\n}\n\nfunction mark (self, p) {\n  var abs = makeAbs(self, p)\n  var c = self.cache[abs]\n  var m = p\n  if (c) {\n    var isDir = c === 'DIR' || Array.isArray(c)\n    var slash = p.slice(-1) === '/'\n\n    if (isDir && !slash)\n      m += '/'\n    else if (!isDir && slash)\n      m = m.slice(0, -1)\n\n    if (m !== p) {\n      var mabs = makeAbs(self, m)\n      self.statCache[mabs] = self.statCache[abs]\n      self.cache[mabs] = self.cache[abs]\n    }\n  }\n\n  return m\n}\n\n// lotta situps...\nfunction makeAbs (self, f) {\n  var abs = f\n  if (f.charAt(0) === '/') {\n    abs = path.join(self.root, f)\n  } else if (isAbsolute(f) || f === '') {\n    abs = f\n  } else if (self.changedCwd) {\n    abs = path.resolve(self.cwd, f)\n  } else {\n    abs = path.resolve(f)\n  }\n  return abs\n}\n\n\n// Return true, if pattern ends with globstar '**', for the accompanying parent directory.\n// Ex:- If node_modules/** is the pattern, add 'node_modules' to ignore list along with it's contents\nfunction isIgnored (self, path) {\n  if (!self.ignore.length)\n    return false\n\n  return self.ignore.some(function(item) {\n    return item.matcher.match(path) || !!(item.gmatcher && item.gmatcher.match(path))\n  })\n}\n\nfunction childrenIgnored (self, path) {\n  if (!self.ignore.length)\n    return false\n\n  return self.ignore.some(function(item) {\n    return !!(item.gmatcher && item.gmatcher.match(path))\n  })\n}\n","// Approach:\n//\n// 1. Get the minimatch set\n// 2. For each pattern in the set, PROCESS(pattern, false)\n// 3. Store matches per-set, then uniq them\n//\n// PROCESS(pattern, inGlobStar)\n// Get the first [n] items from pattern that are all strings\n// Join these together.  This is PREFIX.\n//   If there is no more remaining, then stat(PREFIX) and\n//   add to matches if it succeeds.  END.\n//\n// If inGlobStar and PREFIX is symlink and points to dir\n//   set ENTRIES = []\n// else readdir(PREFIX) as ENTRIES\n//   If fail, END\n//\n// with ENTRIES\n//   If pattern[n] is GLOBSTAR\n//     // handle the case where the globstar match is empty\n//     // by pruning it out, and testing the resulting pattern\n//     PROCESS(pattern[0..n] + pattern[n+1 .. $], false)\n//     // handle other cases.\n//     for ENTRY in ENTRIES (not dotfiles)\n//       // attach globstar + tail onto the entry\n//       // Mark that this entry is a globstar match\n//       PROCESS(pattern[0..n] + ENTRY + pattern[n .. $], true)\n//\n//   else // not globstar\n//     for ENTRY in ENTRIES (not dotfiles, unless pattern[n] is dot)\n//       Test ENTRY against pattern[n]\n//       If fails, continue\n//       If passes, PROCESS(pattern[0..n] + item + pattern[n+1 .. $])\n//\n// Caveat:\n//   Cache all stats and readdirs results to minimize syscall.  Since all\n//   we ever care about is existence and directory-ness, we can just keep\n//   `true` for files, and [children,...] for directories, or `false` for\n//   things that don't exist.\n\nmodule.exports = glob\n\nvar fs = require('fs')\nvar minimatch = require('minimatch')\nvar Minimatch = minimatch.Minimatch\nvar inherits = require('inherits')\nvar EE = require('events').EventEmitter\nvar path = require('path')\nvar assert = require('assert')\nvar isAbsolute = require('path-is-absolute')\nvar globSync = require('./sync.js')\nvar common = require('./common.js')\nvar alphasort = common.alphasort\nvar alphasorti = common.alphasorti\nvar setopts = common.setopts\nvar ownProp = common.ownProp\nvar inflight = require('inflight')\nvar util = require('util')\nvar childrenIgnored = common.childrenIgnored\nvar isIgnored = common.isIgnored\n\nvar once = require('once')\n\nfunction glob (pattern, options, cb) {\n  if (typeof options === 'function') cb = options, options = {}\n  if (!options) options = {}\n\n  if (options.sync) {\n    if (cb)\n      throw new TypeError('callback provided to sync glob')\n    return globSync(pattern, options)\n  }\n\n  return new Glob(pattern, options, cb)\n}\n\nglob.sync = globSync\nvar GlobSync = glob.GlobSync = globSync.GlobSync\n\n// old api surface\nglob.glob = glob\n\nfunction extend (origin, add) {\n  if (add === null || typeof add !== 'object') {\n    return origin\n  }\n\n  var keys = Object.keys(add)\n  var i = keys.length\n  while (i--) {\n    origin[keys[i]] = add[keys[i]]\n  }\n  return origin\n}\n\nglob.hasMagic = function (pattern, options_) {\n  var options = extend({}, options_)\n  options.noprocess = true\n\n  var g = new Glob(pattern, options)\n  var set = g.minimatch.set\n  if (set.length > 1)\n    return true\n\n  for (var j = 0; j < set[0].length; j++) {\n    if (typeof set[0][j] !== 'string')\n      return true\n  }\n\n  return false\n}\n\nglob.Glob = Glob\ninherits(Glob, EE)\nfunction Glob (pattern, options, cb) {\n  if (typeof options === 'function') {\n    cb = options\n    options = null\n  }\n\n  if (options && options.sync) {\n    if (cb)\n      throw new TypeError('callback provided to sync glob')\n    return new GlobSync(pattern, options)\n  }\n\n  if (!(this instanceof Glob))\n    return new Glob(pattern, options, cb)\n\n  setopts(this, pattern, options)\n  this._didRealPath = false\n\n  // process each pattern in the minimatch set\n  var n = this.minimatch.set.length\n\n  // The matches are stored as {<filename>: true,...} so that\n  // duplicates are automagically pruned.\n  // Later, we do an Object.keys() on these.\n  // Keep them as a list so we can fill in when nonull is set.\n  this.matches = new Array(n)\n\n  if (typeof cb === 'function') {\n    cb = once(cb)\n    this.on('error', cb)\n    this.on('end', function (matches) {\n      cb(null, matches)\n    })\n  }\n\n  var self = this\n  var n = this.minimatch.set.length\n  this._processing = 0\n  this.matches = new Array(n)\n\n  this._emitQueue = []\n  this._processQueue = []\n  this.paused = false\n\n  if (this.noprocess)\n    return this\n\n  if (n === 0)\n    return done()\n\n  for (var i = 0; i < n; i ++) {\n    this._process(this.minimatch.set[i], i, false, done)\n  }\n\n  function done () {\n    --self._processing\n    if (self._processing <= 0)\n      self._finish()\n  }\n}\n\nGlob.prototype._finish = function () {\n  assert(this instanceof Glob)\n  if (this.aborted)\n    return\n\n  if (this.realpath && !this._didRealpath)\n    return this._realpath()\n\n  common.finish(this)\n  this.emit('end', this.found)\n}\n\nGlob.prototype._realpath = function () {\n  if (this._didRealpath)\n    return\n\n  this._didRealpath = true\n\n  var n = this.matches.length\n  if (n === 0)\n    return this._finish()\n\n  var self = this\n  for (var i = 0; i < this.matches.length; i++)\n    this._realpathSet(i, next)\n\n  function next () {\n    if (--n === 0)\n      self._finish()\n  }\n}\n\nGlob.prototype._realpathSet = function (index, cb) {\n  var matchset = this.matches[index]\n  if (!matchset)\n    return cb()\n\n  var found = Object.keys(matchset)\n  var self = this\n  var n = found.length\n\n  if (n === 0)\n    return cb()\n\n  var set = this.matches[index] = Object.create(null)\n  found.forEach(function (p, i) {\n    // If there's a problem with the stat, then it means that\n    // one or more of the links in the realpath couldn't be\n    // resolved.  just return the abs value in that case.\n    p = self._makeAbs(p)\n    fs.realpath(p, self.realpathCache, function (er, real) {\n      if (!er)\n        set[real] = true\n      else if (er.syscall === 'stat')\n        set[p] = true\n      else\n        self.emit('error', er) // srsly wtf right here\n\n      if (--n === 0) {\n        self.matches[index] = set\n        cb()\n      }\n    })\n  })\n}\n\nGlob.prototype._mark = function (p) {\n  return common.mark(this, p)\n}\n\nGlob.prototype._makeAbs = function (f) {\n  return common.makeAbs(this, f)\n}\n\nGlob.prototype.abort = function () {\n  this.aborted = true\n  this.emit('abort')\n}\n\nGlob.prototype.pause = function () {\n  if (!this.paused) {\n    this.paused = true\n    this.emit('pause')\n  }\n}\n\nGlob.prototype.resume = function () {\n  if (this.paused) {\n    this.emit('resume')\n    this.paused = false\n    if (this._emitQueue.length) {\n      var eq = this._emitQueue.slice(0)\n      this._emitQueue.length = 0\n      for (var i = 0; i < eq.length; i ++) {\n        var e = eq[i]\n        this._emitMatch(e[0], e[1])\n      }\n    }\n    if (this._processQueue.length) {\n      var pq = this._processQueue.slice(0)\n      this._processQueue.length = 0\n      for (var i = 0; i < pq.length; i ++) {\n        var p = pq[i]\n        this._processing--\n        this._process(p[0], p[1], p[2], p[3])\n      }\n    }\n  }\n}\n\nGlob.prototype._process = function (pattern, index, inGlobStar, cb) {\n  assert(this instanceof Glob)\n  assert(typeof cb === 'function')\n\n  if (this.aborted)\n    return\n\n  this._processing++\n  if (this.paused) {\n    this._processQueue.push([pattern, index, inGlobStar, cb])\n    return\n  }\n\n  //console.error('PROCESS %d', this._processing, pattern)\n\n  // Get the first [n] parts of pattern that are all strings.\n  var n = 0\n  while (typeof pattern[n] === 'string') {\n    n ++\n  }\n  // now n is the index of the first one that is *not* a string.\n\n  // see if there's anything else\n  var prefix\n  switch (n) {\n    // if not, then this is rather simple\n    case pattern.length:\n      this._processSimple(pattern.join('/'), index, cb)\n      return\n\n    case 0:\n      // pattern *starts* with some non-trivial item.\n      // going to readdir(cwd), but not include the prefix in matches.\n      prefix = null\n      break\n\n    default:\n      // pattern has some string bits in the front.\n      // whatever it starts with, whether that's 'absolute' like /foo/bar,\n      // or 'relative' like '../baz'\n      prefix = pattern.slice(0, n).join('/')\n      break\n  }\n\n  var remain = pattern.slice(n)\n\n  // get the list of entries.\n  var read\n  if (prefix === null)\n    read = '.'\n  else if (isAbsolute(prefix) || isAbsolute(pattern.join('/'))) {\n    if (!prefix || !isAbsolute(prefix))\n      prefix = '/' + prefix\n    read = prefix\n  } else\n    read = prefix\n\n  var abs = this._makeAbs(read)\n\n  //if ignored, skip _processing\n  if (childrenIgnored(this, read))\n    return cb()\n\n  var isGlobStar = remain[0] === minimatch.GLOBSTAR\n  if (isGlobStar)\n    this._processGlobStar(prefix, read, abs, remain, index, inGlobStar, cb)\n  else\n    this._processReaddir(prefix, read, abs, remain, index, inGlobStar, cb)\n}\n\nGlob.prototype._processReaddir = function (prefix, read, abs, remain, index, inGlobStar, cb) {\n  var self = this\n  this._readdir(abs, inGlobStar, function (er, entries) {\n    return self._processReaddir2(prefix, read, abs, remain, index, inGlobStar, entries, cb)\n  })\n}\n\nGlob.prototype._processReaddir2 = function (prefix, read, abs, remain, index, inGlobStar, entries, cb) {\n\n  // if the abs isn't a dir, then nothing can match!\n  if (!entries)\n    return cb()\n\n  // It will only match dot entries if it starts with a dot, or if\n  // dot is set.  Stuff like @(.foo|.bar) isn't allowed.\n  var pn = remain[0]\n  var negate = !!this.minimatch.negate\n  var rawGlob = pn._glob\n  var dotOk = this.dot || rawGlob.charAt(0) === '.'\n\n  var matchedEntries = []\n  for (var i = 0; i < entries.length; i++) {\n    var e = entries[i]\n    if (e.charAt(0) !== '.' || dotOk) {\n      var m\n      if (negate && !prefix) {\n        m = !e.match(pn)\n      } else {\n        m = e.match(pn)\n      }\n      if (m)\n        matchedEntries.push(e)\n    }\n  }\n\n  //console.error('prd2', prefix, entries, remain[0]._glob, matchedEntries)\n\n  var len = matchedEntries.length\n  // If there are no matched entries, then nothing matches.\n  if (len === 0)\n    return cb()\n\n  // if this is the last remaining pattern bit, then no need for\n  // an additional stat *unless* the user has specified mark or\n  // stat explicitly.  We know they exist, since readdir returned\n  // them.\n\n  if (remain.length === 1 && !this.mark && !this.stat) {\n    if (!this.matches[index])\n      this.matches[index] = Object.create(null)\n\n    for (var i = 0; i < len; i ++) {\n      var e = matchedEntries[i]\n      if (prefix) {\n        if (prefix !== '/')\n          e = prefix + '/' + e\n        else\n          e = prefix + e\n      }\n\n      if (e.charAt(0) === '/' && !this.nomount) {\n        e = path.join(this.root, e)\n      }\n      this._emitMatch(index, e)\n    }\n    // This was the last one, and no stats were needed\n    return cb()\n  }\n\n  // now test all matched entries as stand-ins for that part\n  // of the pattern.\n  remain.shift()\n  for (var i = 0; i < len; i ++) {\n    var e = matchedEntries[i]\n    var newPattern\n    if (prefix) {\n      if (prefix !== '/')\n        e = prefix + '/' + e\n      else\n        e = prefix + e\n    }\n    this._process([e].concat(remain), index, inGlobStar, cb)\n  }\n  cb()\n}\n\nGlob.prototype._emitMatch = function (index, e) {\n  if (this.aborted)\n    return\n\n  if (this.matches[index][e])\n    return\n\n  if (isIgnored(this, e))\n    return\n\n  if (this.paused) {\n    this._emitQueue.push([index, e])\n    return\n  }\n\n  var abs = this._makeAbs(e)\n\n  if (this.nodir) {\n    var c = this.cache[abs]\n    if (c === 'DIR' || Array.isArray(c))\n      return\n  }\n\n  if (this.mark)\n    e = this._mark(e)\n\n  this.matches[index][e] = true\n\n  var st = this.statCache[abs]\n  if (st)\n    this.emit('stat', e, st)\n\n  this.emit('match', e)\n}\n\nGlob.prototype._readdirInGlobStar = function (abs, cb) {\n  if (this.aborted)\n    return\n\n  // follow all symlinked directories forever\n  // just proceed as if this is a non-globstar situation\n  if (this.follow)\n    return this._readdir(abs, false, cb)\n\n  var lstatkey = 'lstat\\0' + abs\n  var self = this\n  var lstatcb = inflight(lstatkey, lstatcb_)\n\n  if (lstatcb)\n    fs.lstat(abs, lstatcb)\n\n  function lstatcb_ (er, lstat) {\n    if (er)\n      return cb()\n\n    var isSym = lstat.isSymbolicLink()\n    self.symlinks[abs] = isSym\n\n    // If it's not a symlink or a dir, then it's definitely a regular file.\n    // don't bother doing a readdir in that case.\n    if (!isSym && !lstat.isDirectory()) {\n      self.cache[abs] = 'FILE'\n      cb()\n    } else\n      self._readdir(abs, false, cb)\n  }\n}\n\nGlob.prototype._readdir = function (abs, inGlobStar, cb) {\n  if (this.aborted)\n    return\n\n  cb = inflight('readdir\\0'+abs+'\\0'+inGlobStar, cb)\n  if (!cb)\n    return\n\n  //console.error('RD %j %j', +inGlobStar, abs)\n  if (inGlobStar && !ownProp(this.symlinks, abs))\n    return this._readdirInGlobStar(abs, cb)\n\n  if (ownProp(this.cache, abs)) {\n    var c = this.cache[abs]\n    if (!c || c === 'FILE')\n      return cb()\n\n    if (Array.isArray(c))\n      return cb(null, c)\n  }\n\n  var self = this\n  fs.readdir(abs, readdirCb(this, abs, cb))\n}\n\nfunction readdirCb (self, abs, cb) {\n  return function (er, entries) {\n    if (er)\n      self._readdirError(abs, er, cb)\n    else\n      self._readdirEntries(abs, entries, cb)\n  }\n}\n\nGlob.prototype._readdirEntries = function (abs, entries, cb) {\n  if (this.aborted)\n    return\n\n  // if we haven't asked to stat everything, then just\n  // assume that everything in there exists, so we can avoid\n  // having to stat it a second time.\n  if (!this.mark && !this.stat) {\n    for (var i = 0; i < entries.length; i ++) {\n      var e = entries[i]\n      if (abs === '/')\n        e = abs + e\n      else\n        e = abs + '/' + e\n      this.cache[e] = true\n    }\n  }\n\n  this.cache[abs] = entries\n  return cb(null, entries)\n}\n\nGlob.prototype._readdirError = function (f, er, cb) {\n  if (this.aborted)\n    return\n\n  // handle errors, and cache the information\n  switch (er.code) {\n    case 'ENOTSUP': // https://github.com/isaacs/node-glob/issues/205\n    case 'ENOTDIR': // totally normal. means it *does* exist.\n      this.cache[this._makeAbs(f)] = 'FILE'\n      break\n\n    case 'ENOENT': // not terribly unusual\n    case 'ELOOP':\n    case 'ENAMETOOLONG':\n    case 'UNKNOWN':\n      this.cache[this._makeAbs(f)] = false\n      break\n\n    default: // some unusual error.  Treat as failure.\n      this.cache[this._makeAbs(f)] = false\n      if (this.strict) {\n        this.emit('error', er)\n        // If the error is handled, then we abort\n        // if not, we threw out of here\n        this.abort()\n      }\n      if (!this.silent)\n        console.error('glob error', er)\n      break\n  }\n\n  return cb()\n}\n\nGlob.prototype._processGlobStar = function (prefix, read, abs, remain, index, inGlobStar, cb) {\n  var self = this\n  this._readdir(abs, inGlobStar, function (er, entries) {\n    self._processGlobStar2(prefix, read, abs, remain, index, inGlobStar, entries, cb)\n  })\n}\n\n\nGlob.prototype._processGlobStar2 = function (prefix, read, abs, remain, index, inGlobStar, entries, cb) {\n  //console.error('pgs2', prefix, remain[0], entries)\n\n  // no entries means not a dir, so it can never have matches\n  // foo.txt/** doesn't match foo.txt\n  if (!entries)\n    return cb()\n\n  // test without the globstar, and with every child both below\n  // and replacing the globstar.\n  var remainWithoutGlobStar = remain.slice(1)\n  var gspref = prefix ? [ prefix ] : []\n  var noGlobStar = gspref.concat(remainWithoutGlobStar)\n\n  // the noGlobStar pattern exits the inGlobStar state\n  this._process(noGlobStar, index, false, cb)\n\n  var isSym = this.symlinks[abs]\n  var len = entries.length\n\n  // If it's a symlink, and we're in a globstar, then stop\n  if (isSym && inGlobStar)\n    return cb()\n\n  for (var i = 0; i < len; i++) {\n    var e = entries[i]\n    if (e.charAt(0) === '.' && !this.dot)\n      continue\n\n    // these two cases enter the inGlobStar state\n    var instead = gspref.concat(entries[i], remainWithoutGlobStar)\n    this._process(instead, index, true, cb)\n\n    var below = gspref.concat(entries[i], remain)\n    this._process(below, index, true, cb)\n  }\n\n  cb()\n}\n\nGlob.prototype._processSimple = function (prefix, index, cb) {\n  // XXX review this.  Shouldn't it be doing the mounting etc\n  // before doing stat?  kinda weird?\n  var self = this\n  this._stat(prefix, function (er, exists) {\n    self._processSimple2(prefix, index, er, exists, cb)\n  })\n}\nGlob.prototype._processSimple2 = function (prefix, index, er, exists, cb) {\n\n  //console.error('ps2', prefix, exists)\n\n  if (!this.matches[index])\n    this.matches[index] = Object.create(null)\n\n  // If it doesn't exist, then just mark the lack of results\n  if (!exists)\n    return cb()\n\n  if (prefix && isAbsolute(prefix) && !this.nomount) {\n    var trail = /[\\/\\\\]$/.test(prefix)\n    if (prefix.charAt(0) === '/') {\n      prefix = path.join(this.root, prefix)\n    } else {\n      prefix = path.resolve(this.root, prefix)\n      if (trail)\n        prefix += '/'\n    }\n  }\n\n  if (process.platform === 'win32')\n    prefix = prefix.replace(/\\\\/g, '/')\n\n  // Mark this as a match\n  this._emitMatch(index, prefix)\n  cb()\n}\n\n// Returns either 'DIR', 'FILE', or false\nGlob.prototype._stat = function (f, cb) {\n  var abs = this._makeAbs(f)\n  var needDir = f.slice(-1) === '/'\n\n  if (f.length > this.maxLength)\n    return cb()\n\n  if (!this.stat && ownProp(this.cache, abs)) {\n    var c = this.cache[abs]\n\n    if (Array.isArray(c))\n      c = 'DIR'\n\n    // It exists, but maybe not how we need it\n    if (!needDir || c === 'DIR')\n      return cb(null, c)\n\n    if (needDir && c === 'FILE')\n      return cb()\n\n    // otherwise we have to stat, because maybe c=true\n    // if we know it exists, but not what it is.\n  }\n\n  var exists\n  var stat = this.statCache[abs]\n  if (stat !== undefined) {\n    if (stat === false)\n      return cb(null, stat)\n    else {\n      var type = stat.isDirectory() ? 'DIR' : 'FILE'\n      if (needDir && type === 'FILE')\n        return cb()\n      else\n        return cb(null, type, stat)\n    }\n  }\n\n  var self = this\n  var statcb = inflight('stat\\0' + abs, lstatcb_)\n  if (statcb)\n    fs.lstat(abs, statcb)\n\n  function lstatcb_ (er, lstat) {\n    if (lstat && lstat.isSymbolicLink()) {\n      // If it's a symlink, then treat it as the target, unless\n      // the target does not exist, then treat it as a file.\n      return fs.stat(abs, function (er, stat) {\n        if (er)\n          self._stat2(f, abs, null, lstat, cb)\n        else\n          self._stat2(f, abs, er, stat, cb)\n      })\n    } else {\n      self._stat2(f, abs, er, lstat, cb)\n    }\n  }\n}\n\nGlob.prototype._stat2 = function (f, abs, er, stat, cb) {\n  if (er) {\n    this.statCache[abs] = false\n    return cb()\n  }\n\n  var needDir = f.slice(-1) === '/'\n  this.statCache[abs] = stat\n\n  if (abs.slice(-1) === '/' && !stat.isDirectory())\n    return cb(null, false, stat)\n\n  var c = stat.isDirectory() ? 'DIR' : 'FILE'\n  this.cache[abs] = this.cache[abs] || c\n\n  if (needDir && c !== 'DIR')\n    return cb()\n\n  return cb(null, c, stat)\n}\n","module.exports = globSync\nglobSync.GlobSync = GlobSync\n\nvar fs = require('fs')\nvar minimatch = require('minimatch')\nvar Minimatch = minimatch.Minimatch\nvar Glob = require('./glob.js').Glob\nvar util = require('util')\nvar path = require('path')\nvar assert = require('assert')\nvar isAbsolute = require('path-is-absolute')\nvar common = require('./common.js')\nvar alphasort = common.alphasort\nvar alphasorti = common.alphasorti\nvar setopts = common.setopts\nvar ownProp = common.ownProp\nvar childrenIgnored = common.childrenIgnored\n\nfunction globSync (pattern, options) {\n  if (typeof options === 'function' || arguments.length === 3)\n    throw new TypeError('callback provided to sync glob\\n'+\n                        'See: https://github.com/isaacs/node-glob/issues/167')\n\n  return new GlobSync(pattern, options).found\n}\n\nfunction GlobSync (pattern, options) {\n  if (!pattern)\n    throw new Error('must provide pattern')\n\n  if (typeof options === 'function' || arguments.length === 3)\n    throw new TypeError('callback provided to sync glob\\n'+\n                        'See: https://github.com/isaacs/node-glob/issues/167')\n\n  if (!(this instanceof GlobSync))\n    return new GlobSync(pattern, options)\n\n  setopts(this, pattern, options)\n\n  if (this.noprocess)\n    return this\n\n  var n = this.minimatch.set.length\n  this.matches = new Array(n)\n  for (var i = 0; i < n; i ++) {\n    this._process(this.minimatch.set[i], i, false)\n  }\n  this._finish()\n}\n\nGlobSync.prototype._finish = function () {\n  assert(this instanceof GlobSync)\n  if (this.realpath) {\n    var self = this\n    this.matches.forEach(function (matchset, index) {\n      var set = self.matches[index] = Object.create(null)\n      for (var p in matchset) {\n        try {\n          p = self._makeAbs(p)\n          var real = fs.realpathSync(p, self.realpathCache)\n          set[real] = true\n        } catch (er) {\n          if (er.syscall === 'stat')\n            set[self._makeAbs(p)] = true\n          else\n            throw er\n        }\n      }\n    })\n  }\n  common.finish(this)\n}\n\n\nGlobSync.prototype._process = function (pattern, index, inGlobStar) {\n  assert(this instanceof GlobSync)\n\n  // Get the first [n] parts of pattern that are all strings.\n  var n = 0\n  while (typeof pattern[n] === 'string') {\n    n ++\n  }\n  // now n is the index of the first one that is *not* a string.\n\n  // See if there's anything else\n  var prefix\n  switch (n) {\n    // if not, then this is rather simple\n    case pattern.length:\n      this._processSimple(pattern.join('/'), index)\n      return\n\n    case 0:\n      // pattern *starts* with some non-trivial item.\n      // going to readdir(cwd), but not include the prefix in matches.\n      prefix = null\n      break\n\n    default:\n      // pattern has some string bits in the front.\n      // whatever it starts with, whether that's 'absolute' like /foo/bar,\n      // or 'relative' like '../baz'\n      prefix = pattern.slice(0, n).join('/')\n      break\n  }\n\n  var remain = pattern.slice(n)\n\n  // get the list of entries.\n  var read\n  if (prefix === null)\n    read = '.'\n  else if (isAbsolute(prefix) || isAbsolute(pattern.join('/'))) {\n    if (!prefix || !isAbsolute(prefix))\n      prefix = '/' + prefix\n    read = prefix\n  } else\n    read = prefix\n\n  var abs = this._makeAbs(read)\n\n  //if ignored, skip processing\n  if (childrenIgnored(this, read))\n    return\n\n  var isGlobStar = remain[0] === minimatch.GLOBSTAR\n  if (isGlobStar)\n    this._processGlobStar(prefix, read, abs, remain, index, inGlobStar)\n  else\n    this._processReaddir(prefix, read, abs, remain, index, inGlobStar)\n}\n\n\nGlobSync.prototype._processReaddir = function (prefix, read, abs, remain, index, inGlobStar) {\n  var entries = this._readdir(abs, inGlobStar)\n\n  // if the abs isn't a dir, then nothing can match!\n  if (!entries)\n    return\n\n  // It will only match dot entries if it starts with a dot, or if\n  // dot is set.  Stuff like @(.foo|.bar) isn't allowed.\n  var pn = remain[0]\n  var negate = !!this.minimatch.negate\n  var rawGlob = pn._glob\n  var dotOk = this.dot || rawGlob.charAt(0) === '.'\n\n  var matchedEntries = []\n  for (var i = 0; i < entries.length; i++) {\n    var e = entries[i]\n    if (e.charAt(0) !== '.' || dotOk) {\n      var m\n      if (negate && !prefix) {\n        m = !e.match(pn)\n      } else {\n        m = e.match(pn)\n      }\n      if (m)\n        matchedEntries.push(e)\n    }\n  }\n\n  var len = matchedEntries.length\n  // If there are no matched entries, then nothing matches.\n  if (len === 0)\n    return\n\n  // if this is the last remaining pattern bit, then no need for\n  // an additional stat *unless* the user has specified mark or\n  // stat explicitly.  We know they exist, since readdir returned\n  // them.\n\n  if (remain.length === 1 && !this.mark && !this.stat) {\n    if (!this.matches[index])\n      this.matches[index] = Object.create(null)\n\n    for (var i = 0; i < len; i ++) {\n      var e = matchedEntries[i]\n      if (prefix) {\n        if (prefix.slice(-1) !== '/')\n          e = prefix + '/' + e\n        else\n          e = prefix + e\n      }\n\n      if (e.charAt(0) === '/' && !this.nomount) {\n        e = path.join(this.root, e)\n      }\n      this.matches[index][e] = true\n    }\n    // This was the last one, and no stats were needed\n    return\n  }\n\n  // now test all matched entries as stand-ins for that part\n  // of the pattern.\n  remain.shift()\n  for (var i = 0; i < len; i ++) {\n    var e = matchedEntries[i]\n    var newPattern\n    if (prefix)\n      newPattern = [prefix, e]\n    else\n      newPattern = [e]\n    this._process(newPattern.concat(remain), index, inGlobStar)\n  }\n}\n\n\nGlobSync.prototype._emitMatch = function (index, e) {\n  var abs = this._makeAbs(e)\n  if (this.mark)\n    e = this._mark(e)\n\n  if (this.matches[index][e])\n    return\n\n  if (this.nodir) {\n    var c = this.cache[this._makeAbs(e)]\n    if (c === 'DIR' || Array.isArray(c))\n      return\n  }\n\n  this.matches[index][e] = true\n  if (this.stat)\n    this._stat(e)\n}\n\n\nGlobSync.prototype._readdirInGlobStar = function (abs) {\n  // follow all symlinked directories forever\n  // just proceed as if this is a non-globstar situation\n  if (this.follow)\n    return this._readdir(abs, false)\n\n  var entries\n  var lstat\n  var stat\n  try {\n    lstat = fs.lstatSync(abs)\n  } catch (er) {\n    // lstat failed, doesn't exist\n    return null\n  }\n\n  var isSym = lstat.isSymbolicLink()\n  this.symlinks[abs] = isSym\n\n  // If it's not a symlink or a dir, then it's definitely a regular file.\n  // don't bother doing a readdir in that case.\n  if (!isSym && !lstat.isDirectory())\n    this.cache[abs] = 'FILE'\n  else\n    entries = this._readdir(abs, false)\n\n  return entries\n}\n\nGlobSync.prototype._readdir = function (abs, inGlobStar) {\n  var entries\n\n  if (inGlobStar && !ownProp(this.symlinks, abs))\n    return this._readdirInGlobStar(abs)\n\n  if (ownProp(this.cache, abs)) {\n    var c = this.cache[abs]\n    if (!c || c === 'FILE')\n      return null\n\n    if (Array.isArray(c))\n      return c\n  }\n\n  try {\n    return this._readdirEntries(abs, fs.readdirSync(abs))\n  } catch (er) {\n    this._readdirError(abs, er)\n    return null\n  }\n}\n\nGlobSync.prototype._readdirEntries = function (abs, entries) {\n  // if we haven't asked to stat everything, then just\n  // assume that everything in there exists, so we can avoid\n  // having to stat it a second time.\n  if (!this.mark && !this.stat) {\n    for (var i = 0; i < entries.length; i ++) {\n      var e = entries[i]\n      if (abs === '/')\n        e = abs + e\n      else\n        e = abs + '/' + e\n      this.cache[e] = true\n    }\n  }\n\n  this.cache[abs] = entries\n\n  // mark and cache dir-ness\n  return entries\n}\n\nGlobSync.prototype._readdirError = function (f, er) {\n  // handle errors, and cache the information\n  switch (er.code) {\n    case 'ENOTSUP': // https://github.com/isaacs/node-glob/issues/205\n    case 'ENOTDIR': // totally normal. means it *does* exist.\n      this.cache[this._makeAbs(f)] = 'FILE'\n      break\n\n    case 'ENOENT': // not terribly unusual\n    case 'ELOOP':\n    case 'ENAMETOOLONG':\n    case 'UNKNOWN':\n      this.cache[this._makeAbs(f)] = false\n      break\n\n    default: // some unusual error.  Treat as failure.\n      this.cache[this._makeAbs(f)] = false\n      if (this.strict)\n        throw er\n      if (!this.silent)\n        console.error('glob error', er)\n      break\n  }\n}\n\nGlobSync.prototype._processGlobStar = function (prefix, read, abs, remain, index, inGlobStar) {\n\n  var entries = this._readdir(abs, inGlobStar)\n\n  // no entries means not a dir, so it can never have matches\n  // foo.txt/** doesn't match foo.txt\n  if (!entries)\n    return\n\n  // test without the globstar, and with every child both below\n  // and replacing the globstar.\n  var remainWithoutGlobStar = remain.slice(1)\n  var gspref = prefix ? [ prefix ] : []\n  var noGlobStar = gspref.concat(remainWithoutGlobStar)\n\n  // the noGlobStar pattern exits the inGlobStar state\n  this._process(noGlobStar, index, false)\n\n  var len = entries.length\n  var isSym = this.symlinks[abs]\n\n  // If it's a symlink, and we're in a globstar, then stop\n  if (isSym && inGlobStar)\n    return\n\n  for (var i = 0; i < len; i++) {\n    var e = entries[i]\n    if (e.charAt(0) === '.' && !this.dot)\n      continue\n\n    // these two cases enter the inGlobStar state\n    var instead = gspref.concat(entries[i], remainWithoutGlobStar)\n    this._process(instead, index, true)\n\n    var below = gspref.concat(entries[i], remain)\n    this._process(below, index, true)\n  }\n}\n\nGlobSync.prototype._processSimple = function (prefix, index) {\n  // XXX review this.  Shouldn't it be doing the mounting etc\n  // before doing stat?  kinda weird?\n  var exists = this._stat(prefix)\n\n  if (!this.matches[index])\n    this.matches[index] = Object.create(null)\n\n  // If it doesn't exist, then just mark the lack of results\n  if (!exists)\n    return\n\n  if (prefix && isAbsolute(prefix) && !this.nomount) {\n    var trail = /[\\/\\\\]$/.test(prefix)\n    if (prefix.charAt(0) === '/') {\n      prefix = path.join(this.root, prefix)\n    } else {\n      prefix = path.resolve(this.root, prefix)\n      if (trail)\n        prefix += '/'\n    }\n  }\n\n  if (process.platform === 'win32')\n    prefix = prefix.replace(/\\\\/g, '/')\n\n  // Mark this as a match\n  this.matches[index][prefix] = true\n}\n\n// Returns either 'DIR', 'FILE', or false\nGlobSync.prototype._stat = function (f) {\n  var abs = this._makeAbs(f)\n  var needDir = f.slice(-1) === '/'\n\n  if (f.length > this.maxLength)\n    return false\n\n  if (!this.stat && ownProp(this.cache, abs)) {\n    var c = this.cache[abs]\n\n    if (Array.isArray(c))\n      c = 'DIR'\n\n    // It exists, but maybe not how we need it\n    if (!needDir || c === 'DIR')\n      return c\n\n    if (needDir && c === 'FILE')\n      return false\n\n    // otherwise we have to stat, because maybe c=true\n    // if we know it exists, but not what it is.\n  }\n\n  var exists\n  var stat = this.statCache[abs]\n  if (!stat) {\n    var lstat\n    try {\n      lstat = fs.lstatSync(abs)\n    } catch (er) {\n      return false\n    }\n\n    if (lstat.isSymbolicLink()) {\n      try {\n        stat = fs.statSync(abs)\n      } catch (er) {\n        stat = lstat\n      }\n    } else {\n      stat = lstat\n    }\n  }\n\n  this.statCache[abs] = stat\n\n  var c = stat.isDirectory() ? 'DIR' : 'FILE'\n  this.cache[abs] = this.cache[abs] || c\n\n  if (needDir && c !== 'DIR')\n    return false\n\n  return c\n}\n\nGlobSync.prototype._mark = function (p) {\n  return common.mark(this, p)\n}\n\nGlobSync.prototype._makeAbs = function (f) {\n  return common.makeAbs(this, f)\n}\n","'use strict';\n//\n// Algorithms\n//\n\n// probably move these to another file when there get to be lots of them.\n\nfunction count(obj) {\n  var c = 0\n  for(var k in obj) c++\n  return c\n}\n\nfunction widthTraverse (graph, reachable, start, depth, hops, max, iter) {\n  if(!start)\n    throw new Error('Graphmitter#traverse: start must be provided')\n\n  var nodes = 1\n\n  reachable[start] = reachable[start] == null ? 0 : reachable[start]\n\n  var queue = [{key: start, hops: depth}]\n  iter = iter || function () {}\n  var abort = false\n  while(queue.length && (!max || nodes < max) && !abort) {\n    var o = queue.shift()\n    var h = o.hops\n    var n = graph.nodes[o.key]\n    if(n && (!hops || (h + 1 <= hops)))\n      for(var k in n.edges) {\n        // If we have already been to this node by a shorter path,\n        // then skip this node (this only happens when processing\n        // a realtime edge)\n        if(!(reachable[k] != null && reachable[k] < h + 1)) {\n          if(false === iter(o.key, k, h + 1, reachable[k]))\n            return reachable\n\n          reachable[k] = h + 1\n          nodes ++\n          queue.push({key: k, hops: h + 1})\n        }\n    }\n  }\n\n  return reachable\n}\n\nexports.traverse = function (opts, onEach) {\n  var self = this\n  var maxHops = opts.hops || 3\n  var maxNodes = opts.max || 150\n  var reachable = {}\n  opts.each = onEach = onEach || opts.each\n\n  widthTraverse(\n    this, reachable,\n    opts.start,\n    0,             //initial hops\n    opts.hops,     //max hops\n    opts.max,      //max nodes\n    opts.old !== false && onEach\n  )\n\n  if(!onEach || opts.live === false) return reachable\n\n  function onEdge (from, to) {\n    //if this edge is part of the initial setd\n    if(reachable[from] != null && reachable[from] < maxHops) {\n      //edges to new nodes.\n      var h = reachable[from] + 1\n      var _h = reachable[to]\n      if(_h == null)\n        onEach(from, to, reachable[to] = h, _h)\n      else if(Math.min(h, _h) != _h)\n        onEach(from, to, reachable[to] = Math.min(h, _h), _h)\n\n      if(h <= maxHops && h != _h) {\n        //also add other nodes that are now reachable.\n        widthTraverse(self, reachable, to, h, maxHops, maxNodes, onEach)\n\n      }\n    }\n  }\n\n  this.on('edge', onEdge)\n\n  return function () {\n    self.removeListener('edge', onEdge)\n  }\n}\n\n// page rank. I adapted the algorithm to use\n// forward links instead of backward links which means\n// we only have to traverse the graph one time.\n\nexports.rank = function (opts) {\n  opts = opts || {}\n\n  var ranks = {}, links = {}, _ranks = {}\n  var N = count(this.nodes)\n  var iterations = opts.iterations || 1\n  var damping = opts.damping || 0.85\n  var init = (1 - damping) / N\n\n  //initialize\n  this.each(function (k, n) {\n    ranks[k] = 1/N; _ranks[k] = init\n    links[k] = count(n.edges)\n  })\n\n  while(iterations --> 0) {\n\n    //iteration\n    this.each(function (j, n) {\n      var r = damping*(ranks[j]/links[j])\n      n.each(function (k) { _ranks[k] += r })\n    })\n\n    //reset\n    for(var k in ranks)\n      ranks[k] = init\n\n    var __ranks = ranks\n    ranks = _ranks\n    _ranks = __ranks\n  }\n  return ranks\n}\n\n//find the shortest path between two nodes.\n//if there was no path within max hops, return null.\n\n//convert a spanning tree to an array.\nfunction toArray (span, root) {\n  if(!span[root]) return null\n  var a = [root]\n  while(span[root])\n    a.push(root = span[root])\n  return a.reverse()\n}\n\nexports.path = function (opts) {\n  var reverse = {}\n  if(opts.source == opts.dest)\n    return [opts.source]\n\n  opts.start = opts.source\n  opts.live = false\n  opts.each = function (f, t, h) {\n    reverse[t] = f\n  }\n\n  this.traverse(opts)\n  return toArray(reverse, opts.dest)\n}\n\n\n","\n\nvar EventEmitter = require('events').EventEmitter\n\nvar inherits = require('util').inherits\n\ninherits(Graphmitter, EventEmitter)\n\nmodule.exports = Graphmitter\n\nfunction each(obj, iter) {\n  for(var k in obj) iter(k, obj[k])\n}\n\n//\n// Node / Vertice\n//\n\nfunction Node () {\n  this.edges = {}\n}\n\nvar nproto = Node.prototype\n\n//returns the old data for this edge..\nnproto.edge = function (to, data) {\n  var _data = this.edges[to]\n  this.edges[to] = (data == null ? true : data)\n  return _data\n}\n\nnproto.has = function (to) {\n  return this.edges[to]\n}\n\n//also returns the old data for this edge..\nnproto.del = function (to, data) {\n  var _data = this.edges[to]\n  delete this.edges[to]\n  return _data\n}\n\nnproto.each = function (iter) {\n  each(this.edges, iter)\n  return this\n}\n\n//\n// the whole graph\n//\n\nfunction Graphmitter () {\n  if(!(this instanceof Graphmitter)) return new Graphmitter()\n  this.nodes = {}\n}\n\nvar proto = Graphmitter.prototype\n\nproto.hasNode = function (n) {\n  return !!this.nodes[n]\n}\n\nproto.hasEdge = function (f, t) {\n  return this.hasNode(f) && !!this.nodes[f].edges[t] != null\n}\n\nproto.node = function (n) {\n  return this.nodes[n] = this.nodes[n] || new Node(n)\n}\n\nproto.get = function (f, t) {\n  if(t == null) return this.nodes[f]\n  return this.hasNode(f) ? this.nodes[f].edges[t] : null\n}\n\nproto.edge = function (from, to, data) {\n  data = (data == null ? true : data)\n  var f = this.node(from)\n  this.node(to)\n  var _data = f.edge(to, data)\n\n  if(_data !== data)\n    this.emit('edge', from, to, data, _data)\n  return this\n}\n\nproto.del = function (from, to) {\n  var data = this.node(from).del(to)\n  if (typeof data !== 'undefined')\n    this.emit('del', from, to, data)\n  return this\n}\n\nproto.each = function (iter) {\n  each(this.nodes, iter)\n  return this\n}\n\nproto.eachEdge = function (iter) {\n  each(this.nodes, function (from, n) {\n    each(n.edges, function (to, data) {\n      iter(from, to, data)\n    })\n  })\n  return this\n}\n\n//get a random node\nproto.random = function () {\n  var keys = Object.keys(this.nodes)\n  return keys[~~(keys.length*Math.random())]\n}\n\n//add another subgraph\nproto.add = function (g2) {\n  var g1 = this\n  g2.eachEdge(function (from, to, data) {\n    g1.edge(from, to, data)\n  })\n  return this\n}\n\nproto.toJSON = function (iter) {\n  var g = {}\n  this.each(function (k, v) {\n    var e = {}\n    v.each(function (k, v) {\n      e[k] = v\n    })\n    g[k] = e\n  })\n  return g\n}\n\n//\n// graph generators\n//\n\nGraphmitter.random = function (nodes, edges, prefix) {\n  prefix = prefix || '#'\n  if(isNaN(+nodes)) throw new Error('nodes must be a number')\n  if(isNaN(+edges)) throw new Error('edges must be a number')\n\n  var n = 0, g = new Graphmitter()\n\n  function rand(n) {\n    return prefix+~~(Math.random()*n)\n  }\n\n  for(var i = 0; i < nodes; i++)\n    g.node(prefix+i)\n\n  for(var i = 0; i < edges; i++) {\n    var a = rand(nodes), b = rand(nodes)\n    g.edge(a, b).edge(b, a)\n  }\n\n  return g\n}\n\n\nvar algorithms = require('./algorithms')\n\nfor(var k in algorithms) proto[k] = algorithms[k]\n\n","var hash = exports;\n\nhash.utils = require('./hash/utils');\nhash.common = require('./hash/common');\nhash.sha = require('./hash/sha');\nhash.ripemd = require('./hash/ripemd');\nhash.hmac = require('./hash/hmac');\n\n// Proxy hash functions to the main object\nhash.sha1 = hash.sha.sha1;\nhash.sha256 = hash.sha.sha256;\nhash.sha224 = hash.sha.sha224;\nhash.sha384 = hash.sha.sha384;\nhash.sha512 = hash.sha.sha512;\nhash.ripemd160 = hash.ripemd.ripemd160;\n","var hash = require('../hash');\nvar utils = hash.utils;\nvar assert = utils.assert;\n\nfunction BlockHash() {\n  this.pending = null;\n  this.pendingTotal = 0;\n  this.blockSize = this.constructor.blockSize;\n  this.outSize = this.constructor.outSize;\n  this.hmacStrength = this.constructor.hmacStrength;\n  this.padLength = this.constructor.padLength / 8;\n  this.endian = 'big';\n\n  this._delta8 = this.blockSize / 8;\n  this._delta32 = this.blockSize / 32;\n}\nexports.BlockHash = BlockHash;\n\nBlockHash.prototype.update = function update(msg, enc) {\n  // Convert message to array, pad it, and join into 32bit blocks\n  msg = utils.toArray(msg, enc);\n  if (!this.pending)\n    this.pending = msg;\n  else\n    this.pending = this.pending.concat(msg);\n  this.pendingTotal += msg.length;\n\n  // Enough data, try updating\n  if (this.pending.length >= this._delta8) {\n    msg = this.pending;\n\n    // Process pending data in blocks\n    var r = msg.length % this._delta8;\n    this.pending = msg.slice(msg.length - r, msg.length);\n    if (this.pending.length === 0)\n      this.pending = null;\n\n    msg = utils.join32(msg, 0, msg.length - r, this.endian);\n    for (var i = 0; i < msg.length; i += this._delta32)\n      this._update(msg, i, i + this._delta32);\n  }\n\n  return this;\n};\n\nBlockHash.prototype.digest = function digest(enc) {\n  this.update(this._pad());\n  assert(this.pending === null);\n\n  return this._digest(enc);\n};\n\nBlockHash.prototype._pad = function pad() {\n  var len = this.pendingTotal;\n  var bytes = this._delta8;\n  var k = bytes - ((len + this.padLength) % bytes);\n  var res = new Array(k + this.padLength);\n  res[0] = 0x80;\n  for (var i = 1; i < k; i++)\n    res[i] = 0;\n\n  // Append length\n  len <<= 3;\n  if (this.endian === 'big') {\n    for (var t = 8; t < this.padLength; t++)\n      res[i++] = 0;\n\n    res[i++] = 0;\n    res[i++] = 0;\n    res[i++] = 0;\n    res[i++] = 0;\n    res[i++] = (len >>> 24) & 0xff;\n    res[i++] = (len >>> 16) & 0xff;\n    res[i++] = (len >>> 8) & 0xff;\n    res[i++] = len & 0xff;\n  } else {\n    res[i++] = len & 0xff;\n    res[i++] = (len >>> 8) & 0xff;\n    res[i++] = (len >>> 16) & 0xff;\n    res[i++] = (len >>> 24) & 0xff;\n    res[i++] = 0;\n    res[i++] = 0;\n    res[i++] = 0;\n    res[i++] = 0;\n\n    for (var t = 8; t < this.padLength; t++)\n      res[i++] = 0;\n  }\n\n  return res;\n};\n","var hmac = exports;\n\nvar hash = require('../hash');\nvar utils = hash.utils;\nvar assert = utils.assert;\n\nfunction Hmac(hash, key, enc) {\n  if (!(this instanceof Hmac))\n    return new Hmac(hash, key, enc);\n  this.Hash = hash;\n  this.blockSize = hash.blockSize / 8;\n  this.outSize = hash.outSize / 8;\n  this.inner = null;\n  this.outer = null;\n\n  this._init(utils.toArray(key, enc));\n}\nmodule.exports = Hmac;\n\nHmac.prototype._init = function init(key) {\n  // Shorten key, if needed\n  if (key.length > this.blockSize)\n    key = new this.Hash().update(key).digest();\n  assert(key.length <= this.blockSize);\n\n  // Add padding to key\n  for (var i = key.length; i < this.blockSize; i++)\n    key.push(0);\n\n  for (var i = 0; i < key.length; i++)\n    key[i] ^= 0x36;\n  this.inner = new this.Hash().update(key);\n\n  // 0x36 ^ 0x5c = 0x6a\n  for (var i = 0; i < key.length; i++)\n    key[i] ^= 0x6a;\n  this.outer = new this.Hash().update(key);\n};\n\nHmac.prototype.update = function update(msg, enc) {\n  this.inner.update(msg, enc);\n  return this;\n};\n\nHmac.prototype.digest = function digest(enc) {\n  this.outer.update(this.inner.digest());\n  return this.outer.digest(enc);\n};\n","var hash = require('../hash');\nvar utils = hash.utils;\n\nvar rotl32 = utils.rotl32;\nvar sum32 = utils.sum32;\nvar sum32_3 = utils.sum32_3;\nvar sum32_4 = utils.sum32_4;\nvar BlockHash = hash.common.BlockHash;\n\nfunction RIPEMD160() {\n  if (!(this instanceof RIPEMD160))\n    return new RIPEMD160();\n\n  BlockHash.call(this);\n\n  this.h = [ 0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476, 0xc3d2e1f0 ];\n  this.endian = 'little';\n}\nutils.inherits(RIPEMD160, BlockHash);\nexports.ripemd160 = RIPEMD160;\n\nRIPEMD160.blockSize = 512;\nRIPEMD160.outSize = 160;\nRIPEMD160.hmacStrength = 192;\nRIPEMD160.padLength = 64;\n\nRIPEMD160.prototype._update = function update(msg, start) {\n  var A = this.h[0];\n  var B = this.h[1];\n  var C = this.h[2];\n  var D = this.h[3];\n  var E = this.h[4];\n  var Ah = A;\n  var Bh = B;\n  var Ch = C;\n  var Dh = D;\n  var Eh = E;\n  for (var j = 0; j < 80; j++) {\n    var T = sum32(\n      rotl32(\n        sum32_4(A, f(j, B, C, D), msg[r[j] + start], K(j)),\n        s[j]),\n      E);\n    A = E;\n    E = D;\n    D = rotl32(C, 10);\n    C = B;\n    B = T;\n    T = sum32(\n      rotl32(\n        sum32_4(Ah, f(79 - j, Bh, Ch, Dh), msg[rh[j] + start], Kh(j)),\n        sh[j]),\n      Eh);\n    Ah = Eh;\n    Eh = Dh;\n    Dh = rotl32(Ch, 10);\n    Ch = Bh;\n    Bh = T;\n  }\n  T = sum32_3(this.h[1], C, Dh);\n  this.h[1] = sum32_3(this.h[2], D, Eh);\n  this.h[2] = sum32_3(this.h[3], E, Ah);\n  this.h[3] = sum32_3(this.h[4], A, Bh);\n  this.h[4] = sum32_3(this.h[0], B, Ch);\n  this.h[0] = T;\n};\n\nRIPEMD160.prototype._digest = function digest(enc) {\n  if (enc === 'hex')\n    return utils.toHex32(this.h, 'little');\n  else\n    return utils.split32(this.h, 'little');\n};\n\nfunction f(j, x, y, z) {\n  if (j <= 15)\n    return x ^ y ^ z;\n  else if (j <= 31)\n    return (x & y) | ((~x) & z);\n  else if (j <= 47)\n    return (x | (~y)) ^ z;\n  else if (j <= 63)\n    return (x & z) | (y & (~z));\n  else\n    return x ^ (y | (~z));\n}\n\nfunction K(j) {\n  if (j <= 15)\n    return 0x00000000;\n  else if (j <= 31)\n    return 0x5a827999;\n  else if (j <= 47)\n    return 0x6ed9eba1;\n  else if (j <= 63)\n    return 0x8f1bbcdc;\n  else\n    return 0xa953fd4e;\n}\n\nfunction Kh(j) {\n  if (j <= 15)\n    return 0x50a28be6;\n  else if (j <= 31)\n    return 0x5c4dd124;\n  else if (j <= 47)\n    return 0x6d703ef3;\n  else if (j <= 63)\n    return 0x7a6d76e9;\n  else\n    return 0x00000000;\n}\n\nvar r = [\n  0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,\n  7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8,\n  3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12,\n  1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2,\n  4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13\n];\n\nvar rh = [\n  5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12,\n  6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2,\n  15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13,\n  8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14,\n  12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11\n];\n\nvar s = [\n  11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8,\n  7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12,\n  11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5,\n  11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12,\n  9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6\n];\n\nvar sh = [\n  8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6,\n  9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11,\n  9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5,\n  15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8,\n  8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11\n];\n","var hash = require('../hash');\nvar utils = hash.utils;\nvar assert = utils.assert;\n\nvar rotr32 = utils.rotr32;\nvar rotl32 = utils.rotl32;\nvar sum32 = utils.sum32;\nvar sum32_4 = utils.sum32_4;\nvar sum32_5 = utils.sum32_5;\nvar rotr64_hi = utils.rotr64_hi;\nvar rotr64_lo = utils.rotr64_lo;\nvar shr64_hi = utils.shr64_hi;\nvar shr64_lo = utils.shr64_lo;\nvar sum64 = utils.sum64;\nvar sum64_hi = utils.sum64_hi;\nvar sum64_lo = utils.sum64_lo;\nvar sum64_4_hi = utils.sum64_4_hi;\nvar sum64_4_lo = utils.sum64_4_lo;\nvar sum64_5_hi = utils.sum64_5_hi;\nvar sum64_5_lo = utils.sum64_5_lo;\nvar BlockHash = hash.common.BlockHash;\n\nvar sha256_K = [\n  0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5,\n  0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5,\n  0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3,\n  0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174,\n  0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc,\n  0x2de92c6f, 0x4a7484aa, 0x5cb0a9dc, 0x76f988da,\n  0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7,\n  0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967,\n  0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13,\n  0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85,\n  0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3,\n  0xd192e819, 0xd6990624, 0xf40e3585, 0x106aa070,\n  0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5,\n  0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3,\n  0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208,\n  0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2\n];\n\nvar sha512_K = [\n  0x428a2f98, 0xd728ae22, 0x71374491, 0x23ef65cd,\n  0xb5c0fbcf, 0xec4d3b2f, 0xe9b5dba5, 0x8189dbbc,\n  0x3956c25b, 0xf348b538, 0x59f111f1, 0xb605d019,\n  0x923f82a4, 0xaf194f9b, 0xab1c5ed5, 0xda6d8118,\n  0xd807aa98, 0xa3030242, 0x12835b01, 0x45706fbe,\n  0x243185be, 0x4ee4b28c, 0x550c7dc3, 0xd5ffb4e2,\n  0x72be5d74, 0xf27b896f, 0x80deb1fe, 0x3b1696b1,\n  0x9bdc06a7, 0x25c71235, 0xc19bf174, 0xcf692694,\n  0xe49b69c1, 0x9ef14ad2, 0xefbe4786, 0x384f25e3,\n  0x0fc19dc6, 0x8b8cd5b5, 0x240ca1cc, 0x77ac9c65,\n  0x2de92c6f, 0x592b0275, 0x4a7484aa, 0x6ea6e483,\n  0x5cb0a9dc, 0xbd41fbd4, 0x76f988da, 0x831153b5,\n  0x983e5152, 0xee66dfab, 0xa831c66d, 0x2db43210,\n  0xb00327c8, 0x98fb213f, 0xbf597fc7, 0xbeef0ee4,\n  0xc6e00bf3, 0x3da88fc2, 0xd5a79147, 0x930aa725,\n  0x06ca6351, 0xe003826f, 0x14292967, 0x0a0e6e70,\n  0x27b70a85, 0x46d22ffc, 0x2e1b2138, 0x5c26c926,\n  0x4d2c6dfc, 0x5ac42aed, 0x53380d13, 0x9d95b3df,\n  0x650a7354, 0x8baf63de, 0x766a0abb, 0x3c77b2a8,\n  0x81c2c92e, 0x47edaee6, 0x92722c85, 0x1482353b,\n  0xa2bfe8a1, 0x4cf10364, 0xa81a664b, 0xbc423001,\n  0xc24b8b70, 0xd0f89791, 0xc76c51a3, 0x0654be30,\n  0xd192e819, 0xd6ef5218, 0xd6990624, 0x5565a910,\n  0xf40e3585, 0x5771202a, 0x106aa070, 0x32bbd1b8,\n  0x19a4c116, 0xb8d2d0c8, 0x1e376c08, 0x5141ab53,\n  0x2748774c, 0xdf8eeb99, 0x34b0bcb5, 0xe19b48a8,\n  0x391c0cb3, 0xc5c95a63, 0x4ed8aa4a, 0xe3418acb,\n  0x5b9cca4f, 0x7763e373, 0x682e6ff3, 0xd6b2b8a3,\n  0x748f82ee, 0x5defb2fc, 0x78a5636f, 0x43172f60,\n  0x84c87814, 0xa1f0ab72, 0x8cc70208, 0x1a6439ec,\n  0x90befffa, 0x23631e28, 0xa4506ceb, 0xde82bde9,\n  0xbef9a3f7, 0xb2c67915, 0xc67178f2, 0xe372532b,\n  0xca273ece, 0xea26619c, 0xd186b8c7, 0x21c0c207,\n  0xeada7dd6, 0xcde0eb1e, 0xf57d4f7f, 0xee6ed178,\n  0x06f067aa, 0x72176fba, 0x0a637dc5, 0xa2c898a6,\n  0x113f9804, 0xbef90dae, 0x1b710b35, 0x131c471b,\n  0x28db77f5, 0x23047d84, 0x32caab7b, 0x40c72493,\n  0x3c9ebe0a, 0x15c9bebc, 0x431d67c4, 0x9c100d4c,\n  0x4cc5d4be, 0xcb3e42b6, 0x597f299c, 0xfc657e2a,\n  0x5fcb6fab, 0x3ad6faec, 0x6c44198c, 0x4a475817\n];\n\nvar sha1_K = [\n  0x5A827999, 0x6ED9EBA1,\n  0x8F1BBCDC, 0xCA62C1D6\n];\n\nfunction SHA256() {\n  if (!(this instanceof SHA256))\n    return new SHA256();\n\n  BlockHash.call(this);\n  this.h = [ 0x6a09e667, 0xbb67ae85, 0x3c6ef372, 0xa54ff53a,\n             0x510e527f, 0x9b05688c, 0x1f83d9ab, 0x5be0cd19 ];\n  this.k = sha256_K;\n  this.W = new Array(64);\n}\nutils.inherits(SHA256, BlockHash);\nexports.sha256 = SHA256;\n\nSHA256.blockSize = 512;\nSHA256.outSize = 256;\nSHA256.hmacStrength = 192;\nSHA256.padLength = 64;\n\nSHA256.prototype._update = function _update(msg, start) {\n  var W = this.W;\n\n  for (var i = 0; i < 16; i++)\n    W[i] = msg[start + i];\n  for (; i < W.length; i++)\n    W[i] = sum32_4(g1_256(W[i - 2]), W[i - 7], g0_256(W[i - 15]), W[i - 16]);\n\n  var a = this.h[0];\n  var b = this.h[1];\n  var c = this.h[2];\n  var d = this.h[3];\n  var e = this.h[4];\n  var f = this.h[5];\n  var g = this.h[6];\n  var h = this.h[7];\n\n  assert(this.k.length === W.length);\n  for (var i = 0; i < W.length; i++) {\n    var T1 = sum32_5(h, s1_256(e), ch32(e, f, g), this.k[i], W[i]);\n    var T2 = sum32(s0_256(a), maj32(a, b, c));\n    h = g;\n    g = f;\n    f = e;\n    e = sum32(d, T1);\n    d = c;\n    c = b;\n    b = a;\n    a = sum32(T1, T2);\n  }\n\n  this.h[0] = sum32(this.h[0], a);\n  this.h[1] = sum32(this.h[1], b);\n  this.h[2] = sum32(this.h[2], c);\n  this.h[3] = sum32(this.h[3], d);\n  this.h[4] = sum32(this.h[4], e);\n  this.h[5] = sum32(this.h[5], f);\n  this.h[6] = sum32(this.h[6], g);\n  this.h[7] = sum32(this.h[7], h);\n};\n\nSHA256.prototype._digest = function digest(enc) {\n  if (enc === 'hex')\n    return utils.toHex32(this.h, 'big');\n  else\n    return utils.split32(this.h, 'big');\n};\n\nfunction SHA224() {\n  if (!(this instanceof SHA224))\n    return new SHA224();\n\n  SHA256.call(this);\n  this.h = [ 0xc1059ed8, 0x367cd507, 0x3070dd17, 0xf70e5939,\n             0xffc00b31, 0x68581511, 0x64f98fa7, 0xbefa4fa4 ];\n}\nutils.inherits(SHA224, SHA256);\nexports.sha224 = SHA224;\n\nSHA224.blockSize = 512;\nSHA224.outSize = 224;\nSHA224.hmacStrength = 192;\nSHA224.padLength = 64;\n\nSHA224.prototype._digest = function digest(enc) {\n  // Just truncate output\n  if (enc === 'hex')\n    return utils.toHex32(this.h.slice(0, 7), 'big');\n  else\n    return utils.split32(this.h.slice(0, 7), 'big');\n};\n\nfunction SHA512() {\n  if (!(this instanceof SHA512))\n    return new SHA512();\n\n  BlockHash.call(this);\n  this.h = [ 0x6a09e667, 0xf3bcc908,\n             0xbb67ae85, 0x84caa73b,\n             0x3c6ef372, 0xfe94f82b,\n             0xa54ff53a, 0x5f1d36f1,\n             0x510e527f, 0xade682d1,\n             0x9b05688c, 0x2b3e6c1f,\n             0x1f83d9ab, 0xfb41bd6b,\n             0x5be0cd19, 0x137e2179 ];\n  this.k = sha512_K;\n  this.W = new Array(160);\n}\nutils.inherits(SHA512, BlockHash);\nexports.sha512 = SHA512;\n\nSHA512.blockSize = 1024;\nSHA512.outSize = 512;\nSHA512.hmacStrength = 192;\nSHA512.padLength = 128;\n\nSHA512.prototype._prepareBlock = function _prepareBlock(msg, start) {\n  var W = this.W;\n\n  // 32 x 32bit words\n  for (var i = 0; i < 32; i++)\n    W[i] = msg[start + i];\n  for (; i < W.length; i += 2) {\n    var c0_hi = g1_512_hi(W[i - 4], W[i - 3]);  // i - 2\n    var c0_lo = g1_512_lo(W[i - 4], W[i - 3]);\n    var c1_hi = W[i - 14];  // i - 7\n    var c1_lo = W[i - 13];\n    var c2_hi = g0_512_hi(W[i - 30], W[i - 29]);  // i - 15\n    var c2_lo = g0_512_lo(W[i - 30], W[i - 29]);\n    var c3_hi = W[i - 32];  // i - 16\n    var c3_lo = W[i - 31];\n\n    W[i] = sum64_4_hi(c0_hi, c0_lo,\n                      c1_hi, c1_lo,\n                      c2_hi, c2_lo,\n                      c3_hi, c3_lo);\n    W[i + 1] = sum64_4_lo(c0_hi, c0_lo,\n                          c1_hi, c1_lo,\n                          c2_hi, c2_lo,\n                          c3_hi, c3_lo);\n  }\n};\n\nSHA512.prototype._update = function _update(msg, start) {\n  this._prepareBlock(msg, start);\n\n  var W = this.W;\n\n  var ah = this.h[0];\n  var al = this.h[1];\n  var bh = this.h[2];\n  var bl = this.h[3];\n  var ch = this.h[4];\n  var cl = this.h[5];\n  var dh = this.h[6];\n  var dl = this.h[7];\n  var eh = this.h[8];\n  var el = this.h[9];\n  var fh = this.h[10];\n  var fl = this.h[11];\n  var gh = this.h[12];\n  var gl = this.h[13];\n  var hh = this.h[14];\n  var hl = this.h[15];\n\n  assert(this.k.length === W.length);\n  for (var i = 0; i < W.length; i += 2) {\n    var c0_hi = hh;\n    var c0_lo = hl;\n    var c1_hi = s1_512_hi(eh, el);\n    var c1_lo = s1_512_lo(eh, el);\n    var c2_hi = ch64_hi(eh, el, fh, fl, gh, gl);\n    var c2_lo = ch64_lo(eh, el, fh, fl, gh, gl);\n    var c3_hi = this.k[i];\n    var c3_lo = this.k[i + 1];\n    var c4_hi = W[i];\n    var c4_lo = W[i + 1];\n\n    var T1_hi = sum64_5_hi(c0_hi, c0_lo,\n                           c1_hi, c1_lo,\n                           c2_hi, c2_lo,\n                           c3_hi, c3_lo,\n                           c4_hi, c4_lo);\n    var T1_lo = sum64_5_lo(c0_hi, c0_lo,\n                           c1_hi, c1_lo,\n                           c2_hi, c2_lo,\n                           c3_hi, c3_lo,\n                           c4_hi, c4_lo);\n\n    var c0_hi = s0_512_hi(ah, al);\n    var c0_lo = s0_512_lo(ah, al);\n    var c1_hi = maj64_hi(ah, al, bh, bl, ch, cl);\n    var c1_lo = maj64_lo(ah, al, bh, bl, ch, cl);\n\n    var T2_hi = sum64_hi(c0_hi, c0_lo, c1_hi, c1_lo);\n    var T2_lo = sum64_lo(c0_hi, c0_lo, c1_hi, c1_lo);\n\n    hh = gh;\n    hl = gl;\n\n    gh = fh;\n    gl = fl;\n\n    fh = eh;\n    fl = el;\n\n    eh = sum64_hi(dh, dl, T1_hi, T1_lo);\n    el = sum64_lo(dl, dl, T1_hi, T1_lo);\n\n    dh = ch;\n    dl = cl;\n\n    ch = bh;\n    cl = bl;\n\n    bh = ah;\n    bl = al;\n\n    ah = sum64_hi(T1_hi, T1_lo, T2_hi, T2_lo);\n    al = sum64_lo(T1_hi, T1_lo, T2_hi, T2_lo);\n  }\n\n  sum64(this.h, 0, ah, al);\n  sum64(this.h, 2, bh, bl);\n  sum64(this.h, 4, ch, cl);\n  sum64(this.h, 6, dh, dl);\n  sum64(this.h, 8, eh, el);\n  sum64(this.h, 10, fh, fl);\n  sum64(this.h, 12, gh, gl);\n  sum64(this.h, 14, hh, hl);\n};\n\nSHA512.prototype._digest = function digest(enc) {\n  if (enc === 'hex')\n    return utils.toHex32(this.h, 'big');\n  else\n    return utils.split32(this.h, 'big');\n};\n\nfunction SHA384() {\n  if (!(this instanceof SHA384))\n    return new SHA384();\n\n  SHA512.call(this);\n  this.h = [ 0xcbbb9d5d, 0xc1059ed8,\n             0x629a292a, 0x367cd507,\n             0x9159015a, 0x3070dd17,\n             0x152fecd8, 0xf70e5939,\n             0x67332667, 0xffc00b31,\n             0x8eb44a87, 0x68581511,\n             0xdb0c2e0d, 0x64f98fa7,\n             0x47b5481d, 0xbefa4fa4 ];\n}\nutils.inherits(SHA384, SHA512);\nexports.sha384 = SHA384;\n\nSHA384.blockSize = 1024;\nSHA384.outSize = 384;\nSHA384.hmacStrength = 192;\nSHA384.padLength = 128;\n\nSHA384.prototype._digest = function digest(enc) {\n  if (enc === 'hex')\n    return utils.toHex32(this.h.slice(0, 12), 'big');\n  else\n    return utils.split32(this.h.slice(0, 12), 'big');\n};\n\nfunction SHA1() {\n  if (!(this instanceof SHA1))\n    return new SHA1();\n\n  BlockHash.call(this);\n  this.h = [ 0x67452301, 0xefcdab89, 0x98badcfe,\n             0x10325476, 0xc3d2e1f0 ];\n  this.W = new Array(80);\n}\n\nutils.inherits(SHA1, BlockHash);\nexports.sha1 = SHA1;\n\nSHA1.blockSize = 512;\nSHA1.outSize = 160;\nSHA1.hmacStrength = 80;\nSHA1.padLength = 64;\n\nSHA1.prototype._update = function _update(msg, start) {\n  var W = this.W;\n\n  for (var i = 0; i < 16; i++)\n    W[i] = msg[start + i];\n\n  for(; i < W.length; i++)\n    W[i] = rotl32(W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16], 1);\n\n  var a = this.h[0];\n  var b = this.h[1];\n  var c = this.h[2];\n  var d = this.h[3];\n  var e = this.h[4];\n\n  for (var i = 0; i < W.length; i++) {\n    var s = ~~(i / 20);\n    var t = sum32_5(rotl32(a, 5), ft_1(s, b, c, d), e, W[i], sha1_K[s]);\n    e = d;\n    d = c;\n    c = rotl32(b, 30);\n    b = a;\n    a = t;\n  }\n\n  this.h[0] = sum32(this.h[0], a);\n  this.h[1] = sum32(this.h[1], b);\n  this.h[2] = sum32(this.h[2], c);\n  this.h[3] = sum32(this.h[3], d);\n  this.h[4] = sum32(this.h[4], e);\n};\n\nSHA1.prototype._digest = function digest(enc) {\n  if (enc === 'hex')\n    return utils.toHex32(this.h, 'big');\n  else\n    return utils.split32(this.h, 'big');\n};\n\nfunction ch32(x, y, z) {\n  return (x & y) ^ ((~x) & z);\n}\n\nfunction maj32(x, y, z) {\n  return (x & y) ^ (x & z) ^ (y & z);\n}\n\nfunction p32(x, y, z) {\n  return x ^ y ^ z;\n}\n\nfunction s0_256(x) {\n  return rotr32(x, 2) ^ rotr32(x, 13) ^ rotr32(x, 22);\n}\n\nfunction s1_256(x) {\n  return rotr32(x, 6) ^ rotr32(x, 11) ^ rotr32(x, 25);\n}\n\nfunction g0_256(x) {\n  return rotr32(x, 7) ^ rotr32(x, 18) ^ (x >>> 3);\n}\n\nfunction g1_256(x) {\n  return rotr32(x, 17) ^ rotr32(x, 19) ^ (x >>> 10);\n}\n\nfunction ft_1(s, x, y, z) {\n  if (s === 0)\n    return ch32(x, y, z);\n  if (s === 1 || s === 3)\n    return p32(x, y, z);\n  if (s === 2)\n    return maj32(x, y, z);\n}\n\nfunction ch64_hi(xh, xl, yh, yl, zh, zl) {\n  var r = (xh & yh) ^ ((~xh) & zh);\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction ch64_lo(xh, xl, yh, yl, zh, zl) {\n  var r = (xl & yl) ^ ((~xl) & zl);\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction maj64_hi(xh, xl, yh, yl, zh, zl) {\n  var r = (xh & yh) ^ (xh & zh) ^ (yh & zh);\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction maj64_lo(xh, xl, yh, yl, zh, zl) {\n  var r = (xl & yl) ^ (xl & zl) ^ (yl & zl);\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction s0_512_hi(xh, xl) {\n  var c0_hi = rotr64_hi(xh, xl, 28);\n  var c1_hi = rotr64_hi(xl, xh, 2);  // 34\n  var c2_hi = rotr64_hi(xl, xh, 7);  // 39\n\n  var r = c0_hi ^ c1_hi ^ c2_hi;\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction s0_512_lo(xh, xl) {\n  var c0_lo = rotr64_lo(xh, xl, 28);\n  var c1_lo = rotr64_lo(xl, xh, 2);  // 34\n  var c2_lo = rotr64_lo(xl, xh, 7);  // 39\n\n  var r = c0_lo ^ c1_lo ^ c2_lo;\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction s1_512_hi(xh, xl) {\n  var c0_hi = rotr64_hi(xh, xl, 14);\n  var c1_hi = rotr64_hi(xh, xl, 18);\n  var c2_hi = rotr64_hi(xl, xh, 9);  // 41\n\n  var r = c0_hi ^ c1_hi ^ c2_hi;\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction s1_512_lo(xh, xl) {\n  var c0_lo = rotr64_lo(xh, xl, 14);\n  var c1_lo = rotr64_lo(xh, xl, 18);\n  var c2_lo = rotr64_lo(xl, xh, 9);  // 41\n\n  var r = c0_lo ^ c1_lo ^ c2_lo;\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction g0_512_hi(xh, xl) {\n  var c0_hi = rotr64_hi(xh, xl, 1);\n  var c1_hi = rotr64_hi(xh, xl, 8);\n  var c2_hi = shr64_hi(xh, xl, 7);\n\n  var r = c0_hi ^ c1_hi ^ c2_hi;\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction g0_512_lo(xh, xl) {\n  var c0_lo = rotr64_lo(xh, xl, 1);\n  var c1_lo = rotr64_lo(xh, xl, 8);\n  var c2_lo = shr64_lo(xh, xl, 7);\n\n  var r = c0_lo ^ c1_lo ^ c2_lo;\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction g1_512_hi(xh, xl) {\n  var c0_hi = rotr64_hi(xh, xl, 19);\n  var c1_hi = rotr64_hi(xl, xh, 29);  // 61\n  var c2_hi = shr64_hi(xh, xl, 6);\n\n  var r = c0_hi ^ c1_hi ^ c2_hi;\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n\nfunction g1_512_lo(xh, xl) {\n  var c0_lo = rotr64_lo(xh, xl, 19);\n  var c1_lo = rotr64_lo(xl, xh, 29);  // 61\n  var c2_lo = shr64_lo(xh, xl, 6);\n\n  var r = c0_lo ^ c1_lo ^ c2_lo;\n  if (r < 0)\n    r += 0x100000000;\n  return r;\n}\n","var utils = exports;\nvar inherits = require('inherits');\n\nfunction toArray(msg, enc) {\n  if (Array.isArray(msg))\n    return msg.slice();\n  if (!msg)\n    return [];\n  var res = [];\n  if (typeof msg === 'string') {\n    if (!enc) {\n      for (var i = 0; i < msg.length; i++) {\n        var c = msg.charCodeAt(i);\n        var hi = c >> 8;\n        var lo = c & 0xff;\n        if (hi)\n          res.push(hi, lo);\n        else\n          res.push(lo);\n      }\n    } else if (enc === 'hex') {\n      msg = msg.replace(/[^a-z0-9]+/ig, '');\n      if (msg.length % 2 !== 0)\n        msg = '0' + msg;\n      for (var i = 0; i < msg.length; i += 2)\n        res.push(parseInt(msg[i] + msg[i + 1], 16));\n    }\n  } else {\n    for (var i = 0; i < msg.length; i++)\n      res[i] = msg[i] | 0;\n  }\n  return res;\n}\nutils.toArray = toArray;\n\nfunction toHex(msg) {\n  var res = '';\n  for (var i = 0; i < msg.length; i++)\n    res += zero2(msg[i].toString(16));\n  return res;\n}\nutils.toHex = toHex;\n\nfunction htonl(w) {\n  var res = (w >>> 24) |\n            ((w >>> 8) & 0xff00) |\n            ((w << 8) & 0xff0000) |\n            ((w & 0xff) << 24);\n  return res >>> 0;\n}\nutils.htonl = htonl;\n\nfunction toHex32(msg, endian) {\n  var res = '';\n  for (var i = 0; i < msg.length; i++) {\n    var w = msg[i];\n    if (endian === 'little')\n      w = htonl(w);\n    res += zero8(w.toString(16));\n  }\n  return res;\n}\nutils.toHex32 = toHex32;\n\nfunction zero2(word) {\n  if (word.length === 1)\n    return '0' + word;\n  else\n    return word;\n}\nutils.zero2 = zero2;\n\nfunction zero8(word) {\n  if (word.length === 7)\n    return '0' + word;\n  else if (word.length === 6)\n    return '00' + word;\n  else if (word.length === 5)\n    return '000' + word;\n  else if (word.length === 4)\n    return '0000' + word;\n  else if (word.length === 3)\n    return '00000' + word;\n  else if (word.length === 2)\n    return '000000' + word;\n  else if (word.length === 1)\n    return '0000000' + word;\n  else\n    return word;\n}\nutils.zero8 = zero8;\n\nfunction join32(msg, start, end, endian) {\n  var len = end - start;\n  assert(len % 4 === 0);\n  var res = new Array(len / 4);\n  for (var i = 0, k = start; i < res.length; i++, k += 4) {\n    var w;\n    if (endian === 'big')\n      w = (msg[k] << 24) | (msg[k + 1] << 16) | (msg[k + 2] << 8) | msg[k + 3];\n    else\n      w = (msg[k + 3] << 24) | (msg[k + 2] << 16) | (msg[k + 1] << 8) | msg[k];\n    res[i] = w >>> 0;\n  }\n  return res;\n}\nutils.join32 = join32;\n\nfunction split32(msg, endian) {\n  var res = new Array(msg.length * 4);\n  for (var i = 0, k = 0; i < msg.length; i++, k += 4) {\n    var m = msg[i];\n    if (endian === 'big') {\n      res[k] = m >>> 24;\n      res[k + 1] = (m >>> 16) & 0xff;\n      res[k + 2] = (m >>> 8) & 0xff;\n      res[k + 3] = m & 0xff;\n    } else {\n      res[k + 3] = m >>> 24;\n      res[k + 2] = (m >>> 16) & 0xff;\n      res[k + 1] = (m >>> 8) & 0xff;\n      res[k] = m & 0xff;\n    }\n  }\n  return res;\n}\nutils.split32 = split32;\n\nfunction rotr32(w, b) {\n  return (w >>> b) | (w << (32 - b));\n}\nutils.rotr32 = rotr32;\n\nfunction rotl32(w, b) {\n  return (w << b) | (w >>> (32 - b));\n}\nutils.rotl32 = rotl32;\n\nfunction sum32(a, b) {\n  return (a + b) >>> 0;\n}\nutils.sum32 = sum32;\n\nfunction sum32_3(a, b, c) {\n  return (a + b + c) >>> 0;\n}\nutils.sum32_3 = sum32_3;\n\nfunction sum32_4(a, b, c, d) {\n  return (a + b + c + d) >>> 0;\n}\nutils.sum32_4 = sum32_4;\n\nfunction sum32_5(a, b, c, d, e) {\n  return (a + b + c + d + e) >>> 0;\n}\nutils.sum32_5 = sum32_5;\n\nfunction assert(cond, msg) {\n  if (!cond)\n    throw new Error(msg || 'Assertion failed');\n}\nutils.assert = assert;\n\nutils.inherits = inherits;\n\nfunction sum64(buf, pos, ah, al) {\n  var bh = buf[pos];\n  var bl = buf[pos + 1];\n\n  var lo = (al + bl) >>> 0;\n  var hi = (lo < al ? 1 : 0) + ah + bh;\n  buf[pos] = hi >>> 0;\n  buf[pos + 1] = lo;\n}\nexports.sum64 = sum64;\n\nfunction sum64_hi(ah, al, bh, bl) {\n  var lo = (al + bl) >>> 0;\n  var hi = (lo < al ? 1 : 0) + ah + bh;\n  return hi >>> 0;\n};\nexports.sum64_hi = sum64_hi;\n\nfunction sum64_lo(ah, al, bh, bl) {\n  var lo = al + bl;\n  return lo >>> 0;\n};\nexports.sum64_lo = sum64_lo;\n\nfunction sum64_4_hi(ah, al, bh, bl, ch, cl, dh, dl) {\n  var carry = 0;\n  var lo = al;\n  lo = (lo + bl) >>> 0;\n  carry += lo < al ? 1 : 0;\n  lo = (lo + cl) >>> 0;\n  carry += lo < cl ? 1 : 0;\n  lo = (lo + dl) >>> 0;\n  carry += lo < dl ? 1 : 0;\n\n  var hi = ah + bh + ch + dh + carry;\n  return hi >>> 0;\n};\nexports.sum64_4_hi = sum64_4_hi;\n\nfunction sum64_4_lo(ah, al, bh, bl, ch, cl, dh, dl) {\n  var lo = al + bl + cl + dl;\n  return lo >>> 0;\n};\nexports.sum64_4_lo = sum64_4_lo;\n\nfunction sum64_5_hi(ah, al, bh, bl, ch, cl, dh, dl, eh, el) {\n  var carry = 0;\n  var lo = al;\n  lo = (lo + bl) >>> 0;\n  carry += lo < al ? 1 : 0;\n  lo = (lo + cl) >>> 0;\n  carry += lo < cl ? 1 : 0;\n  lo = (lo + dl) >>> 0;\n  carry += lo < dl ? 1 : 0;\n  lo = (lo + el) >>> 0;\n  carry += lo < el ? 1 : 0;\n\n  var hi = ah + bh + ch + dh + eh + carry;\n  return hi >>> 0;\n};\nexports.sum64_5_hi = sum64_5_hi;\n\nfunction sum64_5_lo(ah, al, bh, bl, ch, cl, dh, dl, eh, el) {\n  var lo = al + bl + cl + dl + el;\n\n  return lo >>> 0;\n};\nexports.sum64_5_lo = sum64_5_lo;\n\nfunction rotr64_hi(ah, al, num) {\n  var r = (al << (32 - num)) | (ah >>> num);\n  return r >>> 0;\n};\nexports.rotr64_hi = rotr64_hi;\n\nfunction rotr64_lo(ah, al, num) {\n  var r = (ah << (32 - num)) | (al >>> num);\n  return r >>> 0;\n};\nexports.rotr64_lo = rotr64_lo;\n\nfunction shr64_hi(ah, al, num) {\n  return ah >>> num;\n};\nexports.shr64_hi = shr64_hi;\n\nfunction shr64_lo(ah, al, num) {\n  var r = (ah << (32 - num)) | (al >>> num);\n  return r >>> 0;\n};\nexports.shr64_lo = shr64_lo;\n","'use strict';\nvar zeroBuffer = new Buffer(128)\nzeroBuffer.fill(0)\n\nmodule.exports = Hmac\n\nfunction Hmac (createHash, blocksize, key) {\n  if(!(this instanceof Hmac)) return new Hmac(createHash, blocksize, key)\n\n  this._opad = opad\n  this._createHash = createHash\n\n  if(blocksize !== 128 && blocksize !== 64)\n    throw new Error('blocksize must be either 64 for or 128 , but was:'+blocksize)\n\n  key = this._key = !Buffer.isBuffer(key) ? new Buffer(key) : key\n\n  if(key.length > blocksize) {\n    key = this._createHash().update(key).digest()\n  } else if(key.length < blocksize) {\n    key = Buffer.concat([key, zeroBuffer], blocksize)\n  }\n\n  var ipad = this._ipad = new Buffer(blocksize)\n  var opad = this._opad = new Buffer(blocksize)\n\n  for(var i = 0; i < blocksize; i++) {\n    ipad[i] = key[i] ^ 0x36\n    opad[i] = key[i] ^ 0x5C\n  }\n\n  this._hash = this._createHash().update(ipad)\n}\n\nHmac.prototype.update = function (data, enc) {\n  this._hash.update(data, enc)\n  return this\n}\n\nHmac.prototype.digest = function (enc) {\n  var h = this._hash.digest()\n  return this._createHash().update(this._opad).update(h).digest(enc)\n}\n\n\n","function wrap (fn, hook) {\n  return function () {\n    return hook.call(this, fn, [].slice.call(arguments))\n  }\n}\n\nmodule.exports = function hookable(fn) {\n\n  function hooked () {\n    return fn.apply(this, [].slice.call(arguments))\n  }\n\n  hooked.hook = function (hook) {\n    fn = wrap(fn, hook)\n    return this\n  }\n\n  return hooked\n}\n","exports.read = function (buffer, offset, isLE, mLen, nBytes) {\n  var e, m\n  var eLen = nBytes * 8 - mLen - 1\n  var eMax = (1 << eLen) - 1\n  var eBias = eMax >> 1\n  var nBits = -7\n  var i = isLE ? (nBytes - 1) : 0\n  var d = isLE ? -1 : 1\n  var s = buffer[offset + i]\n\n  i += d\n\n  e = s & ((1 << (-nBits)) - 1)\n  s >>= (-nBits)\n  nBits += eLen\n  for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  m = e & ((1 << (-nBits)) - 1)\n  e >>= (-nBits)\n  nBits += mLen\n  for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  if (e === 0) {\n    e = 1 - eBias\n  } else if (e === eMax) {\n    return m ? NaN : ((s ? -1 : 1) * Infinity)\n  } else {\n    m = m + Math.pow(2, mLen)\n    e = e - eBias\n  }\n  return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n  var e, m, c\n  var eLen = nBytes * 8 - mLen - 1\n  var eMax = (1 << eLen) - 1\n  var eBias = eMax >> 1\n  var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n  var i = isLE ? 0 : (nBytes - 1)\n  var d = isLE ? 1 : -1\n  var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n  value = Math.abs(value)\n\n  if (isNaN(value) || value === Infinity) {\n    m = isNaN(value) ? 1 : 0\n    e = eMax\n  } else {\n    e = Math.floor(Math.log(value) / Math.LN2)\n    if (value * (c = Math.pow(2, -e)) < 1) {\n      e--\n      c *= 2\n    }\n    if (e + eBias >= 1) {\n      value += rt / c\n    } else {\n      value += rt * Math.pow(2, 1 - eBias)\n    }\n    if (value * c >= 2) {\n      e++\n      c /= 2\n    }\n\n    if (e + eBias >= eMax) {\n      m = 0\n      e = eMax\n    } else if (e + eBias >= 1) {\n      m = (value * c - 1) * Math.pow(2, mLen)\n      e = e + eBias\n    } else {\n      m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n      e = 0\n    }\n  }\n\n  for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n  e = (e << mLen) | m\n  eLen += mLen\n  for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n  buffer[offset + i - d] |= s * 128\n}\n","\n\nmodule.exports = function (buf) {\n  var len = buf.length, i\n\n  for(i = len - 1; buf[i] === 255; i--) buf[i] = 0\n  if(~i) buf[i] = buf[i] + 1\n\n  return buf\n}\n","\nvar indexOf = [].indexOf;\n\nmodule.exports = function(arr, obj){\n  if (indexOf) return arr.indexOf(obj);\n  for (var i = 0; i < arr.length; ++i) {\n    if (arr[i] === obj) return i;\n  }\n  return -1;\n};","var wrappy = require('wrappy')\nvar reqs = Object.create(null)\nvar once = require('once')\n\nmodule.exports = wrappy(inflight)\n\nfunction inflight (key, cb) {\n  if (reqs[key]) {\n    reqs[key].push(cb)\n    return null\n  } else {\n    reqs[key] = [cb]\n    return makeres(key)\n  }\n}\n\nfunction makeres (key) {\n  return once(function RES () {\n    var cbs = reqs[key]\n    var len = cbs.length\n    var args = slice(arguments)\n    for (var i = 0; i < len; i++) {\n      cbs[i].apply(null, args)\n    }\n    if (cbs.length > len) {\n      // added more in the interim.\n      // de-zalgo, just in case, but don't call again.\n      cbs.splice(0, len)\n      process.nextTick(function () {\n        RES.apply(null, args)\n      })\n    } else {\n      delete reqs[key]\n    }\n  })\n}\n\nfunction slice (args) {\n  var length = args.length\n  var array = []\n\n  for (var i = 0; i < length; i++) array[i] = args[i]\n  return array\n}\n","if (typeof Object.create === 'function') {\n  // implementation from standard node.js 'util' module\n  module.exports = function inherits(ctor, superCtor) {\n    ctor.super_ = superCtor\n    ctor.prototype = Object.create(superCtor.prototype, {\n      constructor: {\n        value: ctor,\n        enumerable: false,\n        writable: true,\n        configurable: true\n      }\n    });\n  };\n} else {\n  // old school shim for old browsers\n  module.exports = function inherits(ctor, superCtor) {\n    ctor.super_ = superCtor\n    var TempCtor = function () {}\n    TempCtor.prototype = superCtor.prototype\n    ctor.prototype = new TempCtor()\n    ctor.prototype.constructor = ctor\n  }\n}\n","'use strict';\n\nvar v4 = '(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])(?:\\\\.(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])){3}';\nvar v6 = '(?:(?:[0-9a-fA-F:]){1,4}(?:(?::(?:[0-9a-fA-F]){1,4}|:)){2,7})+';\n\nvar ip = module.exports = function (opts) {\n\topts = opts || {};\n\treturn opts.exact ? new RegExp('(?:^' + v4 + '$)|(?:^' + v6 + '$)') :\n\t                    new RegExp('(?:' + v4 + ')|(?:' + v6 + ')', 'g');\n};\n\nip.v4 = function (opts) {\n\topts = opts || {};\n\treturn opts.exact ? new RegExp('^' + v4 + '$') : new RegExp(v4, 'g');\n};\n\nip.v6 = function (opts) {\n\topts = opts || {};\n\treturn opts.exact ? new RegExp('^' + v6 + '$') : new RegExp(v6, 'g');\n};\n","var ip = exports,\n    Buffer = require('buffer').Buffer,\n    os = require('os');\n\nip.toBuffer = function toBuffer(ip, buff, offset) {\n  offset = ~~offset;\n\n  var result;\n\n  if (/^(\\d{1,3}\\.){3,3}\\d{1,3}$/.test(ip)) {\n    result = buff || new Buffer(offset + 4);\n    ip.split(/\\./g).map(function(byte) {\n      result[offset++] = parseInt(byte, 10) & 0xff;\n    });\n  } else if (/^[a-f0-9:]+$/.test(ip)) {\n    var s = ip.split(/::/g, 2),\n        head = (s[0] || '').split(/:/g, 8),\n        tail = (s[1] || '').split(/:/g, 8);\n\n    if (tail.length === 0) {\n      // xxxx::\n      while (head.length < 8) head.push('0000');\n    } else if (head.length === 0) {\n      // ::xxxx\n      while (tail.length < 8) tail.unshift('0000');\n    } else {\n      // xxxx::xxxx\n      while (head.length + tail.length < 8) head.push('0000');\n    }\n\n    result = buff || new Buffer(offset + 16);\n    head.concat(tail).map(function(word) {\n      word = parseInt(word, 16);\n      result[offset++] = (word >> 8) & 0xff;\n      result[offset++] = word & 0xff;\n    });\n  } else {\n    throw Error('Invalid ip address: ' + ip);\n  }\n\n  return result;\n};\n\nip.toString = function toString(buff, offset, length) {\n  offset = ~~offset;\n  length = length || (buff.length - offset);\n\n  var result = [];\n  if (length === 4) {\n    // IPv4\n    for (var i = 0; i < length; i++) {\n      result.push(buff[offset + i]);\n    }\n    result = result.join('.');\n  } else if (length === 16) {\n    // IPv6\n    for (var i = 0; i < length; i += 2) {\n      result.push(buff.readUInt16BE(offset + i).toString(16));\n    }\n    result = result.join(':');\n    result = result.replace(/(^|:)0(:0)*:0(:|$)/, '$1::$3');\n    result = result.replace(/:{3,4}/, '::');\n  }\n\n  return result;\n};\n\nip.fromPrefixLen = function fromPrefixLen(prefixlen, family) {\n  if (prefixlen > 32) {\n    family = 'ipv6';\n  } else {\n    family = _normalizeFamily(family);\n  }\n\n  var len = 4;\n  if (family === 'ipv6') {\n    len = 16;\n  }\n  var buff = new Buffer(len);\n\n  for (var i = 0, n = buff.length; i < n; ++i) {\n    var bits = 8;\n    if (prefixlen < 8) {\n      bits = prefixlen;\n    }\n    prefixlen -= bits;\n\n    buff[i] = ~(0xff >> bits);\n  }\n\n  return ip.toString(buff);\n};\n\nip.mask = function mask(addr, mask) {\n  addr = ip.toBuffer(addr);\n  mask = ip.toBuffer(mask);\n\n  var result = new Buffer(Math.max(addr.length, mask.length));\n\n  // Same protocol - do bitwise and\n  if (addr.length === mask.length) {\n    for (var i = 0; i < addr.length; i++) {\n      result[i] = addr[i] & mask[i];\n    }\n  } else if (mask.length === 4) {\n    // IPv6 address and IPv4 mask\n    // (Mask low bits)\n    for (var i = 0; i < mask.length; i++) {\n      result[i] = addr[addr.length - 4  + i] & mask[i];\n    }\n  } else {\n    // IPv6 mask and IPv4 addr\n    for (var i = 0; i < result.length - 6; i++) {\n      result[i] = 0;\n    }\n\n    // ::ffff:ipv4\n    result[10] = 0xff;\n    result[11] = 0xff;\n    for (var i = 0; i < addr.length; i++) {\n      result[i + 12] = addr[i] & mask[i + 12];\n    }\n  }\n\n  return ip.toString(result);\n};\n\nip.cidr = function cidr(cidrString) {\n  var cidrParts = cidrString.split('/');\n\n  if (cidrParts.length != 2)\n    throw new Error('invalid CIDR subnet: ' + addr);\n\n  var addr = cidrParts[0];\n  var mask = ip.fromPrefixLen(parseInt(cidrParts[1], 10));\n\n  return ip.mask(addr, mask);\n}\n\nip.subnet = function subnet(addr, mask) {\n  var networkAddress = ip.toLong(ip.mask(addr, mask));\n\n  // Calculate the mask's length.\n  var maskBuffer = ip.toBuffer(mask);\n  var maskLength = 0;\n\n  for (var i = 0; i < maskBuffer.length; i++) {\n    if (maskBuffer[i] == 0xff) {\n      maskLength += 8;\n    } else {\n      var octet = maskBuffer[i] & 0xff;\n      while (octet) {\n        octet = (octet << 1) & 0xff;\n        maskLength++;\n      }\n    }\n  }\n\n  var numberOfAddresses = Math.pow(2, 32 - maskLength);\n\n  return {\n    networkAddress: ip.fromLong(networkAddress),\n    firstAddress: numberOfAddresses <= 2 ?\n                    ip.fromLong(networkAddress) :\n                    ip.fromLong(networkAddress + 1),\n    lastAddress: numberOfAddresses <= 2 ?\n                    ip.fromLong(networkAddress + numberOfAddresses - 1) :\n                    ip.fromLong(networkAddress + numberOfAddresses - 2),\n    broadcastAddress: ip.fromLong(networkAddress + numberOfAddresses - 1),\n    subnetMask: mask,\n    subnetMaskLength: maskLength,\n    numHosts: numberOfAddresses <= 2 ?\n                numberOfAddresses : numberOfAddresses - 2,\n    length: numberOfAddresses\n  };\n}\n\nip.cidrSubnet = function cidrSubnet(cidrString) {\n  var cidrParts = cidrString.split('/');\n\n  if (cidrParts.length !== 2)\n    throw new Error('invalid CIDR subnet: ' + addr);\n\n  var addr = cidrParts[0];\n  var mask = ip.fromPrefixLen(parseInt(cidrParts[1], 10));\n\n  return ip.subnet(addr, mask);\n}\n\nip.not = function not(addr) {\n  var buff = ip.toBuffer(addr);\n  for (var i = 0; i < buff.length; i++) {\n    buff[i] = 0xff ^ buff[i];\n  }\n  return ip.toString(buff);\n};\n\nip.or = function or(a, b) {\n  a = ip.toBuffer(a);\n  b = ip.toBuffer(b);\n\n  // same protocol\n  if (a.length == b.length) {\n    for (var i = 0; i < a.length; ++i) {\n      a[i] |= b[i];\n    }\n    return ip.toString(a);\n\n  // mixed protocols\n  } else {\n    var buff = a;\n    var other = b;\n    if (b.length > a.length) {\n      buff = b;\n      other = a;\n    }\n\n    var offset = buff.length - other.length;\n    for (var i = offset; i < buff.length; ++i) {\n      buff[i] |= other[i - offset];\n    }\n\n    return ip.toString(buff);\n  }\n};\n\nip.isEqual = function isEqual(a, b) {\n  a = ip.toBuffer(a);\n  b = ip.toBuffer(b);\n\n  // Same protocol\n  if (a.length === b.length) {\n    for (var i = 0; i < a.length; i++) {\n      if (a[i] !== b[i]) return false;\n    }\n    return true;\n  }\n\n  // Swap\n  if (b.length === 4) {\n    var t = b;\n    b = a;\n    a = t;\n  }\n\n  // a - IPv4, b - IPv6\n  for (var i = 0; i < 10; i++) {\n    if (b[i] !== 0) return false;\n  }\n\n  var word = b.readUInt16BE(10);\n  if (word !== 0 && word !== 0xffff) return false;\n\n  for (var i = 0; i < 4; i++) {\n    if (a[i] !== b[i + 12]) return false;\n  }\n\n  return true;\n};\n\nip.isPrivate = function isPrivate(addr) {\n  return addr.match(/^10\\.([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})/) != null ||\n    addr.match(/^192\\.168\\.([0-9]{1,3})\\.([0-9]{1,3})/) != null ||\n    addr.match(\n        /^172\\.(1[6-9]|2\\d|30|31)\\.([0-9]{1,3})\\.([0-9]{1,3})/) != null ||\n    addr.match(/^127\\.([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})/) != null ||\n    addr.match(/^169\\.254\\.([0-9]{1,3})\\.([0-9]{1,3})/) != null ||\n    addr.match(/^fc00:/) != null || addr.match(/^fe80:/) != null ||\n    addr.match(/^::1$/) != null || addr.match(/^::$/) != null;\n};\n\nip.isPublic = function isPublic(addr) {\n  return !ip.isPrivate(addr);\n}\n\nip.isLoopback = function isLoopback(addr) {\n  return /^127\\.0\\.0\\.1$/.test(addr)\n    || /^fe80::1$/.test(addr)\n    || /^::1$/.test(addr)\n    || /^::$/.test(addr);\n};\n\nip.loopback = function loopback(family) {\n  //\n  // Default to `ipv4`\n  //\n  family = _normalizeFamily(family);\n\n  if (family !== 'ipv4' && family !== 'ipv6') {\n    throw new Error('family must be ipv4 or ipv6');\n  }\n\n  return family === 'ipv4'\n    ? '127.0.0.1'\n    : 'fe80::1';\n};\n\n//\n// ### function address (name, family)\n// #### @name {string|'public'|'private'} **Optional** Name or security\n//      of the network interface.\n// #### @family {ipv4|ipv6} **Optional** IP family of the address (defaults\n//      to ipv4).\n//\n// Returns the address for the network interface on the current system with\n// the specified `name`:\n//   * String: First `family` address of the interface.\n//             If not found see `undefined`.\n//   * 'public': the first public ip address of family.\n//   * 'private': the first private ip address of family.\n//   * undefined: First address with `ipv4` or loopback addres `127.0.0.1`.\n//\nip.address = function address(name, family) {\n  var interfaces = os.networkInterfaces(),\n      all;\n\n  //\n  // Default to `ipv4`\n  //\n  family = _normalizeFamily(family);\n\n  //\n  // If a specific network interface has been named,\n  // return the address.\n  //\n  if (name && !~['public', 'private'].indexOf(name)) {\n    return interfaces[name].filter(function (details) {\n      details.family = details.family.toLowerCase();\n      return details.family === family;\n    })[0].address;\n  }\n\n  var all = Object.keys(interfaces).map(function (nic) {\n    //\n    // Note: name will only be `public` or `private`\n    // when this is called.\n    //\n    var addresses = interfaces[nic].filter(function (details) {\n      details.family = details.family.toLowerCase();\n      if (details.family !== family || ip.isLoopback(details.address)) {\n        return false;\n      }\n      else if (!name) {\n        return true;\n      }\n\n      return name === 'public'\n        ? !ip.isPrivate(details.address)\n        : ip.isPrivate(details.address)\n    });\n\n    return addresses.length\n      ? addresses[0].address\n      : undefined;\n  }).filter(Boolean);\n\n  return !all.length\n    ? ip.loopback(family)\n    : all[0];\n};\n\nip.toLong = function toInt(ip){\n  var ipl=0;\n  ip.split('.').forEach(function( octet ) {\n      ipl<<=8;\n      ipl+=parseInt(octet);\n  });\n  return(ipl >>>0);\n};\n\nip.fromLong = function fromInt(ipl){\n  return ( (ipl>>>24) +'.' +\n      (ipl>>16 & 255) +'.' +\n      (ipl>>8 & 255) +'.' +\n      (ipl & 255) );\n};\n\nfunction _normalizeFamily(family) {\n  return family ? family.toLowerCase() : 'ipv4';\n}\n","/**\n * Determine if an object is Buffer\n *\n * Author:   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>\n * License:  MIT\n *\n * `npm install is-buffer`\n */\n\nmodule.exports = function (obj) {\n  return !!(obj != null &&\n    (obj._isBuffer || // For Safari 5-7 (missing Object.prototype.constructor)\n      (obj.constructor &&\n      typeof obj.constructor.isBuffer === 'function' &&\n      obj.constructor.isBuffer(obj))\n    ))\n}\n","(function(root) {\n\n  function isValidDomain(v) {\n    if (!v) return false;\n    var re = /^(?!:\\/\\/)([a-zA-Z0-9-]+\\.){0,5}[a-zA-Z0-9-][a-zA-Z0-9-]+\\.[a-zA-Z]{2,64}?$/gi;\n    return re.test(v);\n  }\n\n  if (typeof exports !== 'undefined') {\n    if (typeof module !== 'undefined' && module.exports) {\n      exports = module.exports = isValidDomain;\n    }\n    exports.isValidDomain = isValidDomain;\n  } else if (typeof define === 'function' && define.amd) {\n    define([], function() {\n      return isValidDomain;\n    });\n  } else {\n    root.isValidDomain = isValidDomain;\n  }\n\n})(this);","module.exports = Array.isArray || function (arr) {\n  return Object.prototype.toString.call(arr) == '[object Array]';\n};\n","var encodings = require('./lib/encodings');\n\nmodule.exports = Codec;\n\nfunction Codec(opts){\n  this.opts = opts || {};\n  this.encodings = encodings;\n}\n\nCodec.prototype._encoding = function(encoding){\n  if (typeof encoding == 'string') encoding = encodings[encoding];\n  if (!encoding) encoding = encodings.id;\n  return encoding;\n};\n\nCodec.prototype._keyEncoding = function(opts, batchOpts){\n  return this._encoding(batchOpts && batchOpts.keyEncoding\n    || opts && opts.keyEncoding\n    || this.opts.keyEncoding);\n};\n\nCodec.prototype._valueEncoding = function(opts, batchOpts){\n  return this._encoding(\n    batchOpts && (batchOpts.valueEncoding || batchOpts.encoding)\n    || opts && (opts.valueEncoding || opts.encoding)\n    || (this.opts.valueEncoding || this.opts.encoding));\n};\n\nCodec.prototype.encodeKey = function(key, opts, batchOpts){\n  return this._keyEncoding(opts, batchOpts).encode(key);\n};\n\nCodec.prototype.encodeValue = function(value, opts, batchOpts){\n  return this._valueEncoding(opts, batchOpts).encode(value);\n};\n\nCodec.prototype.decodeKey = function(key, opts){\n  return this._keyEncoding(opts).decode(key);\n};\n\nCodec.prototype.decodeValue = function(value, opts){\n  return this._valueEncoding(opts).decode(value);\n};\n\nCodec.prototype.encodeBatch = function(ops, opts){\n  var self = this;\n\n  return ops.map(function(_op){\n    var op = {\n      type: _op.type,\n      key: self.encodeKey(_op.key, opts, _op)\n    };\n    if (self.keyAsBuffer(opts, _op)) op.keyEncoding = 'binary';\n    if (_op.prefix) op.prefix = _op.prefix;\n    if ('value' in _op) {\n      op.value = self.encodeValue(_op.value, opts, _op);\n      if (self.valueAsBuffer(opts, _op)) op.valueEncoding = 'binary';\n    }\n    return op;\n  });\n};\n\nvar ltgtKeys = ['lt', 'gt', 'lte', 'gte', 'start', 'end'];\n\nCodec.prototype.encodeLtgt = function(ltgt){\n  var self = this;\n  var ret = {};\n  Object.keys(ltgt).forEach(function(key){\n    ret[key] = ltgtKeys.indexOf(key) > -1\n      ? self.encodeKey(ltgt[key], ltgt)\n      : ltgt[key]\n  });\n  return ret;\n};\n\nCodec.prototype.createStreamDecoder = function(opts){\n  var self = this;\n\n  if (opts.keys && opts.values) {\n    return function(key, value){\n      return {\n        key: self.decodeKey(key, opts),\n        value: self.decodeValue(value, opts)\n      };\n    };\n  } else if (opts.keys) {\n    return function(key) {\n      return self.decodeKey(key, opts);\n    }; \n  } else if (opts.values) {\n    return function(_, value){\n      return self.decodeValue(value, opts);\n    }\n  } else {\n    return function(){};\n  }\n};\n\nCodec.prototype.keyAsBuffer = function(opts){\n  return this._keyEncoding(opts).buffer;\n};\n\nCodec.prototype.valueAsBuffer = function(opts){\n  return this._valueEncoding(opts).buffer;\n};\n\n","\nexports.utf8 = exports['utf-8'] = {\n  encode: function(data){\n    return isBinary(data)\n      ? data\n      : String(data);\n  },\n  decode: identity,\n  buffer: false,\n  type: 'utf8'\n};\n\nexports.json = {\n  encode: JSON.stringify,\n  decode: JSON.parse,\n  buffer: false,\n  type: 'json'\n};\n\nexports.binary = {\n  encode: function(data){\n    return isBinary(data)\n      ? data\n      : new Buffer(data);      \n  },\n  decode: identity,\n  buffer: true,\n  type: 'binary'\n};\n\nexports.id = {\n  encode: function(data){\n    return data;\n  },\n  decode: function(data){\n    return data;\n  },\n  buffer: false,\n  type: 'id'\n};\n\nvar bufferEncodings = [\n  'hex',\n  'ascii',\n  'base64',\n  'ucs2',\n  'ucs-2',\n  'utf16le',\n  'utf-16le'\n];\n\nbufferEncodings.forEach(function(type){\n  exports[type] = {\n    encode: function(data){\n      return isBinary(data)\n        ? data\n        : new Buffer(data, type);\n    },\n    decode: function(buffer){\n      return buffer.toString(type);\n    },\n    buffer: true,\n    type: type\n  };\n});\n\nfunction identity(value){\n  return value;\n}\n\nfunction isBinary(data){\n  return data === undefined\n    || data === null\n    || Buffer.isBuffer(data);\n}\n\n","/* Copyright (c) 2012-2015 LevelUP contributors\n * See list at <https://github.com/rvagg/node-levelup#contributing>\n * MIT License\n * <https://github.com/rvagg/node-levelup/blob/master/LICENSE.md>\n */\n\nvar createError   = require('errno').create\n  , LevelUPError  = createError('LevelUPError')\n  , NotFoundError = createError('NotFoundError', LevelUPError)\n\nNotFoundError.prototype.notFound = true\nNotFoundError.prototype.status   = 404\n\nmodule.exports = {\n    LevelUPError        : LevelUPError\n  , InitializationError : createError('InitializationError', LevelUPError)\n  , OpenError           : createError('OpenError', LevelUPError)\n  , ReadError           : createError('ReadError', LevelUPError)\n  , WriteError          : createError('WriteError', LevelUPError)\n  , NotFoundError       : NotFoundError\n  , EncodingError       : createError('EncodingError', LevelUPError)\n}\n","var inherits = require('inherits');\nvar Readable = require('readable-stream').Readable;\nvar extend = require('xtend');\nvar EncodingError = require('level-errors').EncodingError;\n\nmodule.exports = ReadStream;\ninherits(ReadStream, Readable);\n\nfunction ReadStream(iterator, options){\n  if (!(this instanceof ReadStream)) return new ReadStream(iterator, options);\n  Readable.call(this, extend(options, {\n    objectMode: true\n  }));\n  this._iterator = iterator;\n  this._destroyed = false;\n  this._decoder = null;\n  if (options && options.decoder) this._decoder = options.decoder;\n  this.on('end', this._cleanup.bind(this));\n}\n\nReadStream.prototype._read = function(){\n  var self = this;\n  if (this._destroyed) return;\n\n  this._iterator.next(function(err, key, value){\n    if (self._destroyed) return;\n    if (err) return self.emit('error', err);\n    if (key === undefined && value === undefined) {\n      self.push(null);\n    } else {\n      if (!self._decoder) return self.push({ key: key, value: value });\n\n      try {\n        var value = self._decoder(key, value);\n      } catch (err) {\n        self.emit('error', new EncodingError(err));\n        self.push(null);\n        return;\n      }\n      self.push(value);\n    }\n  });\n};\n\nReadStream.prototype.destroy =\nReadStream.prototype._cleanup = function(){\n  var self = this;\n  if (this._destroyed) return;\n  this._destroyed = true;\n\n  this._iterator.end(function(err){\n    if (err) return self.emit('error', err);\n    self.emit('close');\n  });\n};\n\n","module.exports = extend\n\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\nfunction extend() {\n    var target = {}\n\n    for (var i = 0; i < arguments.length; i++) {\n        var source = arguments[i]\n\n        for (var key in source) {\n            if (hasOwnProperty.call(source, key)) {\n                target[key] = source[key]\n            }\n        }\n    }\n\n    return target\n}\n","var pl   = require('pull-level')\nvar pull = require('pull-stream')\n\nmodule.exports = function (db, update, get) {\n  var waiting = [], ready = false\n  pull(\n    pl.read(db, {\n      onSync: function () {\n        ready = true\n        while(waiting.length) {\n          waiting.shift()()\n        }\n      },\n      live: true\n    }),\n    pull.drain(update)\n  )\n\n  function call (opts, cb) {\n    var value\n    try { value = get(opts) }\n    catch (err) { return cb(err) }\n    cb(null, value)\n  }\n\n  return function (opts, cb) {\n    if(!cb) cb = opts, opts = null\n    if(ready) call(opts, cb)\n    else waiting.push(function () { call(opts, cb) })\n  }\n\n}\n","var sources  = require('./sources')\nvar sinks    = require('./sinks')\nvar throughs = require('./throughs')\nvar u        = require('pull-core')\n\nfunction isFunction (fun) {\n  return 'function' === typeof fun\n}\n\nfunction isReader (fun) {\n  return fun && (fun.type === \"Through\" || fun.length === 1)\n}\nvar exports = module.exports = function pull () {\n  var args = [].slice.call(arguments)\n\n  if(isReader(args[0]))\n    return function (read) {\n      args.unshift(read)\n      return pull.apply(null, args)\n    }\n\n  var read = args.shift()\n\n  //if the first function is a duplex stream,\n  //pipe from the source.\n  if(isFunction(read.source))\n    read = read.source\n\n  function next () {\n    var s = args.shift()\n\n    if(null == s)\n      return next()\n\n    if(isFunction(s)) return s\n\n    return function (read) {\n      s.sink(read)\n      //this supports pipeing through a duplex stream\n      //pull(a, b, a) \"telephone style\".\n      //if this stream is in the a (first & last position)\n      //s.source will have already been used, but this should never be called\n      //so that is okay.\n      return s.source\n    }\n  }\n\n  while(args.length)\n    read = next() (read)\n\n  return read\n}\n\n\nfor(var k in sources)\n  exports[k] = u.Source(sources[k])\n\nfor(var k in throughs)\n  exports[k] = u.Through(throughs[k])\n\nfor(var k in sinks)\n  exports[k] = u.Sink(sinks[k])\n\nvar maybe = require('./maybe')(exports)\n\nfor(var k in maybe)\n  exports[k] = maybe[k]\n\nexports.Duplex  = \nexports.Through = exports.pipeable       = u.Through\nexports.Source  = exports.pipeableSource = u.Source\nexports.Sink    = exports.pipeableSink   = u.Sink\n\n\n","var u = require('pull-core')\nvar prop = u.prop\nvar id   = u.id\nvar maybeSink = u.maybeSink\n\nmodule.exports = function (pull) {\n\n  var exports = {}\n  var drain = pull.drain\n\n  var find =\n  exports.find = function (test, cb) {\n    return maybeSink(function (cb) {\n      var ended = false\n      if(!cb)\n        cb = test, test = id\n      else\n        test = prop(test) || id\n\n      return drain(function (data) {\n        if(test(data)) {\n          ended = true\n          cb(null, data)\n        return false\n        }\n      }, function (err) {\n        if(ended) return //already called back\n        cb(err === true ? null : err, null)\n      })\n\n    }, cb)\n  }\n\n  var reduce = exports.reduce =\n  function (reduce, acc, cb) {\n\n    return maybeSink(function (cb) {\n      return drain(function (data) {\n        acc = reduce(acc, data)\n      }, function (err) {\n        cb(err, acc)\n      })\n\n    }, cb)\n  }\n\n  var collect = exports.collect = exports.writeArray =\n  function (cb) {\n    return reduce(function (arr, item) {\n      arr.push(item)\n      return arr\n    }, [], cb)\n  }\n\n  var concat = exports.concat =\n  function (cb) {\n    return reduce(function (a, b) {\n      return a + b\n    }, '', cb)\n  }\n\n  return exports\n}\n","var drain = exports.drain = function (read, op, done) {\n\n  ;(function next() {\n    var loop = true, cbed = false\n    while(loop) {\n      cbed = false\n      read(null, function (end, data) {\n        cbed = true\n        if(end) {\n          loop = false\n          if(done) done(end === true ? null : end)\n          else if(end && end !== true)\n            throw end\n        }\n        else if(op && false === op(data)) {\n          loop = false\n          read(true, done || function () {})\n        }\n        else if(!loop){\n          next()\n        }\n      })\n      if(!cbed) {\n        loop = false\n        return\n      }\n    }\n  })()\n}\n\nvar onEnd = exports.onEnd = function (read, done) {\n  return drain(read, null, done)\n}\n\nvar log = exports.log = function (read, done) {\n  return drain(read, function (data) {\n    console.log(data)\n  }, done)\n}\n\n","\nvar keys = exports.keys =\nfunction (object) {\n  return values(Object.keys(object))\n}\n\nvar once = exports.once =\nfunction (value) {\n  return function (abort, cb) {\n    if(abort) return cb(abort)\n    if(value != null) {\n      var _value = value; value = null\n      cb(null, _value)\n    } else\n      cb(true)\n  }\n}\n\nvar values = exports.values = exports.readArray =\nfunction (array) {\n  if(!array)\n    return function (abort, cb) {\n      return cb(abort || true)\n    }\n  if(!Array.isArray(array))\n    array = Object.keys(array).map(function (k) {\n      return array[k]\n    })\n  var i = 0\n  return function (end, cb) {\n    if(end)\n      return cb && cb(end)\n    cb(i >= array.length || null, array[i++])\n  }\n}\n\n\nvar count = exports.count =\nfunction (max) {\n  var i = 0; max = max || Infinity\n  return function (end, cb) {\n    if(end) return cb && cb(end)\n    if(i > max)\n      return cb(true)\n    cb(null, i++)\n  }\n}\n\nvar infinite = exports.infinite =\nfunction (generate) {\n  generate = generate || Math.random\n  return function (end, cb) {\n    if(end) return cb && cb(end)\n    return cb(null, generate())\n  }\n}\n\nvar defer = exports.defer = function () {\n  var _read, cbs = [], _end\n\n  var read = function (end, cb) {\n    if(!_read) {\n      _end = end\n      cbs.push(cb)\n    } \n    else _read(end, cb)\n  }\n  read.resolve = function (read) {\n    if(_read) throw new Error('already resolved')\n    _read = read\n    if(!_read) throw new Error('no read cannot resolve!' + _read)\n    while(cbs.length)\n      _read(_end, cbs.shift())\n  }\n  read.abort = function(err) {\n    read.resolve(function (_, cb) {\n      cb(err || true)\n    })\n  }\n  return read\n}\n\nvar empty = exports.empty = function () {\n  return function (abort, cb) {\n    cb(true)\n  }\n}\n\nvar error = exports.error = function (err) {\n  return function (abort, cb) {\n    cb(err)\n  }\n}\n\nvar depthFirst = exports.depthFirst =\nfunction (start, createStream) {\n  var reads = []\n\n  reads.unshift(once(start))\n\n  return function next (end, cb) {\n    if(!reads.length)\n      return cb(true)\n    reads[0](end, function (end, data) {\n      if(end) {\n        //if this stream has ended, go to the next queue\n        reads.shift()\n        return next(null, cb)\n      }\n      reads.unshift(createStream(data))\n      cb(end, data)\n    })\n  }\n}\n//width first is just like depth first,\n//but push each new stream onto the end of the queue\nvar widthFirst = exports.widthFirst =\nfunction (start, createStream) {\n  var reads = []\n\n  reads.push(once(start))\n\n  return function next (end, cb) {\n    if(!reads.length)\n      return cb(true)\n    reads[0](end, function (end, data) {\n      if(end) {\n        reads.shift()\n        return next(null, cb)\n      }\n      reads.push(createStream(data))\n      cb(end, data)\n    })\n  }\n}\n\n//this came out different to the first (strm)\n//attempt at leafFirst, but it's still a valid\n//topological sort.\nvar leafFirst = exports.leafFirst =\nfunction (start, createStream) {\n  var reads = []\n  var output = []\n  reads.push(once(start))\n\n  return function next (end, cb) {\n    reads[0](end, function (end, data) {\n      if(end) {\n        reads.shift()\n        if(!output.length)\n          return cb(true)\n        return cb(null, output.shift())\n      }\n      reads.unshift(createStream(data))\n      output.unshift(data)\n      next(null, cb)\n    })\n  }\n}\n\n","var u      = require('pull-core')\nvar sources = require('./sources')\nvar sinks = require('./sinks')\n\nvar prop   = u.prop\nvar id     = u.id\nvar tester = u.tester\n\nvar map = exports.map =\nfunction (read, map) {\n  map = prop(map) || id\n  return function (abort, cb) {\n    read(abort, function (end, data) {\n      try {\n      data = !end ? map(data) : null\n      } catch (err) {\n        return read(err, function () {\n          return cb(err)\n        })\n      }\n      cb(end, data)\n    })\n  }\n}\n\nvar asyncMap = exports.asyncMap =\nfunction (read, map) {\n  if(!map) return read\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    read(null, function (end, data) {\n      if(end) return cb(end, data)\n      map(data, cb)\n    })\n  }\n}\n\nvar paraMap = exports.paraMap =\nfunction (read, map, width) {\n  if(!map) return read\n  var ended = false, queue = [], _cb\n\n  function drain () {\n    if(!_cb) return\n    var cb = _cb\n    _cb = null\n    if(queue.length)\n      return cb(null, queue.shift())\n    else if(ended && !n)\n      return cb(ended)\n    _cb = cb\n  }\n\n  function pull () {\n    read(null, function (end, data) {\n      if(end) {\n        ended = end\n        return drain()\n      }\n      n++\n      map(data, function (err, data) {\n        n--\n\n        queue.push(data)\n        drain()\n      })\n\n      if(n < width && !ended)\n        pull()\n    })\n  }\n\n  var n = 0\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    //continue to read while there are less than 3 maps in flight\n    _cb = cb\n    if(queue.length || ended)\n      pull(), drain()\n    else pull()\n  }\n  return highWaterMark(asyncMap(read, map), width)\n}\n\nvar filter = exports.filter =\nfunction (read, test) {\n  //regexp\n  test = tester(test)\n  return function next (end, cb) {\n    var sync, loop = true\n    while(loop) {\n      loop = false\n      sync = true\n      read(end, function (end, data) {\n        if(!end && !test(data))\n          return sync ? loop = true : next(end, cb)\n        cb(end, data)\n      })\n      sync = false\n    }\n  }\n}\n\nvar filterNot = exports.filterNot =\nfunction (read, test) {\n  test = tester(test)\n  return filter(read, function (e) {\n    return !test(e)\n  })\n}\n\nvar through = exports.through =\nfunction (read, op, onEnd) {\n  var a = false\n  function once (abort) {\n    if(a || !onEnd) return\n    a = true\n    onEnd(abort === true ? null : abort)\n  }\n\n  return function (end, cb) {\n    if(end) once(end)\n    return read(end, function (end, data) {\n      if(!end) op && op(data)\n      else once(end)\n      cb(end, data)\n    })\n  }\n}\n\nvar take = exports.take =\nfunction (read, test) {\n  var ended = false\n  if('number' === typeof test) {\n    var n = test; test = function () {\n      return n --\n    }\n  }\n\n  return function (end, cb) {\n    if(ended) return cb(ended)\n    if(ended = end) return read(ended, cb)\n\n    read(null, function (end, data) {\n      if(ended = ended || end) return cb(ended)\n      if(!test(data)) {\n        ended = true\n        read(true, function (end, data) {\n          cb(ended, data)\n        })\n      }\n      else\n        cb(null, data)\n    })\n  }\n}\n\nvar unique = exports.unique = function (read, field, invert) {\n  field = prop(field) || id\n  var seen = {}\n  return filter(read, function (data) {\n    var key = field(data)\n    if(seen[key]) return !!invert //false, by default\n    else seen[key] = true\n    return !invert //true by default\n  })\n}\n\nvar nonUnique = exports.nonUnique = function (read, field) {\n  return unique(read, field, true)\n}\n\nvar group = exports.group =\nfunction (read, size) {\n  var ended; size = size || 5\n  var queue = []\n\n  return function (end, cb) {\n    //this means that the upstream is sending an error.\n    if(end) return read(ended = end, cb)\n    //this means that we read an end before.\n    if(ended) return cb(ended)\n\n    read(null, function next(end, data) {\n      if(ended = ended || end) {\n        if(!queue.length)\n          return cb(ended)\n\n        var _queue = queue; queue = []\n        return cb(null, _queue)\n      }\n      queue.push(data)\n      if(queue.length < size)\n        return read(null, next)\n\n      var _queue = queue; queue = []\n      cb(null, _queue)\n    })\n  }\n}\n\nvar flatten = exports.flatten = function (read) {\n  var _read\n  return function (abort, cb) {\n    if(_read) nextChunk()\n    else      nextStream()\n\n    function nextChunk () {\n      _read(null, function (end, data) {\n        if(end) nextStream()\n        else    cb(null, data)\n      })\n    }\n    function nextStream () {\n      read(null, function (end, stream) {\n        if(end)\n          return cb(end)\n        if(Array.isArray(stream) || stream && 'object' === typeof stream)\n          stream = sources.values(stream)\n        else if('function' != typeof stream)\n          throw new Error('expected stream of streams')\n        _read = stream\n        nextChunk()\n      })\n    }\n  }\n}\n\nvar prepend =\nexports.prepend =\nfunction (read, head) {\n\n  return function (abort, cb) {\n    if(head !== null) {\n      if(abort)\n        return read(abort, cb)\n      var _head = head\n      head = null\n      cb(null, _head)\n    } else {\n      read(abort, cb)\n    }\n  }\n\n}\n\n//var drainIf = exports.drainIf = function (op, done) {\n//  sinks.drain(\n//}\n\nvar _reduce = exports._reduce = function (read, reduce, initial) {\n  return function (close, cb) {\n    if(close) return read(close, cb)\n    if(ended) return cb(ended)\n\n    sinks.drain(function (item) {\n      initial = reduce(initial, item)\n    }, function (err, data) {\n      ended = err || true\n      if(!err) cb(null, initial)\n      else     cb(ended)\n    })\n    (read)\n  }\n}\n\nvar nextTick = process.nextTick\n\nvar highWaterMark = exports.highWaterMark =\nfunction (read, highWaterMark) {\n  var buffer = [], waiting = [], ended, ending, reading = false\n  highWaterMark = highWaterMark || 10\n\n  function readAhead () {\n    while(waiting.length && (buffer.length || ended))\n      waiting.shift()(ended, ended ? null : buffer.shift())\n\n    if (!buffer.length && ending) ended = ending;\n  }\n\n  function next () {\n    if(ended || ending || reading || buffer.length >= highWaterMark)\n      return\n    reading = true\n    return read(ended || ending, function (end, data) {\n      reading = false\n      ending = ending || end\n      if(data != null) buffer.push(data)\n\n      next(); readAhead()\n    })\n  }\n\n  process.nextTick(next)\n\n  return function (end, cb) {\n    ended = ended || end\n    waiting.push(cb)\n\n    next(); readAhead()\n  }\n}\n\nvar flatMap = exports.flatMap =\nfunction (read, mapper) {\n  mapper = mapper || id\n  var queue = [], ended\n\n  return function (abort, cb) {\n    if(queue.length) return cb(null, queue.shift())\n    else if(ended)   return cb(ended)\n\n    read(abort, function next (end, data) {\n      if(end) ended = end\n      else {\n        var add = mapper(data)\n        while(add && add.length)\n          queue.push(add.shift())\n      }\n\n      if(queue.length) cb(null, queue.shift())\n      else if(ended)   cb(ended)\n      else             read(null, next)\n    })\n  }\n}\n\n","const levelup = require('levelup')\n\nfunction packager (leveldown) {\n  function Level (location, options, callback) {\n    if (typeof options === 'function')\n      callback = options\n    if (!(typeof options === 'object' && options !== null))\n      options  = {}\n\n    options.db = leveldown\n\n    return levelup(location, options, callback)\n  }\n\n  [ 'destroy', 'repair' ].forEach(function (m) {\n    if (typeof leveldown[m] === 'function') {\n      Level[m] = function (location, callback) {\n        leveldown[m](location, callback || function () {})\n      }\n    }\n  })\n\n  return Level\n}\n\nmodule.exports = packager\n","/* Copyright (c) 2013 Rod Vagg, MIT License */\n\nfunction AbstractChainedBatch (db) {\n  this._db         = db\n  this._operations = []\n  this._written    = false\n}\n\nAbstractChainedBatch.prototype._checkWritten = function () {\n  if (this._written)\n    throw new Error('write() already called on this batch')\n}\n\nAbstractChainedBatch.prototype.put = function (key, value) {\n  this._checkWritten()\n\n  var err = this._db._checkKey(key, 'key', this._db._isBuffer)\n  if (err)\n    throw err\n\n  if (!this._db._isBuffer(key)) key = String(key)\n  if (!this._db._isBuffer(value)) value = String(value)\n\n  if (typeof this._put == 'function' )\n    this._put(key, value)\n  else\n    this._operations.push({ type: 'put', key: key, value: value })\n\n  return this\n}\n\nAbstractChainedBatch.prototype.del = function (key) {\n  this._checkWritten()\n\n  var err = this._db._checkKey(key, 'key', this._db._isBuffer)\n  if (err) throw err\n\n  if (!this._db._isBuffer(key)) key = String(key)\n\n  if (typeof this._del == 'function' )\n    this._del(key)\n  else\n    this._operations.push({ type: 'del', key: key })\n\n  return this\n}\n\nAbstractChainedBatch.prototype.clear = function () {\n  this._checkWritten()\n\n  this._operations = []\n\n  if (typeof this._clear == 'function' )\n    this._clear()\n\n  return this\n}\n\nAbstractChainedBatch.prototype.write = function (options, callback) {\n  this._checkWritten()\n\n  if (typeof options == 'function')\n    callback = options\n  if (typeof callback != 'function')\n    throw new Error('write() requires a callback argument')\n  if (typeof options != 'object')\n    options = {}\n\n  this._written = true\n\n  if (typeof this._write == 'function' )\n    return this._write(callback)\n\n  if (typeof this._db._batch == 'function')\n    return this._db._batch(this._operations, options, callback)\n\n  process.nextTick(callback)\n}\n\nmodule.exports = AbstractChainedBatch","/* Copyright (c) 2013 Rod Vagg, MIT License */\n\nfunction AbstractIterator (db) {\n  this.db = db\n  this._ended = false\n  this._nexting = false\n}\n\nAbstractIterator.prototype.next = function (callback) {\n  var self = this\n\n  if (typeof callback != 'function')\n    throw new Error('next() requires a callback argument')\n\n  if (self._ended)\n    return callback(new Error('cannot call next() after end()'))\n  if (self._nexting)\n    return callback(new Error('cannot call next() before previous next() has completed'))\n\n  self._nexting = true\n  if (typeof self._next == 'function') {\n    return self._next(function () {\n      self._nexting = false\n      callback.apply(null, arguments)\n    })\n  }\n\n  process.nextTick(function () {\n    self._nexting = false\n    callback()\n  })\n}\n\nAbstractIterator.prototype.end = function (callback) {\n  if (typeof callback != 'function')\n    throw new Error('end() requires a callback argument')\n\n  if (this._ended)\n    return callback(new Error('end() already called on iterator'))\n\n  this._ended = true\n\n  if (typeof this._end == 'function')\n    return this._end(callback)\n\n  process.nextTick(callback)\n}\n\nmodule.exports = AbstractIterator\n","/* Copyright (c) 2013 Rod Vagg, MIT License */\n\nvar xtend                = require('xtend')\n  , AbstractIterator     = require('./abstract-iterator')\n  , AbstractChainedBatch = require('./abstract-chained-batch')\n\nfunction AbstractLevelDOWN (location) {\n  if (!arguments.length || location === undefined)\n    throw new Error('constructor requires at least a location argument')\n\n  if (typeof location != 'string')\n    throw new Error('constructor requires a location string argument')\n\n  this.location = location\n  this.status = 'new'\n}\n\nAbstractLevelDOWN.prototype.open = function (options, callback) {\n  var self      = this\n    , oldStatus = this.status\n\n  if (typeof options == 'function')\n    callback = options\n\n  if (typeof callback != 'function')\n    throw new Error('open() requires a callback argument')\n\n  if (typeof options != 'object')\n    options = {}\n\n  options.createIfMissing = options.createIfMissing != false\n  options.errorIfExists = !!options.errorIfExists\n\n  if (typeof this._open == 'function') {\n    this.status = 'opening'\n    this._open(options, function (err) {\n      if (err) {\n        self.status = oldStatus\n        return callback(err)\n      }\n      self.status = 'open'\n      callback()\n    })\n  } else {\n    this.status = 'open'\n    process.nextTick(callback)\n  }\n}\n\nAbstractLevelDOWN.prototype.close = function (callback) {\n  var self      = this\n    , oldStatus = this.status\n\n  if (typeof callback != 'function')\n    throw new Error('close() requires a callback argument')\n\n  if (typeof this._close == 'function') {\n    this.status = 'closing'\n    this._close(function (err) {\n      if (err) {\n        self.status = oldStatus\n        return callback(err)\n      }\n      self.status = 'closed'\n      callback()\n    })\n  } else {\n    this.status = 'closed'\n    process.nextTick(callback)\n  }\n}\n\nAbstractLevelDOWN.prototype.get = function (key, options, callback) {\n  var err\n\n  if (typeof options == 'function')\n    callback = options\n\n  if (typeof callback != 'function')\n    throw new Error('get() requires a callback argument')\n\n  if (err = this._checkKey(key, 'key', this._isBuffer))\n    return callback(err)\n\n  if (!this._isBuffer(key))\n    key = String(key)\n\n  if (typeof options != 'object')\n    options = {}\n\n  options.asBuffer = options.asBuffer != false\n\n  if (typeof this._get == 'function')\n    return this._get(key, options, callback)\n\n  process.nextTick(function () { callback(new Error('NotFound')) })\n}\n\nAbstractLevelDOWN.prototype.put = function (key, value, options, callback) {\n  var err\n\n  if (typeof options == 'function')\n    callback = options\n\n  if (typeof callback != 'function')\n    throw new Error('put() requires a callback argument')\n\n  if (err = this._checkKey(key, 'key', this._isBuffer))\n    return callback(err)\n\n  if (!this._isBuffer(key))\n    key = String(key)\n\n  // coerce value to string in node, don't touch it in browser\n  // (indexeddb can store any JS type)\n  if (value != null && !this._isBuffer(value) && !process.browser)\n    value = String(value)\n\n  if (typeof options != 'object')\n    options = {}\n\n  if (typeof this._put == 'function')\n    return this._put(key, value, options, callback)\n\n  process.nextTick(callback)\n}\n\nAbstractLevelDOWN.prototype.del = function (key, options, callback) {\n  var err\n\n  if (typeof options == 'function')\n    callback = options\n\n  if (typeof callback != 'function')\n    throw new Error('del() requires a callback argument')\n\n  if (err = this._checkKey(key, 'key', this._isBuffer))\n    return callback(err)\n\n  if (!this._isBuffer(key))\n    key = String(key)\n\n  if (typeof options != 'object')\n    options = {}\n\n  if (typeof this._del == 'function')\n    return this._del(key, options, callback)\n\n  process.nextTick(callback)\n}\n\nAbstractLevelDOWN.prototype.batch = function (array, options, callback) {\n  if (!arguments.length)\n    return this._chainedBatch()\n\n  if (typeof options == 'function')\n    callback = options\n\n  if (typeof array == 'function')\n    callback = array\n\n  if (typeof callback != 'function')\n    throw new Error('batch(array) requires a callback argument')\n\n  if (!Array.isArray(array))\n    return callback(new Error('batch(array) requires an array argument'))\n\n  if (!options || typeof options != 'object')\n    options = {}\n\n  var i = 0\n    , l = array.length\n    , e\n    , err\n\n  for (; i < l; i++) {\n    e = array[i]\n    if (typeof e != 'object')\n      continue\n\n    if (err = this._checkKey(e.type, 'type', this._isBuffer))\n      return callback(err)\n\n    if (err = this._checkKey(e.key, 'key', this._isBuffer))\n      return callback(err)\n  }\n\n  if (typeof this._batch == 'function')\n    return this._batch(array, options, callback)\n\n  process.nextTick(callback)\n}\n\n//TODO: remove from here, not a necessary primitive\nAbstractLevelDOWN.prototype.approximateSize = function (start, end, callback) {\n  if (   start == null\n      || end == null\n      || typeof start == 'function'\n      || typeof end == 'function') {\n    throw new Error('approximateSize() requires valid `start`, `end` and `callback` arguments')\n  }\n\n  if (typeof callback != 'function')\n    throw new Error('approximateSize() requires a callback argument')\n\n  if (!this._isBuffer(start))\n    start = String(start)\n\n  if (!this._isBuffer(end))\n    end = String(end)\n\n  if (typeof this._approximateSize == 'function')\n    return this._approximateSize(start, end, callback)\n\n  process.nextTick(function () {\n    callback(null, 0)\n  })\n}\n\nAbstractLevelDOWN.prototype._setupIteratorOptions = function (options) {\n  var self = this\n\n  options = xtend(options)\n\n  ;[ 'start', 'end', 'gt', 'gte', 'lt', 'lte' ].forEach(function (o) {\n    if (options[o] && self._isBuffer(options[o]) && options[o].length === 0)\n      delete options[o]\n  })\n\n  options.reverse = !!options.reverse\n  options.keys = options.keys != false\n  options.values = options.values != false\n  options.limit = 'limit' in options ? options.limit : -1\n  options.keyAsBuffer = options.keyAsBuffer != false\n  options.valueAsBuffer = options.valueAsBuffer != false\n\n  return options\n}\n\nAbstractLevelDOWN.prototype.iterator = function (options) {\n  if (typeof options != 'object')\n    options = {}\n\n  options = this._setupIteratorOptions(options)\n\n  if (typeof this._iterator == 'function')\n    return this._iterator(options)\n\n  return new AbstractIterator(this)\n}\n\nAbstractLevelDOWN.prototype._chainedBatch = function () {\n  return new AbstractChainedBatch(this)\n}\n\nAbstractLevelDOWN.prototype._isBuffer = function (obj) {\n  return Buffer.isBuffer(obj)\n}\n\nAbstractLevelDOWN.prototype._checkKey = function (obj, type) {\n\n  if (obj === null || obj === undefined)\n    return new Error(type + ' cannot be `null` or `undefined`')\n\n  if (this._isBuffer(obj)) {\n    if (obj.length === 0)\n      return new Error(type + ' cannot be an empty Buffer')\n  } else if (String(obj) === '')\n    return new Error(type + ' cannot be an empty String')\n}\n\nmodule.exports = AbstractLevelDOWN\n","exports.AbstractLevelDOWN    = require('./abstract-leveldown')\nexports.AbstractIterator     = require('./abstract-iterator')\nexports.AbstractChainedBatch = require('./abstract-chained-batch')\nexports.isLevelDOWN          = require('./is-leveldown')\n","var AbstractLevelDOWN = require('./abstract-leveldown')\n\nfunction isLevelDOWN (db) {\n  if (!db || typeof db !== 'object')\n    return false\n  return Object.keys(AbstractLevelDOWN.prototype).filter(function (name) {\n    // TODO remove approximateSize check when method is gone\n    return name[0] != '_' && name != 'approximateSize'\n  }).every(function (name) {\n    return typeof db[name] == 'function'\n  })\n}\n\nmodule.exports = isLevelDOWN\n","var util = require('util')\n  , AbstractIterator = require('abstract-leveldown').AbstractIterator\n\n\nfunction DeferredIterator (options) {\n  AbstractIterator.call(this, options)\n\n  this._options = options\n  this._iterator = null\n  this._operations = []\n}\n\nutil.inherits(DeferredIterator, AbstractIterator)\n\nDeferredIterator.prototype.setDb = function (db) {\n  var it = this._iterator = db.iterator(this._options)\n  this._operations.forEach(function (op) {\n    it[op.method].apply(it, op.args)\n  })\n}\n\nDeferredIterator.prototype._operation = function (method, args) {\n  if (this._iterator)\n    return this._iterator[method].apply(this._iterator, args)\n  this._operations.push({ method: method, args: args })\n}\n\n'next end'.split(' ').forEach(function (m) {\n  DeferredIterator.prototype['_' + m] = function () {\n    this._operation(m, arguments)\n  }\n})\n\nmodule.exports = DeferredIterator;\n","var util              = require('util')\n  , AbstractLevelDOWN = require('abstract-leveldown').AbstractLevelDOWN\n  , DeferredIterator  = require('./deferred-iterator')\n\nfunction DeferredLevelDOWN (location) {\n  AbstractLevelDOWN.call(this, typeof location == 'string' ? location : '') // optional location, who cares?\n  this._db         = undefined\n  this._operations = []\n  this._iterators  = []\n}\n\nutil.inherits(DeferredLevelDOWN, AbstractLevelDOWN)\n\n// called by LevelUP when we have a real DB to take its place\nDeferredLevelDOWN.prototype.setDb = function (db) {\n  this._db = db\n  this._operations.forEach(function (op) {\n    db[op.method].apply(db, op.args)\n  })\n  this._iterators.forEach(function (it) {\n    it.setDb(db)\n  })\n}\n\nDeferredLevelDOWN.prototype._open = function (options, callback) {\n  return process.nextTick(callback)\n}\n\n// queue a new deferred operation\nDeferredLevelDOWN.prototype._operation = function (method, args) {\n  if (this._db)\n    return this._db[method].apply(this._db, args)\n  this._operations.push({ method: method, args: args })\n}\n\n// deferrables\n'put get del batch approximateSize'.split(' ').forEach(function (m) {\n  DeferredLevelDOWN.prototype['_' + m] = function () {\n    this._operation(m, arguments)\n  }\n})\n\nDeferredLevelDOWN.prototype._isBuffer = function (obj) {\n  return Buffer.isBuffer(obj)\n}\n\nDeferredLevelDOWN.prototype._iterator = function (options) {\n  if (this._db)\n    return this._db.iterator.apply(this._db, arguments)\n  var it = new DeferredIterator(options)\n  this._iterators.push(it)\n  return it\n}\n\nmodule.exports                  = DeferredLevelDOWN\nmodule.exports.DeferredIterator = DeferredIterator\n","/* Copyright (c) 2012-2015 LevelUP contributors\n * See list at <https://github.com/level/levelup#contributing>\n * MIT License\n * <https://github.com/level/levelup/blob/master/LICENSE.md>\n */\n\nvar util          = require('./util')\n  , WriteError    = require('level-errors').WriteError\n\n  , getOptions    = util.getOptions\n  , dispatchError = util.dispatchError\n\nfunction Batch (levelup, codec) {\n  this._levelup = levelup\n  this._codec = codec\n  this.batch = levelup.db.batch()\n  this.ops = []\n  this.length = 0\n}\n\nBatch.prototype.put = function (key_, value_, options) {\n  options = getOptions(options)\n\n  var key   = this._codec.encodeKey(key_, options)\n    , value = this._codec.encodeValue(value_, options)\n\n  try {\n    this.batch.put(key, value)\n  } catch (e) {\n    throw new WriteError(e)\n  }\n  this.ops.push({ type : 'put', key : key, value : value })\n  this.length++\n\n  return this\n}\n\nBatch.prototype.del = function (key_, options) {\n  options = getOptions(options)\n\n  var key = this._codec.encodeKey(key_, options)\n\n  try {\n    this.batch.del(key)\n  } catch (err) {\n    throw new WriteError(err)\n  }\n  this.ops.push({ type : 'del', key : key })\n  this.length++\n\n  return this\n}\n\nBatch.prototype.clear = function () {\n  try {\n    this.batch.clear()\n  } catch (err) {\n    throw new WriteError(err)\n  }\n\n  this.ops = []\n  this.length = 0\n  return this\n}\n\nBatch.prototype.write = function (callback) {\n  var levelup = this._levelup\n    , ops     = this.ops\n\n  try {\n    this.batch.write(function (err) {\n      if (err)\n        return dispatchError(levelup, new WriteError(err), callback)\n      levelup.emit('batch', ops)\n      if (callback)\n        callback()\n    })\n  } catch (err) {\n    throw new WriteError(err)\n  }\n}\n\nmodule.exports = Batch\n","/* Copyright (c) 2012-2015 LevelUP contributors\n * See list at <https://github.com/level/levelup#contributing>\n * MIT License\n * <https://github.com/level/levelup/blob/master/LICENSE.md>\n */\n\nvar EventEmitter        = require('events').EventEmitter\n  , inherits            = require('util').inherits\n  , deprecate           = require('util').deprecate\n  , extend              = require('xtend')\n  , prr                 = require('prr')\n  , DeferredLevelDOWN   = require('deferred-leveldown')\n  , IteratorStream      = require('level-iterator-stream')\n\n  , errors              = require('level-errors')\n  , WriteError          = errors.WriteError\n  , ReadError           = errors.ReadError\n  , NotFoundError       = errors.NotFoundError\n  , OpenError           = errors.OpenError\n  , EncodingError       = errors.EncodingError\n  , InitializationError = errors.InitializationError\n\n  , util                = require('./util')\n  , Batch               = require('./batch')\n  , Codec               = require('level-codec')\n\n  , getOptions          = util.getOptions\n  , defaultOptions      = util.defaultOptions\n  , getLevelDOWN        = util.getLevelDOWN\n  , dispatchError       = util.dispatchError\n  , isDefined           = util.isDefined\n\nfunction getCallback (options, callback) {\n  return typeof options == 'function' ? options : callback\n}\n\n// Possible LevelUP#_status values:\n//  - 'new'     - newly created, not opened or closed\n//  - 'opening' - waiting for the database to be opened, post open()\n//  - 'open'    - successfully opened the database, available for use\n//  - 'closing' - waiting for the database to be closed, post close()\n//  - 'closed'  - database has been successfully closed, should not be\n//                 used except for another open() operation\n\nfunction LevelUP (location, options, callback) {\n  if (!(this instanceof LevelUP))\n    return new LevelUP(location, options, callback)\n\n  var error\n\n  EventEmitter.call(this)\n  this.setMaxListeners(Infinity)\n\n  if (typeof location == 'function') {\n    options = typeof options == 'object' ? options : {}\n    options.db = location\n    location = null\n  } else if (typeof location == 'object' && typeof location.db == 'function') {\n    options = location\n    location = null\n  }\n\n\n  if (typeof options == 'function') {\n    callback = options\n    options  = {}\n  }\n\n  if ((!options || typeof options.db != 'function') && typeof location != 'string') {\n    error = new InitializationError(\n        'Must provide a location for the database')\n    if (callback) {\n      return process.nextTick(function () {\n        callback(error)\n      })\n    }\n    throw error\n  }\n\n  options      = getOptions(options)\n  this.options = extend(defaultOptions, options)\n  this._codec = new Codec(this.options)\n  this._status = 'new'\n  // set this.location as enumerable but not configurable or writable\n  prr(this, 'location', location, 'e')\n\n  this.open(callback)\n}\n\ninherits(LevelUP, EventEmitter)\n\nLevelUP.prototype.open = function (callback) {\n  var self = this\n    , dbFactory\n    , db\n\n  if (this.isOpen()) {\n    if (callback)\n      process.nextTick(function () { callback(null, self) })\n    return this\n  }\n\n  if (this._isOpening()) {\n    return callback && this.once(\n        'open'\n      , function () { callback(null, self) }\n    )\n  }\n\n  this.emit('opening')\n\n  this._status = 'opening'\n  this.db      = new DeferredLevelDOWN(this.location)\n  dbFactory    = this.options.db || getLevelDOWN()\n  db           = dbFactory(this.location)\n\n  db.open(this.options, function (err) {\n    if (err) {\n      return dispatchError(self, new OpenError(err), callback)\n    } else {\n      self.db.setDb(db)\n      self.db = db\n      self._status = 'open'\n      if (callback)\n        callback(null, self)\n      self.emit('open')\n      self.emit('ready')\n    }\n  })\n}\n\nLevelUP.prototype.close = function (callback) {\n  var self = this\n\n  if (this.isOpen()) {\n    this._status = 'closing'\n    this.db.close(function () {\n      self._status = 'closed'\n      self.emit('closed')\n      if (callback)\n        callback.apply(null, arguments)\n    })\n    this.emit('closing')\n    this.db = new DeferredLevelDOWN(this.location)\n  } else if (this._status == 'closed' && callback) {\n    return process.nextTick(callback)\n  } else if (this._status == 'closing' && callback) {\n    this.once('closed', callback)\n  } else if (this._isOpening()) {\n    this.once('open', function () {\n      self.close(callback)\n    })\n  }\n}\n\nLevelUP.prototype.isOpen = function () {\n  return this._status == 'open'\n}\n\nLevelUP.prototype._isOpening = function () {\n  return this._status == 'opening'\n}\n\nLevelUP.prototype.isClosed = function () {\n  return (/^clos/).test(this._status)\n}\n\nfunction maybeError(db, options, callback) {\n  if (!db._isOpening() && !db.isOpen()) {\n    dispatchError(\n        db\n      , new ReadError('Database is not open')\n      , callback\n    )\n    return true\n  }\n}\n\nfunction writeError (db, message, callback) {\n  dispatchError(\n      db\n     , new WriteError(message)\n     , callback\n  )\n}\n\nfunction readError (db, message, callback) {\n  dispatchError(\n      db\n     , new ReadError(message)\n     , callback\n  )\n}\n\n\nLevelUP.prototype.get = function (key_, options, callback) {\n  var self = this\n    , key\n\n  callback = getCallback(options, callback)\n\n  if (maybeError(this, options, callback))\n    return\n\n  if (key_ === null || key_ === undefined || 'function' !== typeof callback)\n    return readError(this\n      , 'get() requires key and callback arguments', callback)\n\n  options = util.getOptions(options)\n  key = this._codec.encodeKey(key_, options)\n\n  options.asBuffer = this._codec.valueAsBuffer(options)\n\n  this.db.get(key, options, function (err, value) {\n    if (err) {\n      if ((/notfound/i).test(err) || err.notFound) {\n        err = new NotFoundError(\n            'Key not found in database [' + key_ + ']', err)\n      } else {\n        err = new ReadError(err)\n      }\n      return dispatchError(self, err, callback)\n    }\n    if (callback) {\n      try {\n        value = self._codec.decodeValue(value, options)\n      } catch (e) {\n        return callback(new EncodingError(e))\n      }\n      callback(null, value)\n    }\n  })\n}\n\nLevelUP.prototype.put = function (key_, value_, options, callback) {\n  var self = this\n    , key\n    , value\n\n  callback = getCallback(options, callback)\n\n  if (key_ === null || key_ === undefined)\n    return writeError(this, 'put() requires a key argument', callback)\n\n  if (maybeError(this, options, callback))\n    return\n\n  options = getOptions(options)\n  key     = this._codec.encodeKey(key_, options)\n  value   = this._codec.encodeValue(value_, options)\n\n  this.db.put(key, value, options, function (err) {\n    if (err) {\n      return dispatchError(self, new WriteError(err), callback)\n    } else {\n      self.emit('put', key_, value_)\n      if (callback)\n        callback()\n    }\n  })\n}\n\nLevelUP.prototype.del = function (key_, options, callback) {\n  var self = this\n    , key\n\n  callback = getCallback(options, callback)\n\n  if (key_ === null || key_ === undefined)\n    return writeError(this, 'del() requires a key argument', callback)\n\n  if (maybeError(this, options, callback))\n    return\n\n  options = getOptions(options)\n  key     = this._codec.encodeKey(key_, options)\n\n  this.db.del(key, options, function (err) {\n    if (err) {\n      return dispatchError(self, new WriteError(err), callback)\n    } else {\n      self.emit('del', key_)\n      if (callback)\n        callback()\n    }\n  })\n}\n\nLevelUP.prototype.batch = function (arr_, options, callback) {\n  var self = this\n    , keyEnc\n    , valueEnc\n    , arr\n\n  if (!arguments.length)\n    return new Batch(this, this._codec)\n\n  callback = getCallback(options, callback)\n\n  if (!Array.isArray(arr_))\n    return writeError(this, 'batch() requires an array argument', callback)\n\n  if (maybeError(this, options, callback))\n    return\n\n  options  = getOptions(options)\n  arr      = self._codec.encodeBatch(arr_, options)\n  arr      = arr.map(function (op) {\n    if (!op.type && op.key !== undefined && op.value !== undefined)\n      op.type = 'put'\n    return op\n  })\n\n  this.db.batch(arr, options, function (err) {\n    if (err) {\n      return dispatchError(self, new WriteError(err), callback)\n    } else {\n      self.emit('batch', arr_)\n      if (callback)\n        callback()\n    }\n  })\n}\n\nLevelUP.prototype.approximateSize = deprecate(function (start_, end_, options, callback) {   \n  var self = this    \n    , start    \n    , end    \n   \n  callback = getCallback(options, callback)    \n   \n  options = getOptions(options)    \n   \n  if (start_ === null || start_ === undefined    \n        || end_ === null || end_ === undefined || 'function' !== typeof callback)    \n    return readError(this, 'approximateSize() requires start, end and callback arguments', callback)   \n   \n  start = this._codec.encodeKey(start_, options)   \n  end   = this._codec.encodeKey(end_, options)   \n   \n  this.db.approximateSize(start, end, function (err, size) {   \n    if (err) {   \n      return dispatchError(self, new OpenError(err), callback)   \n    } else if (callback) {   \n      callback(null, size)   \n    }    \n  })   \n}, 'db.approximateSize() is deprecated. Use db.db.approximateSize() instead')\n\nLevelUP.prototype.readStream =\nLevelUP.prototype.createReadStream = function (options) {\n  options = extend( {keys: true, values: true}, this.options, options)\n\n  options.keyEncoding   = options.keyEncoding\n  options.valueEncoding = options.valueEncoding\n\n  options = this._codec.encodeLtgt(options);\n  options.keyAsBuffer   = this._codec.keyAsBuffer(options)\n  options.valueAsBuffer = this._codec.valueAsBuffer(options)\n\n  if ('number' !== typeof options.limit)\n    options.limit = -1\n\n  return new IteratorStream(this.db.iterator(options), extend(options, {\n    decoder: this._codec.createStreamDecoder(options)\n  }))\n}\n\nLevelUP.prototype.keyStream =\nLevelUP.prototype.createKeyStream = function (options) {\n  return this.createReadStream(extend(options, { keys: true, values: false }))\n}\n\nLevelUP.prototype.valueStream =\nLevelUP.prototype.createValueStream = function (options) {\n  return this.createReadStream(extend(options, { keys: false, values: true }))\n}\n\nLevelUP.prototype.toString = function () {\n  return 'LevelUP'\n}\n\nfunction utilStatic (name) {\n  return function (location, callback) {\n    getLevelDOWN()[name](location, callback || function () {})\n  }\n}\n\nmodule.exports         = LevelUP\nmodule.exports.errors  = require('level-errors')\nmodule.exports.destroy = deprecate(\n    utilStatic('destroy')\n  , 'levelup.destroy() is deprecated. Use leveldown.destroy() instead'\n)\nmodule.exports.repair  = deprecate(\n    utilStatic('repair')\n  , 'levelup.repair() is deprecated. Use leveldown.repair() instead'\n)\n\n","/* Copyright (c) 2012-2015 LevelUP contributors\n * See list at <https://github.com/level/levelup#contributing>\n * MIT License\n * <https://github.com/level/levelup/blob/master/LICENSE.md>\n */\n\nvar extend         = require('xtend')\n  , LevelUPError   = require('level-errors').LevelUPError\n  , format         = require('util').format\n  , defaultOptions = {\n        createIfMissing : true\n      , errorIfExists   : false\n      , keyEncoding     : 'utf8'\n      , valueEncoding   : 'utf8'\n      , compression     : true\n    }\n\n  , leveldown\n\nfunction getOptions (options) {\n  if (typeof options == 'string')\n    options = { valueEncoding: options }\n  if (typeof options != 'object')\n    options = {}\n  return options\n}\n\nfunction getLevelDOWN () {\n  if (leveldown)\n    return leveldown\n\n  var requiredVersion  = require('../package.json').devDependencies.leveldown\n    , leveldownVersion\n\n  try {\n    leveldownVersion = require('leveldown/package').version\n  } catch (e) {\n    throw requireError(e)\n  }\n\n  if (!require('semver').satisfies(leveldownVersion, requiredVersion)) {\n    throw new LevelUPError(\n        'Installed version of LevelDOWN ('\n      + leveldownVersion\n      + ') does not match required version ('\n      + requiredVersion\n      + ')'\n    )\n  }\n\n  try {\n    return leveldown = require('leveldown')\n  } catch (e) {\n    throw requireError(e)\n  }\n}\n\nfunction requireError (e) {\n  var template = 'Failed to require LevelDOWN (%s). Try `npm install leveldown` if it\\'s missing'\n  return new LevelUPError(format(template, e.message))\n}\n\nfunction dispatchError (db, error, callback) {\n  typeof callback == 'function' ? callback(error) : db.emit('error', error)\n}\n\nfunction isDefined (v) {\n  return typeof v !== 'undefined'\n}\n\nmodule.exports = {\n    defaultOptions  : defaultOptions\n  , getOptions      : getOptions\n  , getLevelDOWN    : getLevelDOWN\n  , dispatchError   : dispatchError\n  , isDefined       : isDefined\n}\n","module.exports={\n  \"_args\": [\n    [\n      \"levelup@~1.3.0\",\n      \"/Users/joran/Documents/development/patchdeck/node_modules/level-packager\"\n    ]\n  ],\n  \"_from\": \"levelup@>=1.3.0 <1.4.0\",\n  \"_id\": \"levelup@1.3.1\",\n  \"_inCache\": true,\n  \"_installable\": true,\n  \"_location\": \"/level-packager/levelup\",\n  \"_nodeVersion\": \"4.2.2\",\n  \"_npmUser\": {\n    \"email\": \"ralphtheninja@riseup.net\",\n    \"name\": \"ralphtheninja\"\n  },\n  \"_npmVersion\": \"3.5.0\",\n  \"_phantomChildren\": {},\n  \"_requested\": {\n    \"name\": \"levelup\",\n    \"raw\": \"levelup@~1.3.0\",\n    \"rawSpec\": \"~1.3.0\",\n    \"scope\": null,\n    \"spec\": \">=1.3.0 <1.4.0\",\n    \"type\": \"range\"\n  },\n  \"_requiredBy\": [\n    \"/level-packager\"\n  ],\n  \"_resolved\": \"https://registry.npmjs.org/levelup/-/levelup-1.3.1.tgz\",\n  \"_shasum\": \"8030758bb1b1dafdb71bfb55fff0caa2740cb846\",\n  \"_shrinkwrap\": null,\n  \"_spec\": \"levelup@~1.3.0\",\n  \"_where\": \"/Users/joran/Documents/development/patchdeck/node_modules/level-packager\",\n  \"browser\": {\n    \"leveldown\": false,\n    \"leveldown/package\": false,\n    \"semver\": false\n  },\n  \"bugs\": {\n    \"url\": \"https://github.com/level/levelup/issues\"\n  },\n  \"contributors\": [\n    {\n      \"name\": \"Julian Gruber\",\n      \"email\": \"julian@juliangruber.com\",\n      \"url\": \"https://github.com/juliangruber\"\n    },\n    {\n      \"name\": \"Rod Vagg\",\n      \"email\": \"r@va.gg\",\n      \"url\": \"https://github.com/rvagg\"\n    },\n    {\n      \"name\": \"Jake Verbaten\",\n      \"email\": \"raynos2@gmail.com\",\n      \"url\": \"https://github.com/raynos\"\n    },\n    {\n      \"name\": \"Dominic Tarr\",\n      \"email\": \"dominic.tarr@gmail.com\",\n      \"url\": \"https://github.com/dominictarr\"\n    },\n    {\n      \"name\": \"Max Ogden\",\n      \"email\": \"max@maxogden.com\",\n      \"url\": \"https://github.com/maxogden\"\n    },\n    {\n      \"name\": \"Lars-Magnus Skog\",\n      \"email\": \"ralphtheninja@riseup.net\",\n      \"url\": \"https://github.com/ralphtheninja\"\n    },\n    {\n      \"name\": \"David Björklund\",\n      \"email\": \"david.bjorklund@gmail.com\",\n      \"url\": \"https://github.com/kesla\"\n    },\n    {\n      \"name\": \"John Chesley\",\n      \"email\": \"john@chesl.es\",\n      \"url\": \"https://github.com/chesles/\"\n    },\n    {\n      \"name\": \"Paolo Fragomeni\",\n      \"email\": \"paolo@async.ly\",\n      \"url\": \"https://github.com/hij1nx\"\n    },\n    {\n      \"name\": \"Anton Whalley\",\n      \"email\": \"anton.whalley@nearform.com\",\n      \"url\": \"https://github.com/No9\"\n    },\n    {\n      \"name\": \"Matteo Collina\",\n      \"email\": \"matteo.collina@gmail.com\",\n      \"url\": \"https://github.com/mcollina\"\n    },\n    {\n      \"name\": \"Pedro Teixeira\",\n      \"email\": \"pedro.teixeira@gmail.com\",\n      \"url\": \"https://github.com/pgte\"\n    },\n    {\n      \"name\": \"James Halliday\",\n      \"email\": \"mail@substack.net\",\n      \"url\": \"https://github.com/substack\"\n    },\n    {\n      \"name\": \"Jarrett Cruger\",\n      \"email\": \"jcrugzz@gmail.com\",\n      \"url\": \"https://github.com/jcrugzz\"\n    }\n  ],\n  \"dependencies\": {\n    \"deferred-leveldown\": \"~1.2.1\",\n    \"level-codec\": \"~6.1.0\",\n    \"level-errors\": \"~1.0.3\",\n    \"level-iterator-stream\": \"~1.3.0\",\n    \"prr\": \"~1.0.1\",\n    \"semver\": \"~5.1.0\",\n    \"xtend\": \"~4.0.0\"\n  },\n  \"description\": \"Fast & simple storage - a Node.js-style LevelDB wrapper\",\n  \"devDependencies\": {\n    \"async\": \"~1.5.0\",\n    \"bustermove\": \"~1.0.0\",\n    \"delayed\": \"~1.0.1\",\n    \"faucet\": \"~0.0.1\",\n    \"leveldown\": \"^1.1.0\",\n    \"memdown\": \"~1.1.0\",\n    \"msgpack-js\": \"~0.3.0\",\n    \"referee\": \"~1.2.0\",\n    \"rimraf\": \"~2.4.3\",\n    \"slow-stream\": \"0.0.4\",\n    \"tap\": \"~2.3.1\",\n    \"tape\": \"~4.2.1\"\n  },\n  \"directories\": {},\n  \"dist\": {\n    \"shasum\": \"8030758bb1b1dafdb71bfb55fff0caa2740cb846\",\n    \"tarball\": \"https://registry.npmjs.org/levelup/-/levelup-1.3.1.tgz\"\n  },\n  \"gitHead\": \"40bd66872974140c79a74d9411b992ddffa926a4\",\n  \"homepage\": \"https://github.com/level/levelup\",\n  \"keywords\": [\n    \"database\",\n    \"db\",\n    \"json\",\n    \"leveldb\",\n    \"storage\",\n    \"store\",\n    \"stream\"\n  ],\n  \"license\": \"MIT\",\n  \"main\": \"lib/levelup.js\",\n  \"maintainers\": [\n    {\n      \"name\": \"rvagg\",\n      \"email\": \"rod@vagg.org\"\n    },\n    {\n      \"name\": \"ralphtheninja\",\n      \"email\": \"ralphtheninja@riseup.net\"\n    },\n    {\n      \"name\": \"juliangruber\",\n      \"email\": \"julian@juliangruber.com\"\n    }\n  ],\n  \"name\": \"levelup\",\n  \"optionalDependencies\": {},\n  \"readme\": \"ERROR: No README data found!\",\n  \"repository\": {\n    \"type\": \"git\",\n    \"url\": \"git+https://github.com/level/levelup.git\"\n  },\n  \"scripts\": {\n    \"test\": \"tape test/*-test.js | faucet\"\n  },\n  \"version\": \"1.3.1\"\n}\n","/*!\n  * prr\n  * (c) 2013 Rod Vagg <rod@vagg.org>\n  * https://github.com/rvagg/prr\n  * License: MIT\n  */\n\n(function (name, context, definition) {\n  if (typeof module != 'undefined' && module.exports)\n    module.exports = definition()\n  else\n    context[name] = definition()\n})('prr', this, function() {\n\n  var setProperty = typeof Object.defineProperty == 'function'\n      ? function (obj, key, options) {\n          Object.defineProperty(obj, key, options)\n          return obj\n        }\n      : function (obj, key, options) { // < es5\n          obj[key] = options.value\n          return obj\n        }\n\n    , makeOptions = function (value, options) {\n        var oo = typeof options == 'object'\n          , os = !oo && typeof options == 'string'\n          , op = function (p) {\n              return oo\n                ? !!options[p]\n                : os\n                  ? options.indexOf(p[0]) > -1\n                  : false\n            }\n\n        return {\n            enumerable   : op('enumerable')\n          , configurable : op('configurable')\n          , writable     : op('writable')\n          , value        : value\n        }\n      }\n\n    , prr = function (obj, key, value, options) {\n        var k\n\n        options = makeOptions(value, options)\n\n        if (typeof key == 'object') {\n          for (k in key) {\n            if (Object.hasOwnProperty.call(key, k)) {\n              options.value = key[k]\n              setProperty(obj, k, options)\n            }\n          }\n          return obj\n        }\n\n        return setProperty(obj, key, options)\n      }\n\n  return prr\n})","\nvar sr = require('string-range')\nvar defined = require('defined')\nvar beq = require('buffer-equal')\n\nfunction eq (a, b) {\n  if (Buffer.isBuffer(a) && Buffer.isBuffer(b)) {\n    return beq(a, b)\n  }\n  else return a === b\n}\n\nmodule.exports = function post (db, opts, each) {\n  if(!each)\n    each = opts, opts = {}\n\n  if('function' === typeof db.post)\n    return db.post(opts, each)\n\n  var encode = (opts && opts.keyEncoding && opts.keyEncoding.encode)\n    || (db.options && db.options.keyEncoding && db.options.keyEncoding.encode)\n    || function (x) { return x }\n\n  var min = defined(opts.min, opts.gt, opts.gte, opts.start)\n  var max = defined(opts.max, opts.lt, opts.lte, opts.end)\n\n  var copts = {}\n  if (min !== undefined) copts.min = encode(min)\n  if (max !== undefined) copts.max = encode(max)\n  var checker = sr.checker(copts)\n \n  function cmp (key) {\n    var ek = encode(key)\n    if (opts.gt && eq(ek, copts.min)) return false\n    if (opts.lt && eq(ek, copts.max)) return false\n    return checker(ek)\n  }\n\n  function onPut (key, val) {\n    if(cmp(key))\n      each({type: 'put', key: key, value: val})\n  }\n\n  function onDel (key, val) {\n    if(cmp(key))\n      each({type: 'del', key: key, value: val})\n  }\n\n  function onBatch (ary) {\n    ary.forEach(function (op) {\n      if(cmp(op.key))\n        each(op)\n    })\n  }\n\n  db.on('put', onPut)\n  db.on('del', onDel)\n  db.on('batch', onBatch)\n\n  return function () {\n    db.removeListener('put', onPut)\n    db.removeListener('del', onPut)\n    db.removeListener('batch', onPut)\n  }\n}\n","module.exports = require('level-packager')(require('leveldown'))","const util                 = require('util')\n    , AbstractChainedBatch = require('abstract-leveldown').AbstractChainedBatch\n\n\nfunction ChainedBatch (db) {\n  AbstractChainedBatch.call(this, db)\n  this.binding = db.binding.batch()\n}\n\n\nChainedBatch.prototype._put = function (key, value) {\n  this.binding.put(key, value)\n}\n\n\nChainedBatch.prototype._del = function (key) {\n  this.binding.del(key)\n}\n\n\nChainedBatch.prototype._clear = function (key) {\n  this.binding.clear(key)\n}\n\n\nChainedBatch.prototype._write = function (options, callback) {\n  this.binding.write(options, callback)\n}\n\nutil.inherits(ChainedBatch, AbstractChainedBatch)\n\n\nmodule.exports = ChainedBatch","const util             = require('util')\n    , AbstractIterator = require('abstract-leveldown').AbstractIterator\n    , fastFuture       = require('fast-future')\n\n\nfunction Iterator (db, options) {\n  AbstractIterator.call(this, db)\n\n  this.binding    = db.binding.iterator(options)\n  this.cache      = null\n  this.finished   = false\n  this.fastFuture = fastFuture()\n}\n\nutil.inherits(Iterator, AbstractIterator)\n\nIterator.prototype.seek = function (key) {\n  if (typeof key !== 'string')\n    throw new Error('seek requires a string key')\n  this.cache = null\n  this.binding.seek(key)\n}\n\nIterator.prototype._next = function (callback) {\n  var that = this\n    , key\n    , value\n\n  if (this.cache && this.cache.length) {\n    key   = this.cache.pop()\n    value = this.cache.pop()\n\n    this.fastFuture(function () {\n      callback(null, key, value)\n    })\n\n  } else if (this.finished) {\n    this.fastFuture(function () {\n      callback()\n    })\n  } else {\n    this.binding.next(function (err, array, finished) {\n      if (err) return callback(err)\n\n      that.cache    = array\n      that.finished = finished\n      that._next(callback)\n    })\n  }\n\n  return this\n}\n\n\nIterator.prototype._end = function (callback) {\n  delete this.cache\n  this.binding.end(callback)\n}\n\n\nmodule.exports = Iterator\n","const util              = require('util')\n    , AbstractLevelDOWN = require('abstract-leveldown').AbstractLevelDOWN\n\n    , binding           = require('bindings')('leveldown').leveldown\n\n    , ChainedBatch      = require('./chained-batch')\n    , Iterator          = require('./iterator')\n\n\nfunction LevelDOWN (location) {\n  if (!(this instanceof LevelDOWN))\n    return new LevelDOWN(location)\n\n  AbstractLevelDOWN.call(this, location)\n  this.binding = binding(location)\n}\n\nutil.inherits(LevelDOWN, AbstractLevelDOWN)\n\n\nLevelDOWN.prototype._open = function (options, callback) {\n  this.binding.open(options, callback)\n}\n\n\nLevelDOWN.prototype._close = function (callback) {\n  this.binding.close(callback)\n}\n\n\nLevelDOWN.prototype._put = function (key, value, options, callback) {\n  this.binding.put(key, value, options, callback)\n}\n\n\nLevelDOWN.prototype._get = function (key, options, callback) {\n  this.binding.get(key, options, callback)\n}\n\n\nLevelDOWN.prototype._del = function (key, options, callback) {\n  this.binding.del(key, options, callback)\n}\n\n\nLevelDOWN.prototype._chainedBatch = function () {\n  return new ChainedBatch(this)\n}\n\n\nLevelDOWN.prototype._batch = function (operations, options, callback) {\n  return this.binding.batch(operations, options, callback)\n}\n\n\nLevelDOWN.prototype._approximateSize = function (start, end, callback) {\n  this.binding.approximateSize(start, end, callback)\n}\n\n\nLevelDOWN.prototype.getProperty = function (property) {\n  if (typeof property != 'string')\n    throw new Error('getProperty() requires a valid `property` argument')\n\n  return this.binding.getProperty(property)\n}\n\n\nLevelDOWN.prototype._iterator = function (options) {\n  return new Iterator(this, options)\n}\n\n\nLevelDOWN.destroy = function (location, callback) {\n  if (arguments.length < 2)\n    throw new Error('destroy() requires `location` and `callback` arguments')\n\n  if (typeof location != 'string')\n    throw new Error('destroy() requires a location string argument')\n\n  if (typeof callback != 'function')\n    throw new Error('destroy() requires a callback function argument')\n\n  binding.destroy(location, callback)\n}\n\n\nLevelDOWN.repair = function (location, callback) {\n  if (arguments.length < 2)\n    throw new Error('repair() requires `location` and `callback` arguments')\n\n  if (typeof location != 'string')\n    throw new Error('repair() requires a location string argument')\n\n  if (typeof callback != 'function')\n    throw new Error('repair() requires a callback function argument')\n\n  binding.repair(location, callback)\n}\n\n\nmodule.exports = LevelDOWN\n","/* Copyright (c) 2013 Rod Vagg, MIT License */\n\nfunction AbstractChainedBatch (db) {\n  this._db         = db\n  this._operations = []\n  this._written    = false\n}\n\nAbstractChainedBatch.prototype._checkWritten = function () {\n  if (this._written)\n    throw new Error('write() already called on this batch')\n}\n\nAbstractChainedBatch.prototype.put = function (key, value) {\n  this._checkWritten()\n\n  var err = this._db._checkKey(key, 'key', this._db._isBuffer)\n  if (err)\n    throw err\n\n  if (!this._db._isBuffer(key)) key = String(key)\n  if (!this._db._isBuffer(value)) value = String(value)\n\n  if (typeof this._put == 'function' )\n    this._put(key, value)\n  else\n    this._operations.push({ type: 'put', key: key, value: value })\n\n  return this\n}\n\nAbstractChainedBatch.prototype.del = function (key) {\n  this._checkWritten()\n\n  var err = this._db._checkKey(key, 'key', this._db._isBuffer)\n  if (err) throw err\n\n  if (!this._db._isBuffer(key)) key = String(key)\n\n  if (typeof this._del == 'function' )\n    this._del(key)\n  else\n    this._operations.push({ type: 'del', key: key })\n\n  return this\n}\n\nAbstractChainedBatch.prototype.clear = function () {\n  this._checkWritten()\n\n  this._operations = []\n\n  if (typeof this._clear == 'function' )\n    this._clear()\n\n  return this\n}\n\nAbstractChainedBatch.prototype.write = function (options, callback) {\n  this._checkWritten()\n\n  if (typeof options == 'function')\n    callback = options\n  if (typeof callback != 'function')\n    throw new Error('write() requires a callback argument')\n  if (typeof options != 'object')\n    options = {}\n\n  this._written = true\n\n  if (typeof this._write == 'function' )\n    return this._write(callback)\n\n  if (typeof this._db._batch == 'function')\n    return this._db._batch(this._operations, options, callback)\n\n  process.nextTick(callback)\n}\n\nmodule.exports = AbstractChainedBatch","/* Copyright (c) 2013 Rod Vagg, MIT License */\n\nfunction AbstractIterator (db) {\n  this.db = db\n  this._ended = false\n  this._nexting = false\n}\n\nAbstractIterator.prototype.next = function (callback) {\n  var self = this\n\n  if (typeof callback != 'function')\n    throw new Error('next() requires a callback argument')\n\n  if (self._ended)\n    return callback(new Error('cannot call next() after end()'))\n  if (self._nexting)\n    return callback(new Error('cannot call next() before previous next() has completed'))\n\n  self._nexting = true\n  if (typeof self._next == 'function') {\n    return self._next(function () {\n      self._nexting = false\n      callback.apply(null, arguments)\n    })\n  }\n\n  process.nextTick(function () {\n    self._nexting = false\n    callback()\n  })\n}\n\nAbstractIterator.prototype.end = function (callback) {\n  if (typeof callback != 'function')\n    throw new Error('end() requires a callback argument')\n\n  if (this._ended)\n    return callback(new Error('end() already called on iterator'))\n\n  this._ended = true\n\n  if (typeof this._end == 'function')\n    return this._end(callback)\n\n  process.nextTick(callback)\n}\n\nmodule.exports = AbstractIterator\n","/* Copyright (c) 2013 Rod Vagg, MIT License */\n\nvar xtend                = require('xtend')\n  , AbstractIterator     = require('./abstract-iterator')\n  , AbstractChainedBatch = require('./abstract-chained-batch')\n\nfunction AbstractLevelDOWN (location) {\n  if (!arguments.length || location === undefined)\n    throw new Error('constructor requires at least a location argument')\n\n  if (typeof location != 'string')\n    throw new Error('constructor requires a location string argument')\n\n  this.location = location\n  this.status = 'new'\n}\n\nAbstractLevelDOWN.prototype.open = function (options, callback) {\n  var self      = this\n    , oldStatus = this.status\n\n  if (typeof options == 'function')\n    callback = options\n\n  if (typeof callback != 'function')\n    throw new Error('open() requires a callback argument')\n\n  if (typeof options != 'object')\n    options = {}\n\n  options.createIfMissing = options.createIfMissing != false\n  options.errorIfExists = !!options.errorIfExists\n\n  if (typeof this._open == 'function') {\n    this.status = 'opening'\n    this._open(options, function (err) {\n      if (err) {\n        self.status = oldStatus\n        return callback(err)\n      }\n      self.status = 'open'\n      callback()\n    })\n  } else {\n    this.status = 'open'\n    process.nextTick(callback)\n  }\n}\n\nAbstractLevelDOWN.prototype.close = function (callback) {\n  var self      = this\n    , oldStatus = this.status\n\n  if (typeof callback != 'function')\n    throw new Error('close() requires a callback argument')\n\n  if (typeof this._close == 'function') {\n    this.status = 'closing'\n    this._close(function (err) {\n      if (err) {\n        self.status = oldStatus\n        return callback(err)\n      }\n      self.status = 'closed'\n      callback()\n    })\n  } else {\n    this.status = 'closed'\n    process.nextTick(callback)\n  }\n}\n\nAbstractLevelDOWN.prototype.get = function (key, options, callback) {\n  var err\n\n  if (typeof options == 'function')\n    callback = options\n\n  if (typeof callback != 'function')\n    throw new Error('get() requires a callback argument')\n\n  if (err = this._checkKey(key, 'key', this._isBuffer))\n    return callback(err)\n\n  if (!this._isBuffer(key))\n    key = String(key)\n\n  if (typeof options != 'object')\n    options = {}\n\n  options.asBuffer = options.asBuffer != false\n\n  if (typeof this._get == 'function')\n    return this._get(key, options, callback)\n\n  process.nextTick(function () { callback(new Error('NotFound')) })\n}\n\nAbstractLevelDOWN.prototype.put = function (key, value, options, callback) {\n  var err\n\n  if (typeof options == 'function')\n    callback = options\n\n  if (typeof callback != 'function')\n    throw new Error('put() requires a callback argument')\n\n  if (err = this._checkKey(key, 'key', this._isBuffer))\n    return callback(err)\n\n  if (!this._isBuffer(key))\n    key = String(key)\n\n  // coerce value to string in node, don't touch it in browser\n  // (indexeddb can store any JS type)\n  if (value != null && !this._isBuffer(value) && !process.browser)\n    value = String(value)\n\n  if (typeof options != 'object')\n    options = {}\n\n  if (typeof this._put == 'function')\n    return this._put(key, value, options, callback)\n\n  process.nextTick(callback)\n}\n\nAbstractLevelDOWN.prototype.del = function (key, options, callback) {\n  var err\n\n  if (typeof options == 'function')\n    callback = options\n\n  if (typeof callback != 'function')\n    throw new Error('del() requires a callback argument')\n\n  if (err = this._checkKey(key, 'key', this._isBuffer))\n    return callback(err)\n\n  if (!this._isBuffer(key))\n    key = String(key)\n\n  if (typeof options != 'object')\n    options = {}\n\n  if (typeof this._del == 'function')\n    return this._del(key, options, callback)\n\n  process.nextTick(callback)\n}\n\nAbstractLevelDOWN.prototype.batch = function (array, options, callback) {\n  if (!arguments.length)\n    return this._chainedBatch()\n\n  if (typeof options == 'function')\n    callback = options\n\n  if (typeof array == 'function')\n    callback = array\n\n  if (typeof callback != 'function')\n    throw new Error('batch(array) requires a callback argument')\n\n  if (!Array.isArray(array))\n    return callback(new Error('batch(array) requires an array argument'))\n\n  if (!options || typeof options != 'object')\n    options = {}\n\n  var i = 0\n    , l = array.length\n    , e\n    , err\n\n  for (; i < l; i++) {\n    e = array[i]\n    if (typeof e != 'object')\n      continue\n\n    if (err = this._checkKey(e.type, 'type', this._isBuffer))\n      return callback(err)\n\n    if (err = this._checkKey(e.key, 'key', this._isBuffer))\n      return callback(err)\n  }\n\n  if (typeof this._batch == 'function')\n    return this._batch(array, options, callback)\n\n  process.nextTick(callback)\n}\n\n//TODO: remove from here, not a necessary primitive\nAbstractLevelDOWN.prototype.approximateSize = function (start, end, callback) {\n  if (   start == null\n      || end == null\n      || typeof start == 'function'\n      || typeof end == 'function') {\n    throw new Error('approximateSize() requires valid `start`, `end` and `callback` arguments')\n  }\n\n  if (typeof callback != 'function')\n    throw new Error('approximateSize() requires a callback argument')\n\n  if (!this._isBuffer(start))\n    start = String(start)\n\n  if (!this._isBuffer(end))\n    end = String(end)\n\n  if (typeof this._approximateSize == 'function')\n    return this._approximateSize(start, end, callback)\n\n  process.nextTick(function () {\n    callback(null, 0)\n  })\n}\n\nAbstractLevelDOWN.prototype._setupIteratorOptions = function (options) {\n  var self = this\n\n  options = xtend(options)\n\n  ;[ 'start', 'end', 'gt', 'gte', 'lt', 'lte' ].forEach(function (o) {\n    if (options[o] && self._isBuffer(options[o]) && options[o].length === 0)\n      delete options[o]\n  })\n\n  options.reverse = !!options.reverse\n  options.keys = options.keys != false\n  options.values = options.values != false\n  options.limit = 'limit' in options ? options.limit : -1\n  options.keyAsBuffer = options.keyAsBuffer != false\n  options.valueAsBuffer = options.valueAsBuffer != false\n\n  return options\n}\n\nAbstractLevelDOWN.prototype.iterator = function (options) {\n  if (typeof options != 'object')\n    options = {}\n\n  options = this._setupIteratorOptions(options)\n\n  if (typeof this._iterator == 'function')\n    return this._iterator(options)\n\n  return new AbstractIterator(this)\n}\n\nAbstractLevelDOWN.prototype._chainedBatch = function () {\n  return new AbstractChainedBatch(this)\n}\n\nAbstractLevelDOWN.prototype._isBuffer = function (obj) {\n  return Buffer.isBuffer(obj)\n}\n\nAbstractLevelDOWN.prototype._checkKey = function (obj, type) {\n\n  if (obj === null || obj === undefined)\n    return new Error(type + ' cannot be `null` or `undefined`')\n\n  if (this._isBuffer(obj)) {\n    if (obj.length === 0)\n      return new Error(type + ' cannot be an empty Buffer')\n  } else if (String(obj) === '')\n    return new Error(type + ' cannot be an empty String')\n}\n\nmodule.exports = AbstractLevelDOWN\n","/* Copyright (c) 2012-2014 LevelUP contributors\n * See list at <https://github.com/rvagg/node-levelup#contributing>\n * MIT License\n * <https://github.com/rvagg/node-levelup/blob/master/LICENSE.md>\n */\n\nvar encodings = require('./encodings')\n\nfunction getKeyEncoder (options, op) {\n  var type = ((op && op.keyEncoding) || options.keyEncoding) || 'utf8'\n  return encodings[type] || type\n}\n\nfunction getValueEncoder (options, op) {\n  var type = (((op && (op.valueEncoding || op.encoding))\n      || options.valueEncoding || options.encoding)) || 'utf8'\n  return encodings[type] || type\n}\n\n/*\n  Encode a key.\n  This method takes two options, because the leveldb instance\n  has options, and this operation (a put, del, or batch)\n  also has options that may override the leveldb's options.\n*/\n\nfunction encodeKey (key, options, op) {\n  return getKeyEncoder(options, op).encode(key)\n}\n\n/*\n  Encode a value.\n  Takes 2 options, for the same reason as encodeKey\n*/\n\nfunction encodeValue (value, options, op) {\n  return getValueEncoder(options, op).encode(value)\n}\n\n/*\n  Decode an encoded key\n*/\n\nfunction decodeKey (key, options) {\n  return getKeyEncoder(options).decode(key)\n}\n\n/*\n  Decode an encoded value\n*/\n\nfunction decodeValue (value, options) {\n  return getValueEncoder(options).decode(value)\n}\n\n/*\n  check whether this value should be requested as a buffer\n  (if false, then it will be a string)\n  this allows an optimization in leveldown where leveldown\n  retrives a string directly, and thus avoids a memory copy.\n*/\n\nfunction isValueAsBuffer (options, op) {\n  return getValueEncoder(options, op).buffer\n}\n\n/*\n  check whether a given key should be requested as a buffer.\n*/\n\nfunction isKeyAsBuffer (options, op) {\n  return getKeyEncoder(options, op).buffer\n}\n\n\nmodule.exports = {\n    encodeKey       : encodeKey\n  , encodeValue     : encodeValue\n  , isValueAsBuffer : isValueAsBuffer\n  , isKeyAsBuffer   : isKeyAsBuffer\n  , decodeValue     : decodeValue\n  , decodeKey       : decodeKey\n}\n","/* Copyright (c) 2012-2014 LevelUP contributors\n * See list at <https://github.com/rvagg/node-levelup#contributing>\n * MIT License\n * <https://github.com/rvagg/node-levelup/blob/master/LICENSE.md>\n */\n\nvar encodingNames = [\n        'hex'\n      , 'utf8'\n      , 'utf-8'\n      , 'ascii'\n      , 'binary'\n      , 'base64'\n      , 'ucs2'\n      , 'ucs-2'\n      , 'utf16le'\n      , 'utf-16le'\n    ]\n\nmodule.exports = (function () {\n  function isBinary (data) {\n    return data === undefined || data === null || Buffer.isBuffer(data)\n  }\n\n  var encodings = {}\n\n  encodings.utf8 = encodings['utf-8'] = {\n      encode : function (data) {\n        return isBinary(data) ? data : String(data)\n      }\n    , decode : function (data) { return data }\n    , buffer : false\n    , type   : 'utf8'\n  }\n\n  encodings.json = {\n      encode : JSON.stringify\n    , decode : JSON.parse\n    , buffer : false\n    , type   : 'json'\n  }\n\n  encodings.binary = {\n      encode : function (data) {\n        return isBinary(data) ? data : new Buffer(data)\n      }\n    , decode : function (data) {\n        return data\n      }\n    , buffer : true\n    , type   : 'binary'\n  }\n\n  encodingNames.forEach(function (type) {\n    if (encodings[type])\n      return\n\n    encodings[type] = {\n        encode : function (data) {\n          return isBinary(data) ? data : new Buffer(data, type)\n        }\n      , decode : function (buffer) {\n          return buffer.toString(type)\n        }\n      , buffer : true\n      , type   : type // useful for debugging purposes\n    }\n  })\n\n  return encodings\n})()\n\n","/* Copyright (c) 2012-2014 LevelUP contributors\n * See list at <https://github.com/rvagg/node-levelup#contributing>\n * MIT License\n * <https://github.com/rvagg/node-levelup/blob/master/LICENSE.md>\n */\n\nvar createError   = require('errno').create\n  , LevelUPError  = createError('LevelUPError')\n  , NotFoundError = createError('NotFoundError', LevelUPError)\n\nNotFoundError.prototype.notFound = true\nNotFoundError.prototype.status   = 404\n\nmodule.exports = {\n    LevelUPError        : LevelUPError\n  , InitializationError : createError('InitializationError', LevelUPError)\n  , OpenError           : createError('OpenError', LevelUPError)\n  , ReadError           : createError('ReadError', LevelUPError)\n  , WriteError          : createError('WriteError', LevelUPError)\n  , NotFoundError       : NotFoundError\n  , EncodingError       : createError('EncodingError', LevelUPError)\n}\n","/* Copyright (c) 2012-2014 LevelUP contributors\n * See list at <https://github.com/rvagg/node-levelup#contributing>\n * MIT License <https://github.com/rvagg/node-levelup/blob/master/LICENSE.md>\n */\n\n// NOTE: we are fixed to readable-stream@1.0.x for now\n// for pure Streams2 across Node versions\nvar Readable      = require('readable-stream').Readable\n  , inherits      = require('util').inherits\n  , extend        = require('xtend')\n  , EncodingError = require('./errors').EncodingError\n  , util          = require('./util')\n\n\n\nfunction ReadStream (options, makeData) {\n  if (!(this instanceof ReadStream))\n    return new ReadStream(options, makeData)\n\n  Readable.call(this, { objectMode: true, highWaterMark: options.highWaterMark })\n\n  // purely to keep `db` around until we're done so it's not GCed if the user doesn't keep a ref\n\n  this._waiting = false\n  this._options = options\n  this._makeData = makeData\n}\n\ninherits(ReadStream, Readable)\n\nReadStream.prototype.setIterator = function (it) {\n  var self = this\n  this._iterator = it\n  if(this._destroyed) return it.end(function () {})\n  if(this._waiting) {\n    this._waiting = false\n    return this._read()\n  }\n  return this\n}\n\nReadStream.prototype._read = function read () {\n  var self = this\n  if (self._destroyed)\n    return\n  if(!self._iterator)\n    return this._waiting = true\n\n  self._iterator.next(function(err, key, value) {\n    if (err || (key === undefined && value === undefined)) {\n      if (!err && !self._destroyed)\n        self.push(null)\n      return self._cleanup(err)\n    }\n\n\n    try {\n      value = self._makeData(key, value)\n    } catch (e) {\n      return self._cleanup(new EncodingError(e))\n    }\n    if (!self._destroyed)\n      self.push(value)\n  })\n}\n\nReadStream.prototype._cleanup = function (err) {\n  if (this._destroyed)\n    return\n\n  this._destroyed = true\n\n  var self = this\n  if (err)\n    self.emit('error', err)\n\n  if (self._iterator) {\n    self._iterator.end(function () {\n      self._iterator = null\n      self.emit('close')\n    })\n  } else {\n    self.emit('close')\n  }\n}\n\nReadStream.prototype.destroy = function () {\n  this._cleanup()\n}\n\nReadStream.prototype.toString = function () {\n  return 'LevelUP.ReadStream'\n}\n\n\nmodule.exports = ReadStream\n\n","/* Copyright (c) 2012-2014 LevelUP contributors\n * See list at <https://github.com/rvagg/node-levelup#contributing>\n * MIT License\n * <https://github.com/rvagg/node-levelup/blob/master/LICENSE.md>\n */\n\nvar extend        = require('xtend')\n  , LevelUPError  = require('./errors').LevelUPError\n  , encodings     = require('./encodings')\n  , defaultOptions = {\n        createIfMissing : true\n      , errorIfExists   : false\n      , keyEncoding     : 'utf8'\n      , valueEncoding   : 'utf8'\n      , compression     : true\n    }\n\n  , leveldown\n  , encodingOpts = (function () {\n      var eo = {}\n      for(var e in encodings)\n        eo[e] = {valueEncoding: encodings[e]}\n      return eo\n    }())\n\nfunction copy (srcdb, dstdb, callback) {\n  srcdb.readStream()\n    .pipe(dstdb.writeStream())\n    .on('close', callback ? callback : function () {})\n    .on('error', callback ? callback : function (err) { throw err })\n}\n\nfunction getOptions (levelup, options) {\n  var s = typeof options == 'string' // just an encoding\n  if (!s && options && options.encoding && !options.valueEncoding)\n    options.valueEncoding = options.encoding\n  return extend(\n      (levelup && levelup.options) || {}\n    , s ? encodingOpts[options] || encodingOpts[defaultOptions.valueEncoding]\n        : options\n  )\n}\n\nfunction getLevelDOWN () {\n  if (leveldown)\n    return leveldown\n\n  var requiredVersion       = require('../package.json').devDependencies.leveldown\n    , missingLevelDOWNError = 'Could not locate LevelDOWN, try `npm install leveldown`'\n    , leveldownVersion\n\n  try {\n    leveldownVersion = require('leveldown/package').version\n  } catch (e) {\n    throw new LevelUPError(missingLevelDOWNError)\n  }\n\n  if (!require('semver').satisfies(leveldownVersion, requiredVersion)) {\n    throw new LevelUPError(\n        'Installed version of LevelDOWN ('\n      + leveldownVersion\n      + ') does not match required version ('\n      + requiredVersion\n      + ')'\n    )\n  }\n\n  try {\n    return leveldown = require('leveldown')\n  } catch (e) {\n    throw new LevelUPError(missingLevelDOWNError)\n  }\n}\n\nfunction dispatchError (levelup, error, callback) {\n  return typeof callback == 'function'\n    ? callback(error)\n    : levelup.emit('error', error)\n}\n\nfunction isDefined (v) {\n  return typeof v !== 'undefined'\n}\n\nmodule.exports = {\n    defaultOptions  : defaultOptions\n  , copy            : copy\n  , getOptions      : getOptions\n  , getLevelDOWN    : getLevelDOWN\n  , dispatchError   : dispatchError\n  , isDefined       : isDefined\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a duplex stream is just a stream that is both readable and writable.\n// Since JS doesn't have multiple prototypal inheritance, this class\n// prototypally inherits from Readable, and then parasitically from\n// Writable.\n\nmodule.exports = Duplex;\n\n/*<replacement>*/\nvar objectKeys = Object.keys || function (obj) {\n  var keys = [];\n  for (var key in obj) keys.push(key);\n  return keys;\n}\n/*</replacement>*/\n\n\n/*<replacement>*/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/*</replacement>*/\n\nvar Readable = require('./_stream_readable');\nvar Writable = require('./_stream_writable');\n\nutil.inherits(Duplex, Readable);\n\nforEach(objectKeys(Writable.prototype), function(method) {\n  if (!Duplex.prototype[method])\n    Duplex.prototype[method] = Writable.prototype[method];\n});\n\nfunction Duplex(options) {\n  if (!(this instanceof Duplex))\n    return new Duplex(options);\n\n  Readable.call(this, options);\n  Writable.call(this, options);\n\n  if (options && options.readable === false)\n    this.readable = false;\n\n  if (options && options.writable === false)\n    this.writable = false;\n\n  this.allowHalfOpen = true;\n  if (options && options.allowHalfOpen === false)\n    this.allowHalfOpen = false;\n\n  this.once('end', onend);\n}\n\n// the no-half-open enforcer\nfunction onend() {\n  // if we allow half-open state, or if the writable side ended,\n  // then we're ok.\n  if (this.allowHalfOpen || this._writableState.ended)\n    return;\n\n  // no more data can be written.\n  // But allow more writes to happen in this tick.\n  process.nextTick(this.end.bind(this));\n}\n\nfunction forEach (xs, f) {\n  for (var i = 0, l = xs.length; i < l; i++) {\n    f(xs[i], i);\n  }\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a passthrough stream.\n// basically just the most minimal sort of Transform stream.\n// Every written chunk gets output as-is.\n\nmodule.exports = PassThrough;\n\nvar Transform = require('./_stream_transform');\n\n/*<replacement>*/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/*</replacement>*/\n\nutil.inherits(PassThrough, Transform);\n\nfunction PassThrough(options) {\n  if (!(this instanceof PassThrough))\n    return new PassThrough(options);\n\n  Transform.call(this, options);\n}\n\nPassThrough.prototype._transform = function(chunk, encoding, cb) {\n  cb(null, chunk);\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nmodule.exports = Readable;\n\n/*<replacement>*/\nvar isArray = require('isarray');\n/*</replacement>*/\n\n\n/*<replacement>*/\nvar Buffer = require('buffer').Buffer;\n/*</replacement>*/\n\nReadable.ReadableState = ReadableState;\n\nvar EE = require('events').EventEmitter;\n\n/*<replacement>*/\nif (!EE.listenerCount) EE.listenerCount = function(emitter, type) {\n  return emitter.listeners(type).length;\n};\n/*</replacement>*/\n\nvar Stream = require('stream');\n\n/*<replacement>*/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/*</replacement>*/\n\nvar StringDecoder;\n\nutil.inherits(Readable, Stream);\n\nfunction ReadableState(options, stream) {\n  options = options || {};\n\n  // the point at which it stops calling _read() to fill the buffer\n  // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n  var hwm = options.highWaterMark;\n  this.highWaterMark = (hwm || hwm === 0) ? hwm : 16 * 1024;\n\n  // cast to ints.\n  this.highWaterMark = ~~this.highWaterMark;\n\n  this.buffer = [];\n  this.length = 0;\n  this.pipes = null;\n  this.pipesCount = 0;\n  this.flowing = false;\n  this.ended = false;\n  this.endEmitted = false;\n  this.reading = false;\n\n  // In streams that never have any data, and do push(null) right away,\n  // the consumer can miss the 'end' event if they do some I/O before\n  // consuming the stream.  So, we don't emit('end') until some reading\n  // happens.\n  this.calledRead = false;\n\n  // a flag to be able to tell if the onwrite cb is called immediately,\n  // or on a later tick.  We set this to true at first, becuase any\n  // actions that shouldn't happen until \"later\" should generally also\n  // not happen before the first write call.\n  this.sync = true;\n\n  // whenever we return null, then we set a flag to say\n  // that we're awaiting a 'readable' event emission.\n  this.needReadable = false;\n  this.emittedReadable = false;\n  this.readableListening = false;\n\n\n  // object stream flag. Used to make read(n) ignore n and to\n  // make all the buffer merging and length checks go away\n  this.objectMode = !!options.objectMode;\n\n  // Crypto is kind of old and crusty.  Historically, its default string\n  // encoding is 'binary' so we have to make this configurable.\n  // Everything else in the universe uses 'utf8', though.\n  this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n  // when piping, we only care about 'readable' events that happen\n  // after read()ing all the bytes and not getting any pushback.\n  this.ranOut = false;\n\n  // the number of writers that are awaiting a drain event in .pipe()s\n  this.awaitDrain = 0;\n\n  // if true, a maybeReadMore has been scheduled\n  this.readingMore = false;\n\n  this.decoder = null;\n  this.encoding = null;\n  if (options.encoding) {\n    if (!StringDecoder)\n      StringDecoder = require('string_decoder/').StringDecoder;\n    this.decoder = new StringDecoder(options.encoding);\n    this.encoding = options.encoding;\n  }\n}\n\nfunction Readable(options) {\n  if (!(this instanceof Readable))\n    return new Readable(options);\n\n  this._readableState = new ReadableState(options, this);\n\n  // legacy\n  this.readable = true;\n\n  Stream.call(this);\n}\n\n// Manually shove something into the read() buffer.\n// This returns true if the highWaterMark has not been hit yet,\n// similar to how Writable.write() returns true if you should\n// write() some more.\nReadable.prototype.push = function(chunk, encoding) {\n  var state = this._readableState;\n\n  if (typeof chunk === 'string' && !state.objectMode) {\n    encoding = encoding || state.defaultEncoding;\n    if (encoding !== state.encoding) {\n      chunk = new Buffer(chunk, encoding);\n      encoding = '';\n    }\n  }\n\n  return readableAddChunk(this, state, chunk, encoding, false);\n};\n\n// Unshift should *always* be something directly out of read()\nReadable.prototype.unshift = function(chunk) {\n  var state = this._readableState;\n  return readableAddChunk(this, state, chunk, '', true);\n};\n\nfunction readableAddChunk(stream, state, chunk, encoding, addToFront) {\n  var er = chunkInvalid(state, chunk);\n  if (er) {\n    stream.emit('error', er);\n  } else if (chunk === null || chunk === undefined) {\n    state.reading = false;\n    if (!state.ended)\n      onEofChunk(stream, state);\n  } else if (state.objectMode || chunk && chunk.length > 0) {\n    if (state.ended && !addToFront) {\n      var e = new Error('stream.push() after EOF');\n      stream.emit('error', e);\n    } else if (state.endEmitted && addToFront) {\n      var e = new Error('stream.unshift() after end event');\n      stream.emit('error', e);\n    } else {\n      if (state.decoder && !addToFront && !encoding)\n        chunk = state.decoder.write(chunk);\n\n      // update the buffer info.\n      state.length += state.objectMode ? 1 : chunk.length;\n      if (addToFront) {\n        state.buffer.unshift(chunk);\n      } else {\n        state.reading = false;\n        state.buffer.push(chunk);\n      }\n\n      if (state.needReadable)\n        emitReadable(stream);\n\n      maybeReadMore(stream, state);\n    }\n  } else if (!addToFront) {\n    state.reading = false;\n  }\n\n  return needMoreData(state);\n}\n\n\n\n// if it's past the high water mark, we can push in some more.\n// Also, if we have no data yet, we can stand some\n// more bytes.  This is to work around cases where hwm=0,\n// such as the repl.  Also, if the push() triggered a\n// readable event, and the user called read(largeNumber) such that\n// needReadable was set, then we ought to push more, so that another\n// 'readable' event will be triggered.\nfunction needMoreData(state) {\n  return !state.ended &&\n         (state.needReadable ||\n          state.length < state.highWaterMark ||\n          state.length === 0);\n}\n\n// backwards compatibility.\nReadable.prototype.setEncoding = function(enc) {\n  if (!StringDecoder)\n    StringDecoder = require('string_decoder/').StringDecoder;\n  this._readableState.decoder = new StringDecoder(enc);\n  this._readableState.encoding = enc;\n};\n\n// Don't raise the hwm > 128MB\nvar MAX_HWM = 0x800000;\nfunction roundUpToNextPowerOf2(n) {\n  if (n >= MAX_HWM) {\n    n = MAX_HWM;\n  } else {\n    // Get the next highest power of 2\n    n--;\n    for (var p = 1; p < 32; p <<= 1) n |= n >> p;\n    n++;\n  }\n  return n;\n}\n\nfunction howMuchToRead(n, state) {\n  if (state.length === 0 && state.ended)\n    return 0;\n\n  if (state.objectMode)\n    return n === 0 ? 0 : 1;\n\n  if (n === null || isNaN(n)) {\n    // only flow one buffer at a time\n    if (state.flowing && state.buffer.length)\n      return state.buffer[0].length;\n    else\n      return state.length;\n  }\n\n  if (n <= 0)\n    return 0;\n\n  // If we're asking for more than the target buffer level,\n  // then raise the water mark.  Bump up to the next highest\n  // power of 2, to prevent increasing it excessively in tiny\n  // amounts.\n  if (n > state.highWaterMark)\n    state.highWaterMark = roundUpToNextPowerOf2(n);\n\n  // don't have that much.  return null, unless we've ended.\n  if (n > state.length) {\n    if (!state.ended) {\n      state.needReadable = true;\n      return 0;\n    } else\n      return state.length;\n  }\n\n  return n;\n}\n\n// you can override either this method, or the async _read(n) below.\nReadable.prototype.read = function(n) {\n  var state = this._readableState;\n  state.calledRead = true;\n  var nOrig = n;\n  var ret;\n\n  if (typeof n !== 'number' || n > 0)\n    state.emittedReadable = false;\n\n  // if we're doing read(0) to trigger a readable event, but we\n  // already have a bunch of data in the buffer, then just trigger\n  // the 'readable' event and move on.\n  if (n === 0 &&\n      state.needReadable &&\n      (state.length >= state.highWaterMark || state.ended)) {\n    emitReadable(this);\n    return null;\n  }\n\n  n = howMuchToRead(n, state);\n\n  // if we've ended, and we're now clear, then finish it up.\n  if (n === 0 && state.ended) {\n    ret = null;\n\n    // In cases where the decoder did not receive enough data\n    // to produce a full chunk, then immediately received an\n    // EOF, state.buffer will contain [<Buffer >, <Buffer 00 ...>].\n    // howMuchToRead will see this and coerce the amount to\n    // read to zero (because it's looking at the length of the\n    // first <Buffer > in state.buffer), and we'll end up here.\n    //\n    // This can only happen via state.decoder -- no other venue\n    // exists for pushing a zero-length chunk into state.buffer\n    // and triggering this behavior. In this case, we return our\n    // remaining data and end the stream, if appropriate.\n    if (state.length > 0 && state.decoder) {\n      ret = fromList(n, state);\n      state.length -= ret.length;\n    }\n\n    if (state.length === 0)\n      endReadable(this);\n\n    return ret;\n  }\n\n  // All the actual chunk generation logic needs to be\n  // *below* the call to _read.  The reason is that in certain\n  // synthetic stream cases, such as passthrough streams, _read\n  // may be a completely synchronous operation which may change\n  // the state of the read buffer, providing enough data when\n  // before there was *not* enough.\n  //\n  // So, the steps are:\n  // 1. Figure out what the state of things will be after we do\n  // a read from the buffer.\n  //\n  // 2. If that resulting state will trigger a _read, then call _read.\n  // Note that this may be asynchronous, or synchronous.  Yes, it is\n  // deeply ugly to write APIs this way, but that still doesn't mean\n  // that the Readable class should behave improperly, as streams are\n  // designed to be sync/async agnostic.\n  // Take note if the _read call is sync or async (ie, if the read call\n  // has returned yet), so that we know whether or not it's safe to emit\n  // 'readable' etc.\n  //\n  // 3. Actually pull the requested chunks out of the buffer and return.\n\n  // if we need a readable event, then we need to do some reading.\n  var doRead = state.needReadable;\n\n  // if we currently have less than the highWaterMark, then also read some\n  if (state.length - n <= state.highWaterMark)\n    doRead = true;\n\n  // however, if we've ended, then there's no point, and if we're already\n  // reading, then it's unnecessary.\n  if (state.ended || state.reading)\n    doRead = false;\n\n  if (doRead) {\n    state.reading = true;\n    state.sync = true;\n    // if the length is currently zero, then we *need* a readable event.\n    if (state.length === 0)\n      state.needReadable = true;\n    // call internal read method\n    this._read(state.highWaterMark);\n    state.sync = false;\n  }\n\n  // If _read called its callback synchronously, then `reading`\n  // will be false, and we need to re-evaluate how much data we\n  // can return to the user.\n  if (doRead && !state.reading)\n    n = howMuchToRead(nOrig, state);\n\n  if (n > 0)\n    ret = fromList(n, state);\n  else\n    ret = null;\n\n  if (ret === null) {\n    state.needReadable = true;\n    n = 0;\n  }\n\n  state.length -= n;\n\n  // If we have nothing in the buffer, then we want to know\n  // as soon as we *do* get something into the buffer.\n  if (state.length === 0 && !state.ended)\n    state.needReadable = true;\n\n  // If we happened to read() exactly the remaining amount in the\n  // buffer, and the EOF has been seen at this point, then make sure\n  // that we emit 'end' on the very next tick.\n  if (state.ended && !state.endEmitted && state.length === 0)\n    endReadable(this);\n\n  return ret;\n};\n\nfunction chunkInvalid(state, chunk) {\n  var er = null;\n  if (!Buffer.isBuffer(chunk) &&\n      'string' !== typeof chunk &&\n      chunk !== null &&\n      chunk !== undefined &&\n      !state.objectMode) {\n    er = new TypeError('Invalid non-string/buffer chunk');\n  }\n  return er;\n}\n\n\nfunction onEofChunk(stream, state) {\n  if (state.decoder && !state.ended) {\n    var chunk = state.decoder.end();\n    if (chunk && chunk.length) {\n      state.buffer.push(chunk);\n      state.length += state.objectMode ? 1 : chunk.length;\n    }\n  }\n  state.ended = true;\n\n  // if we've ended and we have some data left, then emit\n  // 'readable' now to make sure it gets picked up.\n  if (state.length > 0)\n    emitReadable(stream);\n  else\n    endReadable(stream);\n}\n\n// Don't emit readable right away in sync mode, because this can trigger\n// another read() call => stack overflow.  This way, it might trigger\n// a nextTick recursion warning, but that's not so bad.\nfunction emitReadable(stream) {\n  var state = stream._readableState;\n  state.needReadable = false;\n  if (state.emittedReadable)\n    return;\n\n  state.emittedReadable = true;\n  if (state.sync)\n    process.nextTick(function() {\n      emitReadable_(stream);\n    });\n  else\n    emitReadable_(stream);\n}\n\nfunction emitReadable_(stream) {\n  stream.emit('readable');\n}\n\n\n// at this point, the user has presumably seen the 'readable' event,\n// and called read() to consume some data.  that may have triggered\n// in turn another _read(n) call, in which case reading = true if\n// it's in progress.\n// However, if we're not ended, or reading, and the length < hwm,\n// then go ahead and try to read some more preemptively.\nfunction maybeReadMore(stream, state) {\n  if (!state.readingMore) {\n    state.readingMore = true;\n    process.nextTick(function() {\n      maybeReadMore_(stream, state);\n    });\n  }\n}\n\nfunction maybeReadMore_(stream, state) {\n  var len = state.length;\n  while (!state.reading && !state.flowing && !state.ended &&\n         state.length < state.highWaterMark) {\n    stream.read(0);\n    if (len === state.length)\n      // didn't get any data, stop spinning.\n      break;\n    else\n      len = state.length;\n  }\n  state.readingMore = false;\n}\n\n// abstract method.  to be overridden in specific implementation classes.\n// call cb(er, data) where data is <= n in length.\n// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n// arbitrary, and perhaps not very meaningful.\nReadable.prototype._read = function(n) {\n  this.emit('error', new Error('not implemented'));\n};\n\nReadable.prototype.pipe = function(dest, pipeOpts) {\n  var src = this;\n  var state = this._readableState;\n\n  switch (state.pipesCount) {\n    case 0:\n      state.pipes = dest;\n      break;\n    case 1:\n      state.pipes = [state.pipes, dest];\n      break;\n    default:\n      state.pipes.push(dest);\n      break;\n  }\n  state.pipesCount += 1;\n\n  var doEnd = (!pipeOpts || pipeOpts.end !== false) &&\n              dest !== process.stdout &&\n              dest !== process.stderr;\n\n  var endFn = doEnd ? onend : cleanup;\n  if (state.endEmitted)\n    process.nextTick(endFn);\n  else\n    src.once('end', endFn);\n\n  dest.on('unpipe', onunpipe);\n  function onunpipe(readable) {\n    if (readable !== src) return;\n    cleanup();\n  }\n\n  function onend() {\n    dest.end();\n  }\n\n  // when the dest drains, it reduces the awaitDrain counter\n  // on the source.  This would be more elegant with a .once()\n  // handler in flow(), but adding and removing repeatedly is\n  // too slow.\n  var ondrain = pipeOnDrain(src);\n  dest.on('drain', ondrain);\n\n  function cleanup() {\n    // cleanup event handlers once the pipe is broken\n    dest.removeListener('close', onclose);\n    dest.removeListener('finish', onfinish);\n    dest.removeListener('drain', ondrain);\n    dest.removeListener('error', onerror);\n    dest.removeListener('unpipe', onunpipe);\n    src.removeListener('end', onend);\n    src.removeListener('end', cleanup);\n\n    // if the reader is waiting for a drain event from this\n    // specific writer, then it would cause it to never start\n    // flowing again.\n    // So, if this is awaiting a drain, then we just call it now.\n    // If we don't know, then assume that we are waiting for one.\n    if (!dest._writableState || dest._writableState.needDrain)\n      ondrain();\n  }\n\n  // if the dest has an error, then stop piping into it.\n  // however, don't suppress the throwing behavior for this.\n  function onerror(er) {\n    unpipe();\n    dest.removeListener('error', onerror);\n    if (EE.listenerCount(dest, 'error') === 0)\n      dest.emit('error', er);\n  }\n  // This is a brutally ugly hack to make sure that our error handler\n  // is attached before any userland ones.  NEVER DO THIS.\n  if (!dest._events || !dest._events.error)\n    dest.on('error', onerror);\n  else if (isArray(dest._events.error))\n    dest._events.error.unshift(onerror);\n  else\n    dest._events.error = [onerror, dest._events.error];\n\n\n\n  // Both close and finish should trigger unpipe, but only once.\n  function onclose() {\n    dest.removeListener('finish', onfinish);\n    unpipe();\n  }\n  dest.once('close', onclose);\n  function onfinish() {\n    dest.removeListener('close', onclose);\n    unpipe();\n  }\n  dest.once('finish', onfinish);\n\n  function unpipe() {\n    src.unpipe(dest);\n  }\n\n  // tell the dest that it's being piped to\n  dest.emit('pipe', src);\n\n  // start the flow if it hasn't been started already.\n  if (!state.flowing) {\n    // the handler that waits for readable events after all\n    // the data gets sucked out in flow.\n    // This would be easier to follow with a .once() handler\n    // in flow(), but that is too slow.\n    this.on('readable', pipeOnReadable);\n\n    state.flowing = true;\n    process.nextTick(function() {\n      flow(src);\n    });\n  }\n\n  return dest;\n};\n\nfunction pipeOnDrain(src) {\n  return function() {\n    var dest = this;\n    var state = src._readableState;\n    state.awaitDrain--;\n    if (state.awaitDrain === 0)\n      flow(src);\n  };\n}\n\nfunction flow(src) {\n  var state = src._readableState;\n  var chunk;\n  state.awaitDrain = 0;\n\n  function write(dest, i, list) {\n    var written = dest.write(chunk);\n    if (false === written) {\n      state.awaitDrain++;\n    }\n  }\n\n  while (state.pipesCount && null !== (chunk = src.read())) {\n\n    if (state.pipesCount === 1)\n      write(state.pipes, 0, null);\n    else\n      forEach(state.pipes, write);\n\n    src.emit('data', chunk);\n\n    // if anyone needs a drain, then we have to wait for that.\n    if (state.awaitDrain > 0)\n      return;\n  }\n\n  // if every destination was unpiped, either before entering this\n  // function, or in the while loop, then stop flowing.\n  //\n  // NB: This is a pretty rare edge case.\n  if (state.pipesCount === 0) {\n    state.flowing = false;\n\n    // if there were data event listeners added, then switch to old mode.\n    if (EE.listenerCount(src, 'data') > 0)\n      emitDataEvents(src);\n    return;\n  }\n\n  // at this point, no one needed a drain, so we just ran out of data\n  // on the next readable event, start it over again.\n  state.ranOut = true;\n}\n\nfunction pipeOnReadable() {\n  if (this._readableState.ranOut) {\n    this._readableState.ranOut = false;\n    flow(this);\n  }\n}\n\n\nReadable.prototype.unpipe = function(dest) {\n  var state = this._readableState;\n\n  // if we're not piping anywhere, then do nothing.\n  if (state.pipesCount === 0)\n    return this;\n\n  // just one destination.  most common case.\n  if (state.pipesCount === 1) {\n    // passed in one, but it's not the right one.\n    if (dest && dest !== state.pipes)\n      return this;\n\n    if (!dest)\n      dest = state.pipes;\n\n    // got a match.\n    state.pipes = null;\n    state.pipesCount = 0;\n    this.removeListener('readable', pipeOnReadable);\n    state.flowing = false;\n    if (dest)\n      dest.emit('unpipe', this);\n    return this;\n  }\n\n  // slow case. multiple pipe destinations.\n\n  if (!dest) {\n    // remove all.\n    var dests = state.pipes;\n    var len = state.pipesCount;\n    state.pipes = null;\n    state.pipesCount = 0;\n    this.removeListener('readable', pipeOnReadable);\n    state.flowing = false;\n\n    for (var i = 0; i < len; i++)\n      dests[i].emit('unpipe', this);\n    return this;\n  }\n\n  // try to find the right one.\n  var i = indexOf(state.pipes, dest);\n  if (i === -1)\n    return this;\n\n  state.pipes.splice(i, 1);\n  state.pipesCount -= 1;\n  if (state.pipesCount === 1)\n    state.pipes = state.pipes[0];\n\n  dest.emit('unpipe', this);\n\n  return this;\n};\n\n// set up data events if they are asked for\n// Ensure readable listeners eventually get something\nReadable.prototype.on = function(ev, fn) {\n  var res = Stream.prototype.on.call(this, ev, fn);\n\n  if (ev === 'data' && !this._readableState.flowing)\n    emitDataEvents(this);\n\n  if (ev === 'readable' && this.readable) {\n    var state = this._readableState;\n    if (!state.readableListening) {\n      state.readableListening = true;\n      state.emittedReadable = false;\n      state.needReadable = true;\n      if (!state.reading) {\n        this.read(0);\n      } else if (state.length) {\n        emitReadable(this, state);\n      }\n    }\n  }\n\n  return res;\n};\nReadable.prototype.addListener = Readable.prototype.on;\n\n// pause() and resume() are remnants of the legacy readable stream API\n// If the user uses them, then switch into old mode.\nReadable.prototype.resume = function() {\n  emitDataEvents(this);\n  this.read(0);\n  this.emit('resume');\n};\n\nReadable.prototype.pause = function() {\n  emitDataEvents(this, true);\n  this.emit('pause');\n};\n\nfunction emitDataEvents(stream, startPaused) {\n  var state = stream._readableState;\n\n  if (state.flowing) {\n    // https://github.com/isaacs/readable-stream/issues/16\n    throw new Error('Cannot switch to old mode now.');\n  }\n\n  var paused = startPaused || false;\n  var readable = false;\n\n  // convert to an old-style stream.\n  stream.readable = true;\n  stream.pipe = Stream.prototype.pipe;\n  stream.on = stream.addListener = Stream.prototype.on;\n\n  stream.on('readable', function() {\n    readable = true;\n\n    var c;\n    while (!paused && (null !== (c = stream.read())))\n      stream.emit('data', c);\n\n    if (c === null) {\n      readable = false;\n      stream._readableState.needReadable = true;\n    }\n  });\n\n  stream.pause = function() {\n    paused = true;\n    this.emit('pause');\n  };\n\n  stream.resume = function() {\n    paused = false;\n    if (readable)\n      process.nextTick(function() {\n        stream.emit('readable');\n      });\n    else\n      this.read(0);\n    this.emit('resume');\n  };\n\n  // now make it start, just in case it hadn't already.\n  stream.emit('readable');\n}\n\n// wrap an old-style stream as the async data source.\n// This is *not* part of the readable stream interface.\n// It is an ugly unfortunate mess of history.\nReadable.prototype.wrap = function(stream) {\n  var state = this._readableState;\n  var paused = false;\n\n  var self = this;\n  stream.on('end', function() {\n    if (state.decoder && !state.ended) {\n      var chunk = state.decoder.end();\n      if (chunk && chunk.length)\n        self.push(chunk);\n    }\n\n    self.push(null);\n  });\n\n  stream.on('data', function(chunk) {\n    if (state.decoder)\n      chunk = state.decoder.write(chunk);\n\n    // don't skip over falsy values in objectMode\n    //if (state.objectMode && util.isNullOrUndefined(chunk))\n    if (state.objectMode && (chunk === null || chunk === undefined))\n      return;\n    else if (!state.objectMode && (!chunk || !chunk.length))\n      return;\n\n    var ret = self.push(chunk);\n    if (!ret) {\n      paused = true;\n      stream.pause();\n    }\n  });\n\n  // proxy all the other methods.\n  // important when wrapping filters and duplexes.\n  for (var i in stream) {\n    if (typeof stream[i] === 'function' &&\n        typeof this[i] === 'undefined') {\n      this[i] = function(method) { return function() {\n        return stream[method].apply(stream, arguments);\n      }}(i);\n    }\n  }\n\n  // proxy certain important events.\n  var events = ['error', 'close', 'destroy', 'pause', 'resume'];\n  forEach(events, function(ev) {\n    stream.on(ev, self.emit.bind(self, ev));\n  });\n\n  // when we try to consume some more bytes, simply unpause the\n  // underlying stream.\n  self._read = function(n) {\n    if (paused) {\n      paused = false;\n      stream.resume();\n    }\n  };\n\n  return self;\n};\n\n\n\n// exposed for testing purposes only.\nReadable._fromList = fromList;\n\n// Pluck off n bytes from an array of buffers.\n// Length is the combined lengths of all the buffers in the list.\nfunction fromList(n, state) {\n  var list = state.buffer;\n  var length = state.length;\n  var stringMode = !!state.decoder;\n  var objectMode = !!state.objectMode;\n  var ret;\n\n  // nothing in the list, definitely empty.\n  if (list.length === 0)\n    return null;\n\n  if (length === 0)\n    ret = null;\n  else if (objectMode)\n    ret = list.shift();\n  else if (!n || n >= length) {\n    // read it all, truncate the array.\n    if (stringMode)\n      ret = list.join('');\n    else\n      ret = Buffer.concat(list, length);\n    list.length = 0;\n  } else {\n    // read just some of it.\n    if (n < list[0].length) {\n      // just take a part of the first list item.\n      // slice is the same for buffers and strings.\n      var buf = list[0];\n      ret = buf.slice(0, n);\n      list[0] = buf.slice(n);\n    } else if (n === list[0].length) {\n      // first list is a perfect match\n      ret = list.shift();\n    } else {\n      // complex case.\n      // we have enough to cover it, but it spans past the first buffer.\n      if (stringMode)\n        ret = '';\n      else\n        ret = new Buffer(n);\n\n      var c = 0;\n      for (var i = 0, l = list.length; i < l && c < n; i++) {\n        var buf = list[0];\n        var cpy = Math.min(n - c, buf.length);\n\n        if (stringMode)\n          ret += buf.slice(0, cpy);\n        else\n          buf.copy(ret, c, 0, cpy);\n\n        if (cpy < buf.length)\n          list[0] = buf.slice(cpy);\n        else\n          list.shift();\n\n        c += cpy;\n      }\n    }\n  }\n\n  return ret;\n}\n\nfunction endReadable(stream) {\n  var state = stream._readableState;\n\n  // If we get here before consuming all the bytes, then that is a\n  // bug in node.  Should never happen.\n  if (state.length > 0)\n    throw new Error('endReadable called on non-empty stream');\n\n  if (!state.endEmitted && state.calledRead) {\n    state.ended = true;\n    process.nextTick(function() {\n      // Check that we didn't get one last unshift.\n      if (!state.endEmitted && state.length === 0) {\n        state.endEmitted = true;\n        stream.readable = false;\n        stream.emit('end');\n      }\n    });\n  }\n}\n\nfunction forEach (xs, f) {\n  for (var i = 0, l = xs.length; i < l; i++) {\n    f(xs[i], i);\n  }\n}\n\nfunction indexOf (xs, x) {\n  for (var i = 0, l = xs.length; i < l; i++) {\n    if (xs[i] === x) return i;\n  }\n  return -1;\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n\n// a transform stream is a readable/writable stream where you do\n// something with the data.  Sometimes it's called a \"filter\",\n// but that's not a great name for it, since that implies a thing where\n// some bits pass through, and others are simply ignored.  (That would\n// be a valid example of a transform, of course.)\n//\n// While the output is causally related to the input, it's not a\n// necessarily symmetric or synchronous transformation.  For example,\n// a zlib stream might take multiple plain-text writes(), and then\n// emit a single compressed chunk some time in the future.\n//\n// Here's how this works:\n//\n// The Transform stream has all the aspects of the readable and writable\n// stream classes.  When you write(chunk), that calls _write(chunk,cb)\n// internally, and returns false if there's a lot of pending writes\n// buffered up.  When you call read(), that calls _read(n) until\n// there's enough pending readable data buffered up.\n//\n// In a transform stream, the written data is placed in a buffer.  When\n// _read(n) is called, it transforms the queued up data, calling the\n// buffered _write cb's as it consumes chunks.  If consuming a single\n// written chunk would result in multiple output chunks, then the first\n// outputted bit calls the readcb, and subsequent chunks just go into\n// the read buffer, and will cause it to emit 'readable' if necessary.\n//\n// This way, back-pressure is actually determined by the reading side,\n// since _read has to be called to start processing a new chunk.  However,\n// a pathological inflate type of transform can cause excessive buffering\n// here.  For example, imagine a stream where every byte of input is\n// interpreted as an integer from 0-255, and then results in that many\n// bytes of output.  Writing the 4 bytes {ff,ff,ff,ff} would result in\n// 1kb of data being output.  In this case, you could write a very small\n// amount of input, and end up with a very large amount of output.  In\n// such a pathological inflating mechanism, there'd be no way to tell\n// the system to stop doing the transform.  A single 4MB write could\n// cause the system to run out of memory.\n//\n// However, even in such a pathological case, only a single written chunk\n// would be consumed, and then the rest would wait (un-transformed) until\n// the results of the previous transformed chunk were consumed.\n\nmodule.exports = Transform;\n\nvar Duplex = require('./_stream_duplex');\n\n/*<replacement>*/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/*</replacement>*/\n\nutil.inherits(Transform, Duplex);\n\n\nfunction TransformState(options, stream) {\n  this.afterTransform = function(er, data) {\n    return afterTransform(stream, er, data);\n  };\n\n  this.needTransform = false;\n  this.transforming = false;\n  this.writecb = null;\n  this.writechunk = null;\n}\n\nfunction afterTransform(stream, er, data) {\n  var ts = stream._transformState;\n  ts.transforming = false;\n\n  var cb = ts.writecb;\n\n  if (!cb)\n    return stream.emit('error', new Error('no writecb in Transform class'));\n\n  ts.writechunk = null;\n  ts.writecb = null;\n\n  if (data !== null && data !== undefined)\n    stream.push(data);\n\n  if (cb)\n    cb(er);\n\n  var rs = stream._readableState;\n  rs.reading = false;\n  if (rs.needReadable || rs.length < rs.highWaterMark) {\n    stream._read(rs.highWaterMark);\n  }\n}\n\n\nfunction Transform(options) {\n  if (!(this instanceof Transform))\n    return new Transform(options);\n\n  Duplex.call(this, options);\n\n  var ts = this._transformState = new TransformState(options, this);\n\n  // when the writable side finishes, then flush out anything remaining.\n  var stream = this;\n\n  // start out asking for a readable event once data is transformed.\n  this._readableState.needReadable = true;\n\n  // we have implemented the _read method, and done the other things\n  // that Readable wants before the first _read call, so unset the\n  // sync guard flag.\n  this._readableState.sync = false;\n\n  this.once('finish', function() {\n    if ('function' === typeof this._flush)\n      this._flush(function(er) {\n        done(stream, er);\n      });\n    else\n      done(stream);\n  });\n}\n\nTransform.prototype.push = function(chunk, encoding) {\n  this._transformState.needTransform = false;\n  return Duplex.prototype.push.call(this, chunk, encoding);\n};\n\n// This is the part where you do stuff!\n// override this function in implementation classes.\n// 'chunk' is an input chunk.\n//\n// Call `push(newChunk)` to pass along transformed output\n// to the readable side.  You may call 'push' zero or more times.\n//\n// Call `cb(err)` when you are done with this chunk.  If you pass\n// an error, then that'll put the hurt on the whole operation.  If you\n// never call cb(), then you'll never get another chunk.\nTransform.prototype._transform = function(chunk, encoding, cb) {\n  throw new Error('not implemented');\n};\n\nTransform.prototype._write = function(chunk, encoding, cb) {\n  var ts = this._transformState;\n  ts.writecb = cb;\n  ts.writechunk = chunk;\n  ts.writeencoding = encoding;\n  if (!ts.transforming) {\n    var rs = this._readableState;\n    if (ts.needTransform ||\n        rs.needReadable ||\n        rs.length < rs.highWaterMark)\n      this._read(rs.highWaterMark);\n  }\n};\n\n// Doesn't matter what the args are here.\n// _transform does all the work.\n// That we got here means that the readable side wants more data.\nTransform.prototype._read = function(n) {\n  var ts = this._transformState;\n\n  if (ts.writechunk !== null && ts.writecb && !ts.transforming) {\n    ts.transforming = true;\n    this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);\n  } else {\n    // mark that we need a transform, so that any data that comes in\n    // will get processed, now that we've asked for it.\n    ts.needTransform = true;\n  }\n};\n\n\nfunction done(stream, er) {\n  if (er)\n    return stream.emit('error', er);\n\n  // if there's nothing in the write buffer, then that means\n  // that nothing more will ever be provided\n  var ws = stream._writableState;\n  var rs = stream._readableState;\n  var ts = stream._transformState;\n\n  if (ws.length)\n    throw new Error('calling transform done when ws.length != 0');\n\n  if (ts.transforming)\n    throw new Error('calling transform done when still transforming');\n\n  return stream.push(null);\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// A bit simpler than readable streams.\n// Implement an async ._write(chunk, cb), and it'll handle all\n// the drain event emission and buffering.\n\nmodule.exports = Writable;\n\n/*<replacement>*/\nvar Buffer = require('buffer').Buffer;\n/*</replacement>*/\n\nWritable.WritableState = WritableState;\n\n\n/*<replacement>*/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/*</replacement>*/\n\nvar Stream = require('stream');\n\nutil.inherits(Writable, Stream);\n\nfunction WriteReq(chunk, encoding, cb) {\n  this.chunk = chunk;\n  this.encoding = encoding;\n  this.callback = cb;\n}\n\nfunction WritableState(options, stream) {\n  options = options || {};\n\n  // the point at which write() starts returning false\n  // Note: 0 is a valid value, means that we always return false if\n  // the entire buffer is not flushed immediately on write()\n  var hwm = options.highWaterMark;\n  this.highWaterMark = (hwm || hwm === 0) ? hwm : 16 * 1024;\n\n  // object stream flag to indicate whether or not this stream\n  // contains buffers or objects.\n  this.objectMode = !!options.objectMode;\n\n  // cast to ints.\n  this.highWaterMark = ~~this.highWaterMark;\n\n  this.needDrain = false;\n  // at the start of calling end()\n  this.ending = false;\n  // when end() has been called, and returned\n  this.ended = false;\n  // when 'finish' is emitted\n  this.finished = false;\n\n  // should we decode strings into buffers before passing to _write?\n  // this is here so that some node-core streams can optimize string\n  // handling at a lower level.\n  var noDecode = options.decodeStrings === false;\n  this.decodeStrings = !noDecode;\n\n  // Crypto is kind of old and crusty.  Historically, its default string\n  // encoding is 'binary' so we have to make this configurable.\n  // Everything else in the universe uses 'utf8', though.\n  this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n  // not an actual buffer we keep track of, but a measurement\n  // of how much we're waiting to get pushed to some underlying\n  // socket or file.\n  this.length = 0;\n\n  // a flag to see when we're in the middle of a write.\n  this.writing = false;\n\n  // a flag to be able to tell if the onwrite cb is called immediately,\n  // or on a later tick.  We set this to true at first, becuase any\n  // actions that shouldn't happen until \"later\" should generally also\n  // not happen before the first write call.\n  this.sync = true;\n\n  // a flag to know if we're processing previously buffered items, which\n  // may call the _write() callback in the same tick, so that we don't\n  // end up in an overlapped onwrite situation.\n  this.bufferProcessing = false;\n\n  // the callback that's passed to _write(chunk,cb)\n  this.onwrite = function(er) {\n    onwrite(stream, er);\n  };\n\n  // the callback that the user supplies to write(chunk,encoding,cb)\n  this.writecb = null;\n\n  // the amount that is being written when _write is called.\n  this.writelen = 0;\n\n  this.buffer = [];\n\n  // True if the error was already emitted and should not be thrown again\n  this.errorEmitted = false;\n}\n\nfunction Writable(options) {\n  var Duplex = require('./_stream_duplex');\n\n  // Writable ctor is applied to Duplexes, though they're not\n  // instanceof Writable, they're instanceof Readable.\n  if (!(this instanceof Writable) && !(this instanceof Duplex))\n    return new Writable(options);\n\n  this._writableState = new WritableState(options, this);\n\n  // legacy.\n  this.writable = true;\n\n  Stream.call(this);\n}\n\n// Otherwise people can pipe Writable streams, which is just wrong.\nWritable.prototype.pipe = function() {\n  this.emit('error', new Error('Cannot pipe. Not readable.'));\n};\n\n\nfunction writeAfterEnd(stream, state, cb) {\n  var er = new Error('write after end');\n  // TODO: defer error events consistently everywhere, not just the cb\n  stream.emit('error', er);\n  process.nextTick(function() {\n    cb(er);\n  });\n}\n\n// If we get something that is not a buffer, string, null, or undefined,\n// and we're not in objectMode, then that's an error.\n// Otherwise stream chunks are all considered to be of length=1, and the\n// watermarks determine how many objects to keep in the buffer, rather than\n// how many bytes or characters.\nfunction validChunk(stream, state, chunk, cb) {\n  var valid = true;\n  if (!Buffer.isBuffer(chunk) &&\n      'string' !== typeof chunk &&\n      chunk !== null &&\n      chunk !== undefined &&\n      !state.objectMode) {\n    var er = new TypeError('Invalid non-string/buffer chunk');\n    stream.emit('error', er);\n    process.nextTick(function() {\n      cb(er);\n    });\n    valid = false;\n  }\n  return valid;\n}\n\nWritable.prototype.write = function(chunk, encoding, cb) {\n  var state = this._writableState;\n  var ret = false;\n\n  if (typeof encoding === 'function') {\n    cb = encoding;\n    encoding = null;\n  }\n\n  if (Buffer.isBuffer(chunk))\n    encoding = 'buffer';\n  else if (!encoding)\n    encoding = state.defaultEncoding;\n\n  if (typeof cb !== 'function')\n    cb = function() {};\n\n  if (state.ended)\n    writeAfterEnd(this, state, cb);\n  else if (validChunk(this, state, chunk, cb))\n    ret = writeOrBuffer(this, state, chunk, encoding, cb);\n\n  return ret;\n};\n\nfunction decodeChunk(state, chunk, encoding) {\n  if (!state.objectMode &&\n      state.decodeStrings !== false &&\n      typeof chunk === 'string') {\n    chunk = new Buffer(chunk, encoding);\n  }\n  return chunk;\n}\n\n// if we're already writing something, then just put this\n// in the queue, and wait our turn.  Otherwise, call _write\n// If we return false, then we need a drain event, so set that flag.\nfunction writeOrBuffer(stream, state, chunk, encoding, cb) {\n  chunk = decodeChunk(state, chunk, encoding);\n  if (Buffer.isBuffer(chunk))\n    encoding = 'buffer';\n  var len = state.objectMode ? 1 : chunk.length;\n\n  state.length += len;\n\n  var ret = state.length < state.highWaterMark;\n  // we must ensure that previous needDrain will not be reset to false.\n  if (!ret)\n    state.needDrain = true;\n\n  if (state.writing)\n    state.buffer.push(new WriteReq(chunk, encoding, cb));\n  else\n    doWrite(stream, state, len, chunk, encoding, cb);\n\n  return ret;\n}\n\nfunction doWrite(stream, state, len, chunk, encoding, cb) {\n  state.writelen = len;\n  state.writecb = cb;\n  state.writing = true;\n  state.sync = true;\n  stream._write(chunk, encoding, state.onwrite);\n  state.sync = false;\n}\n\nfunction onwriteError(stream, state, sync, er, cb) {\n  if (sync)\n    process.nextTick(function() {\n      cb(er);\n    });\n  else\n    cb(er);\n\n  stream._writableState.errorEmitted = true;\n  stream.emit('error', er);\n}\n\nfunction onwriteStateUpdate(state) {\n  state.writing = false;\n  state.writecb = null;\n  state.length -= state.writelen;\n  state.writelen = 0;\n}\n\nfunction onwrite(stream, er) {\n  var state = stream._writableState;\n  var sync = state.sync;\n  var cb = state.writecb;\n\n  onwriteStateUpdate(state);\n\n  if (er)\n    onwriteError(stream, state, sync, er, cb);\n  else {\n    // Check if we're actually ready to finish, but don't emit yet\n    var finished = needFinish(stream, state);\n\n    if (!finished && !state.bufferProcessing && state.buffer.length)\n      clearBuffer(stream, state);\n\n    if (sync) {\n      process.nextTick(function() {\n        afterWrite(stream, state, finished, cb);\n      });\n    } else {\n      afterWrite(stream, state, finished, cb);\n    }\n  }\n}\n\nfunction afterWrite(stream, state, finished, cb) {\n  if (!finished)\n    onwriteDrain(stream, state);\n  cb();\n  if (finished)\n    finishMaybe(stream, state);\n}\n\n// Must force callback to be called on nextTick, so that we don't\n// emit 'drain' before the write() consumer gets the 'false' return\n// value, and has a chance to attach a 'drain' listener.\nfunction onwriteDrain(stream, state) {\n  if (state.length === 0 && state.needDrain) {\n    state.needDrain = false;\n    stream.emit('drain');\n  }\n}\n\n\n// if there's something in the buffer waiting, then process it\nfunction clearBuffer(stream, state) {\n  state.bufferProcessing = true;\n\n  for (var c = 0; c < state.buffer.length; c++) {\n    var entry = state.buffer[c];\n    var chunk = entry.chunk;\n    var encoding = entry.encoding;\n    var cb = entry.callback;\n    var len = state.objectMode ? 1 : chunk.length;\n\n    doWrite(stream, state, len, chunk, encoding, cb);\n\n    // if we didn't call the onwrite immediately, then\n    // it means that we need to wait until it does.\n    // also, that means that the chunk and cb are currently\n    // being processed, so move the buffer counter past them.\n    if (state.writing) {\n      c++;\n      break;\n    }\n  }\n\n  state.bufferProcessing = false;\n  if (c < state.buffer.length)\n    state.buffer = state.buffer.slice(c);\n  else\n    state.buffer.length = 0;\n}\n\nWritable.prototype._write = function(chunk, encoding, cb) {\n  cb(new Error('not implemented'));\n};\n\nWritable.prototype.end = function(chunk, encoding, cb) {\n  var state = this._writableState;\n\n  if (typeof chunk === 'function') {\n    cb = chunk;\n    chunk = null;\n    encoding = null;\n  } else if (typeof encoding === 'function') {\n    cb = encoding;\n    encoding = null;\n  }\n\n  if (typeof chunk !== 'undefined' && chunk !== null)\n    this.write(chunk, encoding);\n\n  // ignore unnecessary end() calls.\n  if (!state.ending && !state.finished)\n    endWritable(this, state, cb);\n};\n\n\nfunction needFinish(stream, state) {\n  return (state.ending &&\n          state.length === 0 &&\n          !state.finished &&\n          !state.writing);\n}\n\nfunction finishMaybe(stream, state) {\n  var need = needFinish(stream, state);\n  if (need) {\n    state.finished = true;\n    stream.emit('finish');\n  }\n  return need;\n}\n\nfunction endWritable(stream, state, cb) {\n  state.ending = true;\n  finishMaybe(stream, state);\n  if (cb) {\n    if (state.finished)\n      process.nextTick(cb);\n    else\n      stream.once('finish', cb);\n  }\n  state.ended = true;\n}\n","var Stream = require('stream'); // hack to fix a circular dependency issue when used with browserify\nexports = module.exports = require('./lib/_stream_readable.js');\nexports.Stream = Stream;\nexports.Readable = exports;\nexports.Writable = require('./lib/_stream_writable.js');\nexports.Duplex = require('./lib/_stream_duplex.js');\nexports.Transform = require('./lib/_stream_transform.js');\nexports.PassThrough = require('./lib/_stream_passthrough.js');\nif (!process.browser && process.env.READABLE_STREAM === 'disable') {\n  module.exports = require('stream');\n}\n","module.exports = extend\n\nfunction extend() {\n    var target = {}\n\n    for (var i = 0; i < arguments.length; i++) {\n        var source = arguments[i]\n\n        for (var key in source) {\n            if (source.hasOwnProperty(key)) {\n                target[key] = source[key]\n            }\n        }\n    }\n\n    return target\n}\n","module.exports={\n  \"_args\": [\n    [\n      \"levelup@~0.19.0\",\n      \"/Users/joran/Documents/development/patchdeck/node_modules/level-sublevel\"\n    ]\n  ],\n  \"_from\": \"levelup@>=0.19.0 <0.20.0\",\n  \"_id\": \"levelup@0.19.1\",\n  \"_inCache\": true,\n  \"_installable\": true,\n  \"_location\": \"/levelup\",\n  \"_nodeVersion\": \"5.5.0\",\n  \"_npmUser\": {\n    \"email\": \"ralphtheninja@riseup.net\",\n    \"name\": \"ralphtheninja\"\n  },\n  \"_npmVersion\": \"3.3.12\",\n  \"_phantomChildren\": {\n    \"core-util-is\": \"1.0.2\",\n    \"inherits\": \"2.0.1\",\n    \"isarray\": \"0.0.1\",\n    \"string_decoder\": \"0.10.31\"\n  },\n  \"_requested\": {\n    \"name\": \"levelup\",\n    \"raw\": \"levelup@~0.19.0\",\n    \"rawSpec\": \"~0.19.0\",\n    \"scope\": null,\n    \"spec\": \">=0.19.0 <0.20.0\",\n    \"type\": \"range\"\n  },\n  \"_requiredBy\": [\n    \"/level-sublevel\",\n    \"/secure-scuttlebutt/level-sublevel\"\n  ],\n  \"_resolved\": \"https://registry.npmjs.org/levelup/-/levelup-0.19.1.tgz\",\n  \"_shasum\": \"f3a6a7205272c4b5f35e412ff004a03a0aedf50b\",\n  \"_shrinkwrap\": null,\n  \"_spec\": \"levelup@~0.19.0\",\n  \"_where\": \"/Users/joran/Documents/development/patchdeck/node_modules/level-sublevel\",\n  \"browser\": {\n    \"leveldown\": false,\n    \"leveldown/package\": false,\n    \"semver\": false\n  },\n  \"bugs\": {\n    \"url\": \"https://github.com/rvagg/node-levelup/issues\"\n  },\n  \"contributors\": [\n    {\n      \"name\": \"David Björklund\",\n      \"email\": \"david.bjorklund@gmail.com\",\n      \"url\": \"https://github.com/kesla\"\n    },\n    {\n      \"name\": \"Rod Vagg\",\n      \"email\": \"r@va.gg\",\n      \"url\": \"https://github.com/rvagg\"\n    },\n    {\n      \"name\": \"Jake Verbaten\",\n      \"email\": \"raynos2@gmail.com\",\n      \"url\": \"https://github.com/raynos\"\n    },\n    {\n      \"name\": \"Dominic Tarr\",\n      \"email\": \"dominic.tarr@gmail.com\",\n      \"url\": \"https://github.com/dominictarr\"\n    },\n    {\n      \"name\": \"Max Ogden\",\n      \"email\": \"max@maxogden.com\",\n      \"url\": \"https://github.com/maxogden\"\n    },\n    {\n      \"name\": \"Lars-Magnus Skog\",\n      \"email\": \"lars.magnus.skog@gmail.com\",\n      \"url\": \"https://github.com/ralphtheninja\"\n    },\n    {\n      \"name\": \"John Chesley\",\n      \"email\": \"john@chesl.es\",\n      \"url\": \"https://github.com/chesles/\"\n    },\n    {\n      \"name\": \"Julian Gruber\",\n      \"email\": \"julian@juliangruber.com\",\n      \"url\": \"https://github.com/juliangruber\"\n    },\n    {\n      \"name\": \"Paolo Fragomeni\",\n      \"email\": \"paolo@async.ly\",\n      \"url\": \"https://github.com/hij1nx\"\n    },\n    {\n      \"name\": \"Anton Whalley\",\n      \"email\": \"anton.whalley@nearform.com\",\n      \"url\": \"https://github.com/No9\"\n    },\n    {\n      \"name\": \"Matteo Collina\",\n      \"email\": \"matteo.collina@gmail.com\",\n      \"url\": \"https://github.com/mcollina\"\n    },\n    {\n      \"name\": \"Pedro Teixeira\",\n      \"email\": \"pedro.teixeira@gmail.com\",\n      \"url\": \"https://github.com/pgte\"\n    },\n    {\n      \"name\": \"James Halliday\",\n      \"email\": \"mail@substack.net\",\n      \"url\": \"https://github.com/substack\"\n    }\n  ],\n  \"dependencies\": {\n    \"bl\": \"~0.8.1\",\n    \"deferred-leveldown\": \"~0.2.0\",\n    \"errno\": \"~0.1.1\",\n    \"prr\": \"~0.0.0\",\n    \"readable-stream\": \"~1.0.26\",\n    \"semver\": \"~5.1.0\",\n    \"xtend\": \"~3.0.0\"\n  },\n  \"description\": \"Fast & simple storage - a Node.js-style LevelDB wrapper\",\n  \"devDependencies\": {\n    \"async\": \"*\",\n    \"boganipsum\": \"*\",\n    \"bustermove\": \"~1.0.1\",\n    \"delayed\": \"*\",\n    \"du\": \"*\",\n    \"fstream\": \"*\",\n    \"leveldown\": \"~0.10.0\",\n    \"memdown\": \"^0.11.0\",\n    \"mkfiletree\": \"*\",\n    \"msgpack-js\": \"*\",\n    \"readfiletree\": \"*\",\n    \"referee\": \"*\",\n    \"rimraf\": \"*\",\n    \"slow-stream\": \">=0.0.4\",\n    \"tap\": \"2.x.x\",\n    \"tape\": \"4.x.x\",\n    \"tar\": \"*\"\n  },\n  \"directories\": {},\n  \"dist\": {\n    \"shasum\": \"f3a6a7205272c4b5f35e412ff004a03a0aedf50b\",\n    \"tarball\": \"https://registry.npmjs.org/levelup/-/levelup-0.19.1.tgz\"\n  },\n  \"gitHead\": \"2847795d54c6eceb865e2c6b5157bccf68132c55\",\n  \"homepage\": \"https://github.com/rvagg/node-levelup\",\n  \"keywords\": [\n    \"database\",\n    \"db\",\n    \"json\",\n    \"leveldb\",\n    \"storage\",\n    \"store\",\n    \"stream\"\n  ],\n  \"license\": \"MIT\",\n  \"main\": \"lib/levelup.js\",\n  \"maintainers\": [\n    {\n      \"name\": \"rvagg\",\n      \"email\": \"rod@vagg.org\"\n    },\n    {\n      \"name\": \"ralphtheninja\",\n      \"email\": \"ralphtheninja@riseup.net\"\n    },\n    {\n      \"name\": \"juliangruber\",\n      \"email\": \"julian@juliangruber.com\"\n    }\n  ],\n  \"name\": \"levelup\",\n  \"optionalDependencies\": {},\n  \"readme\": \"ERROR: No README data found!\",\n  \"repository\": {\n    \"type\": \"git\",\n    \"url\": \"git+https://github.com/rvagg/node-levelup.git\"\n  },\n  \"scripts\": {\n    \"alltests\": \"npm test && npm run-script functionaltests\",\n    \"functionaltests\": \"node ./test/functional/fstream-test.js && node ./test/functional/binary-data-test.js && node ./test/functional/compat-test.js\",\n    \"test\": \"tap test/*-test.js\"\n  },\n  \"version\": \"0.19.1\"\n}\n","(function (root, factory) {\n\tif (typeof process === \"object\" && typeof process.stdout === \"undefined\") {\n\t\tprocess.stderr = process.stdout = { write: function() { } };\n\t}\n\tif (typeof define === \"function\" && define.amd) {\n\t\tdefine([\"exports\", \"libsodium\"], factory);\n\t} else if (typeof exports !== \"undefined\") {\n\t\tfactory(exports, require(\"libsodium\"));\n\t} else {\n\t\tvar cb = root.sodium && root.sodium.onload;\n\t\tfactory((root.sodium = {}), root.libsodium);\n\t\tif (typeof cb === \"function\") {\n\t\t\tcb(root.sodium);\n\t\t}\n\t}\n}(this, function (exports, libsodium) {\n\t\"use strict\";\n\tObject.defineProperty(exports, '__esModule', { value: true });\n\n\tvar output_format = \"uint8array\";\n\n\tlibsodium._sodium_init();\n\n\t// List of functions and constants defined in the wrapped libsodium\n\tfunction symbols() {\n\t\treturn Object.keys(exports).sort();\n\t}\n\n\tfunction increment(bytes) {\n\t\tif (! bytes instanceof Uint8Array) {\n\t\t\tthrow new TypeError(\"Only Uint8Array instances can be incremented\");\n\t\t}\n        var c = 1 << 8;\n\t\tfor (var i = 0 | 0, j = bytes.length; i < j; i++) {\n            c >>= 8;\n            c += bytes[i];\n\t\t\tbytes[i] = c & 0xff;\n\t\t}\n\t}\n\n\tfunction memzero(bytes) {\n\t\tif (! bytes instanceof Uint8Array) {\n\t\t\tthrow new TypeError(\"Only Uint8Array instances can be wiped\");\n\t\t}\n\t\tfor (var i = 0 | 0, j = bytes.length; i < j; i++) {\n\t\t\tbytes[i] = 0;\n\t\t}\n\t}\n\n\tfunction memcmp(b1, b2) {\n\t\tif (!(b1 instanceof Uint8Array && b2 instanceof Uint8Array)) {\n\t\t\tthrow new TypeError(\"Only Uint8Array instances can be compared\");\n\t\t}\n\t\tif (b1.length !== b2.length) {\n\t\t\tthrow new TypeError(\"Only instances of identical length can be compared\");\n\t\t}\n\t\tfor (var d = 0 | 0, i = 0 | 0, j = b1.length; i < j; i++) {\n\t\t\td |= b1[i] ^ b2[i];\n\t\t}\n\t\treturn d === 0;\n\t}\n\n\tfunction compare(b1, b2) {\n\t\tif (!(b1 instanceof Uint8Array && b2 instanceof Uint8Array)) {\n\t\t\tthrow new TypeError(\"Only Uint8Array instances can be compared\");\n\t\t}\n\t\tif (b1.length !== b2.length) {\n\t\t\tthrow new TypeError(\"Only instances of identical length can be compared\");\n\t\t}\n\t\tfor (var gt = 0 | 0, eq = 1 | 1, i = b1.length; i-- > 0;) {\n\t\t\tgt |= ((b2[i] - b1[i]) >> 8) & eq;\n\t\t\teq &= ((b2[i] ^ b1[i]) - 1) >> 8;\n\t\t}\n\t\treturn (gt + gt + eq) - 1;\n\t}\n\n\t//---------------------------------------------------------------------------\n\t// Codecs\n\n\tfunction from_string(str) {\n\t\tif (typeof TextEncoder === \"function\") {\n\t\t\treturn new TextEncoder(\"utf-8\").encode(str);\n\t\t}\n\t\tstr = unescape(encodeURIComponent(str));\n\t\tvar bytes = new Uint8Array(str.length);\n\t\tfor (var i = 0; i < str.length; i++) {\n\t\t\tbytes[i] = str.charCodeAt(i);\n\t\t}\n\t\treturn bytes;\n\t}\n\n\tfunction to_string(bytes) {\n\t\tif (typeof TextDecoder === \"function\") {\n\t\t\treturn new TextDecoder(\"utf-8\", {fatal: true}).decode(bytes);\n\t\t}\n\n\t\ttry {\n\t\t\treturn decodeURIComponent(escape(String.fromCharCode.apply(null, bytes)));\n\t\t}\n\t\tcatch (_) {\n\t\t\tthrow new TypeError(\"The encoded data was not valid.\");\n\t\t}\n\t}\n\n\tfunction from_hex(str) {\n\t\tif (!is_hex(str)) throw new TypeError(\"The provided string doesn't look like hex data\");\n\t\tvar result = new Uint8Array(str.length / 2);\n\t\tfor (var i = 0; i < str.length; i += 2) {\n\t\t\tresult[i >>> 1] = parseInt(str.substr(i, 2), 16);\n\t\t}\n\t\treturn result;\n\t}\n\n\tfunction to_hex(bytes) {\n\t\tvar str = \"\", b, c, x;\n\t\tfor (var i = 0; i < bytes.length; i++) {\n\t\t\tc = bytes[i] & 0xf;\n\t\t\tb = bytes[i] >>> 4;\n\t\t\tx = (87 + c + (((c - 10) >> 8) & ~38)) << 8 |\n\t\t\t    (87 + b + (((b - 10) >> 8) & ~38));\n\t\t\tstr += String.fromCharCode(x & 0xff) + String.fromCharCode(x >>> 8);\n\t\t}\n\t\treturn str;\n\t}\n\n\tfunction is_hex(str) {\n\t\treturn (typeof str === \"string\" && /^[0-9a-f]+$/i.test(str) && str.length % 2 === 0);\n\t}\n\n\tfunction from_base64(sBase64, nBlocksSize) {\n\t\tfunction _b64ToUint6(nChr) {\n\t\t\treturn nChr > 64 && nChr < 91 ?\n\t\t\t\tnChr - 65 : nChr > 96 && nChr < 123 ?\n\t\t\t\tnChr - 71 : nChr > 47 && nChr < 58 ?\n\t\t\t\tnChr + 4 : nChr === 43 ?\n\t\t\t\t62 : nChr === 47 ?\n\t\t\t\t63 :\n\t\t\t\t0;\n\t\t}\n\t\tvar\n\t\t\tsB64Enc = sBase64.replace(/[^A-Za-z0-9\\+\\/]/g, \"\"),\n\t\t\tnInLen = sB64Enc.length,\n\t\t\tnOutLen = nBlocksSize ? Math.ceil((nInLen * 3 + 1 >> 2) / nBlocksSize) * nBlocksSize : nInLen * 3 + 1 >> 2,\n\t\t\ttaBytes = new Uint8Array(nOutLen);\n\t\tfor (var nMod3, nMod4, nUint24 = 0, nOutIdx = 0, nInIdx = 0; nInIdx < nInLen; nInIdx++) {\n\t\t\tnMod4 = nInIdx & 3;\n\t\t\tnUint24 |= _b64ToUint6(sB64Enc.charCodeAt(nInIdx)) << 18 - 6 * nMod4;\n\t\t\tif (nMod4 === 3 || nInLen - nInIdx === 1) {\n\t\t\t\tfor (nMod3 = 0; nMod3 < 3 && nOutIdx < nOutLen; nMod3++, nOutIdx++) {\n\t\t\t\t\ttaBytes[nOutIdx] = nUint24 >>> (16 >>> nMod3 & 24) & 255;\n\t\t\t\t}\n\t\t\t\tnUint24 = 0;\n\t\t\t}\n\t\t}\n\t\treturn taBytes;\n\t}\n\n\tfunction to_base64(aBytes, noNewLine) {\n\t\tfunction _uint6ToB64(nUint6) {\n\t\t\treturn nUint6 < 26 ?\n\t\t\t\tnUint6 + 65 : nUint6 < 52 ?\n\t\t\t\tnUint6 + 71 : nUint6 < 62 ?\n\t\t\t\tnUint6 - 4 : nUint6 === 62 ?\n\t\t\t\t43 : nUint6 === 63 ?\n\t\t\t\t47 :\n\t\t\t\t65;\n\t\t}\n\t\tif (typeof aBytes === \"string\") {\n\t\t\tthrow new Exception(\"input has to be an array\");\n\t\t}\n\t\tvar nMod3 = 2,\n\t\t\tsB64Enc = \"\";\n\t\tfor (var nLen = aBytes.length, nUint24 = 0, nIdx = 0; nIdx < nLen; nIdx++) {\n\t\t\tnMod3 = nIdx % 3;\n\t\t\tif (nIdx > 0 && (nIdx * 4 / 3) % 76 === 0 && !noNewLine) {\n\t\t\t\tsB64Enc += \"\\r\\n\";\n\t\t\t}\n\t\t\tnUint24 |= aBytes[nIdx] << (16 >>> nMod3 & 24);\n\t\t\tif (nMod3 === 2 || aBytes.length - nIdx === 1) {\n\t\t\t\tsB64Enc += String.fromCharCode(_uint6ToB64(nUint24 >>> 18 & 63), _uint6ToB64(nUint24 >>> 12 & 63), _uint6ToB64(nUint24 >>> 6 & 63), _uint6ToB64(nUint24 & 63));\n\t\t\t\tnUint24 = 0;\n\t\t\t}\n\t\t}\n\t\treturn sB64Enc.substr(0, sB64Enc.length - 2 + nMod3) + (nMod3 === 2 ? \"\" : nMod3 === 1 ? \"=\" : \"==\");\n\t}\n\n\tfunction output_formats() {\n\t\treturn [\"uint8array\", \"text\", \"hex\", \"base64\"];\n\t}\n\n\tfunction _format_output(output, optionalOutputFormat) {\n\t\tvar selectedOutputFormat = optionalOutputFormat || output_format;\n\t\tif (!_is_output_format(selectedOutputFormat)) throw new Error(selectedOutputFormat + \" output format is not available\");\n\t\tif (output instanceof AllocatedBuf) {\n\t\t\tif (selectedOutputFormat === \"uint8array\") return output.to_Uint8Array();\n\t\t\telse if (selectedOutputFormat === \"text\") return libsodium.Pointer_stringify(output.address, output.length);\n\t\t\telse if (selectedOutputFormat === \"hex\") return to_hex(output.to_Uint8Array());\n\t\t\telse if (selectedOutputFormat === \"base64\") return to_base64(output.to_Uint8Array());\n\t\t\telse throw new Error(\"What is output format \\\"\" + selectedOutputFormat + \"\\\"?\");\n\t\t} else if (typeof output === \"object\") { //Composed output. Example : key pairs\n\t\t\tvar props = Object.keys(output);\n\t\t\tvar formattedOutput = {};\n\t\t\tfor (var i = 0; i < props.length; i++) {\n\t\t\t\tformattedOutput[props[i]] = _format_output(output[props[i]], selectedOutputFormat);\n\t\t\t}\n\t\t\treturn formattedOutput;\n\t\t} else if (typeof output === \"string\") {\n\t\t\treturn output;\n\t\t} else {\n\t\t\tthrow new TypeError(\"Cannot format output\");\n\t\t}\n\t}\n\n\tfunction _is_output_format(format) {\n\t\tvar formats = output_formats();\n\t\tfor (var i = 0; i < formats.length; i++) {\n\t\t\tif (formats[i] === format) return true;\n\t\t}\n\t\treturn false;\n\t}\n\n\tfunction _check_output_format(format) {\n\t\tif (!format) {\n\t\t\treturn;\n\t\t} else if (typeof format !== \"string\") {\n\t\t\tthrow new TypeError(\"When defined, the output format must be a string\");\n\t\t} else if (!_is_output_format(format)) {\n\t\t\tthrow new Error(format + \" is not a supported output format\");\n\t\t}\n\t}\n\n\t//---------------------------------------------------------------------------\n\t// Memory management\n\n\t// AllocatedBuf: address allocated using _malloc() + length\n\tfunction AllocatedBuf(length) {\n\t\tthis.length = length;\n\t\tthis.address = _malloc(length);\n\t}\n\n\t// Copy the content of a AllocatedBuf (_malloc()'d memory) into a Uint8Array\n\tAllocatedBuf.prototype.to_Uint8Array = function () {\n\t\tvar result = new Uint8Array(this.length);\n\t\tresult.set(libsodium.HEAPU8.subarray(this.address, this.address + this.length));\n\t\treturn result;\n\t};\n\n\t// _malloc() a region and initialize it with the content of a Uint8Array\n\tfunction _to_allocated_buf_address(bytes) {\n\t\tvar address = _malloc(bytes.length);\n\t\tlibsodium.HEAPU8.set(bytes, address);\n\t\treturn address;\n\t}\n\n\tfunction _malloc(length) {\n\t\tvar result = libsodium._malloc(length);\n\t\tif (result === 0) {\n\t\t\tthrow {\n\t\t\t\tmessage: \"_malloc() failed\",\n\t\t\t\tlength: length\n\t\t\t};\n\t\t}\n\t\treturn result;\n\t}\n\n\tfunction _free(address) {\n\t\tlibsodium._free(address);\n\t}\n\n\tfunction _free_all(addresses) {\n\t\tfor (var i = 0; i < addresses.length; i++) {\n\t\t\t_free(addresses[i]);\n\t\t}\n\t}\n\n\tfunction _free_and_throw_error(address_pool, err) {\n\t\t_free_all(address_pool);\n\t\tthrow new Error(err);\n\t}\n\n\tfunction _free_and_throw_type_error(address_pool, err) {\n\t\t_free_all(address_pool);\n\t\tthrow new TypeError(err);\n\t}\n\n\tfunction _require_defined(address_pool, varValue, varName) {\n\t\tif (varValue == undefined) {\n\t\t\t_free_and_throw_type_error(address_pool, varName + \" cannot be null or undefined\");\n\t\t}\n\t}\n\n\tfunction _any_to_Uint8Array(address_pool, varValue, varName) {\n\t\t_require_defined(address_pool, varValue, varName);\n\t\tif (varValue instanceof Uint8Array) {\n\t\t\treturn varValue;\n\t\t} else if (typeof varValue === \"string\") {\n\t\t\treturn from_string(varValue);\n\t\t}\n\t\t_free_and_throw_type_error(address_pool, \"unsupported input type for \" + varName);\n\t}\n\n\t\n\tfunction crypto_aead_chacha20poly1305_decrypt(secret_nonce, ciphertext, additional_data, public_nonce, key, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: secret_nonce (unsized_buf_optional)\n\t\t\n\t\tvar secret_nonce_address = null, secret_nonce_length = 0;\n\t\tif (secret_nonce != undefined) {\n\t\t\tsecret_nonce = _any_to_Uint8Array(address_pool, secret_nonce, \"secret_nonce\");\n\t\t\tsecret_nonce_address = _to_allocated_buf_address(secret_nonce);\n\t\t\tsecret_nonce_length = secret_nonce.length;\n\t\t\taddress_pool.push(secret_nonce_address);\n\t\t}\n\t\t\n\t\t// ---------- input: ciphertext (unsized_buf)\n\t\t\n\t\tciphertext = _any_to_Uint8Array(address_pool, ciphertext, \"ciphertext\");\n\t\tvar ciphertext_address = _to_allocated_buf_address(ciphertext),\n\t\t    ciphertext_length = ciphertext.length;\n\t\taddress_pool.push(ciphertext_address);\n\t\t\n\t\t// ---------- input: additional_data (unsized_buf_optional)\n\t\t\n\t\tvar additional_data_address = null, additional_data_length = 0;\n\t\tif (additional_data != undefined) {\n\t\t\tadditional_data = _any_to_Uint8Array(address_pool, additional_data, \"additional_data\");\n\t\t\tadditional_data_address = _to_allocated_buf_address(additional_data);\n\t\t\tadditional_data_length = additional_data.length;\n\t\t\taddress_pool.push(additional_data_address);\n\t\t}\n\t\t\n\t\t// ---------- input: public_nonce (buf)\n\t\t\n\t\tpublic_nonce = _any_to_Uint8Array(address_pool, public_nonce, \"public_nonce\");\n\t\tvar public_nonce_address, public_nonce_length = (libsodium._crypto_aead_chacha20poly1305_npubbytes()) | 0;\n\t\tif (public_nonce.length !== public_nonce_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid public_nonce length\");\n\t\t}\n\t\tpublic_nonce_address = _to_allocated_buf_address(public_nonce);\n\t\taddress_pool.push(public_nonce_address);\n\t\t\n\t\t// ---------- input: key (buf)\n\t\t\n\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\tvar key_address, key_length = (libsodium._crypto_aead_chacha20poly1305_keybytes()) | 0;\n\t\tif (key.length !== key_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid key length\");\n\t\t}\n\t\tkey_address = _to_allocated_buf_address(key);\n\t\taddress_pool.push(key_address);\n\t\t\n\t\t// ---------- output message (buf)\n\t\t\n\t\tvar message_length = (ciphertext_length - libsodium._crypto_aead_chacha20poly1305_abytes()) | 0,\n\t\t    message = new AllocatedBuf(message_length),\n\t\t    message_address = message.address;\n\t\t\n\t\taddress_pool.push(message_address);\n\t\t\n\t\tif ((libsodium._crypto_aead_chacha20poly1305_decrypt(message_address, null, secret_nonce_address, ciphertext_address, ciphertext_length, 0, additional_data_address, additional_data_length, 0, public_nonce_address, key_address)) === 0) {\n\t\t\tvar ret = _format_output(message, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_aead_chacha20poly1305_encrypt(message, additional_data, secret_nonce, public_nonce, key, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: additional_data (unsized_buf_optional)\n\t\t\n\t\tvar additional_data_address = null, additional_data_length = 0;\n\t\tif (additional_data != undefined) {\n\t\t\tadditional_data = _any_to_Uint8Array(address_pool, additional_data, \"additional_data\");\n\t\t\tadditional_data_address = _to_allocated_buf_address(additional_data);\n\t\t\tadditional_data_length = additional_data.length;\n\t\t\taddress_pool.push(additional_data_address);\n\t\t}\n\t\t\n\t\t// ---------- input: secret_nonce (unsized_buf_optional)\n\t\t\n\t\tvar secret_nonce_address = null, secret_nonce_length = 0;\n\t\tif (secret_nonce != undefined) {\n\t\t\tsecret_nonce = _any_to_Uint8Array(address_pool, secret_nonce, \"secret_nonce\");\n\t\t\tsecret_nonce_address = _to_allocated_buf_address(secret_nonce);\n\t\t\tsecret_nonce_length = secret_nonce.length;\n\t\t\taddress_pool.push(secret_nonce_address);\n\t\t}\n\t\t\n\t\t// ---------- input: public_nonce (buf)\n\t\t\n\t\tpublic_nonce = _any_to_Uint8Array(address_pool, public_nonce, \"public_nonce\");\n\t\tvar public_nonce_address, public_nonce_length = (libsodium._crypto_aead_chacha20poly1305_npubbytes()) | 0;\n\t\tif (public_nonce.length !== public_nonce_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid public_nonce length\");\n\t\t}\n\t\tpublic_nonce_address = _to_allocated_buf_address(public_nonce);\n\t\taddress_pool.push(public_nonce_address);\n\t\t\n\t\t// ---------- input: key (buf)\n\t\t\n\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\tvar key_address, key_length = (libsodium._crypto_aead_chacha20poly1305_keybytes()) | 0;\n\t\tif (key.length !== key_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid key length\");\n\t\t}\n\t\tkey_address = _to_allocated_buf_address(key);\n\t\taddress_pool.push(key_address);\n\t\t\n\t\t// ---------- output ciphertext (buf)\n\t\t\n\t\tvar ciphertext_length = (message_length + libsodium._crypto_aead_chacha20poly1305_abytes()) | 0,\n\t\t    ciphertext = new AllocatedBuf(ciphertext_length),\n\t\t    ciphertext_address = ciphertext.address;\n\t\t\n\t\taddress_pool.push(ciphertext_address);\n\t\t\n\t\tif ((libsodium._crypto_aead_chacha20poly1305_encrypt(ciphertext_address, null, message_address, message_length, 0, additional_data_address, additional_data_length, 0, secret_nonce_address, public_nonce_address, key_address)) === 0) {\n\t\t\tvar ret = _format_output(ciphertext, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_aead_chacha20poly1305_ietf_decrypt(secret_nonce, ciphertext, additional_data, public_nonce, key, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: secret_nonce (unsized_buf_optional)\n\t\t\n\t\tvar secret_nonce_address = null, secret_nonce_length = 0;\n\t\tif (secret_nonce != undefined) {\n\t\t\tsecret_nonce = _any_to_Uint8Array(address_pool, secret_nonce, \"secret_nonce\");\n\t\t\tsecret_nonce_address = _to_allocated_buf_address(secret_nonce);\n\t\t\tsecret_nonce_length = secret_nonce.length;\n\t\t\taddress_pool.push(secret_nonce_address);\n\t\t}\n\t\t\n\t\t// ---------- input: ciphertext (unsized_buf)\n\t\t\n\t\tciphertext = _any_to_Uint8Array(address_pool, ciphertext, \"ciphertext\");\n\t\tvar ciphertext_address = _to_allocated_buf_address(ciphertext),\n\t\t    ciphertext_length = ciphertext.length;\n\t\taddress_pool.push(ciphertext_address);\n\t\t\n\t\t// ---------- input: additional_data (unsized_buf_optional)\n\t\t\n\t\tvar additional_data_address = null, additional_data_length = 0;\n\t\tif (additional_data != undefined) {\n\t\t\tadditional_data = _any_to_Uint8Array(address_pool, additional_data, \"additional_data\");\n\t\t\tadditional_data_address = _to_allocated_buf_address(additional_data);\n\t\t\tadditional_data_length = additional_data.length;\n\t\t\taddress_pool.push(additional_data_address);\n\t\t}\n\t\t\n\t\t// ---------- input: public_nonce (buf)\n\t\t\n\t\tpublic_nonce = _any_to_Uint8Array(address_pool, public_nonce, \"public_nonce\");\n\t\tvar public_nonce_address, public_nonce_length = (libsodium._crypto_aead_chacha20poly1305_ietf_npubbytes()) | 0;\n\t\tif (public_nonce.length !== public_nonce_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid public_nonce length\");\n\t\t}\n\t\tpublic_nonce_address = _to_allocated_buf_address(public_nonce);\n\t\taddress_pool.push(public_nonce_address);\n\t\t\n\t\t// ---------- input: key (buf)\n\t\t\n\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\tvar key_address, key_length = (libsodium._crypto_aead_chacha20poly1305_keybytes()) | 0;\n\t\tif (key.length !== key_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid key length\");\n\t\t}\n\t\tkey_address = _to_allocated_buf_address(key);\n\t\taddress_pool.push(key_address);\n\t\t\n\t\t// ---------- output message (buf)\n\t\t\n\t\tvar message_length = (ciphertext_length - libsodium._crypto_aead_chacha20poly1305_abytes()) | 0,\n\t\t    message = new AllocatedBuf(message_length),\n\t\t    message_address = message.address;\n\t\t\n\t\taddress_pool.push(message_address);\n\t\t\n\t\tif ((libsodium._crypto_aead_chacha20poly1305_ietf_decrypt(message_address, null, secret_nonce_address, ciphertext_address, ciphertext_length, 0, additional_data_address, additional_data_length, 0, public_nonce_address, key_address)) === 0) {\n\t\t\tvar ret = _format_output(message, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_aead_chacha20poly1305_ietf_encrypt(message, additional_data, secret_nonce, public_nonce, key, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: additional_data (unsized_buf_optional)\n\t\t\n\t\tvar additional_data_address = null, additional_data_length = 0;\n\t\tif (additional_data != undefined) {\n\t\t\tadditional_data = _any_to_Uint8Array(address_pool, additional_data, \"additional_data\");\n\t\t\tadditional_data_address = _to_allocated_buf_address(additional_data);\n\t\t\tadditional_data_length = additional_data.length;\n\t\t\taddress_pool.push(additional_data_address);\n\t\t}\n\t\t\n\t\t// ---------- input: secret_nonce (unsized_buf_optional)\n\t\t\n\t\tvar secret_nonce_address = null, secret_nonce_length = 0;\n\t\tif (secret_nonce != undefined) {\n\t\t\tsecret_nonce = _any_to_Uint8Array(address_pool, secret_nonce, \"secret_nonce\");\n\t\t\tsecret_nonce_address = _to_allocated_buf_address(secret_nonce);\n\t\t\tsecret_nonce_length = secret_nonce.length;\n\t\t\taddress_pool.push(secret_nonce_address);\n\t\t}\n\t\t\n\t\t// ---------- input: public_nonce (buf)\n\t\t\n\t\tpublic_nonce = _any_to_Uint8Array(address_pool, public_nonce, \"public_nonce\");\n\t\tvar public_nonce_address, public_nonce_length = (libsodium._crypto_aead_chacha20poly1305_ietf_npubbytes()) | 0;\n\t\tif (public_nonce.length !== public_nonce_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid public_nonce length\");\n\t\t}\n\t\tpublic_nonce_address = _to_allocated_buf_address(public_nonce);\n\t\taddress_pool.push(public_nonce_address);\n\t\t\n\t\t// ---------- input: key (buf)\n\t\t\n\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\tvar key_address, key_length = (libsodium._crypto_aead_chacha20poly1305_keybytes()) | 0;\n\t\tif (key.length !== key_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid key length\");\n\t\t}\n\t\tkey_address = _to_allocated_buf_address(key);\n\t\taddress_pool.push(key_address);\n\t\t\n\t\t// ---------- output ciphertext (buf)\n\t\t\n\t\tvar ciphertext_length = (message_length + libsodium._crypto_aead_chacha20poly1305_abytes()) | 0,\n\t\t    ciphertext = new AllocatedBuf(ciphertext_length),\n\t\t    ciphertext_address = ciphertext.address;\n\t\t\n\t\taddress_pool.push(ciphertext_address);\n\t\t\n\t\tif ((libsodium._crypto_aead_chacha20poly1305_ietf_encrypt(ciphertext_address, null, message_address, message_length, 0, additional_data_address, additional_data_length, 0, secret_nonce_address, public_nonce_address, key_address)) === 0) {\n\t\t\tvar ret = _format_output(ciphertext, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_auth(message, key, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: key (buf)\n\t\t\n\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\tvar key_address, key_length = (libsodium._crypto_auth_keybytes()) | 0;\n\t\tif (key.length !== key_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid key length\");\n\t\t}\n\t\tkey_address = _to_allocated_buf_address(key);\n\t\taddress_pool.push(key_address);\n\t\t\n\t\t// ---------- output tag (buf)\n\t\t\n\t\tvar tag_length = (libsodium._crypto_auth_bytes()) | 0,\n\t\t    tag = new AllocatedBuf(tag_length),\n\t\t    tag_address = tag.address;\n\t\t\n\t\taddress_pool.push(tag_address);\n\t\t\n\t\tif ((libsodium._crypto_auth(tag_address, message_address, message_length, 0, key_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(tag, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_auth_hmacsha256(message, key, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: key (buf)\n\t\t\n\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\tvar key_address, key_length = (libsodium._crypto_auth_hmacsha256_keybytes()) | 0;\n\t\tif (key.length !== key_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid key length\");\n\t\t}\n\t\tkey_address = _to_allocated_buf_address(key);\n\t\taddress_pool.push(key_address);\n\t\t\n\t\t// ---------- output hash (buf)\n\t\t\n\t\tvar hash_length = (libsodium._crypto_auth_hmacsha256_bytes()) | 0,\n\t\t    hash = new AllocatedBuf(hash_length),\n\t\t    hash_address = hash.address;\n\t\t\n\t\taddress_pool.push(hash_address);\n\t\t\n\t\tif ((libsodium._crypto_auth_hmacsha256(hash_address, message_address, message_length, 0, key_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(hash, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_auth_hmacsha256_verify(tag, message, key) {\n\t\tvar address_pool = [];\n\n\t\t// ---------- input: tag (buf)\n\t\t\n\t\ttag = _any_to_Uint8Array(address_pool, tag, \"tag\");\n\t\tvar tag_address, tag_length = (libsodium._crypto_auth_hmacsha256_bytes()) | 0;\n\t\tif (tag.length !== tag_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid tag length\");\n\t\t}\n\t\ttag_address = _to_allocated_buf_address(tag);\n\t\taddress_pool.push(tag_address);\n\t\t\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: key (buf)\n\t\t\n\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\tvar key_address, key_length = (libsodium._crypto_auth_hmacsha256_keybytes()) | 0;\n\t\tif (key.length !== key_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid key length\");\n\t\t}\n\t\tkey_address = _to_allocated_buf_address(key);\n\t\taddress_pool.push(key_address);\n\t\t\n\t\tvar result = libsodium._crypto_auth_hmacsha256_verify(tag_address, message_address, message_length, 0, key_address) | 0;\n\t\tvar ret = (result === 0);\n\t\t_free_all(address_pool);\n\t\treturn ret;\n\t\t\n\t}\n\n\tfunction crypto_auth_hmacsha512(message, key, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: key (buf)\n\t\t\n\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\tvar key_address, key_length = (libsodium._crypto_auth_hmacsha512_keybytes()) | 0;\n\t\tif (key.length !== key_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid key length\");\n\t\t}\n\t\tkey_address = _to_allocated_buf_address(key);\n\t\taddress_pool.push(key_address);\n\t\t\n\t\t// ---------- output hash (buf)\n\t\t\n\t\tvar hash_length = (libsodium._crypto_auth_hmacsha512_bytes()) | 0,\n\t\t    hash = new AllocatedBuf(hash_length),\n\t\t    hash_address = hash.address;\n\t\t\n\t\taddress_pool.push(hash_address);\n\t\t\n\t\tif ((libsodium._crypto_auth_hmacsha512(hash_address, message_address, message_length, 0, key_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(hash, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_auth_hmacsha512_verify(tag, message, key) {\n\t\tvar address_pool = [];\n\n\t\t// ---------- input: tag (buf)\n\t\t\n\t\ttag = _any_to_Uint8Array(address_pool, tag, \"tag\");\n\t\tvar tag_address, tag_length = (libsodium._crypto_auth_hmacsha512_bytes()) | 0;\n\t\tif (tag.length !== tag_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid tag length\");\n\t\t}\n\t\ttag_address = _to_allocated_buf_address(tag);\n\t\taddress_pool.push(tag_address);\n\t\t\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: key (buf)\n\t\t\n\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\tvar key_address, key_length = (libsodium._crypto_auth_hmacsha512_keybytes()) | 0;\n\t\tif (key.length !== key_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid key length\");\n\t\t}\n\t\tkey_address = _to_allocated_buf_address(key);\n\t\taddress_pool.push(key_address);\n\t\t\n\t\tvar result = libsodium._crypto_auth_hmacsha512_verify(tag_address, message_address, message_length, 0, key_address) | 0;\n\t\tvar ret = (result === 0);\n\t\t_free_all(address_pool);\n\t\treturn ret;\n\t\t\n\t}\n\n\tfunction crypto_auth_verify(tag, message, key) {\n\t\tvar address_pool = [];\n\n\t\t// ---------- input: tag (buf)\n\t\t\n\t\ttag = _any_to_Uint8Array(address_pool, tag, \"tag\");\n\t\tvar tag_address, tag_length = (libsodium._crypto_auth_bytes()) | 0;\n\t\tif (tag.length !== tag_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid tag length\");\n\t\t}\n\t\ttag_address = _to_allocated_buf_address(tag);\n\t\taddress_pool.push(tag_address);\n\t\t\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: key (buf)\n\t\t\n\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\tvar key_address, key_length = (libsodium._crypto_auth_keybytes()) | 0;\n\t\tif (key.length !== key_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid key length\");\n\t\t}\n\t\tkey_address = _to_allocated_buf_address(key);\n\t\taddress_pool.push(key_address);\n\t\t\n\t\tvar result = libsodium._crypto_auth_verify(tag_address, message_address, message_length, 0, key_address) | 0;\n\t\tvar ret = (result === 0);\n\t\t_free_all(address_pool);\n\t\treturn ret;\n\t\t\n\t}\n\n\tfunction crypto_box_beforenm(publicKey, secretKey, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: publicKey (buf)\n\t\t\n\t\tpublicKey = _any_to_Uint8Array(address_pool, publicKey, \"publicKey\");\n\t\tvar publicKey_address, publicKey_length = (libsodium._crypto_box_publickeybytes()) | 0;\n\t\tif (publicKey.length !== publicKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid publicKey length\");\n\t\t}\n\t\tpublicKey_address = _to_allocated_buf_address(publicKey);\n\t\taddress_pool.push(publicKey_address);\n\t\t\n\t\t// ---------- input: secretKey (buf)\n\t\t\n\t\tsecretKey = _any_to_Uint8Array(address_pool, secretKey, \"secretKey\");\n\t\tvar secretKey_address, secretKey_length = (libsodium._crypto_box_secretkeybytes()) | 0;\n\t\tif (secretKey.length !== secretKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid secretKey length\");\n\t\t}\n\t\tsecretKey_address = _to_allocated_buf_address(secretKey);\n\t\taddress_pool.push(secretKey_address);\n\t\t\n\t\t// ---------- output sharedKey (buf)\n\t\t\n\t\tvar sharedKey_length = (libsodium._crypto_box_beforenmbytes()) | 0,\n\t\t    sharedKey = new AllocatedBuf(sharedKey_length),\n\t\t    sharedKey_address = sharedKey.address;\n\t\t\n\t\taddress_pool.push(sharedKey_address);\n\t\t\n\t\tif ((libsodium._crypto_box_beforenm(sharedKey_address, publicKey_address, secretKey_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(sharedKey, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_box_detached(message, nonce, publicKey, secretKey, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: nonce (buf)\n\t\t\n\t\tnonce = _any_to_Uint8Array(address_pool, nonce, \"nonce\");\n\t\tvar nonce_address, nonce_length = (libsodium._crypto_box_noncebytes()) | 0;\n\t\tif (nonce.length !== nonce_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid nonce length\");\n\t\t}\n\t\tnonce_address = _to_allocated_buf_address(nonce);\n\t\taddress_pool.push(nonce_address);\n\t\t\n\t\t// ---------- input: publicKey (buf)\n\t\t\n\t\tpublicKey = _any_to_Uint8Array(address_pool, publicKey, \"publicKey\");\n\t\tvar publicKey_address, publicKey_length = (libsodium._crypto_box_publickeybytes()) | 0;\n\t\tif (publicKey.length !== publicKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid publicKey length\");\n\t\t}\n\t\tpublicKey_address = _to_allocated_buf_address(publicKey);\n\t\taddress_pool.push(publicKey_address);\n\t\t\n\t\t// ---------- input: secretKey (buf)\n\t\t\n\t\tsecretKey = _any_to_Uint8Array(address_pool, secretKey, \"secretKey\");\n\t\tvar secretKey_address, secretKey_length = (libsodium._crypto_box_secretkeybytes()) | 0;\n\t\tif (secretKey.length !== secretKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid secretKey length\");\n\t\t}\n\t\tsecretKey_address = _to_allocated_buf_address(secretKey);\n\t\taddress_pool.push(secretKey_address);\n\t\t\n\t\t// ---------- output ciphertext (buf)\n\t\t\n\t\tvar ciphertext_length = (message_length) | 0,\n\t\t    ciphertext = new AllocatedBuf(ciphertext_length),\n\t\t    ciphertext_address = ciphertext.address;\n\t\t\n\t\taddress_pool.push(ciphertext_address);\n\t\t\n\t\t// ---------- output mac (buf)\n\t\t\n\t\tvar mac_length = (libsodium._crypto_box_macbytes()) | 0,\n\t\t    mac = new AllocatedBuf(mac_length),\n\t\t    mac_address = mac.address;\n\t\t\n\t\taddress_pool.push(mac_address);\n\t\t\n\t\tif ((libsodium._crypto_box_detached(ciphertext_address, mac_address, message_address, message_length, 0, nonce_address, publicKey_address, secretKey_address) | 0) === 0) {\n\t\t\tvar ret = _format_output({ciphertext: ciphertext, mac: mac}, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_box_easy(message, nonce, publicKey, secretKey, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: nonce (buf)\n\t\t\n\t\tnonce = _any_to_Uint8Array(address_pool, nonce, \"nonce\");\n\t\tvar nonce_address, nonce_length = (libsodium._crypto_box_noncebytes()) | 0;\n\t\tif (nonce.length !== nonce_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid nonce length\");\n\t\t}\n\t\tnonce_address = _to_allocated_buf_address(nonce);\n\t\taddress_pool.push(nonce_address);\n\t\t\n\t\t// ---------- input: publicKey (buf)\n\t\t\n\t\tpublicKey = _any_to_Uint8Array(address_pool, publicKey, \"publicKey\");\n\t\tvar publicKey_address, publicKey_length = (libsodium._crypto_box_publickeybytes()) | 0;\n\t\tif (publicKey.length !== publicKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid publicKey length\");\n\t\t}\n\t\tpublicKey_address = _to_allocated_buf_address(publicKey);\n\t\taddress_pool.push(publicKey_address);\n\t\t\n\t\t// ---------- input: secretKey (buf)\n\t\t\n\t\tsecretKey = _any_to_Uint8Array(address_pool, secretKey, \"secretKey\");\n\t\tvar secretKey_address, secretKey_length = (libsodium._crypto_box_secretkeybytes()) | 0;\n\t\tif (secretKey.length !== secretKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid secretKey length\");\n\t\t}\n\t\tsecretKey_address = _to_allocated_buf_address(secretKey);\n\t\taddress_pool.push(secretKey_address);\n\t\t\n\t\t// ---------- output ciphertext (buf)\n\t\t\n\t\tvar ciphertext_length = (message_length + libsodium._crypto_box_macbytes()) | 0,\n\t\t    ciphertext = new AllocatedBuf(ciphertext_length),\n\t\t    ciphertext_address = ciphertext.address;\n\t\t\n\t\taddress_pool.push(ciphertext_address);\n\t\t\n\t\tif ((libsodium._crypto_box_easy(ciphertext_address, message_address, message_length, 0, nonce_address, publicKey_address, secretKey_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(ciphertext, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_box_easy_afternm(message, nonce, sharedKey, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: nonce (buf)\n\t\t\n\t\tnonce = _any_to_Uint8Array(address_pool, nonce, \"nonce\");\n\t\tvar nonce_address, nonce_length = (libsodium._crypto_box_noncebytes()) | 0;\n\t\tif (nonce.length !== nonce_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid nonce length\");\n\t\t}\n\t\tnonce_address = _to_allocated_buf_address(nonce);\n\t\taddress_pool.push(nonce_address);\n\t\t\n\t\t// ---------- input: sharedKey (buf)\n\t\t\n\t\tsharedKey = _any_to_Uint8Array(address_pool, sharedKey, \"sharedKey\");\n\t\tvar sharedKey_address, sharedKey_length = (libsodium._crypto_box_beforenmbytes()) | 0;\n\t\tif (sharedKey.length !== sharedKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid sharedKey length\");\n\t\t}\n\t\tsharedKey_address = _to_allocated_buf_address(sharedKey);\n\t\taddress_pool.push(sharedKey_address);\n\t\t\n\t\t// ---------- output ciphertext (buf)\n\t\t\n\t\tvar ciphertext_length = (message_length + libsodium._crypto_box_macbytes()) | 0,\n\t\t    ciphertext = new AllocatedBuf(ciphertext_length),\n\t\t    ciphertext_address = ciphertext.address;\n\t\t\n\t\taddress_pool.push(ciphertext_address);\n\t\t\n\t\tif ((libsodium._crypto_box_easy_afternm(ciphertext_address, message_address, message_length, 0, nonce_address, sharedKey_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(ciphertext, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_box_keypair(outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- output publicKey (buf)\n\t\t\n\t\tvar publicKey_length = (libsodium._crypto_box_publickeybytes()) | 0,\n\t\t    publicKey = new AllocatedBuf(publicKey_length),\n\t\t    publicKey_address = publicKey.address;\n\t\t\n\t\taddress_pool.push(publicKey_address);\n\t\t\n\t\t// ---------- output secretKey (buf)\n\t\t\n\t\tvar secretKey_length = (libsodium._crypto_box_secretkeybytes()) | 0,\n\t\t    secretKey = new AllocatedBuf(secretKey_length),\n\t\t    secretKey_address = secretKey.address;\n\t\t\n\t\taddress_pool.push(secretKey_address);\n\t\t\n\t\tif ((libsodium._crypto_box_keypair(publicKey_address, secretKey_address) | 0) === 0) {\n\t\t\tvar ret = _format_output({publicKey: publicKey, privateKey: secretKey, keyType: \"curve25519\"}, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_box_open_detached(ciphertext, mac, nonce, publicKey, secretKey, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: ciphertext (unsized_buf)\n\t\t\n\t\tciphertext = _any_to_Uint8Array(address_pool, ciphertext, \"ciphertext\");\n\t\tvar ciphertext_address = _to_allocated_buf_address(ciphertext),\n\t\t    ciphertext_length = ciphertext.length;\n\t\taddress_pool.push(ciphertext_address);\n\t\t\n\t\t// ---------- input: mac (buf)\n\t\t\n\t\tmac = _any_to_Uint8Array(address_pool, mac, \"mac\");\n\t\tvar mac_address, mac_length = (libsodium._crypto_box_macbytes()) | 0;\n\t\tif (mac.length !== mac_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid mac length\");\n\t\t}\n\t\tmac_address = _to_allocated_buf_address(mac);\n\t\taddress_pool.push(mac_address);\n\t\t\n\t\t// ---------- input: nonce (buf)\n\t\t\n\t\tnonce = _any_to_Uint8Array(address_pool, nonce, \"nonce\");\n\t\tvar nonce_address, nonce_length = (libsodium._crypto_box_noncebytes()) | 0;\n\t\tif (nonce.length !== nonce_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid nonce length\");\n\t\t}\n\t\tnonce_address = _to_allocated_buf_address(nonce);\n\t\taddress_pool.push(nonce_address);\n\t\t\n\t\t// ---------- input: publicKey (buf)\n\t\t\n\t\tpublicKey = _any_to_Uint8Array(address_pool, publicKey, \"publicKey\");\n\t\tvar publicKey_address, publicKey_length = (libsodium._crypto_box_publickeybytes()) | 0;\n\t\tif (publicKey.length !== publicKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid publicKey length\");\n\t\t}\n\t\tpublicKey_address = _to_allocated_buf_address(publicKey);\n\t\taddress_pool.push(publicKey_address);\n\t\t\n\t\t// ---------- input: secretKey (buf)\n\t\t\n\t\tsecretKey = _any_to_Uint8Array(address_pool, secretKey, \"secretKey\");\n\t\tvar secretKey_address, secretKey_length = (libsodium._crypto_box_secretkeybytes()) | 0;\n\t\tif (secretKey.length !== secretKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid secretKey length\");\n\t\t}\n\t\tsecretKey_address = _to_allocated_buf_address(secretKey);\n\t\taddress_pool.push(secretKey_address);\n\t\t\n\t\t// ---------- output plaintext (buf)\n\t\t\n\t\tvar plaintext_length = (ciphertext_length) | 0,\n\t\t    plaintext = new AllocatedBuf(plaintext_length),\n\t\t    plaintext_address = plaintext.address;\n\t\t\n\t\taddress_pool.push(plaintext_address);\n\t\t\n\t\tif ((libsodium._crypto_box_open_detached(plaintext_address, ciphertext_address, mac_address, ciphertext_length, 0, nonce_address, publicKey_address, secretKey_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(plaintext, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_box_open_easy(ciphertext, nonce, publicKey, secretKey, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: ciphertext (unsized_buf)\n\t\t\n\t\tciphertext = _any_to_Uint8Array(address_pool, ciphertext, \"ciphertext\");\n\t\tvar ciphertext_address = _to_allocated_buf_address(ciphertext),\n\t\t    ciphertext_length = ciphertext.length;\n\t\taddress_pool.push(ciphertext_address);\n\t\t\n\t\t// ---------- input: nonce (buf)\n\t\t\n\t\tnonce = _any_to_Uint8Array(address_pool, nonce, \"nonce\");\n\t\tvar nonce_address, nonce_length = (libsodium._crypto_box_noncebytes()) | 0;\n\t\tif (nonce.length !== nonce_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid nonce length\");\n\t\t}\n\t\tnonce_address = _to_allocated_buf_address(nonce);\n\t\taddress_pool.push(nonce_address);\n\t\t\n\t\t// ---------- input: publicKey (buf)\n\t\t\n\t\tpublicKey = _any_to_Uint8Array(address_pool, publicKey, \"publicKey\");\n\t\tvar publicKey_address, publicKey_length = (libsodium._crypto_box_publickeybytes()) | 0;\n\t\tif (publicKey.length !== publicKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid publicKey length\");\n\t\t}\n\t\tpublicKey_address = _to_allocated_buf_address(publicKey);\n\t\taddress_pool.push(publicKey_address);\n\t\t\n\t\t// ---------- input: secretKey (buf)\n\t\t\n\t\tsecretKey = _any_to_Uint8Array(address_pool, secretKey, \"secretKey\");\n\t\tvar secretKey_address, secretKey_length = (libsodium._crypto_box_secretkeybytes()) | 0;\n\t\tif (secretKey.length !== secretKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid secretKey length\");\n\t\t}\n\t\tsecretKey_address = _to_allocated_buf_address(secretKey);\n\t\taddress_pool.push(secretKey_address);\n\t\t\n\t\t// ---------- output plaintext (buf)\n\t\t\n\t\tvar plaintext_length = (ciphertext_length - libsodium._crypto_box_macbytes()) | 0,\n\t\t    plaintext = new AllocatedBuf(plaintext_length),\n\t\t    plaintext_address = plaintext.address;\n\t\t\n\t\taddress_pool.push(plaintext_address);\n\t\t\n\t\tif ((libsodium._crypto_box_open_easy(plaintext_address, ciphertext_address, ciphertext_length, 0, nonce_address, publicKey_address, secretKey_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(plaintext, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_box_open_easy_afternm(ciphertext, nonce, sharedKey, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: ciphertext (unsized_buf)\n\t\t\n\t\tciphertext = _any_to_Uint8Array(address_pool, ciphertext, \"ciphertext\");\n\t\tvar ciphertext_address = _to_allocated_buf_address(ciphertext),\n\t\t    ciphertext_length = ciphertext.length;\n\t\taddress_pool.push(ciphertext_address);\n\t\t\n\t\t// ---------- input: nonce (buf)\n\t\t\n\t\tnonce = _any_to_Uint8Array(address_pool, nonce, \"nonce\");\n\t\tvar nonce_address, nonce_length = (libsodium._crypto_box_noncebytes()) | 0;\n\t\tif (nonce.length !== nonce_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid nonce length\");\n\t\t}\n\t\tnonce_address = _to_allocated_buf_address(nonce);\n\t\taddress_pool.push(nonce_address);\n\t\t\n\t\t// ---------- input: sharedKey (buf)\n\t\t\n\t\tsharedKey = _any_to_Uint8Array(address_pool, sharedKey, \"sharedKey\");\n\t\tvar sharedKey_address, sharedKey_length = (libsodium._crypto_box_beforenmbytes()) | 0;\n\t\tif (sharedKey.length !== sharedKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid sharedKey length\");\n\t\t}\n\t\tsharedKey_address = _to_allocated_buf_address(sharedKey);\n\t\taddress_pool.push(sharedKey_address);\n\t\t\n\t\t// ---------- output plaintext (buf)\n\t\t\n\t\tvar plaintext_length = (ciphertext_length - libsodium._crypto_box_macbytes()) | 0,\n\t\t    plaintext = new AllocatedBuf(plaintext_length),\n\t\t    plaintext_address = plaintext.address;\n\t\t\n\t\taddress_pool.push(plaintext_address);\n\t\t\n\t\tif ((libsodium._crypto_box_open_easy_afternm(plaintext_address, ciphertext_address, ciphertext_length, 0, nonce_address, sharedKey_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(plaintext, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_box_seal(message, publicKey, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: publicKey (buf)\n\t\t\n\t\tpublicKey = _any_to_Uint8Array(address_pool, publicKey, \"publicKey\");\n\t\tvar publicKey_address, publicKey_length = (libsodium._crypto_box_publickeybytes()) | 0;\n\t\tif (publicKey.length !== publicKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid publicKey length\");\n\t\t}\n\t\tpublicKey_address = _to_allocated_buf_address(publicKey);\n\t\taddress_pool.push(publicKey_address);\n\t\t\n\t\t// ---------- output ciphertext (buf)\n\t\t\n\t\tvar ciphertext_length = (message_length + libsodium._crypto_box_sealbytes()) | 0,\n\t\t    ciphertext = new AllocatedBuf(ciphertext_length),\n\t\t    ciphertext_address = ciphertext.address;\n\t\t\n\t\taddress_pool.push(ciphertext_address);\n\t\t\n\t\tif ((libsodium._crypto_box_seal(ciphertext_address, message_address, message_length, 0, publicKey_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(ciphertext, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_box_seal_open(ciphertext, publicKey, secretKey, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: ciphertext (unsized_buf)\n\t\t\n\t\tciphertext = _any_to_Uint8Array(address_pool, ciphertext, \"ciphertext\");\n\t\tvar ciphertext_address = _to_allocated_buf_address(ciphertext),\n\t\t    ciphertext_length = ciphertext.length;\n\t\taddress_pool.push(ciphertext_address);\n\t\t\n\t\t// ---------- input: publicKey (buf)\n\t\t\n\t\tpublicKey = _any_to_Uint8Array(address_pool, publicKey, \"publicKey\");\n\t\tvar publicKey_address, publicKey_length = (libsodium._crypto_box_publickeybytes()) | 0;\n\t\tif (publicKey.length !== publicKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid publicKey length\");\n\t\t}\n\t\tpublicKey_address = _to_allocated_buf_address(publicKey);\n\t\taddress_pool.push(publicKey_address);\n\t\t\n\t\t// ---------- input: secretKey (buf)\n\t\t\n\t\tsecretKey = _any_to_Uint8Array(address_pool, secretKey, \"secretKey\");\n\t\tvar secretKey_address, secretKey_length = (libsodium._crypto_box_secretkeybytes()) | 0;\n\t\tif (secretKey.length !== secretKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid secretKey length\");\n\t\t}\n\t\tsecretKey_address = _to_allocated_buf_address(secretKey);\n\t\taddress_pool.push(secretKey_address);\n\t\t\n\t\t// ---------- output plaintext (buf)\n\t\t\n\t\tvar plaintext_length = (ciphertext_length - libsodium._crypto_box_sealbytes()) | 0,\n\t\t    plaintext = new AllocatedBuf(plaintext_length),\n\t\t    plaintext_address = plaintext.address;\n\t\t\n\t\taddress_pool.push(plaintext_address);\n\t\t\n\t\tif ((libsodium._crypto_box_seal_open(plaintext_address, ciphertext_address, ciphertext_length, 0, publicKey_address, secretKey_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(plaintext, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_box_seed_keypair(seed, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: seed (buf)\n\t\t\n\t\tseed = _any_to_Uint8Array(address_pool, seed, \"seed\");\n\t\tvar seed_address, seed_length = (libsodium._crypto_box_seedbytes()) | 0;\n\t\tif (seed.length !== seed_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid seed length\");\n\t\t}\n\t\tseed_address = _to_allocated_buf_address(seed);\n\t\taddress_pool.push(seed_address);\n\t\t\n\t\t// ---------- output publicKey (buf)\n\t\t\n\t\tvar publicKey_length = (libsodium._crypto_box_publickeybytes()) | 0,\n\t\t    publicKey = new AllocatedBuf(publicKey_length),\n\t\t    publicKey_address = publicKey.address;\n\t\t\n\t\taddress_pool.push(publicKey_address);\n\t\t\n\t\t// ---------- output privateKey (buf)\n\t\t\n\t\tvar privateKey_length = (libsodium._crypto_box_secretkeybytes()) | 0,\n\t\t    privateKey = new AllocatedBuf(privateKey_length),\n\t\t    privateKey_address = privateKey.address;\n\t\t\n\t\taddress_pool.push(privateKey_address);\n\t\t\n\t\tif ((libsodium._crypto_box_seed_keypair(publicKey_address, privateKey_address, seed_address) | 0) === 0) {\n\t\t\tvar ret = _format_output({publicKey: publicKey, privateKey: privateKey}, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_generichash(hash_length, message, key, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: hash_length (uint)\n\t\t\n\t\t_require_defined(address_pool, hash_length, \"hash_length\");\n\t\t\n\t\tif (!(typeof hash_length === \"number\" && (hash_length | 0) === hash_length) && (hash_length | 0) > 0) {\n\t\t\t_free_and_throw_type_error(address_pool, \"hash_length must be an unsigned integer\");\n\t\t}\n\t\t\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: key (unsized_buf_optional)\n\t\t\n\t\tvar key_address = null, key_length = 0;\n\t\tif (key != undefined) {\n\t\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\t\tkey_address = _to_allocated_buf_address(key);\n\t\t\tkey_length = key.length;\n\t\t\taddress_pool.push(key_address);\n\t\t}\n\t\t\n\t\t// ---------- output hash (buf)\n\t\t\n\t\tvar hash_length = (hash_length) | 0,\n\t\t    hash = new AllocatedBuf(hash_length),\n\t\t    hash_address = hash.address;\n\t\t\n\t\taddress_pool.push(hash_address);\n\t\t\n\t\tif ((libsodium._crypto_generichash(hash_address, hash_length, message_address, message_length, 0, key_address, key_length) | 0) === 0) {\n\t\t\tvar ret = _format_output(hash, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_generichash_final(state_address, hash_length, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: state_address (generichash_state_address)\n\t\t\n\t\t_require_defined(address_pool, state_address, \"state_address\");\n\t\t\n\t\t// ---------- input: hash_length (uint)\n\t\t\n\t\t_require_defined(address_pool, hash_length, \"hash_length\");\n\t\t\n\t\tif (!(typeof hash_length === \"number\" && (hash_length | 0) === hash_length) && (hash_length | 0) > 0) {\n\t\t\t_free_and_throw_type_error(address_pool, \"hash_length must be an unsigned integer\");\n\t\t}\n\t\t\n\t\t// ---------- output hash (buf)\n\t\t\n\t\tvar hash_length = (hash_length) | 0,\n\t\t    hash = new AllocatedBuf(hash_length),\n\t\t    hash_address = hash.address;\n\t\t\n\t\taddress_pool.push(hash_address);\n\t\t\n\t\tif ((libsodium._crypto_generichash_final(state_address, hash_address, hash_length) | 0) === 0) {\n\t\t\tvar ret = (libsodium._free(state_address), _format_output(hash, outputFormat));\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_generichash_init(key, hash_length, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: key (unsized_buf_optional)\n\t\t\n\t\tvar key_address = null, key_length = 0;\n\t\tif (key != undefined) {\n\t\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\t\tkey_address = _to_allocated_buf_address(key);\n\t\t\tkey_length = key.length;\n\t\t\taddress_pool.push(key_address);\n\t\t}\n\t\t\n\t\t// ---------- input: hash_length (uint)\n\t\t\n\t\t_require_defined(address_pool, hash_length, \"hash_length\");\n\t\t\n\t\tif (!(typeof hash_length === \"number\" && (hash_length | 0) === hash_length) && (hash_length | 0) > 0) {\n\t\t\t_free_and_throw_type_error(address_pool, \"hash_length must be an unsigned integer\");\n\t\t}\n\t\t\n\t\t// ---------- output state (generichash_state)\n\t\t\n\t\tvar state_address = new AllocatedBuf(357).address;\n\t\t\n\t\tif ((libsodium._crypto_generichash_init(state_address, key_address, key_length, hash_length) | 0) === 0) {\n\t\t\tvar ret = state_address;\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_generichash_update(state_address, message_chunk, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: state_address (generichash_state_address)\n\t\t\n\t\t_require_defined(address_pool, state_address, \"state_address\");\n\t\t\n\t\t// ---------- input: message_chunk (unsized_buf)\n\t\t\n\t\tmessage_chunk = _any_to_Uint8Array(address_pool, message_chunk, \"message_chunk\");\n\t\tvar message_chunk_address = _to_allocated_buf_address(message_chunk),\n\t\t    message_chunk_length = message_chunk.length;\n\t\taddress_pool.push(message_chunk_address);\n\t\t\n\t\tif ((libsodium._crypto_generichash_update(state_address, message_chunk_address, message_chunk_length) | 0) === 0) {\n\t\t\t_free_all(address_pool);\n\t\t\treturn;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_hash(message, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- output hash (buf)\n\t\t\n\t\tvar hash_length = (libsodium._crypto_hash_bytes()) | 0,\n\t\t    hash = new AllocatedBuf(hash_length),\n\t\t    hash_address = hash.address;\n\t\t\n\t\taddress_pool.push(hash_address);\n\t\t\n\t\tif ((libsodium._crypto_hash(hash_address, message_address, message_length, 0) | 0) === 0) {\n\t\t\tvar ret = _format_output(hash, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_hash_sha256(message, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- output hash (buf)\n\t\t\n\t\tvar hash_length = (libsodium._crypto_hash_sha256_bytes()) | 0,\n\t\t    hash = new AllocatedBuf(hash_length),\n\t\t    hash_address = hash.address;\n\t\t\n\t\taddress_pool.push(hash_address);\n\t\t\n\t\tif ((libsodium._crypto_hash_sha256(hash_address, message_address, message_length, 0) | 0) === 0) {\n\t\t\tvar ret = _format_output(hash, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_hash_sha512(message, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- output hash (buf)\n\t\t\n\t\tvar hash_length = (libsodium._crypto_hash_sha512_bytes()) | 0,\n\t\t    hash = new AllocatedBuf(hash_length),\n\t\t    hash_address = hash.address;\n\t\t\n\t\taddress_pool.push(hash_address);\n\t\t\n\t\tif ((libsodium._crypto_hash_sha512(hash_address, message_address, message_length, 0) | 0) === 0) {\n\t\t\tvar ret = _format_output(hash, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_onetimeauth(message, key, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: key (buf)\n\t\t\n\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\tvar key_address, key_length = (libsodium._crypto_onetimeauth_keybytes()) | 0;\n\t\tif (key.length !== key_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid key length\");\n\t\t}\n\t\tkey_address = _to_allocated_buf_address(key);\n\t\taddress_pool.push(key_address);\n\t\t\n\t\t// ---------- output hash (buf)\n\t\t\n\t\tvar hash_length = (libsodium._crypto_onetimeauth_bytes()) | 0,\n\t\t    hash = new AllocatedBuf(hash_length),\n\t\t    hash_address = hash.address;\n\t\t\n\t\taddress_pool.push(hash_address);\n\t\t\n\t\tif ((libsodium._crypto_onetimeauth(hash_address, message_address, message_length, 0, key_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(hash, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_onetimeauth_final(state_address, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: state_address (onetimeauth_state_address)\n\t\t\n\t\t_require_defined(address_pool, state_address, \"state_address\");\n\t\t\n\t\t// ---------- output hash (buf)\n\t\t\n\t\tvar hash_length = (libsodium._crypto_onetimeauth_bytes()) | 0,\n\t\t    hash = new AllocatedBuf(hash_length),\n\t\t    hash_address = hash.address;\n\t\t\n\t\taddress_pool.push(hash_address);\n\t\t\n\t\tif ((libsodium._crypto_onetimeauth_final(state_address, hash_address) | 0) === 0) {\n\t\t\tvar ret = (libsodium._free(state_address), _format_output(hash, outputFormat));\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_onetimeauth_init(key, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: key (unsized_buf_optional)\n\t\t\n\t\tvar key_address = null, key_length = 0;\n\t\tif (key != undefined) {\n\t\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\t\tkey_address = _to_allocated_buf_address(key);\n\t\t\tkey_length = key.length;\n\t\t\taddress_pool.push(key_address);\n\t\t}\n\t\t\n\t\t// ---------- output state (onetimeauth_state)\n\t\t\n\t\tvar state_address = new AllocatedBuf(144).address;\n\t\t\n\t\tif ((libsodium._crypto_onetimeauth_init(state_address, key_address) | 0) === 0) {\n\t\t\tvar ret = state_address;\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_onetimeauth_update(state_address, message_chunk, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: state_address (onetimeauth_state_address)\n\t\t\n\t\t_require_defined(address_pool, state_address, \"state_address\");\n\t\t\n\t\t// ---------- input: message_chunk (unsized_buf)\n\t\t\n\t\tmessage_chunk = _any_to_Uint8Array(address_pool, message_chunk, \"message_chunk\");\n\t\tvar message_chunk_address = _to_allocated_buf_address(message_chunk),\n\t\t    message_chunk_length = message_chunk.length;\n\t\taddress_pool.push(message_chunk_address);\n\t\t\n\t\tif ((libsodium._crypto_onetimeauth_update(state_address, message_chunk_address, message_chunk_length) | 0) === 0) {\n\t\t\t_free_all(address_pool);\n\t\t\treturn;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_onetimeauth_verify(hash, message, key) {\n\t\tvar address_pool = [];\n\n\t\t// ---------- input: hash (buf)\n\t\t\n\t\thash = _any_to_Uint8Array(address_pool, hash, \"hash\");\n\t\tvar hash_address, hash_length = (libsodium._crypto_onetimeauth_bytes()) | 0;\n\t\tif (hash.length !== hash_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid hash length\");\n\t\t}\n\t\thash_address = _to_allocated_buf_address(hash);\n\t\taddress_pool.push(hash_address);\n\t\t\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: key (buf)\n\t\t\n\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\tvar key_address, key_length = (libsodium._crypto_onetimeauth_keybytes()) | 0;\n\t\tif (key.length !== key_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid key length\");\n\t\t}\n\t\tkey_address = _to_allocated_buf_address(key);\n\t\taddress_pool.push(key_address);\n\t\t\n\t\tvar result = libsodium._crypto_onetimeauth_verify(hash_address, message_address, message_length, 0, key_address) | 0;\n\t\tvar ret = (result === 0);\n\t\t_free_all(address_pool);\n\t\treturn ret;\n\t\t\n\t}\n\n\tfunction crypto_pwhash_scryptsalsa208sha256(password, salt, opsLimit, memLimit, keyLength, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: password (unsized_buf)\n\t\t\n\t\tpassword = _any_to_Uint8Array(address_pool, password, \"password\");\n\t\tvar password_address = _to_allocated_buf_address(password),\n\t\t    password_length = password.length;\n\t\taddress_pool.push(password_address);\n\t\t\n\t\t// ---------- input: salt (buf)\n\t\t\n\t\tsalt = _any_to_Uint8Array(address_pool, salt, \"salt\");\n\t\tvar salt_address, salt_length = (libsodium._crypto_pwhash_scryptsalsa208sha256_saltbytes()) | 0;\n\t\tif (salt.length !== salt_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid salt length\");\n\t\t}\n\t\tsalt_address = _to_allocated_buf_address(salt);\n\t\taddress_pool.push(salt_address);\n\t\t\n\t\t// ---------- input: opsLimit (uint)\n\t\t\n\t\t_require_defined(address_pool, opsLimit, \"opsLimit\");\n\t\t\n\t\tif (!(typeof opsLimit === \"number\" && (opsLimit | 0) === opsLimit) && (opsLimit | 0) > 0) {\n\t\t\t_free_and_throw_type_error(address_pool, \"opsLimit must be an unsigned integer\");\n\t\t}\n\t\t\n\t\t// ---------- input: memLimit (uint)\n\t\t\n\t\t_require_defined(address_pool, memLimit, \"memLimit\");\n\t\t\n\t\tif (!(typeof memLimit === \"number\" && (memLimit | 0) === memLimit) && (memLimit | 0) > 0) {\n\t\t\t_free_and_throw_type_error(address_pool, \"memLimit must be an unsigned integer\");\n\t\t}\n\t\t\n\t\t// ---------- input: keyLength (uint)\n\t\t\n\t\t_require_defined(address_pool, keyLength, \"keyLength\");\n\t\t\n\t\tif (!(typeof keyLength === \"number\" && (keyLength | 0) === keyLength) && (keyLength | 0) > 0) {\n\t\t\t_free_and_throw_type_error(address_pool, \"keyLength must be an unsigned integer\");\n\t\t}\n\t\t\n\t\t// ---------- output derivedKey (buf)\n\t\t\n\t\tvar derivedKey_length = (keyLength) | 0,\n\t\t    derivedKey = new AllocatedBuf(derivedKey_length),\n\t\t    derivedKey_address = derivedKey.address;\n\t\t\n\t\taddress_pool.push(derivedKey_address);\n\t\t\n\t\tif ((libsodium._crypto_pwhash_scryptsalsa208sha256(derivedKey_address, keyLength, 0, password_address, password_length, 0, salt_address, opsLimit, 0, memLimit) | 0) === 0) {\n\t\t\tvar ret = _format_output(derivedKey, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_pwhash_scryptsalsa208sha256_ll(password, salt, opsLimit, r, p, keyLength, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: password (unsized_buf)\n\t\t\n\t\tpassword = _any_to_Uint8Array(address_pool, password, \"password\");\n\t\tvar password_address = _to_allocated_buf_address(password),\n\t\t    password_length = password.length;\n\t\taddress_pool.push(password_address);\n\t\t\n\t\t// ---------- input: salt (unsized_buf)\n\t\t\n\t\tsalt = _any_to_Uint8Array(address_pool, salt, \"salt\");\n\t\tvar salt_address = _to_allocated_buf_address(salt),\n\t\t    salt_length = salt.length;\n\t\taddress_pool.push(salt_address);\n\t\t\n\t\t// ---------- input: opsLimit (uint)\n\t\t\n\t\t_require_defined(address_pool, opsLimit, \"opsLimit\");\n\t\t\n\t\tif (!(typeof opsLimit === \"number\" && (opsLimit | 0) === opsLimit) && (opsLimit | 0) > 0) {\n\t\t\t_free_and_throw_type_error(address_pool, \"opsLimit must be an unsigned integer\");\n\t\t}\n\t\t\n\t\t// ---------- input: r (uint)\n\t\t\n\t\t_require_defined(address_pool, r, \"r\");\n\t\t\n\t\tif (!(typeof r === \"number\" && (r | 0) === r) && (r | 0) > 0) {\n\t\t\t_free_and_throw_type_error(address_pool, \"r must be an unsigned integer\");\n\t\t}\n\t\t\n\t\t// ---------- input: p (uint)\n\t\t\n\t\t_require_defined(address_pool, p, \"p\");\n\t\t\n\t\tif (!(typeof p === \"number\" && (p | 0) === p) && (p | 0) > 0) {\n\t\t\t_free_and_throw_type_error(address_pool, \"p must be an unsigned integer\");\n\t\t}\n\t\t\n\t\t// ---------- input: keyLength (uint)\n\t\t\n\t\t_require_defined(address_pool, keyLength, \"keyLength\");\n\t\t\n\t\tif (!(typeof keyLength === \"number\" && (keyLength | 0) === keyLength) && (keyLength | 0) > 0) {\n\t\t\t_free_and_throw_type_error(address_pool, \"keyLength must be an unsigned integer\");\n\t\t}\n\t\t\n\t\t// ---------- output derivedKey (buf)\n\t\t\n\t\tvar derivedKey_length = (keyLength) | 0,\n\t\t    derivedKey = new AllocatedBuf(derivedKey_length),\n\t\t    derivedKey_address = derivedKey.address;\n\t\t\n\t\taddress_pool.push(derivedKey_address);\n\t\t\n\t\tif ((libsodium._crypto_pwhash_scryptsalsa208sha256_ll(password_address, password_length, salt_address, salt_length, opsLimit, 0, r, p, derivedKey_address, keyLength) | 0) === 0) {\n\t\t\tvar ret = _format_output(derivedKey, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_pwhash_scryptsalsa208sha256_str(password, opsLimit, memLimit, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: password (unsized_buf)\n\t\t\n\t\tpassword = _any_to_Uint8Array(address_pool, password, \"password\");\n\t\tvar password_address = _to_allocated_buf_address(password),\n\t\t    password_length = password.length;\n\t\taddress_pool.push(password_address);\n\t\t\n\t\t// ---------- input: opsLimit (uint)\n\t\t\n\t\t_require_defined(address_pool, opsLimit, \"opsLimit\");\n\t\t\n\t\tif (!(typeof opsLimit === \"number\" && (opsLimit | 0) === opsLimit) && (opsLimit | 0) > 0) {\n\t\t\t_free_and_throw_type_error(address_pool, \"opsLimit must be an unsigned integer\");\n\t\t}\n\t\t\n\t\t// ---------- input: memLimit (uint)\n\t\t\n\t\t_require_defined(address_pool, memLimit, \"memLimit\");\n\t\t\n\t\tif (!(typeof memLimit === \"number\" && (memLimit | 0) === memLimit) && (memLimit | 0) > 0) {\n\t\t\t_free_and_throw_type_error(address_pool, \"memLimit must be an unsigned integer\");\n\t\t}\n\t\t\n\t\t// ---------- output hashed_password (buf)\n\t\t\n\t\tvar hashed_password_length = (libsodium._crypto_pwhash_scryptsalsa208sha256_strbytes()) | 0,\n\t\t    hashed_password = new AllocatedBuf(hashed_password_length),\n\t\t    hashed_password_address = hashed_password.address;\n\t\t\n\t\taddress_pool.push(hashed_password_address);\n\t\t\n\t\tif ((libsodium._crypto_pwhash_scryptsalsa208sha256_str(hashed_password_address, password_address, password_length, 0, opsLimit, 0, memLimit) | 0) === 0) {\n\t\t\tvar ret = libsodium.Pointer_stringify(hashed_password_address);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_pwhash_scryptsalsa208sha256_str_verify(hashed_password, password, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: hashed_password (string)\n\t\t\n\t\thashed_password = from_string(hashed_password + \"\\0\");\n\t\tvar hashed_password_address = _to_allocated_buf_address(hashed_password),\n\t\t    hashed_password_length = hashed_password.length - 1;\n\t\taddress_pool.push(hashed_password_address);\n\t\t\n\t\t// ---------- input: password (unsized_buf)\n\t\t\n\t\tpassword = _any_to_Uint8Array(address_pool, password, \"password\");\n\t\tvar password_address = _to_allocated_buf_address(password),\n\t\t    password_length = password.length;\n\t\taddress_pool.push(password_address);\n\t\t\n\t\tvar result = libsodium._crypto_pwhash_scryptsalsa208sha256_str_verify(hashed_password_address, password_address, password_length, 0) | 0;\n\t\tvar ret = (result === 0);\n\t\t_free_all(address_pool);\n\t\treturn ret;\n\t\t\n\t}\n\n\tfunction crypto_scalarmult(privateKey, publicKey, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: privateKey (buf)\n\t\t\n\t\tprivateKey = _any_to_Uint8Array(address_pool, privateKey, \"privateKey\");\n\t\tvar privateKey_address, privateKey_length = (libsodium._crypto_scalarmult_scalarbytes()) | 0;\n\t\tif (privateKey.length !== privateKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid privateKey length\");\n\t\t}\n\t\tprivateKey_address = _to_allocated_buf_address(privateKey);\n\t\taddress_pool.push(privateKey_address);\n\t\t\n\t\t// ---------- input: publicKey (buf)\n\t\t\n\t\tpublicKey = _any_to_Uint8Array(address_pool, publicKey, \"publicKey\");\n\t\tvar publicKey_address, publicKey_length = (libsodium._crypto_scalarmult_scalarbytes()) | 0;\n\t\tif (publicKey.length !== publicKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid publicKey length\");\n\t\t}\n\t\tpublicKey_address = _to_allocated_buf_address(publicKey);\n\t\taddress_pool.push(publicKey_address);\n\t\t\n\t\t// ---------- output sharedSecret (buf)\n\t\t\n\t\tvar sharedSecret_length = (libsodium._crypto_scalarmult_bytes()) | 0,\n\t\t    sharedSecret = new AllocatedBuf(sharedSecret_length),\n\t\t    sharedSecret_address = sharedSecret.address;\n\t\t\n\t\taddress_pool.push(sharedSecret_address);\n\t\t\n\t\tif ((libsodium._crypto_scalarmult(sharedSecret_address, privateKey_address, publicKey_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(sharedSecret, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_scalarmult_base(privateKey, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: privateKey (buf)\n\t\t\n\t\tprivateKey = _any_to_Uint8Array(address_pool, privateKey, \"privateKey\");\n\t\tvar privateKey_address, privateKey_length = (libsodium._crypto_scalarmult_scalarbytes()) | 0;\n\t\tif (privateKey.length !== privateKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid privateKey length\");\n\t\t}\n\t\tprivateKey_address = _to_allocated_buf_address(privateKey);\n\t\taddress_pool.push(privateKey_address);\n\t\t\n\t\t// ---------- output publicKey (buf)\n\t\t\n\t\tvar publicKey_length = (libsodium._crypto_scalarmult_scalarbytes()) | 0,\n\t\t    publicKey = new AllocatedBuf(publicKey_length),\n\t\t    publicKey_address = publicKey.address;\n\t\t\n\t\taddress_pool.push(publicKey_address);\n\t\t\n\t\tif ((libsodium._crypto_scalarmult_base(publicKey_address, privateKey_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(publicKey, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_secretbox_detached(message, nonce, key, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: nonce (buf)\n\t\t\n\t\tnonce = _any_to_Uint8Array(address_pool, nonce, \"nonce\");\n\t\tvar nonce_address, nonce_length = (libsodium._crypto_secretbox_noncebytes()) | 0;\n\t\tif (nonce.length !== nonce_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid nonce length\");\n\t\t}\n\t\tnonce_address = _to_allocated_buf_address(nonce);\n\t\taddress_pool.push(nonce_address);\n\t\t\n\t\t// ---------- input: key (buf)\n\t\t\n\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\tvar key_address, key_length = (libsodium._crypto_secretbox_keybytes()) | 0;\n\t\tif (key.length !== key_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid key length\");\n\t\t}\n\t\tkey_address = _to_allocated_buf_address(key);\n\t\taddress_pool.push(key_address);\n\t\t\n\t\t// ---------- output cipher (buf)\n\t\t\n\t\tvar cipher_length = (message_length) | 0,\n\t\t    cipher = new AllocatedBuf(cipher_length),\n\t\t    cipher_address = cipher.address;\n\t\t\n\t\taddress_pool.push(cipher_address);\n\t\t\n\t\t// ---------- output mac (buf)\n\t\t\n\t\tvar mac_length = (libsodium._crypto_secretbox_macbytes()) | 0,\n\t\t    mac = new AllocatedBuf(mac_length),\n\t\t    mac_address = mac.address;\n\t\t\n\t\taddress_pool.push(mac_address);\n\t\t\n\t\tif ((libsodium._crypto_secretbox_detached(cipher_address, mac_address, message_address, message_length, 0, nonce_address, key_address) | 0) === 0) {\n\t\t\tvar ret = _format_output({mac: mac, cipher: cipher}, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_secretbox_easy(message, nonce, key, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: nonce (buf)\n\t\t\n\t\tnonce = _any_to_Uint8Array(address_pool, nonce, \"nonce\");\n\t\tvar nonce_address, nonce_length = (libsodium._crypto_secretbox_noncebytes()) | 0;\n\t\tif (nonce.length !== nonce_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid nonce length\");\n\t\t}\n\t\tnonce_address = _to_allocated_buf_address(nonce);\n\t\taddress_pool.push(nonce_address);\n\t\t\n\t\t// ---------- input: key (buf)\n\t\t\n\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\tvar key_address, key_length = (libsodium._crypto_secretbox_keybytes()) | 0;\n\t\tif (key.length !== key_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid key length\");\n\t\t}\n\t\tkey_address = _to_allocated_buf_address(key);\n\t\taddress_pool.push(key_address);\n\t\t\n\t\t// ---------- output cipher (buf)\n\t\t\n\t\tvar cipher_length = (message_length + libsodium._crypto_secretbox_macbytes()) | 0,\n\t\t    cipher = new AllocatedBuf(cipher_length),\n\t\t    cipher_address = cipher.address;\n\t\t\n\t\taddress_pool.push(cipher_address);\n\t\t\n\t\tif ((libsodium._crypto_secretbox_easy(cipher_address, message_address, message_length, 0, nonce_address, key_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(cipher, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_secretbox_open_detached(ciphertext, mac, nonce, key, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: ciphertext (unsized_buf)\n\t\t\n\t\tciphertext = _any_to_Uint8Array(address_pool, ciphertext, \"ciphertext\");\n\t\tvar ciphertext_address = _to_allocated_buf_address(ciphertext),\n\t\t    ciphertext_length = ciphertext.length;\n\t\taddress_pool.push(ciphertext_address);\n\t\t\n\t\t// ---------- input: mac (buf)\n\t\t\n\t\tmac = _any_to_Uint8Array(address_pool, mac, \"mac\");\n\t\tvar mac_address, mac_length = (libsodium._crypto_secretbox_macbytes()) | 0;\n\t\tif (mac.length !== mac_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid mac length\");\n\t\t}\n\t\tmac_address = _to_allocated_buf_address(mac);\n\t\taddress_pool.push(mac_address);\n\t\t\n\t\t// ---------- input: nonce (buf)\n\t\t\n\t\tnonce = _any_to_Uint8Array(address_pool, nonce, \"nonce\");\n\t\tvar nonce_address, nonce_length = (libsodium._crypto_secretbox_noncebytes()) | 0;\n\t\tif (nonce.length !== nonce_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid nonce length\");\n\t\t}\n\t\tnonce_address = _to_allocated_buf_address(nonce);\n\t\taddress_pool.push(nonce_address);\n\t\t\n\t\t// ---------- input: key (buf)\n\t\t\n\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\tvar key_address, key_length = (libsodium._crypto_secretbox_keybytes()) | 0;\n\t\tif (key.length !== key_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid key length\");\n\t\t}\n\t\tkey_address = _to_allocated_buf_address(key);\n\t\taddress_pool.push(key_address);\n\t\t\n\t\t// ---------- output message (buf)\n\t\t\n\t\tvar message_length = (ciphertext_length) | 0,\n\t\t    message = new AllocatedBuf(message_length),\n\t\t    message_address = message.address;\n\t\t\n\t\taddress_pool.push(message_address);\n\t\t\n\t\tif ((libsodium._crypto_secretbox_open_detached(message_address, ciphertext_address, mac_address, ciphertext_length, 0, nonce_address, key_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(message, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_secretbox_open_easy(ciphertext, nonce, key, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: ciphertext (unsized_buf)\n\t\t\n\t\tciphertext = _any_to_Uint8Array(address_pool, ciphertext, \"ciphertext\");\n\t\tvar ciphertext_address = _to_allocated_buf_address(ciphertext),\n\t\t    ciphertext_length = ciphertext.length;\n\t\taddress_pool.push(ciphertext_address);\n\t\t\n\t\t// ---------- input: nonce (buf)\n\t\t\n\t\tnonce = _any_to_Uint8Array(address_pool, nonce, \"nonce\");\n\t\tvar nonce_address, nonce_length = (libsodium._crypto_secretbox_noncebytes()) | 0;\n\t\tif (nonce.length !== nonce_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid nonce length\");\n\t\t}\n\t\tnonce_address = _to_allocated_buf_address(nonce);\n\t\taddress_pool.push(nonce_address);\n\t\t\n\t\t// ---------- input: key (buf)\n\t\t\n\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\tvar key_address, key_length = (libsodium._crypto_secretbox_keybytes()) | 0;\n\t\tif (key.length !== key_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid key length\");\n\t\t}\n\t\tkey_address = _to_allocated_buf_address(key);\n\t\taddress_pool.push(key_address);\n\t\t\n\t\t// ---------- output message (buf)\n\t\t\n\t\tvar message_length = (ciphertext_length - libsodium._crypto_secretbox_macbytes()) | 0,\n\t\t    message = new AllocatedBuf(message_length),\n\t\t    message_address = message.address;\n\t\t\n\t\taddress_pool.push(message_address);\n\t\t\n\t\tif ((libsodium._crypto_secretbox_open_easy(message_address, ciphertext_address, ciphertext_length, 0, nonce_address, key_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(message, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_shorthash(message, key, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: key (buf)\n\t\t\n\t\tkey = _any_to_Uint8Array(address_pool, key, \"key\");\n\t\tvar key_address, key_length = (libsodium._crypto_shorthash_keybytes()) | 0;\n\t\tif (key.length !== key_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid key length\");\n\t\t}\n\t\tkey_address = _to_allocated_buf_address(key);\n\t\taddress_pool.push(key_address);\n\t\t\n\t\t// ---------- output hash (buf)\n\t\t\n\t\tvar hash_length = (libsodium._crypto_shorthash_bytes()) | 0,\n\t\t    hash = new AllocatedBuf(hash_length),\n\t\t    hash_address = hash.address;\n\t\t\n\t\taddress_pool.push(hash_address);\n\t\t\n\t\tif ((libsodium._crypto_shorthash(hash_address, message_address, message_length, 0, key_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(hash, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_sign(message, privateKey, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: privateKey (buf)\n\t\t\n\t\tprivateKey = _any_to_Uint8Array(address_pool, privateKey, \"privateKey\");\n\t\tvar privateKey_address, privateKey_length = (libsodium._crypto_sign_secretkeybytes()) | 0;\n\t\tif (privateKey.length !== privateKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid privateKey length\");\n\t\t}\n\t\tprivateKey_address = _to_allocated_buf_address(privateKey);\n\t\taddress_pool.push(privateKey_address);\n\t\t\n\t\t// ---------- output signature (buf)\n\t\t\n\t\tvar signature_length = (message.length + libsodium._crypto_sign_bytes()) | 0,\n\t\t    signature = new AllocatedBuf(signature_length),\n\t\t    signature_address = signature.address;\n\t\t\n\t\taddress_pool.push(signature_address);\n\t\t\n\t\tif ((libsodium._crypto_sign(signature_address, null, message_address, message_length, 0, privateKey_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(signature, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_sign_detached(message, privateKey, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: privateKey (buf)\n\t\t\n\t\tprivateKey = _any_to_Uint8Array(address_pool, privateKey, \"privateKey\");\n\t\tvar privateKey_address, privateKey_length = (libsodium._crypto_sign_secretkeybytes()) | 0;\n\t\tif (privateKey.length !== privateKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid privateKey length\");\n\t\t}\n\t\tprivateKey_address = _to_allocated_buf_address(privateKey);\n\t\taddress_pool.push(privateKey_address);\n\t\t\n\t\t// ---------- output signature (buf)\n\t\t\n\t\tvar signature_length = (libsodium._crypto_sign_bytes()) | 0,\n\t\t    signature = new AllocatedBuf(signature_length),\n\t\t    signature_address = signature.address;\n\t\t\n\t\taddress_pool.push(signature_address);\n\t\t\n\t\tif ((libsodium._crypto_sign_detached(signature_address, null, message_address, message_length, 0, privateKey_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(signature, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_sign_ed25519_pk_to_curve25519(edPk, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: edPk (buf)\n\t\t\n\t\tedPk = _any_to_Uint8Array(address_pool, edPk, \"edPk\");\n\t\tvar edPk_address, edPk_length = (libsodium._crypto_sign_publickeybytes()) | 0;\n\t\tif (edPk.length !== edPk_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid edPk length\");\n\t\t}\n\t\tedPk_address = _to_allocated_buf_address(edPk);\n\t\taddress_pool.push(edPk_address);\n\t\t\n\t\t// ---------- output cPk (buf)\n\t\t\n\t\tvar cPk_length = (libsodium._crypto_scalarmult_scalarbytes()) | 0,\n\t\t    cPk = new AllocatedBuf(cPk_length),\n\t\t    cPk_address = cPk.address;\n\t\t\n\t\taddress_pool.push(cPk_address);\n\t\t\n\t\tif ((libsodium._crypto_sign_ed25519_pk_to_curve25519(cPk_address, edPk_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(cPk, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_sign_ed25519_sk_to_curve25519(edSk, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: edSk (buf)\n\t\t\n\t\tedSk = _any_to_Uint8Array(address_pool, edSk, \"edSk\");\n\t\tvar edSk_address, edSk_length = (libsodium._crypto_sign_secretkeybytes()) | 0;\n\t\tif (edSk.length !== edSk_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid edSk length\");\n\t\t}\n\t\tedSk_address = _to_allocated_buf_address(edSk);\n\t\taddress_pool.push(edSk_address);\n\t\t\n\t\t// ---------- output cSk (buf)\n\t\t\n\t\tvar cSk_length = (libsodium._crypto_scalarmult_scalarbytes()) | 0,\n\t\t    cSk = new AllocatedBuf(cSk_length),\n\t\t    cSk_address = cSk.address;\n\t\t\n\t\taddress_pool.push(cSk_address);\n\t\t\n\t\tif ((libsodium._crypto_sign_ed25519_sk_to_curve25519(cSk_address, edSk_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(cSk, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_sign_ed25519_sk_to_pk(privateKey, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: privateKey (buf)\n\t\t\n\t\tprivateKey = _any_to_Uint8Array(address_pool, privateKey, \"privateKey\");\n\t\tvar privateKey_address, privateKey_length = (libsodium._crypto_sign_secretkeybytes()) | 0;\n\t\tif (privateKey.length !== privateKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid privateKey length\");\n\t\t}\n\t\tprivateKey_address = _to_allocated_buf_address(privateKey);\n\t\taddress_pool.push(privateKey_address);\n\t\t\n\t\t// ---------- output publicKey (buf)\n\t\t\n\t\tvar publicKey_length = (libsodium._crypto_sign_publickeybytes()) | 0,\n\t\t    publicKey = new AllocatedBuf(publicKey_length),\n\t\t    publicKey_address = publicKey.address;\n\t\t\n\t\taddress_pool.push(publicKey_address);\n\t\t\n\t\tif ((libsodium._crypto_sign_ed25519_sk_to_pk(publicKey_address, privateKey_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(publicKey, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_sign_ed25519_sk_to_seed(privateKey, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: privateKey (buf)\n\t\t\n\t\tprivateKey = _any_to_Uint8Array(address_pool, privateKey, \"privateKey\");\n\t\tvar privateKey_address, privateKey_length = (libsodium._crypto_sign_secretkeybytes()) | 0;\n\t\tif (privateKey.length !== privateKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid privateKey length\");\n\t\t}\n\t\tprivateKey_address = _to_allocated_buf_address(privateKey);\n\t\taddress_pool.push(privateKey_address);\n\t\t\n\t\t// ---------- output seed (buf)\n\t\t\n\t\tvar seed_length = (libsodium._crypto_sign_seedbytes()) | 0,\n\t\t    seed = new AllocatedBuf(seed_length),\n\t\t    seed_address = seed.address;\n\t\t\n\t\taddress_pool.push(seed_address);\n\t\t\n\t\tif ((libsodium._crypto_sign_ed25519_sk_to_seed(seed_address, privateKey_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(seed, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_sign_keypair(outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- output publicKey (buf)\n\t\t\n\t\tvar publicKey_length = (libsodium._crypto_sign_publickeybytes()) | 0,\n\t\t    publicKey = new AllocatedBuf(publicKey_length),\n\t\t    publicKey_address = publicKey.address;\n\t\t\n\t\taddress_pool.push(publicKey_address);\n\t\t\n\t\t// ---------- output privateKey (buf)\n\t\t\n\t\tvar privateKey_length = (libsodium._crypto_sign_secretkeybytes()) | 0,\n\t\t    privateKey = new AllocatedBuf(privateKey_length),\n\t\t    privateKey_address = privateKey.address;\n\t\t\n\t\taddress_pool.push(privateKey_address);\n\t\t\n\t\tif ((libsodium._crypto_sign_keypair(publicKey_address, privateKey_address) | 0) === 0) {\n\t\t\tvar ret = _format_output({publicKey: publicKey, privateKey: privateKey, keyType: 'ed25519'}, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_sign_open(signedMessage, publicKey, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: signedMessage (unsized_buf)\n\t\t\n\t\tsignedMessage = _any_to_Uint8Array(address_pool, signedMessage, \"signedMessage\");\n\t\tvar signedMessage_address = _to_allocated_buf_address(signedMessage),\n\t\t    signedMessage_length = signedMessage.length;\n\t\taddress_pool.push(signedMessage_address);\n\t\t\n\t\t// ---------- input: publicKey (buf)\n\t\t\n\t\tpublicKey = _any_to_Uint8Array(address_pool, publicKey, \"publicKey\");\n\t\tvar publicKey_address, publicKey_length = (libsodium._crypto_sign_publickeybytes()) | 0;\n\t\tif (publicKey.length !== publicKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid publicKey length\");\n\t\t}\n\t\tpublicKey_address = _to_allocated_buf_address(publicKey);\n\t\taddress_pool.push(publicKey_address);\n\t\t\n\t\t// ---------- output message (buf)\n\t\t\n\t\tvar message_length = (signedMessage_length - libsodium._crypto_sign_bytes()) | 0,\n\t\t    message = new AllocatedBuf(message_length),\n\t\t    message_address = message.address;\n\t\t\n\t\taddress_pool.push(message_address);\n\t\t\n\t\tif ((libsodium._crypto_sign_open(message_address, null, signedMessage_address, signedMessage_length, 0, publicKey_address) | 0) === 0) {\n\t\t\tvar ret = _format_output(message, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_sign_seed_keypair(seed, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: seed (buf)\n\t\t\n\t\tseed = _any_to_Uint8Array(address_pool, seed, \"seed\");\n\t\tvar seed_address, seed_length = (libsodium._crypto_sign_seedbytes()) | 0;\n\t\tif (seed.length !== seed_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid seed length\");\n\t\t}\n\t\tseed_address = _to_allocated_buf_address(seed);\n\t\taddress_pool.push(seed_address);\n\t\t\n\t\t// ---------- output publicKey (buf)\n\t\t\n\t\tvar publicKey_length = (libsodium._crypto_sign_publickeybytes()) | 0,\n\t\t    publicKey = new AllocatedBuf(publicKey_length),\n\t\t    publicKey_address = publicKey.address;\n\t\t\n\t\taddress_pool.push(publicKey_address);\n\t\t\n\t\t// ---------- output privateKey (buf)\n\t\t\n\t\tvar privateKey_length = (libsodium._crypto_sign_secretkeybytes()) | 0,\n\t\t    privateKey = new AllocatedBuf(privateKey_length),\n\t\t    privateKey_address = privateKey.address;\n\t\t\n\t\taddress_pool.push(privateKey_address);\n\t\t\n\t\tif ((libsodium._crypto_sign_seed_keypair(publicKey_address, privateKey_address, seed_address) | 0) === 0) {\n\t\t\tvar ret = _format_output({publicKey: publicKey, privateKey: privateKey, keyType: \"ed25519\"}, outputFormat);\n\t\t\t_free_all(address_pool);\n\t\t\treturn ret;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction crypto_sign_verify_detached(signature, message, publicKey) {\n\t\tvar address_pool = [];\n\n\t\t// ---------- input: signature (buf)\n\t\t\n\t\tsignature = _any_to_Uint8Array(address_pool, signature, \"signature\");\n\t\tvar signature_address, signature_length = (libsodium._crypto_sign_bytes()) | 0;\n\t\tif (signature.length !== signature_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid signature length\");\n\t\t}\n\t\tsignature_address = _to_allocated_buf_address(signature);\n\t\taddress_pool.push(signature_address);\n\t\t\n\t\t// ---------- input: message (unsized_buf)\n\t\t\n\t\tmessage = _any_to_Uint8Array(address_pool, message, \"message\");\n\t\tvar message_address = _to_allocated_buf_address(message),\n\t\t    message_length = message.length;\n\t\taddress_pool.push(message_address);\n\t\t\n\t\t// ---------- input: publicKey (buf)\n\t\t\n\t\tpublicKey = _any_to_Uint8Array(address_pool, publicKey, \"publicKey\");\n\t\tvar publicKey_address, publicKey_length = (libsodium._crypto_sign_publickeybytes()) | 0;\n\t\tif (publicKey.length !== publicKey_length) {\n\t\t\t_free_and_throw_type_error(address_pool, \"invalid publicKey length\");\n\t\t}\n\t\tpublicKey_address = _to_allocated_buf_address(publicKey);\n\t\taddress_pool.push(publicKey_address);\n\t\t\n\t\tvar verificationResult = libsodium._crypto_sign_verify_detached(signature_address, message_address, message_length, 0, publicKey_address) | 0;\n\t\tvar ret = (verificationResult === 0);\n\t\t_free_all(address_pool);\n\t\treturn ret;\n\t\t\n\t}\n\n\tfunction randombytes_buf(length, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: length (uint)\n\t\t\n\t\t_require_defined(address_pool, length, \"length\");\n\t\t\n\t\tif (!(typeof length === \"number\" && (length | 0) === length) && (length | 0) > 0) {\n\t\t\t_free_and_throw_type_error(address_pool, \"length must be an unsigned integer\");\n\t\t}\n\t\t\n\t\t// ---------- output output (buf)\n\t\t\n\t\tvar output_length = (length) | 0,\n\t\t    output = new AllocatedBuf(output_length),\n\t\t    output_address = output.address;\n\t\t\n\t\taddress_pool.push(output_address);\n\t\t\n\t\tlibsodium._randombytes_buf(output_address, length);\n\t\tvar ret = (_format_output(output, outputFormat));\n\t\t_free_all(address_pool);\n\t\treturn ret;\n\t\t\n\t}\n\n\tfunction randombytes_close(outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\tlibsodium._randombytes_close();\n\t\t\n\t}\n\n\tfunction randombytes_random(outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\tvar random_value = libsodium._randombytes_random() >>> 0;\n\t\tvar ret = (random_value);\n\t\t_free_all(address_pool);\n\t\treturn ret;\n\t\t\n\t}\n\n\tfunction randombytes_set_implementation(implementation, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: implementation (randombytes_implementation)\n\t\t\n\t\tvar implementation_address = libsodium._malloc(6 * 4);\n\t\tfor (var i = 0; i < 6; i++) {\n\t\t\tlibsodium.setValue(implementation_address + i * 4,\n\t\t\t    libsodium.Runtime.addFunction(implementation\n\t\t\t    [[\"implementation_name\", \"random\", \"stir\", \"uniform\", \"buf\", \"close\"][i]]),\n\t\t\t    \"i32\");\n\t\t}\n\t\t\n\t\tif ((libsodium._randombytes_set_implementation(implementation_address) | 0) === 0) {\n\t\t\t_free_all(address_pool);\n\t\t\treturn;\n\t\t}\n\t\t_free_and_throw_error(address_pool);\n\t\t\n\t}\n\n\tfunction randombytes_stir(outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\tlibsodium._randombytes_stir();\n\t\t\n\t}\n\n\tfunction randombytes_uniform(upper_bound, outputFormat) {\n\t\tvar address_pool = [];\n\t\t_check_output_format(outputFormat);\n\n\t\t// ---------- input: upper_bound (uint)\n\t\t\n\t\t_require_defined(address_pool, upper_bound, \"upper_bound\");\n\t\t\n\t\tif (!(typeof upper_bound === \"number\" && (upper_bound | 0) === upper_bound) && (upper_bound | 0) > 0) {\n\t\t\t_free_and_throw_type_error(address_pool, \"upper_bound must be an unsigned integer\");\n\t\t}\n\t\t\n\t\tvar random_value = libsodium._randombytes_uniform(upper_bound) >>> 0;\n\t\tvar ret = (random_value);\n\t\t_free_all(address_pool);\n\t\treturn ret;\n\t\t\n\t}\n\n\tfunction sodium_version_string() {\n\t\tvar address_pool = [];\n\n\t\tvar version = libsodium._sodium_version_string();\n\t\tvar ret = (libsodium.Pointer_stringify(version));\n\t\t_free_all(address_pool);\n\t\treturn ret;\n\t\t\n\t}\n\n\n\texports.compare = compare;\n\texports.from_base64 = from_base64;\n\texports.from_hex = from_hex;\n\texports.from_string = from_string;\n\texports.increment = increment;\n\texports.libsodium = libsodium;\n\texports.memcmp = memcmp;\n\texports.memzero = memzero;\n\texports.output_formats = output_formats;\n\texports.symbols = symbols;\n\texports.to_base64 = to_base64;\n\texports.to_hex = to_hex;\n\texports.to_string = to_string;\n\n\t\n\tvar exported_functions = [\"crypto_aead_chacha20poly1305_decrypt\", \"crypto_aead_chacha20poly1305_encrypt\", \"crypto_aead_chacha20poly1305_ietf_decrypt\", \"crypto_aead_chacha20poly1305_ietf_encrypt\", \"crypto_auth\", \"crypto_auth_hmacsha256\", \"crypto_auth_hmacsha256_verify\", \"crypto_auth_hmacsha512\", \"crypto_auth_hmacsha512_verify\", \"crypto_auth_verify\", \"crypto_box_beforenm\", \"crypto_box_detached\", \"crypto_box_easy\", \"crypto_box_easy_afternm\", \"crypto_box_keypair\", \"crypto_box_open_detached\", \"crypto_box_open_easy\", \"crypto_box_open_easy_afternm\", \"crypto_box_seal\", \"crypto_box_seal_open\", \"crypto_box_seed_keypair\", \"crypto_generichash\", \"crypto_generichash_final\", \"crypto_generichash_init\", \"crypto_generichash_update\", \"crypto_hash\", \"crypto_hash_sha256\", \"crypto_hash_sha512\", \"crypto_onetimeauth\", \"crypto_onetimeauth_final\", \"crypto_onetimeauth_init\", \"crypto_onetimeauth_update\", \"crypto_onetimeauth_verify\", \"crypto_pwhash_scryptsalsa208sha256\", \"crypto_pwhash_scryptsalsa208sha256_ll\", \"crypto_pwhash_scryptsalsa208sha256_str\", \"crypto_pwhash_scryptsalsa208sha256_str_verify\", \"crypto_scalarmult\", \"crypto_scalarmult_base\", \"crypto_secretbox_detached\", \"crypto_secretbox_easy\", \"crypto_secretbox_open_detached\", \"crypto_secretbox_open_easy\", \"crypto_shorthash\", \"crypto_sign\", \"crypto_sign_detached\", \"crypto_sign_ed25519_pk_to_curve25519\", \"crypto_sign_ed25519_sk_to_curve25519\", \"crypto_sign_ed25519_sk_to_pk\", \"crypto_sign_ed25519_sk_to_seed\", \"crypto_sign_keypair\", \"crypto_sign_open\", \"crypto_sign_seed_keypair\", \"crypto_sign_verify_detached\", \"randombytes_buf\", \"randombytes_close\", \"randombytes_random\", \"randombytes_set_implementation\", \"randombytes_stir\", \"randombytes_uniform\", \"sodium_version_string\"],\n\t\tfunctions = [crypto_aead_chacha20poly1305_decrypt, crypto_aead_chacha20poly1305_encrypt, crypto_aead_chacha20poly1305_ietf_decrypt, crypto_aead_chacha20poly1305_ietf_encrypt, crypto_auth, crypto_auth_hmacsha256, crypto_auth_hmacsha256_verify, crypto_auth_hmacsha512, crypto_auth_hmacsha512_verify, crypto_auth_verify, crypto_box_beforenm, crypto_box_detached, crypto_box_easy, crypto_box_easy_afternm, crypto_box_keypair, crypto_box_open_detached, crypto_box_open_easy, crypto_box_open_easy_afternm, crypto_box_seal, crypto_box_seal_open, crypto_box_seed_keypair, crypto_generichash, crypto_generichash_final, crypto_generichash_init, crypto_generichash_update, crypto_hash, crypto_hash_sha256, crypto_hash_sha512, crypto_onetimeauth, crypto_onetimeauth_final, crypto_onetimeauth_init, crypto_onetimeauth_update, crypto_onetimeauth_verify, crypto_pwhash_scryptsalsa208sha256, crypto_pwhash_scryptsalsa208sha256_ll, crypto_pwhash_scryptsalsa208sha256_str, crypto_pwhash_scryptsalsa208sha256_str_verify, crypto_scalarmult, crypto_scalarmult_base, crypto_secretbox_detached, crypto_secretbox_easy, crypto_secretbox_open_detached, crypto_secretbox_open_easy, crypto_shorthash, crypto_sign, crypto_sign_detached, crypto_sign_ed25519_pk_to_curve25519, crypto_sign_ed25519_sk_to_curve25519, crypto_sign_ed25519_sk_to_pk, crypto_sign_ed25519_sk_to_seed, crypto_sign_keypair, crypto_sign_open, crypto_sign_seed_keypair, crypto_sign_verify_detached, randombytes_buf, randombytes_close, randombytes_random, randombytes_set_implementation, randombytes_stir, randombytes_uniform, sodium_version_string];\n\tfor (var i = 0; i < functions.length; i++) {\n\t\tif (typeof libsodium[\"_\" + exported_functions[i]] === \"function\") {\n\t\t\texports[exported_functions[i]] = functions[i];\n\t\t}\n\t}\n\tvar constants = [\"SODIUM_LIBRARY_VERSION_MAJOR\", \"SODIUM_LIBRARY_VERSION_MINOR\", \"crypto_aead_chacha20poly1305_ABYTES\", \"crypto_aead_chacha20poly1305_KEYBYTES\", \"crypto_aead_chacha20poly1305_NPUBBYTES\", \"crypto_aead_chacha20poly1305_NSECBYTES\", \"crypto_aead_chacha20poly1305_ietf_NPUBBYTES\", \"crypto_auth_BYTES\", \"crypto_auth_KEYBYTES\", \"crypto_auth_hmacsha256_BYTES\", \"crypto_auth_hmacsha256_KEYBYTES\", \"crypto_auth_hmacsha512_BYTES\", \"crypto_auth_hmacsha512_KEYBYTES\", \"crypto_box_BEFORENMBYTES\", \"crypto_box_MACBYTES\", \"crypto_box_NONCEBYTES\", \"crypto_box_PUBLICKEYBYTES\", \"crypto_box_SEALBYTES\", \"crypto_box_SECRETKEYBYTES\", \"crypto_box_SEEDBYTES\", \"crypto_generichash_BYTES\", \"crypto_generichash_BYTES_MAX\", \"crypto_generichash_BYTES_MIN\", \"crypto_generichash_KEYBYTES\", \"crypto_generichash_KEYBYTES_MAX\", \"crypto_generichash_KEYBYTES_MIN\", \"crypto_hash_BYTES\", \"crypto_onetimeauth_BYTES\", \"crypto_onetimeauth_KEYBYTES\", \"crypto_pwhash_scryptsalsa208sha256_MEMLIMIT_INTERACTIVE\", \"crypto_pwhash_scryptsalsa208sha256_MEMLIMIT_SENSITIVE\", \"crypto_pwhash_scryptsalsa208sha256_OPSLIMIT_INTERACTIVE\", \"crypto_pwhash_scryptsalsa208sha256_OPSLIMIT_SENSITIVE\", \"crypto_pwhash_scryptsalsa208sha256_SALTBYTES\", \"crypto_pwhash_scryptsalsa208sha256_STRBYTES\", \"crypto_pwhash_scryptsalsa208sha256_STR_VERIFY\", \"crypto_scalarmult_BYTES\", \"crypto_scalarmult_SCALARBYTES\", \"crypto_secretbox_KEYBYTES\", \"crypto_secretbox_MACBYTES\", \"crypto_secretbox_NONCEBYTES\", \"crypto_shorthash_BYTES\", \"crypto_shorthash_KEYBYTES\", \"crypto_sign_BYTES\", \"crypto_sign_PUBLICKEYBYTES\", \"crypto_sign_SECRETKEYBYTES\", \"crypto_sign_SEEDBYTES\"];\n\tfor (var i = 0; i < constants.length; i++) {\n\t\tvar raw = libsodium[\"_\" + constants[i].toLowerCase()];\n\t\tif (typeof raw === \"function\") exports[constants[i]] = raw()|0;\n\t}\n\tvar constants_str = [\"SODIUM_VERSION_STRING\", \"crypto_pwhash_scryptsalsa208sha256_STRPREFIX\"];\n\tfor (var i = 0; i < constants_str.length; i++) {\n\t\tvar raw = libsodium[\"_\" + constants_str[i].toLowerCase()];\n\t\tif (typeof raw === \"function\") exports[constants_str[i]] = libsodium.Pointer_stringify(raw());\n\t}\n\n\treturn exports;\n}));\n","(function (root, factory) {\n    if (typeof define === \"function\" && define.amd) {\n        define([\"exports\"], factory);\n    } else if (typeof exports === 'object' &&\n               typeof exports.nodeName !== 'string') {\n        factory(exports);\n    } else {\n        factory(root.libsodium = {});\n    }\n})(this, function (exports) {\n    \"use strict\";\n    var Module = exports;\n    Object.defineProperty(exports, '__esModule', { value: true });\nvar Module;if(!Module)Module=(typeof Module!==\"undefined\"?Module:null)||{};var moduleOverrides={};for(var key in Module){if(Module.hasOwnProperty(key)){moduleOverrides[key]=Module[key]}}var ENVIRONMENT_IS_WEB=typeof window===\"object\";var ENVIRONMENT_IS_WORKER=typeof importScripts===\"function\";var ENVIRONMENT_IS_NODE=typeof process===\"object\"&&typeof require===\"function\"&&!ENVIRONMENT_IS_WEB&&!ENVIRONMENT_IS_WORKER;var ENVIRONMENT_IS_SHELL=!ENVIRONMENT_IS_WEB&&!ENVIRONMENT_IS_NODE&&!ENVIRONMENT_IS_WORKER;if(ENVIRONMENT_IS_NODE){if(!Module[\"print\"])Module[\"print\"]=function print(x){process[\"stdout\"].write(x+\"\\n\")};if(!Module[\"printErr\"])Module[\"printErr\"]=function printErr(x){process[\"stderr\"].write(x+\"\\n\")};var nodeFS=require(\"fs\");var nodePath=require(\"path\");Module[\"read\"]=function read(filename,binary){filename=nodePath[\"normalize\"](filename);var ret=nodeFS[\"readFileSync\"](filename);if(!ret&&filename!=nodePath[\"resolve\"](filename)){filename=path.join(__dirname,\"..\",\"src\",filename);ret=nodeFS[\"readFileSync\"](filename)}if(ret&&!binary)ret=ret.toString();return ret};Module[\"readBinary\"]=function readBinary(filename){var ret=Module[\"read\"](filename,true);if(!ret.buffer){ret=new Uint8Array(ret)}assert(ret.buffer);return ret};Module[\"load\"]=function load(f){globalEval(read(f))};if(!Module[\"thisProgram\"]){if(process[\"argv\"].length>1){Module[\"thisProgram\"]=process[\"argv\"][1].replace(/\\\\/g,\"/\")}else{Module[\"thisProgram\"]=\"unknown-program\"}}Module[\"arguments\"]=process[\"argv\"].slice(2);if(typeof module!==\"undefined\"){module[\"exports\"]=Module}process[\"on\"](\"uncaughtException\",(function(ex){if(!(ex instanceof ExitStatus)){throw ex}}));Module[\"inspect\"]=(function(){return\"[Emscripten Module object]\"})}else if(ENVIRONMENT_IS_SHELL){if(!Module[\"print\"])Module[\"print\"]=print;if(typeof printErr!=\"undefined\")Module[\"printErr\"]=printErr;if(typeof read!=\"undefined\"){Module[\"read\"]=read}else{Module[\"read\"]=function read(){throw\"no read() available (jsc?)\"}}Module[\"readBinary\"]=function readBinary(f){if(typeof readbuffer===\"function\"){return new Uint8Array(readbuffer(f))}var data=read(f,\"binary\");assert(typeof data===\"object\");return data};if(typeof scriptArgs!=\"undefined\"){Module[\"arguments\"]=scriptArgs}else if(typeof arguments!=\"undefined\"){Module[\"arguments\"]=arguments}}else if(ENVIRONMENT_IS_WEB||ENVIRONMENT_IS_WORKER){Module[\"read\"]=function read(url){var xhr=new XMLHttpRequest;xhr.open(\"GET\",url,false);xhr.send(null);return xhr.responseText};if(typeof arguments!=\"undefined\"){Module[\"arguments\"]=arguments}if(typeof console!==\"undefined\"){if(!Module[\"print\"])Module[\"print\"]=function print(x){console.log(x)};if(!Module[\"printErr\"])Module[\"printErr\"]=function printErr(x){console.log(x)}}else{var TRY_USE_DUMP=false;if(!Module[\"print\"])Module[\"print\"]=TRY_USE_DUMP&&typeof dump!==\"undefined\"?(function(x){dump(x)}):(function(x){})}if(ENVIRONMENT_IS_WORKER){Module[\"load\"]=importScripts}if(typeof Module[\"setWindowTitle\"]===\"undefined\"){Module[\"setWindowTitle\"]=(function(title){document.title=title})}}else{throw\"Unknown runtime environment. Where are we?\"}function globalEval(x){throw\"NO_DYNAMIC_EXECUTION was set, cannot eval\"}if(!Module[\"load\"]&&Module[\"read\"]){Module[\"load\"]=function load(f){globalEval(Module[\"read\"](f))}}if(!Module[\"print\"]){Module[\"print\"]=(function(){})}if(!Module[\"printErr\"]){Module[\"printErr\"]=Module[\"print\"]}if(!Module[\"arguments\"]){Module[\"arguments\"]=[]}if(!Module[\"thisProgram\"]){Module[\"thisProgram\"]=\"./this.program\"}Module.print=Module[\"print\"];Module.printErr=Module[\"printErr\"];Module[\"preRun\"]=[];Module[\"postRun\"]=[];for(var key in moduleOverrides){if(moduleOverrides.hasOwnProperty(key)){Module[key]=moduleOverrides[key]}}var Runtime={setTempRet0:(function(value){tempRet0=value}),getTempRet0:(function(){return tempRet0}),stackSave:(function(){return STACKTOP}),stackRestore:(function(stackTop){STACKTOP=stackTop}),getNativeTypeSize:(function(type){switch(type){case\"i1\":case\"i8\":return 1;case\"i16\":return 2;case\"i32\":return 4;case\"i64\":return 8;case\"float\":return 4;case\"double\":return 8;default:{if(type[type.length-1]===\"*\"){return Runtime.QUANTUM_SIZE}else if(type[0]===\"i\"){var bits=parseInt(type.substr(1));assert(bits%8===0);return bits/8}else{return 0}}}}),getNativeFieldSize:(function(type){return Math.max(Runtime.getNativeTypeSize(type),Runtime.QUANTUM_SIZE)}),STACK_ALIGN:16,prepVararg:(function(ptr,type){if(type===\"double\"||type===\"i64\"){if(ptr&7){assert((ptr&7)===4);ptr+=4}}else{assert((ptr&3)===0)}return ptr}),getAlignSize:(function(type,size,vararg){if(!vararg&&(type==\"i64\"||type==\"double\"))return 8;if(!type)return Math.min(size,8);return Math.min(size||(type?Runtime.getNativeFieldSize(type):0),Runtime.QUANTUM_SIZE)}),dynCall:(function(sig,ptr,args){if(args&&args.length){if(!args.splice)args=Array.prototype.slice.call(args);args.splice(0,0,ptr);return Module[\"dynCall_\"+sig].apply(null,args)}else{return Module[\"dynCall_\"+sig].call(null,ptr)}}),functionPointers:[null,null,null,null,null,null,null,null],addFunction:(function(func){for(var i=0;i<Runtime.functionPointers.length;i++){if(!Runtime.functionPointers[i]){Runtime.functionPointers[i]=func;return 2*(1+i)}}throw\"Finished up all reserved function pointers. Use a higher value for RESERVED_FUNCTION_POINTERS.\"}),removeFunction:(function(index){Runtime.functionPointers[(index-2)/2]=null}),warnOnce:(function(text){if(!Runtime.warnOnce.shown)Runtime.warnOnce.shown={};if(!Runtime.warnOnce.shown[text]){Runtime.warnOnce.shown[text]=1;Module.printErr(text)}}),funcWrappers:{},getFuncWrapper:(function(func,sig){assert(sig);if(!Runtime.funcWrappers[sig]){Runtime.funcWrappers[sig]={}}var sigCache=Runtime.funcWrappers[sig];if(!sigCache[func]){sigCache[func]=function dynCall_wrapper(){return Runtime.dynCall(sig,func,arguments)}}return sigCache[func]}),getCompilerSetting:(function(name){throw\"You must build with -s RETAIN_COMPILER_SETTINGS=1 for Runtime.getCompilerSetting or emscripten_get_compiler_setting to work\"}),stackAlloc:(function(size){var ret=STACKTOP;STACKTOP=STACKTOP+size|0;STACKTOP=STACKTOP+15&-16;return ret}),staticAlloc:(function(size){var ret=STATICTOP;STATICTOP=STATICTOP+size|0;STATICTOP=STATICTOP+15&-16;return ret}),dynamicAlloc:(function(size){var ret=DYNAMICTOP;DYNAMICTOP=DYNAMICTOP+size|0;DYNAMICTOP=DYNAMICTOP+15&-16;if(DYNAMICTOP>=TOTAL_MEMORY){var success=enlargeMemory();if(!success){DYNAMICTOP=ret;return 0}}return ret}),alignMemory:(function(size,quantum){var ret=size=Math.ceil(size/(quantum?quantum:16))*(quantum?quantum:16);return ret}),makeBigInt:(function(low,high,unsigned){var ret=unsigned?+(low>>>0)+ +(high>>>0)*+4294967296:+(low>>>0)+ +(high|0)*+4294967296;return ret}),GLOBAL_BASE:8,QUANTUM_SIZE:4,__dummy__:0};Module[\"Runtime\"]=Runtime;var __THREW__=0;var ABORT=false;var EXITSTATUS=0;var undef=0;var tempValue,tempInt,tempBigInt,tempInt2,tempBigInt2,tempPair,tempBigIntI,tempBigIntR,tempBigIntS,tempBigIntP,tempBigIntD,tempDouble,tempFloat;var tempI64,tempI64b;var tempRet0,tempRet1,tempRet2,tempRet3,tempRet4,tempRet5,tempRet6,tempRet7,tempRet8,tempRet9;function assert(condition,text){if(!condition){abort(\"Assertion failed: \"+text)}}var globalScope=this;function getCFunc(ident){var func=Module[\"_\"+ident];if(!func){abort(\"NO_DYNAMIC_EXECUTION was set, cannot eval - ccall/cwrap are not functional\")}assert(func,\"Cannot call unknown function \"+ident+\" (perhaps LLVM optimizations or closure removed it?)\");return func}var cwrap,ccall;((function(){var JSfuncs={\"stackSave\":(function(){Runtime.stackSave()}),\"stackRestore\":(function(){Runtime.stackRestore()}),\"arrayToC\":(function(arr){var ret=Runtime.stackAlloc(arr.length);writeArrayToMemory(arr,ret);return ret}),\"stringToC\":(function(str){var ret=0;if(str!==null&&str!==undefined&&str!==0){ret=Runtime.stackAlloc((str.length<<2)+1);writeStringToMemory(str,ret)}return ret})};var toC={\"string\":JSfuncs[\"stringToC\"],\"array\":JSfuncs[\"arrayToC\"]};ccall=function ccallFunc(ident,returnType,argTypes,args,opts){var func=getCFunc(ident);var cArgs=[];var stack=0;if(args){for(var i=0;i<args.length;i++){var converter=toC[argTypes[i]];if(converter){if(stack===0)stack=Runtime.stackSave();cArgs[i]=converter(args[i])}else{cArgs[i]=args[i]}}}var ret=func.apply(null,cArgs);if(returnType===\"string\")ret=Pointer_stringify(ret);if(stack!==0){if(opts&&opts.async){EmterpreterAsync.asyncFinalizers.push((function(){Runtime.stackRestore(stack)}));return}Runtime.stackRestore(stack)}return ret};cwrap=function cwrap(ident,returnType,argTypes){return(function(){return ccall(ident,returnType,argTypes,arguments)})}}))();Module[\"ccall\"]=ccall;Module[\"cwrap\"]=cwrap;function setValue(ptr,value,type,noSafe){type=type||\"i8\";if(type.charAt(type.length-1)===\"*\")type=\"i32\";switch(type){case\"i1\":HEAP8[ptr>>0]=value;break;case\"i8\":HEAP8[ptr>>0]=value;break;case\"i16\":HEAP16[ptr>>1]=value;break;case\"i32\":HEAP32[ptr>>2]=value;break;case\"i64\":tempI64=[value>>>0,(tempDouble=value,+Math_abs(tempDouble)>=+1?tempDouble>+0?(Math_min(+Math_floor(tempDouble/+4294967296),+4294967295)|0)>>>0:~~+Math_ceil((tempDouble- +(~~tempDouble>>>0))/+4294967296)>>>0:0)],HEAP32[ptr>>2]=tempI64[0],HEAP32[ptr+4>>2]=tempI64[1];break;case\"float\":HEAPF32[ptr>>2]=value;break;case\"double\":HEAPF64[ptr>>3]=value;break;default:abort(\"invalid type for setValue: \"+type)}}Module[\"setValue\"]=setValue;function getValue(ptr,type,noSafe){type=type||\"i8\";if(type.charAt(type.length-1)===\"*\")type=\"i32\";switch(type){case\"i1\":return HEAP8[ptr>>0];case\"i8\":return HEAP8[ptr>>0];case\"i16\":return HEAP16[ptr>>1];case\"i32\":return HEAP32[ptr>>2];case\"i64\":return HEAP32[ptr>>2];case\"float\":return HEAPF32[ptr>>2];case\"double\":return HEAPF64[ptr>>3];default:abort(\"invalid type for setValue: \"+type)}return null}Module[\"getValue\"]=getValue;var ALLOC_NORMAL=0;var ALLOC_STACK=1;var ALLOC_STATIC=2;var ALLOC_DYNAMIC=3;var ALLOC_NONE=4;Module[\"ALLOC_NORMAL\"]=ALLOC_NORMAL;Module[\"ALLOC_STACK\"]=ALLOC_STACK;Module[\"ALLOC_STATIC\"]=ALLOC_STATIC;Module[\"ALLOC_DYNAMIC\"]=ALLOC_DYNAMIC;Module[\"ALLOC_NONE\"]=ALLOC_NONE;function allocate(slab,types,allocator,ptr){var zeroinit,size;if(typeof slab===\"number\"){zeroinit=true;size=slab}else{zeroinit=false;size=slab.length}var singleType=typeof types===\"string\"?types:null;var ret;if(allocator==ALLOC_NONE){ret=ptr}else{ret=[_malloc,Runtime.stackAlloc,Runtime.staticAlloc,Runtime.dynamicAlloc][allocator===undefined?ALLOC_STATIC:allocator](Math.max(size,singleType?1:types.length))}if(zeroinit){var ptr=ret,stop;assert((ret&3)==0);stop=ret+(size&~3);for(;ptr<stop;ptr+=4){HEAP32[ptr>>2]=0}stop=ret+size;while(ptr<stop){HEAP8[ptr++>>0]=0}return ret}if(singleType===\"i8\"){if(slab.subarray||slab.slice){HEAPU8.set(slab,ret)}else{HEAPU8.set(new Uint8Array(slab),ret)}return ret}var i=0,type,typeSize,previousType;while(i<size){var curr=slab[i];if(typeof curr===\"function\"){curr=Runtime.getFunctionIndex(curr)}type=singleType||types[i];if(type===0){i++;continue}if(type==\"i64\")type=\"i32\";setValue(ret+i,curr,type);if(previousType!==type){typeSize=Runtime.getNativeTypeSize(type);previousType=type}i+=typeSize}return ret}Module[\"allocate\"]=allocate;function getMemory(size){if(!staticSealed)return Runtime.staticAlloc(size);if(typeof _sbrk!==\"undefined\"&&!_sbrk.called||!runtimeInitialized)return Runtime.dynamicAlloc(size);return _malloc(size)}Module[\"getMemory\"]=getMemory;function Pointer_stringify(ptr,length){if(length===0||!ptr)return\"\";var hasUtf=0;var t;var i=0;while(1){t=HEAPU8[ptr+i>>0];hasUtf|=t;if(t==0&&!length)break;i++;if(length&&i==length)break}if(!length)length=i;var ret=\"\";if(hasUtf<128){var MAX_CHUNK=1024;var curr;while(length>0){curr=String.fromCharCode.apply(String,HEAPU8.subarray(ptr,ptr+Math.min(length,MAX_CHUNK)));ret=ret?ret+curr:curr;ptr+=MAX_CHUNK;length-=MAX_CHUNK}return ret}return Module[\"UTF8ToString\"](ptr)}Module[\"Pointer_stringify\"]=Pointer_stringify;function AsciiToString(ptr){var str=\"\";while(1){var ch=HEAP8[ptr++>>0];if(!ch)return str;str+=String.fromCharCode(ch)}}Module[\"AsciiToString\"]=AsciiToString;function stringToAscii(str,outPtr){return writeAsciiToMemory(str,outPtr,false)}Module[\"stringToAscii\"]=stringToAscii;function UTF8ArrayToString(u8Array,idx){var u0,u1,u2,u3,u4,u5;var str=\"\";while(1){u0=u8Array[idx++];if(!u0)return str;if(!(u0&128)){str+=String.fromCharCode(u0);continue}u1=u8Array[idx++]&63;if((u0&224)==192){str+=String.fromCharCode((u0&31)<<6|u1);continue}u2=u8Array[idx++]&63;if((u0&240)==224){u0=(u0&15)<<12|u1<<6|u2}else{u3=u8Array[idx++]&63;if((u0&248)==240){u0=(u0&7)<<18|u1<<12|u2<<6|u3}else{u4=u8Array[idx++]&63;if((u0&252)==248){u0=(u0&3)<<24|u1<<18|u2<<12|u3<<6|u4}else{u5=u8Array[idx++]&63;u0=(u0&1)<<30|u1<<24|u2<<18|u3<<12|u4<<6|u5}}}if(u0<65536){str+=String.fromCharCode(u0)}else{var ch=u0-65536;str+=String.fromCharCode(55296|ch>>10,56320|ch&1023)}}}Module[\"UTF8ArrayToString\"]=UTF8ArrayToString;function UTF8ToString(ptr){return UTF8ArrayToString(HEAPU8,ptr)}Module[\"UTF8ToString\"]=UTF8ToString;function stringToUTF8Array(str,outU8Array,outIdx,maxBytesToWrite){if(!(maxBytesToWrite>0))return 0;var startIdx=outIdx;var endIdx=outIdx+maxBytesToWrite-1;for(var i=0;i<str.length;++i){var u=str.charCodeAt(i);if(u>=55296&&u<=57343)u=65536+((u&1023)<<10)|str.charCodeAt(++i)&1023;if(u<=127){if(outIdx>=endIdx)break;outU8Array[outIdx++]=u}else if(u<=2047){if(outIdx+1>=endIdx)break;outU8Array[outIdx++]=192|u>>6;outU8Array[outIdx++]=128|u&63}else if(u<=65535){if(outIdx+2>=endIdx)break;outU8Array[outIdx++]=224|u>>12;outU8Array[outIdx++]=128|u>>6&63;outU8Array[outIdx++]=128|u&63}else if(u<=2097151){if(outIdx+3>=endIdx)break;outU8Array[outIdx++]=240|u>>18;outU8Array[outIdx++]=128|u>>12&63;outU8Array[outIdx++]=128|u>>6&63;outU8Array[outIdx++]=128|u&63}else if(u<=67108863){if(outIdx+4>=endIdx)break;outU8Array[outIdx++]=248|u>>24;outU8Array[outIdx++]=128|u>>18&63;outU8Array[outIdx++]=128|u>>12&63;outU8Array[outIdx++]=128|u>>6&63;outU8Array[outIdx++]=128|u&63}else{if(outIdx+5>=endIdx)break;outU8Array[outIdx++]=252|u>>30;outU8Array[outIdx++]=128|u>>24&63;outU8Array[outIdx++]=128|u>>18&63;outU8Array[outIdx++]=128|u>>12&63;outU8Array[outIdx++]=128|u>>6&63;outU8Array[outIdx++]=128|u&63}}outU8Array[outIdx]=0;return outIdx-startIdx}Module[\"stringToUTF8Array\"]=stringToUTF8Array;function stringToUTF8(str,outPtr,maxBytesToWrite){return stringToUTF8Array(str,HEAPU8,outPtr,maxBytesToWrite)}Module[\"stringToUTF8\"]=stringToUTF8;function lengthBytesUTF8(str){var len=0;for(var i=0;i<str.length;++i){var u=str.charCodeAt(i);if(u>=55296&&u<=57343)u=65536+((u&1023)<<10)|str.charCodeAt(++i)&1023;if(u<=127){++len}else if(u<=2047){len+=2}else if(u<=65535){len+=3}else if(u<=2097151){len+=4}else if(u<=67108863){len+=5}else{len+=6}}return len}Module[\"lengthBytesUTF8\"]=lengthBytesUTF8;function UTF16ToString(ptr){var i=0;var str=\"\";while(1){var codeUnit=HEAP16[ptr+i*2>>1];if(codeUnit==0)return str;++i;str+=String.fromCharCode(codeUnit)}}Module[\"UTF16ToString\"]=UTF16ToString;function stringToUTF16(str,outPtr,maxBytesToWrite){if(maxBytesToWrite===undefined){maxBytesToWrite=2147483647}if(maxBytesToWrite<2)return 0;maxBytesToWrite-=2;var startPtr=outPtr;var numCharsToWrite=maxBytesToWrite<str.length*2?maxBytesToWrite/2:str.length;for(var i=0;i<numCharsToWrite;++i){var codeUnit=str.charCodeAt(i);HEAP16[outPtr>>1]=codeUnit;outPtr+=2}HEAP16[outPtr>>1]=0;return outPtr-startPtr}Module[\"stringToUTF16\"]=stringToUTF16;function lengthBytesUTF16(str){return str.length*2}Module[\"lengthBytesUTF16\"]=lengthBytesUTF16;function UTF32ToString(ptr){var i=0;var str=\"\";while(1){var utf32=HEAP32[ptr+i*4>>2];if(utf32==0)return str;++i;if(utf32>=65536){var ch=utf32-65536;str+=String.fromCharCode(55296|ch>>10,56320|ch&1023)}else{str+=String.fromCharCode(utf32)}}}Module[\"UTF32ToString\"]=UTF32ToString;function stringToUTF32(str,outPtr,maxBytesToWrite){if(maxBytesToWrite===undefined){maxBytesToWrite=2147483647}if(maxBytesToWrite<4)return 0;var startPtr=outPtr;var endPtr=startPtr+maxBytesToWrite-4;for(var i=0;i<str.length;++i){var codeUnit=str.charCodeAt(i);if(codeUnit>=55296&&codeUnit<=57343){var trailSurrogate=str.charCodeAt(++i);codeUnit=65536+((codeUnit&1023)<<10)|trailSurrogate&1023}HEAP32[outPtr>>2]=codeUnit;outPtr+=4;if(outPtr+4>endPtr)break}HEAP32[outPtr>>2]=0;return outPtr-startPtr}Module[\"stringToUTF32\"]=stringToUTF32;function lengthBytesUTF32(str){var len=0;for(var i=0;i<str.length;++i){var codeUnit=str.charCodeAt(i);if(codeUnit>=55296&&codeUnit<=57343)++i;len+=4}return len}Module[\"lengthBytesUTF32\"]=lengthBytesUTF32;function demangle(func){var hasLibcxxabi=!!Module[\"___cxa_demangle\"];if(hasLibcxxabi){try{var buf=_malloc(func.length);writeStringToMemory(func.substr(1),buf);var status=_malloc(4);var ret=Module[\"___cxa_demangle\"](buf,0,0,status);if(getValue(status,\"i32\")===0&&ret){return Pointer_stringify(ret)}}catch(e){}finally{if(buf)_free(buf);if(status)_free(status);if(ret)_free(ret)}}var i=3;var basicTypes={\"v\":\"void\",\"b\":\"bool\",\"c\":\"char\",\"s\":\"short\",\"i\":\"int\",\"l\":\"long\",\"f\":\"float\",\"d\":\"double\",\"w\":\"wchar_t\",\"a\":\"signed char\",\"h\":\"unsigned char\",\"t\":\"unsigned short\",\"j\":\"unsigned int\",\"m\":\"unsigned long\",\"x\":\"long long\",\"y\":\"unsigned long long\",\"z\":\"...\"};var subs=[];var first=true;function dump(x){if(x)Module.print(x);Module.print(func);var pre=\"\";for(var a=0;a<i;a++)pre+=\" \";Module.print(pre+\"^\")}function parseNested(){i++;if(func[i]===\"K\")i++;var parts=[];while(func[i]!==\"E\"){if(func[i]===\"S\"){i++;var next=func.indexOf(\"_\",i);var num=func.substring(i,next)||0;parts.push(subs[num]||\"?\");i=next+1;continue}if(func[i]===\"C\"){parts.push(parts[parts.length-1]);i+=2;continue}var size=parseInt(func.substr(i));var pre=size.toString().length;if(!size||!pre){i--;break}var curr=func.substr(i+pre,size);parts.push(curr);subs.push(curr);i+=pre+size}i++;return parts}function parse(rawList,limit,allowVoid){limit=limit||Infinity;var ret=\"\",list=[];function flushList(){return\"(\"+list.join(\", \")+\")\"}var name;if(func[i]===\"N\"){name=parseNested().join(\"::\");limit--;if(limit===0)return rawList?[name]:name}else{if(func[i]===\"K\"||first&&func[i]===\"L\")i++;var size=parseInt(func.substr(i));if(size){var pre=size.toString().length;name=func.substr(i+pre,size);i+=pre+size}}first=false;if(func[i]===\"I\"){i++;var iList=parse(true);var iRet=parse(true,1,true);ret+=iRet[0]+\" \"+name+\"<\"+iList.join(\", \")+\">\"}else{ret=name}paramLoop:while(i<func.length&&limit-->0){var c=func[i++];if(c in basicTypes){list.push(basicTypes[c])}else{switch(c){case\"P\":list.push(parse(true,1,true)[0]+\"*\");break;case\"R\":list.push(parse(true,1,true)[0]+\"&\");break;case\"L\":{i++;var end=func.indexOf(\"E\",i);var size=end-i;list.push(func.substr(i,size));i+=size+2;break};case\"A\":{var size=parseInt(func.substr(i));i+=size.toString().length;if(func[i]!==\"_\")throw\"?\";i++;list.push(parse(true,1,true)[0]+\" [\"+size+\"]\");break};case\"E\":break paramLoop;default:ret+=\"?\"+c;break paramLoop}}}if(!allowVoid&&list.length===1&&list[0]===\"void\")list=[];if(rawList){if(ret){list.push(ret+\"?\")}return list}else{return ret+flushList()}}var parsed=func;try{if(func==\"Object._main\"||func==\"_main\"){return\"main()\"}if(typeof func===\"number\")func=Pointer_stringify(func);if(func[0]!==\"_\")return func;if(func[1]!==\"_\")return func;if(func[2]!==\"Z\")return func;switch(func[3]){case\"n\":return\"operator new()\";case\"d\":return\"operator delete()\"}parsed=parse()}catch(e){parsed+=\"?\"}if(parsed.indexOf(\"?\")>=0&&!hasLibcxxabi){Runtime.warnOnce(\"warning: a problem occurred in builtin C++ name demangling; build with  -s DEMANGLE_SUPPORT=1  to link in libcxxabi demangling\")}return parsed}function demangleAll(text){return text.replace(/__Z[\\w\\d_]+/g,(function(x){var y=demangle(x);return x===y?x:x+\" [\"+y+\"]\"}))}function jsStackTrace(){var err=new Error;if(!err.stack){try{throw new Error(0)}catch(e){err=e}if(!err.stack){return\"(no stack trace available)\"}}return err.stack.toString()}function stackTrace(){return demangleAll(jsStackTrace())}Module[\"stackTrace\"]=stackTrace;var PAGE_SIZE=4096;function alignMemoryPage(x){if(x%4096>0){x+=4096-x%4096}return x}var HEAP;var HEAP8,HEAPU8,HEAP16,HEAPU16,HEAP32,HEAPU32,HEAPF32,HEAPF64;var STATIC_BASE=0,STATICTOP=0,staticSealed=false;var STACK_BASE=0,STACKTOP=0,STACK_MAX=0;var DYNAMIC_BASE=0,DYNAMICTOP=0;function abortOnCannotGrowMemory(){abort(\"Cannot enlarge memory arrays. Either (1) compile with  -s TOTAL_MEMORY=X  with X higher than the current value \"+TOTAL_MEMORY+\", (2) compile with  -s ALLOW_MEMORY_GROWTH=1  which adjusts the size at runtime but prevents some optimizations, (3) set Module.TOTAL_MEMORY to a higher value before the program runs, or if you want malloc to return NULL (0) instead of this abort, compile with  -s ABORTING_MALLOC=0 \")}function enlargeMemory(){abortOnCannotGrowMemory()}var TOTAL_STACK=Module[\"TOTAL_STACK\"]||5242880;var TOTAL_MEMORY=Module[\"TOTAL_MEMORY\"]||33554432;var totalMemory=64*1024;while(totalMemory<TOTAL_MEMORY||totalMemory<2*TOTAL_STACK){if(totalMemory<16*1024*1024){totalMemory*=2}else{totalMemory+=16*1024*1024}}if(totalMemory!==TOTAL_MEMORY){TOTAL_MEMORY=totalMemory}assert(typeof Int32Array!==\"undefined\"&&typeof Float64Array!==\"undefined\"&&!!(new Int32Array(1))[\"subarray\"]&&!!(new Int32Array(1))[\"set\"],\"JS engine does not provide full typed array support\");var buffer;buffer=new ArrayBuffer(TOTAL_MEMORY);HEAP8=new Int8Array(buffer);HEAP16=new Int16Array(buffer);HEAP32=new Int32Array(buffer);HEAPU8=new Uint8Array(buffer);HEAPU16=new Uint16Array(buffer);HEAPU32=new Uint32Array(buffer);HEAPF32=new Float32Array(buffer);HEAPF64=new Float64Array(buffer);HEAP32[0]=255;assert(HEAPU8[0]===255&&HEAPU8[3]===0,\"Typed arrays 2 must be run on a little-endian system\");Module[\"HEAP\"]=HEAP;Module[\"buffer\"]=buffer;Module[\"HEAP8\"]=HEAP8;Module[\"HEAP16\"]=HEAP16;Module[\"HEAP32\"]=HEAP32;Module[\"HEAPU8\"]=HEAPU8;Module[\"HEAPU16\"]=HEAPU16;Module[\"HEAPU32\"]=HEAPU32;Module[\"HEAPF32\"]=HEAPF32;Module[\"HEAPF64\"]=HEAPF64;function callRuntimeCallbacks(callbacks){while(callbacks.length>0){var callback=callbacks.shift();if(typeof callback==\"function\"){callback();continue}var func=callback.func;if(typeof func===\"number\"){if(callback.arg===undefined){Runtime.dynCall(\"v\",func)}else{Runtime.dynCall(\"vi\",func,[callback.arg])}}else{func(callback.arg===undefined?null:callback.arg)}}}var __ATPRERUN__=[];var __ATINIT__=[];var __ATMAIN__=[];var __ATEXIT__=[];var __ATPOSTRUN__=[];var runtimeInitialized=false;var runtimeExited=false;function preRun(){if(Module[\"preRun\"]){if(typeof Module[\"preRun\"]==\"function\")Module[\"preRun\"]=[Module[\"preRun\"]];while(Module[\"preRun\"].length){addOnPreRun(Module[\"preRun\"].shift())}}callRuntimeCallbacks(__ATPRERUN__)}function ensureInitRuntime(){if(runtimeInitialized)return;runtimeInitialized=true;callRuntimeCallbacks(__ATINIT__)}function preMain(){callRuntimeCallbacks(__ATMAIN__)}function exitRuntime(){callRuntimeCallbacks(__ATEXIT__);runtimeExited=true}function postRun(){if(Module[\"postRun\"]){if(typeof Module[\"postRun\"]==\"function\")Module[\"postRun\"]=[Module[\"postRun\"]];while(Module[\"postRun\"].length){addOnPostRun(Module[\"postRun\"].shift())}}callRuntimeCallbacks(__ATPOSTRUN__)}function addOnPreRun(cb){__ATPRERUN__.unshift(cb)}Module[\"addOnPreRun\"]=addOnPreRun;function addOnInit(cb){__ATINIT__.unshift(cb)}Module[\"addOnInit\"]=addOnInit;function addOnPreMain(cb){__ATMAIN__.unshift(cb)}Module[\"addOnPreMain\"]=addOnPreMain;function addOnExit(cb){__ATEXIT__.unshift(cb)}Module[\"addOnExit\"]=addOnExit;function addOnPostRun(cb){__ATPOSTRUN__.unshift(cb)}Module[\"addOnPostRun\"]=addOnPostRun;function intArrayFromString(stringy,dontAddNull,length){var len=length>0?length:lengthBytesUTF8(stringy)+1;var u8array=new Array(len);var numBytesWritten=stringToUTF8Array(stringy,u8array,0,u8array.length);if(dontAddNull)u8array.length=numBytesWritten;return u8array}Module[\"intArrayFromString\"]=intArrayFromString;function intArrayToString(array){var ret=[];for(var i=0;i<array.length;i++){var chr=array[i];if(chr>255){chr&=255}ret.push(String.fromCharCode(chr))}return ret.join(\"\")}Module[\"intArrayToString\"]=intArrayToString;function writeStringToMemory(string,buffer,dontAddNull){var array=intArrayFromString(string,dontAddNull);var i=0;while(i<array.length){var chr=array[i];HEAP8[buffer+i>>0]=chr;i=i+1}}Module[\"writeStringToMemory\"]=writeStringToMemory;function writeArrayToMemory(array,buffer){for(var i=0;i<array.length;i++){HEAP8[buffer++>>0]=array[i]}}Module[\"writeArrayToMemory\"]=writeArrayToMemory;function writeAsciiToMemory(str,buffer,dontAddNull){for(var i=0;i<str.length;++i){HEAP8[buffer++>>0]=str.charCodeAt(i)}if(!dontAddNull)HEAP8[buffer>>0]=0}Module[\"writeAsciiToMemory\"]=writeAsciiToMemory;function unSign(value,bits,ignore){if(value>=0){return value}return bits<=32?2*Math.abs(1<<bits-1)+value:Math.pow(2,bits)+value}function reSign(value,bits,ignore){if(value<=0){return value}var half=bits<=32?Math.abs(1<<bits-1):Math.pow(2,bits-1);if(value>=half&&(bits<=32||value>half)){value=-2*half+value}return value}if(!Math[\"imul\"]||Math[\"imul\"](4294967295,5)!==-5)Math[\"imul\"]=function imul(a,b){var ah=a>>>16;var al=a&65535;var bh=b>>>16;var bl=b&65535;return al*bl+(ah*bl+al*bh<<16)|0};Math.imul=Math[\"imul\"];if(!Math[\"clz32\"])Math[\"clz32\"]=(function(x){x=x>>>0;for(var i=0;i<32;i++){if(x&1<<31-i)return i}return 32});Math.clz32=Math[\"clz32\"];var Math_abs=Math.abs;var Math_cos=Math.cos;var Math_sin=Math.sin;var Math_tan=Math.tan;var Math_acos=Math.acos;var Math_asin=Math.asin;var Math_atan=Math.atan;var Math_atan2=Math.atan2;var Math_exp=Math.exp;var Math_log=Math.log;var Math_sqrt=Math.sqrt;var Math_ceil=Math.ceil;var Math_floor=Math.floor;var Math_pow=Math.pow;var Math_imul=Math.imul;var Math_fround=Math.fround;var Math_min=Math.min;var Math_clz32=Math.clz32;var runDependencies=0;var runDependencyWatcher=null;var dependenciesFulfilled=null;function getUniqueRunDependency(id){return id}function addRunDependency(id){runDependencies++;if(Module[\"monitorRunDependencies\"]){Module[\"monitorRunDependencies\"](runDependencies)}}Module[\"addRunDependency\"]=addRunDependency;function removeRunDependency(id){runDependencies--;if(Module[\"monitorRunDependencies\"]){Module[\"monitorRunDependencies\"](runDependencies)}if(runDependencies==0){if(runDependencyWatcher!==null){clearInterval(runDependencyWatcher);runDependencyWatcher=null}if(dependenciesFulfilled){var callback=dependenciesFulfilled;dependenciesFulfilled=null;callback()}}}Module[\"removeRunDependency\"]=removeRunDependency;Module[\"preloadedImages\"]={};Module[\"preloadedAudios\"]={};var memoryInitializer=null;var ASM_CONSTS=[(function(){{return Module.getRandomValue()}}),(function(){{if(Module.getRandomValue===undefined){try{var window_=\"object\"===typeof window?window:self,crypto_=typeof window_.crypto!==\"undefined\"?window_.crypto:window_.msCrypto,randomValuesStandard=(function(){var buf=new Uint32Array(1);crypto_.getRandomValues(buf);return buf[0]>>>0});randomValuesStandard();Module.getRandomValue=randomValuesStandard}catch(e){try{var crypto=require(\"crypto\"),randomValueNodeJS=(function(){var buf=crypto.randomBytes(4);return(buf[0]<<24|buf[1]<<16|buf[2]<<8|buf[3])>>>0});randomValueNodeJS();Module.getRandomValue=randomValueNodeJS}catch(e){throw\"No secure random number generator found\"}}}}})];function _emscripten_asm_const_0(code){return ASM_CONSTS[code]()}STATIC_BASE=8;STATICTOP=STATIC_BASE+34944;__ATINIT__.push();allocate([8,201,188,243,103,230,9,106,59,167,202,132,133,174,103,187,43,248,148,254,114,243,110,60,241,54,29,95,58,245,79,165,209,130,230,173,127,82,14,81,31,108,62,43,140,104,5,155,107,189,65,251,171,217,131,31,121,33,126,19,25,205,224,91,103,230,9,106,133,174,103,187,114,243,110,60,58,245,79,165,127,82,14,81,140,104,5,155,171,217,131,31,25,205,224,91,133,59,140,1,189,241,36,255,248,37,195,1,96,220,55,0,183,76,62,255,195,66,61,0,50,76,164,1,225,164,76,255,76,61,163,255,117,62,31,0,81,145,64,255,118,65,14,0,162,115,214,255,6,138,46,0,124,230,244,255,10,138,143,0,52,26,194,0,184,244,76,0,129,143,41,1,190,244,19,255,123,170,122,255,98,129,68,0,121,213,147,0,86,101,30,255,161,103,155,0,140,89,67,255,239,229,190,1,67,11,181,0,198,240,137,254,238,69,188,255,67,151,238,0,19,42,108,255,229,85,113,1,50,68,135,255,17,106,9,0,50,103,1,255,80,1,168,1,35,152,30,255,16,168,185,1,56,89,232,255,101,210,252,0,41,250,71,0,204,170,79,255,14,46,239,255,80,77,239,0,189,214,75,255,17,141,249,0,38,80,76,255,190,85,117,0,86,228,170,0,156,216,208,1,195,207,164,255,150,66,76,255,175,225,16,255,141,80,98,1,76,219,242,0,198,162,114,0,46,218,152,0,155,43,241,254,155,160,104,255,51,187,165,0,2,17,175,0,66,84,160,1,247,58,30,0,35,65,53,254,69,236,191,0,45,134,245,1,163,123,221,0,32,110,20,255,52,23,165,0,186,214,71,0,233,176,96,0,242,239,54,1,57,89,138,0,83,0,84,255,136,160,100,0,92,142,120,254,104,124,190,0,181,177,62,255,250,41,85,0,152,130,42,1,96,252,246,0,151,151,63,254,239,133,62,0,32,56,156,0,45,167,189,255,142,133,179,1,131,86,211,0,187,179,150,254,250,170,14,255,210,163,78,0,37,52,151,0,99,77,26,0,238,156,213,255,213,192,209,1,73,46,84,0,20,65,41,1,54,206,79,0,201,131,146,254,170,111,24,255,177,33,50,254,171,38,203,255,78,247,116,0,209,221,153,0,133,128,178,1,58,44,25,0,201,39,59,1,189,19,252,0,49,229,210,1,117,187,117,0,181,179,184,1,0,114,219,0,48,94,147,0,245,41,56,0,125,13,204,254,244,173,119,0,44,221,32,254,84,234,20,0,249,160,198,1,236,126,234,255,47,99,168,254,170,226,153,255,102,179,216,0,226,141,122,255,122,66,153,254,182,245,134,0,227,228,25,1,214,57,235,255,216,173,56,255,181,231,210,0,119,128,157,255,129,95,136,255,110,126,51,0,2,169,183,255,7,130,98,254,69,176,94,255,116,4,227,1,217,242,145,255,202,173,31,1,105,1,39,255,46,175,69,0,228,47,58,255,215,224,69,254,207,56,69,255,16,254,139,255,23,207,212,255,202,20,126,255,95,213,96,255,9,176,33,0,200,5,207,255,241,42,128,254,35,33,192,255,248,229,196,1,129,17,120,0,251,103,151,255,7,52,112,255,140,56,66,255,40,226,245,255,217,70,37,254,172,214,9,255,72,67,134,1,146,192,214,255,44,38,112,0,68,184,75,255,206,90,251,0,149,235,141,0,181,170,58,0,116,244,239,0,92,157,2,0,102,173,98,0,233,137,96,1,127,49,203,0,5,155,148,0,23,148,9,255,211,122,12,0,34,134,26,255,219,204,136,0,134,8,41,255,224,83,43,254,85,25,247,0,109,127,0,254,169,136,48,0,238,119,219,255,231,173,213,0,206,18,254,254,8,186,7,255,126,9,7,1,111,42,72,0,111,52,236,254,96,63,141,0,147,191,127,254,205,78,192,255,14,106,237,1,187,219,76,0,175,243,187,254,105,89,173,0,85,25,89,1,162,243,148,0,2,118,209,254,33,158,9,0,139,163,46,255,93,70,40,0,108,42,142,254,111,252,142,255,155,223,144,0,51,229,167,255,73,252,155,255,94,116,12,255,152,160,218,255,156,238,37,255,179,234,207,255,197,0,179,255,154,164,141,0,225,196,104,0,10,35,25,254,209,212,242,255,97,253,222,254,184,101,229,0,222,18,127,1,164,136,135,255,30,207,140,254,146,97,243,0,129,192,26,254,201,84,33,255,111,10,78,255,147,81,178,255,4,4,24,0,161,238,215,255,6,141,33,0,53,215,14,255,41,181,208,255,231,139,157,0,179,203,221,255,255,185,113,0,189,226,172,255,113,66,214,255,202,62,45,255,102,64,8,255,78,174,16,254,133,117,68,255,182,120,89,255,133,114,211,0,189,110,21,255,15,10,106,0,41,192,1,0,152,232,121,255,188,60,160,255,153,113,206,255,0,183,226,254,180,13,72,255,176,160,14,254,211,201,134,255,158,24,143,0,127,105,53,0,96,12,189,0,167,215,251,255,159,76,128,254,106,101,225,255,30,252,4,0,146,12,174,0,89,241,178,254,10,229,166,255,123,221,42,254,30,20,212,0,82,128,3,0,48,209,243,0,119,121,64,255,50,227,156,255,0,110,197,1,103,27,144,0,133,59,140,1,189,241,36,255,248,37,195,1,96,220,55,0,183,76,62,255,195,66,61,0,50,76,164,1,225,164,76,255,76,61,163,255,117,62,31,0,81,145,64,255,118,65,14,0,162,115,214,255,6,138,46,0,124,230,244,255,10,138,143,0,52,26,194,0,184,244,76,0,129,143,41,1,190,244,19,255,123,170,122,255,98,129,68,0,121,213,147,0,86,101,30,255,161,103,155,0,140,89,67,255,239,229,190,1,67,11,181,0,198,240,137,254,238,69,188,255,234,113,60,255,37,255,57,255,69,178,182,254,128,208,179,0,118,26,125,254,3,7,214,255,241,50,77,255,85,203,197,255,211,135,250,255,25,48,100,255,187,213,180,254,17,88,105,0,83,209,158,1,5,115,98,0,4,174,60,254,171,55,110,255,217,181,17,255,20,188,170,0,146,156,102,254,87,214,174,255,114,122,155,1,233,44,170,0,127,8,239,1,214,236,234,0,175,5,219,0,49,106,61,255,6,66,208,255,2,106,110,255,81,234,19,255,215,107,192,255,67,151,238,0,19,42,108,255,229,85,113,1,50,68,135,255,17,106,9,0,50,103,1,255,80,1,168,1,35,152,30,255,16,168,185,1,56,89,232,255,101,210,252,0,41,250,71,0,204,170,79,255,14,46,239,255,80,77,239,0,189,214,75,255,17,141,249,0,38,80,76,255,190,85,117,0,86,228,170,0,156,216,208,1,195,207,164,255,150,66,76,255,175,225,16,255,141,80,98,1,76,219,242,0,198,162,114,0,46,218,152,0,155,43,241,254,155,160,104,255,178,9,252,254,100,110,212,0,14,5,167,0,233,239,163,255,28,151,157,1,101,146,10,255,254,158,70,254,71,249,228,0,88,30,50,0,68,58,160,255,191,24,104,1,129,66,129,255,192,50,85,255,8,179,138,255,38,250,201,0,115,80,160,0,131,230,113,0,125,88,147,0,90,68,199,0,253,76,158,0,28,255,118,0,113,250,254,0,66,75,46,0,230,218,43,0,229,120,186,1,148,68,43,0,136,124,238,1,187,107,197,255,84,53,246,255,51,116,254,255,51,187,165,0,2,17,175,0,66,84,160,1,247,58,30,0,35,65,53,254,69,236,191,0,45,134,245,1,163,123,221,0,32,110,20,255,52,23,165,0,186,214,71,0,233,176,96,0,242,239,54,1,57,89,138,0,83,0,84,255,136,160,100,0,92,142,120,254,104,124,190,0,181,177,62,255,250,41,85,0,152,130,42,1,96,252,246,0,151,151,63,254,239,133,62,0,32,56,156,0,45,167,189,255,142,133,179,1,131,86,211,0,187,179,150,254,250,170,14,255,68,113,21,255,222,186,59,255,66,7,241,1,69,6,72,0,86,156,108,254,55,167,89,0,109,52,219,254,13,176,23,255,196,44,106,255,239,149,71,255,164,140,125,255,159,173,1,0,51,41,231,0,145,62,33,0,138,111,93,1,185,83,69,0,144,115,46,0,97,151,16,255,24,228,26,0,49,217,226,0,113,75,234,254,193,153,12,255,182,48,96,255,14,13,26,0,128,195,249,254,69,193,59,0,132,37,81,254,125,106,60,0,214,240,169,1,164,227,66,0,210,163,78,0,37,52,151,0,99,77,26,0,238,156,213,255,213,192,209,1,73,46,84,0,20,65,41,1,54,206,79,0,201,131,146,254,170,111,24,255,177,33,50,254,171,38,203,255,78,247,116,0,209,221,153,0,133,128,178,1,58,44,25,0,201,39,59,1,189,19,252,0,49,229,210,1,117,187,117,0,181,179,184,1,0,114,219,0,48,94,147,0,245,41,56,0,125,13,204,254,244,173,119,0,44,221,32,254,84,234,20,0,249,160,198,1,236,126,234,255,143,62,221,0,129,89,214,255,55,139,5,254,68,20,191,255,14,204,178,1,35,195,217,0,47,51,206,1,38,246,165,0,206,27,6,254,158,87,36,0,217,52,146,255,125,123,215,255,85,60,31,255,171,13,7,0,218,245,88,254,252,35,60,0,55,214,160,255,133,101,56,0,224,32,19,254,147,64,234,0,26,145,162,1,114,118,125,0,248,252,250,0,101,94,196,255,198,141,226,254,51,42,182,0,135,12,9,254,109,172,210,255,197,236,194,1,241,65,154,0,48,156,47,255,153,67,55,255,218,165,34,254,74,180,179,0,218,66,71,1,88,122,99,0,212,181,219,255,92,42,231,255,239,0,154,0,245,77,183,255,94,81,170,1,18,213,216,0,171,93,71,0,52,94,248,0,18,151,161,254,197,209,66,255,174,244,15,254,162,48,183,0,49,61,240,254,182,93,195,0,199,228,6,1,200,5,17,255,137,45,237,255,108,148,4,0,90,79,237,255,39,63,77,255,53,82,207,1,142,22,118,255,101,232,18,1,92,26,67,0,5,200,88,255,33,168,138,255,149,225,72,0,2,209,27,255,44,245,168,1,220,237,17,255,30,211,105,254,141,238,221,0,128,80,245,254,111,254,14,0,222,95,190,1,223,9,241,0,146,76,212,255,108,205,104,255,63,117,153,0,144,69,48,0,35,228,111,0,192,33,193,255,112,214,190,254,115,152,151,0,23,102,88,0,51,74,248,0,226,199,143,254,204,162,101,255,208,97,189,1,245,104,18,0,230,246,30,255,23,148,69,0,110,88,52,254,226,181,89,255,208,47,90,254,114,161,80,255,33,116,248,0,179,152,87,255,69,144,177,1,88,238,26,255,58,32,113,1,1,77,69,0,59,121,52,255,152,238,83,0,52,8,193,0,231,39,233,255,199,34,138,0,222,68,173,0,91,57,242,254,220,210,127,255,192,7,246,254,151,35,187,0,195,236,165,0,111,93,206,0,212,247,133,1,154,133,209,255,155,231,10,0,64,78,38,0,122,249,100,1,30,19,97,255,62,91,249,1,248,133,77,0,197,63,168,254,116,10,82,0,184,236,113,254,212,203,194,255,61,100,252,254,36,5,202,255,119,91,153,255,129,79,29,0,103,103,171,254,237,215,111,255,216,53,69,0,239,240,23,0,194,149,221,255,38,225,222,0,232,255,180,254,118,82,133,255,57,209,177,1,139,232,133,0,158,176,46,254,194,115,46,0,88,247,229,1,28,103,191,0,221,222,175,254,149,235,44,0,151,228,25,254,218,105,103,0,142,85,210,0,149,129,190,255,213,65,94,254,117,134,224,255,82,198,117,0,157,221,220,0,163,101,36,0,197,114,37,0,104,172,166,254,11,182,0,0,81,72,188,255,97,188,16,255,69,6,10,0,199,147,145,255,8,9,115,1,65,214,175,255,217,173,209,0,80,127,166,0,247,229,4,254,167,183,124,255,90,28,204,254,175,59,240,255,11,41,248,1,108,40,51,255,144,177,195,254,150,250,126,0,138,91,65,1,120,60,222,255,245,193,239,0,29,214,189,255,128,2,25,0,80,154,162,0,77,220,107,1,234,205,74,255,54,166,103,255,116,72,9,0,228,94,47,255,30,200,25,255,35,214,89,255,61,176,140,255,83,226,163,255,75,130,172,0,128,38,17,0,95,137,152,255,215,124,159,1,79,93,0,0,148,82,157,254,195,130,251,255,40,202,76,255,251,126,224,0,157,99,62,254,207,7,225,255,96,68,195,0,140,186,157,255,131,19,231,255,42,128,254,0,52,219,61,254,102,203,72,0,141,7,11,255,186,164,213,0,31,122,119,0,133,242,145,0,208,252,232,255,91,213,182,255,143,4,250,254,249,215,74,0,165,30,111,1,171,9,223,0,229,123,34,1,92,130,26,255,77,155,45,1,195,139,28,255,59,224,78,0,136,17,247,0,108,121,32,0,79,250,189,255,96,227,252,254,38,241,62,0,62,174,125,255,155,111,93,255,10,230,206,1,97,197,40,255,0,49,57,254,65,250,13,0,18,251,150,255,220,109,210,255,5,174,166,254,44,129,189,0,235,35,147,255,37,247,141,255,72,141,4,255,103,107,255,0,247,90,4,0,53,44,42,0,2,30,240,0,4,59,63,0,88,78,36,0,113,167,180,0,190,71,193,255,199,158,164,255,58,8,172,0,77,33,12,0,65,63,3,0,153,77,33,255,172,254,102,1,228,221,4,255,87,30,254,1,146,41,86,255,138,204,239,254,108,141,17,255,187,242,135,0,210,208,127,0,68,45,14,254,73,96,62,0,81,60,24,255,170,6,36,255,3,249,26,0,35,213,109,0,22,129,54,255,21,35,225,255,234,61,56,255,58,217,6,0,143,124,88,0,236,126,66,0,209,38,183,255,34,238,6,255,174,145,102,0,95,22,211,0,196,15,153,254,46,84,232,255,117,34,146,1,231,250,74,255,27,134,100,1,92,187,195,255,170,198,112,0,120,28,42,0,209,70,67,0,29,81,31,0,29,168,100,1,169,173,160,0,107,35,117,0,62,96,59,255,81,12,69,1,135,239,190,255,220,252,18,0,163,220,58,255,137,137,188,255,83,102,109,0,96,6,76,0,234,222,210,255,185,174,205,1,60,158,213,255,13,241,214,0,172,129,140,0,93,104,242,0,192,156,251,0,43,117,30,0,225,81,158,0,127,232,218,0,226,28,203,0,233,27,151,255,117,43,5,255,242,14,47,255,33,20,6,0,137,251,44,254,27,31,245,255,183,214,125,254,40,121,149,0,186,158,213,255,89,8,227,0,69,88,0,254,203,135,225,0,201,174,203,0,147,71,184,0,18,121,41,254,94,5,78,0,224,214,240,254,36,5,180,0,251,135,231,1,163,138,212,0,210,249,116,254,88,129,187,0,19,8,49,254,62,14,144,255,159,76,211,0,214,51,82,0,109,117,228,254,103,223,203,255,75,252,15,1,154,71,220,255,23,13,91,1,141,168,96,255,181,182,133,0,250,51,55,0,234,234,212,254,175,63,158,0,39,240,52,1,158,189,36,255,213,40,85,1,32,180,247,255,19,102,26,1,84,24,97,255,69,21,222,0,148,139,122,255,220,213,235,1,232,203,255,0,121,57,147,0,227,7,154,0,53,22,147,1,72,1,225,0,82,134,48,254,83,60,157,255,145,72,169,0,34,103,239,0,198,233,47,0,116,19,4,255,184,106,9,255,183,129,83,0,36,176,230,1,34,103,72,0,219,162,134,0,245,42,158,0,32,149,96,254,165,44,144,0,202,239,72,254,215,150,5,0,42,66,36,1,132,215,175,0,86,174,86,255,26,197,156,255,49,232,135,254,103,182,82,0,253,128,176,1,153,178,122,0,245,250,10,0,236,24,178,0,137,106,132,0,40,29,41,0,50,30,152,255,124,105,38,0,230,191,75,0,143,43,170,0,44,131,20,255,44,13,23,255,237,255,155,1,159,109,100,255,112,181,24,255,104,220,108,0,55,211,131,0,99,12,213,255,152,151,145,255,238,5,159,0,97,155,8,0,33,108,81,0,1,3,103,0,62,109,34,255,250,155,180,0,32,71,195,255,38,70,145,1,159,95,245,0,69,229,101,1,136,28,240,0,79,224,25,0,78,110,121,255,248,168,124,0,187,128,247,0,2,147,235,254,79,11,132,0,70,58,12,1,181,8,163,255,79,137,133,255,37,170,11,255,141,243,85,255,176,231,215,255,204,150,164,255,239,215,39,255,46,87,156,254,8,163,88,255,172,34,232,0,66,44,102,255,27,54,41,254,236,99,87,255,41,123,169,1,52,114,43,0,117,134,40,0,155,134,26,0,231,207,91,254,35,132,38,255,19,102,125,254,36,227,133,255,118,3,113,255,29,13,124,0,152,96,74,1,88,146,206,255,167,191,220,254,162,18,88,255,182,100,23,0,31,117,52,0,81,46,106,1,12,2,7,0,69,80,201,1,209,246,172,0,12,48,141,1,224,211,88,0,116,226,159,0,122,98,130,0,65,236,234,1,225,226,9,255,207,226,123,1,89,214,59,0,112,135,88,1,90,244,203,255,49,11,38,1,129,108,186,0,89,112,15,1,101,46,204,255,127,204,45,254,79,255,221,255,51,73,18,255,127,42,101,255,241,21,202,0,160,227,7,0,105,50,236,0,79,52,197,255,104,202,208,1,180,15,16,0,101,197,78,255,98,77,203,0,41,185,241,1,35,193,124,0,35,155,23,255,207,53,192,0,11,125,163,1,249,158,185,255,4,131,48,0,21,93,111,255,61,121,231,1,69,200,36,255,185,48,185,255,111,238,21,255,39,50,25,255,99,215,163,255,87,212,30,255,164,147,5,255,128,6,35,1,108,223,110,255,194,76,178,0,74,101,180,0,243,47,48,0,174,25,43,255,82,173,253,1,54,114,192,255,40,55,91,0,215,108,176,255,11,56,7,0,224,233,76,0,209,98,202,254,242,25,125,0,44,193,93,254,203,8,177,0,135,176,19,0,112,71,213,255,206,59,176,1,4,67,26,0,14,143,213,254,42,55,208,255,60,67,120,0,193,21,163,0,99,164,115,0,10,20,118,0,156,212,222,254,160,7,217,255,114,245,76,1,117,59,123,0,176,194,86,254,213,15,176,0,78,206,207,254,213,129,59,0,233,251,22,1,96,55,152,255,236,255,15,255,197,89,84,255,93,149,133,0,174,160,113,0,234,99,169,255,152,116,88,0,144,164,83,255,95,29,198,255,34,47,15,255,99,120,134,255,5,236,193,0,249,247,126,255,147,187,30,0,50,230,117,255,108,217,219,255,163,81,166,255,72,25,169,254,155,121,79,255,28,155,89,254,7,126,17,0,147,65,33,1,47,234,253,0,26,51,18,0,105,83,199,255,163,196,230,0,113,248,164,0,226,254,218,0,189,209,203,255,164,247,222,254,255,35,165,0,4,188,243,1,127,179,71,0,37,237,254,255,100,186,240,0,5,57,71,254,103,72,73,255,244,18,81,254,229,210,132,255,238,6,180,255,11,229,174,255,227,221,192,1,17,49,28,0,163,215,196,254,9,118,4,255,51,240,71,0,113,129,109,255,76,240,231,0,188,177,127,0,125,71,44,1,26,175,243,0,94,169,25,254,27,230,29,0,15,139,119,1,168,170,186,255,172,197,76,255,252,75,188,0,137,124,196,0,72,22,96,255,45,151,249,1,220,145,100,0,64,192,159,255,120,239,226,0,129,178,146,0,0,192,125,0,235,138,234,0,183,157,146,0,83,199,192,255,184,172,72,255,73,225,128,0,77,6,250,255,186,65,67,0,104,246,207,0,188,32,138,255,218,24,242,0,67,138,81,254,237,129,121,255,20,207,150,1,41,199,16,255,6,20,128,0,159,118,5,0,181,16,143,255,220,38,15,0,23,64,147,254,73,26,13,0,87,228,57,1,204,124,128,0,43,24,223,0,219,99,199,0,22,75,20,255,19,27,126,0,157,62,215,0,110,29,230,0,179,167,255,1,54,252,190,0,221,204,182,254,179,158,65,255,81,157,3,0,194,218,159,0,170,223,0,0,224,11,32,255,38,197,98,0,168,164,37,0,23,88,7,1,164,186,110,0,96,36,134,0,234,242,229,0,250,121,19,0,242,254,112,255,3,47,94,1,9,239,6,255,81,134,153,254,214,253,168,255,67,124,224,0,245,95,74,0,28,30,44,254,1,109,220,255,178,89,89,0,252,36,76,0,24,198,46,255,76,77,111,0,134,234,136,255,39,94,29,0,185,72,234,255,70,68,135,255,231,102,7,254,77,231,140,0,167,47,58,1,148,97,118,255,16,27,225,1,166,206,143,255,110,178,214,255,180,131,162,0,143,141,225,1,13,218,78,255,114,153,33,1,98,104,204,0,175,114,117,1,167,206,75,0,202,196,83,1,58,64,67,0,138,47,111,1,196,247,128,255,137,224,224,254,158,112,207,0,154,100,255,1,134,37,107,0,198,128,79,255,127,209,155,255,163,254,185,254,60,14,243,0,31,219,112,254,29,217,65,0,200,13,116,254,123,60,196,255,224,59,184,254,242,89,196,0,123,16,75,254,149,16,206,0,69,254,48,1,231,116,223,255,209,160,65,1,200,80,98,0,37,194,184,254,148,63,34,0,139,240,65,255,217,144,132,255,56,38,45,254,199,120,210,0,108,177,166,255,160,222,4,0,220,126,119,254,165,107,160,255,82,220,248,1,241,175,136,0,144,141,23,255,169,138,84,0,160,137,78,255,226,118,80,255,52,27,132,255,63,96,139,255,152,250,39,0,188,155,15,0,232,51,150,254,40,15,232,255,240,229,9,255,137,175,27,255,75,73,97,1,218,212,11,0,135,5,162,1,107,185,213,0,2,249,107,255,40,242,70,0,219,200,25,0,25,157,13,0,67,82,80,255,196,249,23,255,145,20,149,0,50,72,146,0,94,76,148,1,24,251,65,0,31,192,23,0,184,212,201,255,123,233,162,1,247,173,72,0,162,87,219,254,126,134,89,0,159,11,12,254,166,105,29,0,73,27,228,1,113,120,183,255,66,163,109,1,212,143,11,255,159,231,168,1,255,128,90,0,57,14,58,254,89,52,10,255,253,8,163,1,0,145,210,255,10,129,85,1,46,181,27,0,103,136,160,254,126,188,209,255,34,35,111,0,215,219,24,255,212,11,214,254,101,5,118,0,232,197,133,255,223,167,109,255,237,80,86,255,70,139,94,0,158,193,191,1,155,15,51,255,15,190,115,0,78,135,207,255,249,10,27,1,181,125,233,0,95,172,13,254,170,213,161,255,39,236,138,255,95,93,87,255,190,128,95,0,125,15,206,0,166,150,159,0,227,15,158,255,206,158,120,255,42,141,128,0,101,178,120,1,156,109,131,0,218,14,44,254,247,168,206,255,212,112,28,0,112,17,228,255,90,16,37,1,197,222,108,0,254,207,83,255,9,90,243,255,243,244,172,0,26,88,115,255,205,116,122,0,191,230,193,0,180,100,11,1,217,37,96,255,154,78,156,0,235,234,31,255,206,178,178,255,149,192,251,0,182,250,135,0,246,22,105,0,124,193,109,255,2,210,149,255,169,17,170,0,0,96,110,255,117,9,8,1,50,123,40,255,193,189,99,0,34,227,160,0,48,80,70,254,211,51,236,0,45,122,245,254,44,174,8,0,173,37,233,255,158,65,171,0,122,69,215,255,90,80,2,255,131,106,96,254,227,114,135,0,205,49,119,254,176,62,64,255,82,51,17,255,241,20,243,255,130,13,8,254,128,217,243,255,162,27,1,254,90,118,241,0,246,198,246,255,55,16,118,255,200,159,157,0,163,17,1,0,140,107,121,0,85,161,118,255,38,0,149,0,156,47,238,0,9,166,166,1,75,98,181,255,50,74,25,0,66,15,47,0,139,225,159,0,76,3,142,255,14,238,184,0,11,207,53,255,183,192,186,1,171,32,174,255,191,76,221,1,247,170,219,0,25,172,50,254,217,9,233,0,203,126,68,255,183,92,48,0,127,167,183,1,65,49,254,0,16,63,127,1,254,21,170,255,59,224,127,254,22,48,63,255,27,78,130,254,40,195,29,0,250,132,112,254,35,203,144,0,104,169,168,0,207,253,30,255,104,40,38,254,94,228,88,0,206,16,128,255,212,55,122,255,223,22,234,0,223,197,127,0,253,181,181,1,145,102,118,0,236,153,36,255,212,217,72,255,20,38,24,254,138,62,62,0,152,140,4,0,230,220,99,255,1,21,212,255,148,201,231,0,244,123,9,254,0,171,210,0,51,58,37,255,1,255,14,255,244,183,145,254,0,242,166,0,22,74,132,0,121,216,41,0,95,195,114,254,133,24,151,255,156,226,231,255,247,5,77,255,246,148,115,254,225,92,81,255,222,80,246,254,170,123,89,255,74,199,141,0,29,20,8,255,138,136,70,255,93,75,92,0,221,147,49,254,52,126,226,0,229,124,23,0,46,9,181,0,205,64,52,1,131,254,28,0,151,158,212,0,131,64,78,0,206,25,171,0,0,230,139,0,191,253,110,254,103,247,167,0,64,40,40,1,42,165,241,255,59,75,228,254,124,243,189,255,196,92,178,255,130,140,86,255,141,89,56,1,147,198,5,255,203,248,158,254,144,162,141,0,11,172,226,0,130,42,21,255,1,167,143,255,144,36,36,255,48,88,164,254,168,170,220,0,98,71,214,0,91,208,79,0,159,76,201,1,166,42,214,255,69,255,0,255,6,128,125,255,190,1,140,0,146,83,218,255,215,238,72,1,122,127,53,0,189,116,165,255,84,8,66,255,214,3,208,255,213,110,133,0,195,168,44,1,158,231,69,0,162,64,200,254,91,58,104,0,182,58,187,254,249,228,136,0,203,134,76,254,99,221,233,0,75,254,214,254,80,69,154,0,64,152,248,254,236,136,202,255,157,105,153,254,149,175,20,0,22,35,19,255,124,121,233,0,186,250,198,254,132,229,139,0,137,80,174,255,165,125,68,0,144,202,148,254,235,239,248,0,135,184,118,0,101,94,17,255,122,72,70,254,69,130,146,0,127,222,248,1,69,127,118,255,30,82,215,254,188,74,19,255,229,167,194,254,117,25,66,255,65,234,56,254,213,22,156,0,151,59,93,254,45,28,27,255,186,126,164,255,32,6,239,0,127,114,99,1,219,52,2,255,99,96,166,254,62,190,126,255,108,222,168,1,75,226,174,0,230,226,199,0,60,117,218,255,252,248,20,1,214,188,204,0,31,194,134,254,123,69,192,255,169,173,36,254,55,98,91,0,223,42,102,254,137,1,102,0,157,90,25,0,239,122,64,255,252,6,233,0,7,54,20,255,82,116,174,0,135,37,54,255,15,186,125,0,227,112,175,255,100,180,225,255,42,237,244,255,244,173,226,254,248,18,33,0,171,99,150,255,74,235,50,255,117,82,32,254,106,168,237,0,207,109,208,1,228,9,186,0,135,60,169,254,179,92,143,0,244,170,104,255,235,45,124,255,70,99,186,0,117,137,183,0,224,31,215,0,40,9,100,0,26,16,95,1,68,217,87,0,8,151,20,255,26,100,58,255,176,165,203,1,52,118,70,0,7,32,254,254,244,254,245,255,167,144,194,255,125,113,23,255,176,121,181,0,136,84,209,0,138,6,30,255,89,48,28,0,33,155,14,255,25,240,154,0,141,205,109,1,70,115,62,255,20,40,107,254,138,154,199,255,94,223,226,255,157,171,38,0,163,177,25,254,45,118,3,255,14,222,23,1,209,190,81,255,118,123,232,1,13,213,101,255,123,55,123,254,27,246,165,0,50,99,76,255,140,214,32,255,97,65,67,255,24,12,28,0,174,86,78,1,64,247,96,0,160,135,67,0,66,55,243,255,147,204,96,255,26,6,33,255,98,51,83,1,153,213,208,255,2,184,54,255,25,218,11,0,49,67,246,254,18,149,72,255,13,25,72,0,42,79,214,0,42,4,38,1,27,139,144,255,149,187,23,0,18,164,132,0,245,84,184,254,120,198,104,255,126,218,96,0,56,117,234,255,13,29,214,254,68,47,10,255,167,154,132,254,152,38,198,0,66,178,89,255,200,46,171,255,13,99,83,255,210,187,253,255,170,45,42,1,138,209,124,0,214,162,141,0,12,230,156,0,102,36,112,254,3,147,67,0,52,215,123,255,233,171,54,255,98,137,62,0,247,218,39,255,231,218,236,0,247,191,127,0,195,146,84,0,165,176,92,255,19,212,94,255,17,74,227,0,88,40,153,1,198,147,1,255,206,67,245,254,240,3,218,255,61,141,213,255,97,183,106,0,195,232,235,254,95,86,154,0,209,48,205,254,118,209,241,255,240,120,223,1,213,29,159,0,163,127,147,255,13,218,93,0,85,24,68,254,70,20,80,255,189,5,140,1,82,97,254,255,99,99,191,255,132,84,133,255,107,218,116,255,112,122,46,0,105,17,32,0,194,160,63,255,68,222,39,1,216,253,92,0,177,105,205,255,149,201,195,0,42,225,11,255,40,162,115,0,9,7,81,0,165,218,219,0,180,22,0,254,29,146,252,255,146,207,225,1,180,135,96,0,31,163,112,0,177,11,219,255,133,12,193,254,43,78,50,0,65,113,121,1,59,217,6,255,110,94,24,1,112,172,111,0,7,15,96,0,36,85,123,0,71,150,21,255,208,73,188,0,192,11,167,1,213,245,34,0,9,230,92,0,162,142,39,255,215,90,27,0,98,97,89,0,94,79,211,0,90,157,240,0,95,220,126,1,102,176,226,0,36,30,224,254,35,31,127,0,231,232,115,1,85,83,130,0,210,73,245,255,47,143,114,255,68,65,197,0,59,72,62,255,183,133,173,254,93,121,118,255,59,177,81,255,234,69,173,255,205,128,177,0,220,244,51,0,26,244,209,1,73,222,77,255,163,8,96,254,150,149,211,0,158,254,203,1,54,127,139,0,161,224,59,0,4,109,22,255,222,42,45,255,208,146,102,255,236,142,187,0,50,205,245,255,10,74,89,254,48,79,142,0,222,76,130,255,30,166,63,0,236,12,13,255,49,184,244,0,187,113,102,0,218,101,253,0,153,57,182,254,32,150,42,0,25,198,146,1,237,241,56,0,140,68,5,0,91,164,172,255,78,145,186,254,67,52,205,0,219,207,129,1,109,115,17,0,54,143,58,1,21,248,120,255,179,255,30,0,193,236,66,255,1,255,7,255,253,192,48,255,19,69,217,1,3,214,0,255,64,101,146,1,223,125,35,255,235,73,179,255,249,167,226,0,225,175,10,1,97,162,58,0,106,112,171,1,84,172,5,255,133,140,178,255,134,245,142,0,97,90,125,255,186,203,185,255,223,77,23,255,192,92,106,0,15,198,115,255,217,152,248,0,171,178,120,255,228,134,53,0,176,54,193,1,250,251,53,0,213,10,100,1,34,199,106,0,151,31,244,254,172,224,87,255,14,237,23,255,253,85,26,255,127,39,116,255,172,104,100,0,251,14,70,255,212,208,138,255,253,211,250,0,176,49,165,0,15,76,123,255,37,218,160,255,92,135,16,1,10,126,114,255,70,5,224,255,247,249,141,0,68,20,60,1,241,210,189,255,195,217,187,1,151,3,113,0,151,92,174,0,231,62,178,255,219,183,225,0,23,23,33,255,205,181,80,0,57,184,248,255,67,180,1,255,90,123,93,255,39,0,162,255,96,248,52,255,84,66,140,0,34,127,228,255,194,138,7,1,166,110,188,0,21,17,155,1,154,190,198,255,214,80,59,255,18,7,143,0,72,29,226,1,199,217,249,0,232,161,71,1,149,190,201,0,217,175,95,254,113,147,67,255,138,143,199,255,127,204,1,0,29,182,83,1,206,230,155,255,186,204,60,0,10,125,85,255,232,96,25,255,255,89,247,255,213,254,175,1,232,193,81,0,28,43,156,254,12,69,8,0,147,24,248,0,18,198,49,0,134,60,35,0,118,246,18,255,49,88,254,254,228,21,186,255,182,65,112,1,219,22,1,255,22,126,52,255,189,53,49,255,112,25,143,0,38,127,55,255,226,101,163,254,208,133,61,255,137,69,174,1,190,118,145,255,60,98,219,255,217,13,245,255,250,136,10,0,84,254,226,0,201,31,125,1,240,51,251,255,31,131,130,255,2,138,50,255,215,215,177,1,223,12,238,255,252,149,56,255,124,91,68,255,72,126,170,254,119,255,100,0,130,135,232,255,14,79,178,0,250,131,197,0,138,198,208,0,121,216,139,254,119,18,36,255,29,193,122,0,16,42,45,255,213,240,235,1,230,190,169,255,198,35,228,254,110,173,72,0,214,221,241,255,56,148,135,0,192,117,78,254,141,93,207,255,143,65,149,0,21,18,98,255,95,44,244,1,106,191,77,0,254,85,8,254,214,110,176,255,73,173,19,254,160,196,199,255,237,90,144,0,193,172,113,255,200,155,136,254,228,90,221,0,137,49,74,1,164,221,215,255,209,189,5,255,105,236,55,255,42,31,129,1,193,255,236,0,46,217,60,0,138,88,187,255,226,82,236,255,81,69,151,255,142,190,16,1,13,134,8,0,127,122,48,255,81,64,156,0,171,243,139,0,237,35,246,0,122,143,193,254,212,122,146,0,95,41,255,1,87,132,77,0,4,212,31,0,17,31,78,0,39,45,173,254,24,142,217,255,95,9,6,255,227,83,6,0,98,59,130,254,62,30,33,0,8,115,211,1,162,97,128,255,7,184,23,254,116,28,168,255,248,138,151,255,98,244,240,0,186,118,130,0,114,248,235,255,105,173,200,1,160,124,71,255,94,36,164,1,175,65,146,255,238,241,170,254,202,198,197,0,228,71,138,254,45,246,109,255,194,52,158,0,133,187,176,0,83,252,154,254,89,189,221,255,170,73,252,0,148,58,125,0,36,68,51,254,42,69,177,255,168,76,86,255,38,100,204,255,38,53,35,0,175,19,97,0,225,238,253,255,81,81,135,0,210,27,255,254,235,73,107,0,8,207,115,0,82,127,136,0,84,99,21,254,207,19,136,0,100,164,101,0,80,208,77,255,132,207,237,255,15,3,15,255,33,166,110,0,156,95,85,255,37,185,111,1,150,106,35,255,166,151,76,0,114,87,135,255,159,194,64,0,12,122,31,255,232,7,101,254,173,119,98,0,154,71,220,254,191,57,53,255,168,232,160,255,224,32,99,255,218,156,165,0,151,153,163,0,217,13,148,1,197,113,89,0,149,28,161,254,207,23,30,0,105,132,227,255,54,230,94,255,133,173,204,255,92,183,157,255,88,144,252,254,102,33,90,0,159,97,3,0,181,218,155,255,240,114,119,0,106,214,53,255,165,190,115,1,152,91,225,255,88,106,44,255,208,61,113,0,151,52,124,0,191,27,156,255,110,54,236,1,14,30,166,255,39,127,207,1,229,199,28,0,188,228,188,254,100,157,235,0,246,218,183,1,107,22,193,255,206,160,95,0,76,239,147,0,207,161,117,0,51,166,2,255,52,117,10,254,73,56,227,255,152,193,225,0,132,94,136,255,101,191,209,0,32,107,229,255,198,43,180,1,100,210,118,0,114,67,153,255,23,88,26,255,89,154,92,1,220,120,140,255,144,114,207,255,252,115,250,255,34,206,72,0,138,133,127,255,8,178,124,1,87,75,97,0,15,229,92,254,240,67,131,255,118,123,227,254,146,120,104,255,145,213,255,1,129,187,70,255,219,119,54,0,1,19,173,0,45,150,148,1,248,83,72,0,203,233,169,1,142,107,56,0,247,249,38,1,45,242,80,255,30,233,103,0,96,82,70,0,23,201,111,0,81,39,30,255,161,183,78,255,194,234,33,255,68,227,140,254,216,206,116,0,70,27,235,255,104,144,79,0,164,230,93,254,214,135,156,0,154,187,242,254,188,20,131,255,36,109,174,0,159,112,241,0,5,110,149,1,36,165,218,0,166,29,19,1,178,46,73,0,93,43,32,254,248,189,237,0,102,155,141,0,201,93,195,255,241,139,253,255,15,111,98,255,108,65,163,254,155,79,190,255,73,174,193,254,246,40,48,255,107,88,11,254,202,97,85,255,253,204,18,255,113,242,66,0,110,160,194,254,208,18,186,0,81,21,60,0,188,104,167,255,124,166,97,254,210,133,142,0,56,242,137,254,41,111,130,0,111,151,58,1,111,213,141,255,183,172,241,255,38,6,196,255,185,7,123,255,46,11,246,0,245,105,119,1,15,2,161,255,8,206,45,255,18,202,74,255,83,124,115,1,212,141,157,0,83,8,209,254,139,15,232,255,172,54,173,254,50,247,132,0,214,189,213,0,144,184,105,0,223,254,248,0,255,147,240,255,23,188,72,0,7,51,54,0,188,25,180,254,220,180,0,255,83,160,20,0,163,189,243,255,58,209,194,255,87,73,60,0,106,24,49,0,245,249,220,0,22,173,167,0,118,11,195,255,19,126,237,0,110,159,37,255,59,82,47,0,180,187,86,0,188,148,208,1,100,37,133,255,7,112,193,0,129,188,156,255,84,106,129,255,133,225,202,0,14,236,111,255,40,20,101,0,172,172,49,254,51,54,74,255,251,185,184,255,93,155,224,255,180,249,224,1,230,178,146,0,72,57,54,254,178,62,184,0,119,205,72,0,185,239,253,255,61,15,218,0,196,67,56,255,234,32,171,1,46,219,228,0,208,108,234,255,20,63,232,255,165,53,199,1,133,228,5,255,52,205,107,0,74,238,140,255,150,156,219,254,239,172,178,255,251,189,223,254,32,142,211,255,218,15,138,1,241,196,80,0,28,36,98,254,22,234,199,0,61,237,220,255,246,57,37,0,142,17,142,255,157,62,26,0,43,238,95,254,3,217,6,255,213,25,240,1,39,220,174,255,154,205,48,254,19,13,192,255,244,34,54,254,140,16,155,0,240,181,5,254,155,193,60,0,166,128,4,255,36,145,56,255,150,240,219,0,120,51,145,0,82,153,42,1,140,236,146,0,107,92,248,1,189,10,3,0,63,136,242,0,211,39,24,0,19,202,161,1,173,27,186,255,210,204,239,254,41,209,162,255,182,254,159,255,172,116,52,0,195,103,222,254,205,69,59,0,53,22,41,1,218,48,194,0,80,210,242,0,210,188,207,0,187,161,161,254,216,17,1,0,136,225,113,0,250,184,63,0,223,30,98,254,77,168,162,0,59,53,175,0,19,201,10,255,139,224,194,0,147,193,154,255,212,189,12,254,1,200,174,255,50,133,113,1,94,179,90,0,173,182,135,0,94,177,113,0,43,89,215,255,136,252,106,255,123,134,83,254,5,245,66,255,82,49,39,1,220,2,224,0,97,129,177,0,77,59,89,0,61,29,155,1,203,171,220,255,92,78,139,0,145,33,181,255,169,24,141,1,55,150,179,0,139,60,80,255,218,39,97,0,2,147,107,255,60,248,72,0,173,230,47,1,6,83,182,255,16,105,162,254,137,212,81,255,180,184,134,1,39,222,164,255,221,105,251,1,239,112,125,0,63,7,97,0,63,104,227,255,148,58,12,0,90,60,224,255,84,212,252,0,79,215,168,0,248,221,199,1,115,121,1,0,36,172,120,0,32,162,187,255,57,107,49,255,147,42,21,0,106,198,43,1,57,74,87,0,126,203,81,255,129,135,195,0,140,31,177,0,221,139,194,0,3,222,215,0,131,68,231,0,177,86,178,254,124,151,180,0,184,124,38,1,70,163,17,0,249,251,181,1,42,55,227,0,226,161,44,0,23,236,110,0,51,149,142,1,93,5,236,0,218,183,106,254,67,24,77,0,40,245,209,255,222,121,153,0,165,57,30,0,83,125,60,0,70,38,82,1,229,6,188,0,109,222,157,255,55,118,63,255,205,151,186,0,227,33,149,255,254,176,246,1,227,177,227,0,34,106,163,254,176,43,79,0,106,95,78,1,185,241,122,255,185,14,61,0,36,1,202,0,13,178,162,255,247,11,132,0,161,230,92,1,65,1,185,255,212,50,165,1,141,146,64,255,158,242,218,0,21,164,125,0,213,139,122,1,67,71,87,0,203,158,178,1,151,92,43,0,152,111,5,255,39,3,239,255,217,255,250,255,176,63,71,255,74,245,77,1,250,174,18,255,34,49,227,255,246,46,251,255,154,35,48,1,125,157,61,255,106,36,78,255,97,236,153,0,136,187,120,255,113,134,171,255,19,213,217,254,216,94,209,255,252,5,61,0,94,3,202,0,3,26,183,255,64,191,43,255,30,23,21,0,129,141,77,255,102,120,7,1,194,76,140,0,188,175,52,255,17,81,148,0,232,86,55,1,225,48,172,0,134,42,42,255,238,50,47,0,169,18,254,0,20,147,87,255,14,195,239,255,69,247,23,0,238,229,128,255,177,49,112,0,168,98,251,255,121,71,248,0,243,8,145,254,246,227,153,255,219,169,177,254,251,139,165,255,12,163,185,255,164,40,171,255,153,159,27,254,243,109,91,255,222,24,112,1,18,214,231,0,107,157,181,254,195,147,0,255,194,99,104,255,89,140,190,255,177,66,126,254,106,185,66,0,49,218,31,0,252,174,158,0,188,79,230,1,238,41,224,0,212,234,8,1,136,11,181,0,166,117,83,255,68,195,94,0,46,132,201,0,240,152,88,0,164,57,69,254,160,224,42,255,59,215,67,255,119,195,141,255,36,180,121,254,207,47,8,255,174,210,223,0,101,197,68,255,255,82,141,1,250,137,233,0,97,86,133,1,16,80,69,0,132,131,159,0,116,93,100,0,45,141,139,0,152,172,157,255,90,43,91,0,71,153,46,0,39,16,112,255,217,136,97,255,220,198,25,254,177,53,49,0,222,88,134,255,128,15,60,0,207,192,169,255,192,116,209,255,106,78,211,1,200,213,183,255,7,12,122,254,222,203,60,255,33,110,199,254,251,106,117,0,228,225,4,1,120,58,7,255,221,193,84,254,112,133,27,0,189,200,201,255,139,135,150,0,234,55,176,255,61,50,65,0,152,108,169,255,220,85,1,255,112,135,227,0,162,26,186,0,207,96,185,254,244,136,107,0,93,153,50,1,198,97,151,0,110,11,86,255,143,117,174,255,115,212,200,0,5,202,183,0,237,164,10,254,185,239,62,0,236,120,18,254,98,123,99,255,168,201,194,254,46,234,214,0,191,133,49,255,99,169,119,0,190,187,35,1,115,21,45,255,249,131,72,0,112,6,123,255,214,49,181,254,166,233,34,0,92,197,102,254,253,228,205,255,3,59,201,1,42,98,46,0,219,37,35,255,169,195,38,0,94,124,193,1,156,43,223,0,95,72,133,254,120,206,191,0,122,197,239,255,177,187,79,255,254,46,2,1,250,167,190,0,84,129,19,0,203,113,166,255,249,31,189,254,72,157,202,255,208,71,73,255,207,24,72,0,10,16,18,1,210,81,76,255,88,208,192,255,126,243,107,255,238,141,120,255,199,121,234,255,137,12,59,255,36,220,123,255,148,179,60,254,240,12,29,0,66,0,97,1,36,30,38,255,115,1,93,255,96,103,231,255,197,158,59,1,192,164,240,0,202,202,57,255,24,174,48,0,89,77,155,1,42,76,215,0,244,151,233,0,23,48,81,0,239,127,52,254,227,130,37,255,248,116,93,1,124,132,118,0,173,254,192,1,6,235,83,255,110,175,231,1,251,28,182,0,129,249,93,254,84,184,128,0,76,181,62,0,175,128,186,0,100,53,136,254,109,29,226,0,221,233,58,1,20,99,74,0,0,22,160,0,134,13,21,0,9,52,55,255,17,89,140,0,175,34,59,0,84,165,119,255,224,226,234,255,7,72,166,255,123,115,255,1,18,214,246,0,250,7,71,1,217,220,185,0,212,35,76,255,38,125,175,0,189,97,210,0,114,238,44,255,41,188,169,254,45,186,154,0,81,92,22,0,132,160,193,0,121,208,98,255,13,81,44,255,203,156,82,0,71,58,21,255,208,114,191,254,50,38,147,0,154,216,195,0,101,25,18,0,60,250,215,255,233,132,235,255,103,175,142,1,16,14,92,0,141,31,110,254,238,241,45,255,153,217,239,1,97,168,47,255,249,85,16,1,28,175,62,255,57,254,54,0,222,231,126,0,166,45,117,254,18,189,96,255,228,76,50,0,200,244,94,0,198,152,120,1,68,34,69,255,12,65,160,254,101,19,90,0,167,197,120,255,68,54,185,255,41,218,188,0,113,168,48,0,88,105,189,1,26,82,32,255,185,93,164,1,228,240,237,255,66,182,53,0,171,197,92,255,107,9,233,1,199,120,144,255,78,49,10,255,109,170,105,255,90,4,31,255,28,244,113,255,74,58,11,0,62,220,246,255,121,154,200,254,144,210,178,255,126,57,129,1,43,250,14,255,101,111,28,1,47,86,241,255,61,70,150,255,53,73,5,255,30,26,158,0,209,26,86,0,138,237,74,0,164,95,188,0,142,60,29,254,162,116,248,255,187,175,160,0,151,18,16,0,209,111,65,254,203,134,39,255,88,108,49,255,131,26,71,255,221,27,215,254,104,105,93,255,31,236,31,254,135,0,211,255,143,127,110,1,212,73,229,0,233,67,167,254,195,1,208,255,132,17,221,255,51,217,90,0,67,235,50,255,223,210,143,0,179,53,130,1,233,106,198,0,217,173,220,255,112,229,24,255,175,154,93,254,71,203,246,255,48,66,133,255,3,136,230,255,23,221,113,254,235,111,213,0,170,120,95,254,251,221,2,0,45,130,158,254,105,94,217,255,242,52,180,254,213,68,45,255,104,38,28,0,244,158,76,0,161,200,96,255,207,53,13,255,187,67,148,0,170,54,248,0,119,162,178,255,83,20,11,0,42,42,192,1,146,159,163,255,183,232,111,0,77,229,21,255,71,53,143,0,27,76,34],\"i8\",ALLOC_NONE,Runtime.GLOBAL_BASE);allocate([246,136,47,255,219,39,182,255,92,224,201,1,19,142,14,255,69,182,241,255,163,118,245,0,9,109,106,1,170,181,247,255,78,47,238,255,84,210,176,255,213,107,139,0,39,38,11,0,72,21,150,0,72,130,69,0,205,77,155,254,142,133,21,0,71,111,172,254,226,42,59,255,179,0,215,1,33,128,241,0,234,252,13,1,184,79,8,0,110,30,73,255,246,141,189,0,170,207,218,1,74,154,69,255,138,246,49,255,155,32,100,0,125,74,105,255,90,85,61,255,35,229,177,255,62,125,193,255,153,86,188,1,73,120,212,0,209,123,246,254,135,209,38,255,151,58,44,1,92,69,214,255,14,12,88,255,252,153,166,255,253,207,112,255,60,78,83,255,227,124,110,0,180,96,252,255,53,117,33,254,164,220,82,255,41,1,27,255,38,164,166,255,164,99,169,254,61,144,70,255,192,166,18,0,107,250,66,0,197,65,50,0,1,179,18,255,255,104,1,255,43,153,35,255,80,111,168,0,110,175,168,0,41,105,45,255,219,14,205,255,164,233,140,254,43,1,118,0,233,67,195,0,178,82,159,255,138,87,122,255,212,238,90,255,144,35,124,254,25,140,164,0,251,215,44,254,133,70,107,255,101,227,80,254,92,169,55,0,215,42,49,0,114,180,85,255,33,232,27,1,172,213,25,0,62,176,123,254,32,133,24,255,225,191,62,0,93,70,153,0,181,42,104,1,22,191,224,255,200,200,140,255,249,234,37,0,149,57,141,0,195,56,208,255,254,130,70,255,32,173,240,255,29,220,199,0,110,100,115,255,132,229,249,0,228,233,223,255,37,216,209,254,178,177,209,255,183,45,165,254,224,97,114,0,137,97,168,255,225,222,172,0,165,13,49,1,210,235,204,255,252,4,28,254,70,160,151,0,232,190,52,254,83,248,93,255,62,215,77,1,175,175,179,255,160,50,66,0,121,48,208,0,63,169,209,255,0,210,200,0,224,187,44,1,73,162,82,0,9,176,143,255,19,76,193,255,29,59,167,1,24,43,154,0,28,190,190,0,141,188,129,0,232,235,203,255,234,0,109,255,54,65,159,0,60,88,232,255,121,253,150,254,252,233,131,255,198,110,41,1,83,77,71,255,200,22,59,254,106,253,242,255,21,12,207,255,237,66,189,0,90,198,202,1,225,172,127,0,53,22,202,0,56,230,132,0,1,86,183,0,109,190,42,0,243,68,174,1,109,228,154,0,200,177,122,1,35,160,183,255,177,48,85,255,90,218,169,255,248,152,78,0,202,254,110,0,6,52,43,0,142,98,65,255,63,145,22,0,70,106,93,0,232,138,107,1,110,179,61,255,211,129,218,1,242,209,92,0,35,90,217,1,182,143,106,255,116,101,217,255,114,250,221,255,173,204,6,0,60,150,163,0,73,172,44,255,239,110,80,255,237,76,153,254,161,140,249,0,149,232,229,0,133,31,40,255,174,164,119,0,113,51,214,0,129,228,2,254,64,34,243,0,107,227,244,255,174,106,200,255,84,153,70,1,50,35,16,0,250,74,216,254,236,189,66,255,153,249,13,0,230,178,4,255,221,41,238,0,118,227,121,255,94,87,140,254,254,119,92,0,73,239,246,254,117,87,128,0,19,211,145,255,177,46,252,0,229,91,246,1,69,128,247,255,202,77,54,1,8,11,9,255,153,96,166,0,217,214,173,255,134,192,2,1,0,207,0,0,189,174,107,1,140,134,100,0,158,193,243,1,182,102,171,0,235,154,51,0,142,5,123,255,60,168,89,1,217,14,92,255,19,214,5,1,211,167,254,0,44,6,202,254,120,18,236,255,15,113,184,255,184,223,139,0,40,177,119,254,182,123,90,255,176,165,176,0,247,77,194,0,27,234,120,0,231,0,214,255,59,39,30,0,125,99,145,255,150,68,68,1,141,222,248,0,153,123,210,255,110,127,152,255,229,33,214,1,135,221,197,0,137,97,2,0,12,143,204,255,81,41,188,0,115,79,130,255,94,3,132,0,152,175,187,255,124,141,10,255,126,192,179,255,11,103,198,0,149,6,45,0,219,85,187,1,230,18,178,255,72,182,152,0,3,198,184,255,128,112,224,1,97,161,230,0,254,99,38,255,58,159,197,0,151,66,219,0,59,69,143,255,185,112,249,0,119,136,47,255,123,130,132,0,168,71,95,255,113,176,40,1,232,185,173,0,207,93,117,1,68,157,108,255,102,5,147,254,49,97,33,0,89,65,111,254,247,30,163,255,124,217,221,1,102,250,216,0,198,174,75,254,57,55,18,0,227,5,236,1,229,213,173,0,201,109,218,1,49,233,239,0,30,55,158,1,25,178,106,0,155,111,188,1,94,126,140,0,215,31,238,1,77,240,16,0,213,242,25,1,38,71,168,0,205,186,93,254,49,211,140,255,219,0,180,255,134,118,165,0,160,147,134,255,110,186,35,255,198,243,42,0,243,146,119,0,134,235,163,1,4,241,135,255,193,46,193,254,103,180,79,255,225,4,184,254,242,118,130,0,146,135,176,1,234,111,30,0,69,66,213,254,41,96,123,0,121,94,42,255,178,191,195,255,46,130,42,0,117,84,8,255,233,49,214,254,238,122,109,0,6,71,89,1,236,211,123,0,244,13,48,254,119,148,14,0,114,28,86,255,75,237,25,255,145,229,16,254,129,100,53,255,134,150,120,254,168,157,50,0,23,72,104,255,224,49,14,0,255,123,22,255,151,185,151,255,170,80,184,1,134,182,20,0,41,100,101,1,153,33,16,0,76,154,111,1,86,206,234,255,192,160,164,254,165,123,93,255,1,216,164,254,67,17,175,255,169,11,59,255,158,41,61,255,73,188,14,255,195,6,137,255,22,147,29,255,20,103,3,255,246,130,227,255,122,40,128,0,226,47,24,254,35,36,32,0,152,186,183,255,69,202,20,0,195,133,195,0,222,51,247,0,169,171,94,1,183,0,160,255,64,205,18,1,156,83,15,255,197,58,249,254,251,89,110,255,50,10,88,254,51,43,216,0,98,242,198,1,245,151,113,0,171,236,194,1,197,31,199,255,229,81,38,1,41,59,20,0,253,104,230,0,152,93,14,255,246,242,146,254,214,169,240,255,240,102,108,254,160,167,236,0,154,218,188,0,150,233,202,255,27,19,250,1,2,71,133,255,175,12,63,1,145,183,198,0,104,120,115,255,130,251,247,0,17,212,167,255,62,123,132,255,247,100,189,0,155,223,152,0,143,197,33,0,155,59,44,255,150,93,240,1,127,3,87,255,95,71,207,1,167,85,1,255,188,152,116,255,10,23,23,0,137,195,93,1,54,98,97,0,240,0,168,255,148,188,127,0,134,107,151,0,76,253,171,0,90,132,192,0,146,22,54,0,224,66,54,254,230,186,229,255,39,182,196,0,148,251,130,255,65,131,108,254,128,1,160,0,169,49,167,254,199,254,148,255,251,6,131,0,187,254,129,255,85,82,62,0,178,23,58,255,254,132,5,0,164,213,39,0,134,252,146,254,37,53,81,255,155,134,82,0,205,167,238,255,94,45,180,255,132,40,161,0,254,111,112,1,54,75,217,0,179,230,221,1,235,94,191,255,23,243,48,1,202,145,203,255,39,118,42,255,117,141,253,0,254,0,222,0,43,251,50,0,54,169,234,1,80,68,208,0,148,203,243,254,145,7,135,0,6,254,0,0,252,185,127,0,98,8,129,255,38,35,72,255,211,36,220,1,40,26,89,0,168,64,197,254,3,222,239,255,2,83,215,254,180,159,105,0,58,115,194,0,186,116,106,255,229,247,219,255,129,118,193,0,202,174,183,1,166,161,72,0,201,107,147,254,237,136,74,0,233,230,106,1,105,111,168,0,64,224,30,1,1,229,3,0,102,151,175,255,194,238,228,255,254,250,212,0,187,237,121,0,67,251,96,1,197,30,11,0,183,95,204,0,205,89,138,0,64,221,37,1,255,223,30,255,178,48,211,255,241,200,90,255,167,209,96,255,57,130,221,0,46,114,200,255,61,184,66,0,55,182,24,254,110,182,33,0,171,190,232,255,114,94,31,0,18,221,8,0,47,231,254,0,255,112,83,0,118,15,215,255,173,25,40,254,192,193,31,255,238,21,146,255,171,193,118,255,101,234,53,254,131,212,112,0,89,192,107,1,8,208,27,0,181,217,15,255,231,149,232,0,140,236,126,0,144,9,199,255,12,79,181,254,147,182,202,255,19,109,182,255,49,212,225,0,74,163,203,0,175,233,148,0,26,112,51,0,193,193,9,255,15,135,249,0,150,227,130,0,204,0,219,1,24,242,205,0,238,208,117,255,22,244,112,0,26,229,34,0,37,80,188,255,38,45,206,254,240,90,225,255,29,3,47,255,42,224,76,0,186,243,167,0,32,132,15,255,5,51,125,0,139,135,24,0,6,241,219,0,172,229,133,255,246,214,50,0,231,11,207,255,191,126,83,1,180,163,170,255,245,56,24,1,178,164,211,255,3,16,202,1,98,57,118,255,141,131,89,254,33,51,24,0,243,149,91,255,253,52,14,0,35,169,67,254,49,30,88,255,179,27,36,255,165,140,183,0,58,189,151,0,88,31,0,0,75,169,66,0,66,101,199,255,24,216,199,1,121,196,26,255,14,79,203,254,240,226,81,255,94,28,10,255,83,193,240,255,204,193,131,255,94,15,86,0,218,40,157,0,51,193,209,0,0,242,177,0,102,185,247,0,158,109,116,0,38,135,91,0,223,175,149,0,220,66,1,255,86,60,232,0,25,96,37,255,225,122,162,1,215,187,168,255,158,157,46,0,56,171,162,0,232,240,101,1,122,22,9,0,51,9,21,255,53,25,238,255,217,30,232,254,125,169,148,0,13,232,102,0,148,9,37,0,165,97,141,1,228,131,41,0,222,15,243,255,254,18,17,0,6,60,237,1,106,3,113,0,59,132,189,0,92,112,30,0,105,208,213,0,48,84,179,255,187,121,231,254,27,216,109,255,162,221,107,254,73,239,195,255,250,31,57,255,149,135,89,255,185,23,115,1,3,163,157,255,18,112,250,0,25,57,187,255,161,96,164,0,47,16,243,0,12,141,251,254,67,234,184,255,41,18,161,0,175,6,96,255,160,172,52,254,24,176,183,255,198,193,85,1,124,121,137,255,151,50,114,255,220,203,60,255,207,239,5,1,0,38,107,255,55,238,94,254,70,152,94,0,213,220,77,1,120,17,69,255,85,164,190,255,203,234,81,0,38,49,37,254,61,144,124,0,137,78,49,254,168,247,48,0,95,164,252,0,105,169,135,0,253,228,134,0,64,166,75,0,81,73,20,255,207,210,10,0,234,106,150,255,94,34,90,255,254,159,57,254,220,133,99,0,139,147,180,254,24,23,185,0,41,57,30,255,189,97,76,0,65,187,223,255,224,172,37,255,34,62,95,1,231,144,240,0,77,106,126,254,64,152,91,0,29,98,155,0,226,251,53,255,234,211,5,255,144,203,222,255,164,176,221,254,5,231,24,0,179,122,205,0,36,1,134,255,125,70,151,254,97,228,252,0,172,129,23,254,48,90,209,255,150,224,82,1,84,134,30,0,241,196,46,0,103,113,234,255,46,101,121,254,40,124,250,255,135,45,242,254,9,249,168,255,140,108,131,255,143,163,171,0,50,173,199,255,88,222,142,255,200,95,158,0,142,192,163,255,7,117,135,0,111,124,22,0,236,12,65,254,68,38,65,255,227,174,254,0,244,245,38,0,240,50,208,255,161,63,250,0,60,209,239,0,122,35,19,0,14,33,230,254,2,159,113,0,106,20,127,255,228,205,96,0,137,210,174,254,180,212,144,255,89,98,154,1,34,88,139,0,167,162,112,1,65,110,197,0,241,37,169,0,66,56,131,255,10,201,83,254,133,253,187,255,177,112,45,254,196,251,0,0,196,250,151,255,238,232,214,255,150,209,205,0,28,240,118,0,71,76,83,1,236,99,91,0,42,250,131,1,96,18,64,255,118,222,35,0,113,214,203,255,122,119,184,255,66,19,36,0,204,64,249,0,146,89,139,0,134,62,135,1,104,233,101,0,188,84,26,0,49,249,129,0,208,214,75,255,207,130,77,255,115,175,235,0,171,2,137,255,175,145,186,1,55,245,135,255,154,86,181,1,100,58,246,255,109,199,60,255,82,204,134,255,215,49,230,1,140,229,192,255,222,193,251,255,81,136,15,255,179,149,162,255,23,39,29,255,7,95,75,254,191,81,222,0,241,81,90,255,107,49,201,255,244,211,157,0,222,140,149,255,65,219,56,254,189,246,90,255,178,59,157,1,48,219,52,0,98,34,215,0,28,17,187,255,175,169,24,0,92,79,161,255,236,200,194,1,147,143,234,0,229,225,7,1,197,168,14,0,235,51,53,1,253,120,174,0,197,6,168,255,202,117,171,0,163,21,206,0,114,85,90,255,15,41,10,255,194,19,99,0,65,55,216,254,162,146,116,0,50,206,212,255,64,146,29,255,158,158,131,1,100,165,130,255,172,23,129,255,125,53,9,255,15,193,18,1,26,49,11,255,181,174,201,1,135,201,14,255,100,19,149,0,219,98,79,0,42,99,143,254,96,0,48,255,197,249,83,254,104,149,79,255,235,110,136,254,82,128,44,255,65,41,36,254,88,211,10,0,187,121,187,0,98,134,199,0,171,188,179,254,210,11,238,255,66,123,130,254,52,234,61,0,48,113,23,254,6,86,120,255,119,178,245,0,87,129,201,0,242,141,209,0,202,114,85,0,148,22,161,0,103,195,48,0,25,49,171,255,138,67,130,0,182,73,122,254,148,24,130,0,211,229,154,0,32,155,158,0,84,105,61,0,177,194,9,255,166,89,86,1,54,83,187,0,249,40,117,255,109,3,215,255,53,146,44,1,63,47,179,0,194,216,3,254,14,84,136,0,136,177,13,255,72,243,186,255,117,17,125,255,211,58,211,255,93,79,223,0,90,88,245,255,139,209,111,255,70,222,47,0,10,246,79,255,198,217,178,0,227,225,11,1,78,126,179,255,62,43,126,0,103,148,35,0,129,8,165,254,245,240,148,0,61,51,142,0,81,208,134,0,15,137,115,255,211,119,236,255,159,245,248,255,2,134,136,255,230,139,58,1,160,164,254,0,114,85,141,255,49,166,182,255,144,70,84,1,85,182,7,0,46,53,93,0,9,166,161,255,55,162,178,255,45,184,188,0,146,28,44,254,169,90,49,0,120,178,241,1,14,123,127,255,7,241,199,1,189,66,50,255,198,143,101,254,189,243,135,255,141,24,24,254,75,97,87,0,118,251,154,1,237,54,156,0,171,146,207,255,131,196,246,255,136,64,113,1,151,232,57,0,240,218,115,0,49,61,27,255,64,129,73,1,252,169,27,255,40,132,10,1,90,201,193,255,252,121,240,1,186,206,41,0,43,198,97,0,145,100,183,0,204,216,80,254,172,150,65,0,249,229,196,254,104,123,73,255,77,104,96,254,130,180,8,0,104,123,57,0,220,202,229,255,102,249,211,0,86,14,232,255,182,78,209,0,239,225,164,0,106,13,32,255,120,73,17,255,134,67,233,0,83,254,181,0,183,236,112,1,48,64,131,255,241,216,243,255,65,193,226,0,206,241,100,254,100,134,166,255,237,202,197,0,55,13,81,0,32,124,102,255,40,228,177,0,118,181,31,1,231,160,134,255,119,187,202,0,0,142,60,255,128,38,189,255,166,201,150,0,207,120,26,1,54,184,172,0,12,242,204,254,133,66,230,0,34,38,31,1,184,112,80,0,32,51,165,254,191,243,55,0,58,73,146,254,155,167,205,255,100,104,152,255,197,254,207,255,173,19,247,0,238,10,202,0,239,151,242,0,94,59,39,255,240,29,102,255,10,92,154,255,229,84,219,255,161,129,80,0,208,90,204,1,240,219,174,255,158,102,145,1,53,178,76,255,52,108,168,1,83,222,107,0,211,36,109,0,118,58,56,0,8,29,22,0,237,160,199,0,170,209,157,0,137,71,47,0,143,86,32,0,198,242,2,0,212,48,136,1,92,172,186,0,230,151,105,1,96,191,229,0,138,80,191,254,240,216,130,255,98,43,6,254,168,196,49,0,253,18,91,1,144,73,121,0,61,146,39,1,63,104,24,255,184,165,112,254,126,235,98,0,80,213,98,255,123,60,87,255,82,140,245,1,223,120,173,255,15,198,134,1,206,60,239,0,231,234,92,255,33,238,19,255,165,113,142,1,176,119,38,0,160,43,166,254,239,91,105,0,107,61,194,1,25,4,68,0,15,139,51,0,164,132,106,255,34,116,46,254,168,95,197,0,137,212,23,0,72,156,58,0,137,112,69,254,150,105,154,255,236,201,157,0,23,212,154,255,136,82,227,254,226,59,221,255,95,149,192,0,81,118,52,255,33,43,215,1,14,147,75,255,89,156,121,254,14,18,79,0,147,208,139,1,151,218,62,255,156,88,8,1,210,184,98,255,20,175,123,255,102,83,229,0,220,65,116,1,150,250,4,255,92,142,220,255,34,247,66,255,204,225,179,254,151,81,151,0,71,40,236,255,138,63,62,0,6,79,240,255,183,185,181,0,118,50,27,0,63,227,192,0,123,99,58,1,50,224,155,255,17,225,223,254,220,224,77,255,14,44,123,1,141,128,175,0,248,212,200,0,150,59,183,255,147,97,29,0,150,204,181,0,253,37,71,0,145,85,119,0,154,200,186,0,2,128,249,255,83,24,124,0,14,87,143,0,168,51,245,1,124,151,231,255,208,240,197,1,124,190,185,0,48,58,246,0,20,233,232,0,125,18,98,255,13,254,31,255,245,177,130,255,108,142,35,0,171,125,242,254,140,12,34,255,165,161,162,0,206,205,101,0,247,25,34,1,100,145,57,0,39,70,57,0,118,204,203,255,242,0,162,0,165,244,30,0,198,116,226,0,128,111,153,255,140,54,182,1,60,122,15,255,155,58,57,1,54,50,198,0,171,211,29,255,107,138,167,255,173,107,199,255,109,161,193,0,89,72,242,255,206,115,89,255,250,254,142,254,177,202,94,255,81,89,50,0,7,105,66,255,25,254,255,254,203,64,23,255,79,222,108,255,39,249,75,0,241,124,50,0,239,152,133,0,221,241,105,0,147,151,98,0,213,161,121,254,242,49,137,0,233,37,249,254,42,183,27,0,184,119,230,255,217,32,163,255,208,251,228,1,137,62,131,255,79,64,9,254,94,48,113,0,17,138,50,254,193,255,22,0,247,18,197,1,67,55,104,0,16,205,95,255,48,37,66,0,55,156,63,1,64,82,74,255,200,53,71,254,239,67,125,0,26,224,222,0,223,137,93,255,30,224,202,255,9,220,132,0,198,38,235,1,102,141,86,0,60,43,81,1,136,28,26,0,233,36,8,254,207,242,148,0,164,162,63,0,51,46,224,255,114,48,79,255,9,175,226,0,222,3,193,255,47,160,232,255,255,93,105,254,14,42,230,0,26,138,82,1,208,43,244,0,27,39,38,255,98,208,127,255,64,149,182,255,5,250,209,0,187,60,28,254,49,25,218,255,169,116,205,255,119,18,120,0,156,116,147,255,132,53,109,255,13,10,202,0,110,83,167,0,157,219,137,255,6,3,130,255,50,167,30,255,60,159,47,255,129,128,157,254,94,3,189,0,3,166,68,0,83,223,215,0,150,90,194,1,15,168,65,0,227,83,51,255,205,171,66,255,54,187,60,1,152,102,45,255,119,154,225,0,240,247,136,0,100,197,178,255,139,71,223,255,204,82,16,1,41,206,42,255,156,192,221,255,216,123,244,255,218,218,185,255,187,186,239,255,252,172,160,255,195,52,22,0,144,174,181,254,187,100,115,255,211,78,176,255,27,7,193,0,147,213,104,255,90,201,10,255,80,123,66,1,22,33,186,0,1,7,99,254,30,206,10,0,229,234,5,0,53,30,210,0,138,8,220,254,71,55,167,0,72,225,86,1,118,190,188,0,254,193,101,1,171,249,172,255,94,158,183,254,93,2,108,255,176,93,76,255,73,99,79,255,74,64,129,254,246,46,65,0,99,241,127,254,246,151,102,255,44,53,208,254,59,102,234,0,154,175,164,255,88,242,32,0,111,38,1,0,255,182,190,255,115,176,15,254,169,60,129,0,122,237,241,0,90,76,63,0,62,74,120,255,122,195,110,0,119,4,178,0,222,242,210,0,130,33,46,254,156,40,41,0,167,146,112,1,49,163,111,255,121,176,235,0,76,207,14,255,3,25,198,1,41,235,213,0,85,36,214,1,49,92,109,255,200,24,30,254,168,236,195,0,145,39,124,1,236,195,149,0,90,36,184,255,67,85,170,255,38,35,26,254,131,124,68,255,239,155,35,255,54,201,164,0,196,22,117,255,49,15,205,0,24,224,29,1,126,113,144,0,117,21,182,0,203,159,141,0,223,135,77,0,176,230,176,255,190,229,215,255,99,37,181,255,51,21,138,255,25,189,89,255,49,48,165,254,152,45,247,0,170,108,222,0,80,202,5,0,27,69,103,254,204,22,129,255,180,252,62,254,210,1,91,255,146,110,254,255,219,162,28,0,223,252,213,1,59,8,33,0,206,16,244,0,129,211,48,0,107,160,208,0,112,59,209,0,109,77,216,254,34,21,185,255,246,99,56,255,179,139,19,255,185,29,50,255,84,89,19,0,74,250,98,255,225,42,200,255,192,217,205,255,210,16,167,0,99,132,95,1,43,230,57,0,254,11,203,255,99,188,63,255,119,193,251,254,80,105,54,0,232,181,189,1,183,69,112,255,208,171,165,255,47,109,180,255,123,83,165,0,146,162,52,255,154,11,4,255,151,227,90,255,146,137,97,254,61,233,41,255,94,42,55,255,108,164,236,0,152,68,254,0,10,140,131,255,10,106,79,254,243,158,137,0,67,178,66,254,177,123,198,255,15,62,34,0,197,88,42,255,149,95,177,255,152,0,198,255,149,254,113,255,225,90,163,255,125,217,247,0,18,17,224,0,128,66,120,254,192,25,9,255,50,221,205,0,49,212,70,0,233,255,164,0,2,209,9,0,221,52,219,254,172,224,244,255,94,56,206,1,242,179,2,255,31,91,164,1,230,46,138,255,189,230,220,0,57,47,61,255,111,11,157,0,177,91,152,0,28,230,98,0,97,87,126,0,198,89,145,255,167,79,107,0,249,77,160,1,29,233,230,255,150,21,86,254,60,11,193,0,151,37,36,254,185,150,243,255,228,212,83,1,172,151,180,0,201,169,155,0,244,60,234,0,142,235,4,1,67,218,60,0,192,113,75,1,116,243,207,255,65,172,155,0,81,30,156,255,80,72,33,254,18,231,109,255,142,107,21,254,125,26,132,255,176,16,59,255,150,201,58,0,206,169,201,0,208,121,226,0,40,172,14,255,150,61,94,255,56,57,156,255,141,60,145,255,45,108,149,255,238,145,155,255,209,85,31,254,192,12,210,0,99,98,93,254,152,16,151,0,225,185,220,0,141,235,44,255,160,172,21,254,71,26,31,255,13,64,93,254,28,56,198,0,177,62,248,1,182,8,241,0,166,101,148,255,78,81,133,255,129,222,215,1,188,169,129,255,232,7,97,0,49,112,60,255,217,229,251,0,119,108,138,0,39,19,123,254,131,49,235,0,132,84,145,0,130,230,148,255,25,74,187,0,5,245,54,255,185,219,241,1,18,194,228,255,241,202,102,0,105,113,202,0,155,235,79,0,21,9,178,255,156,1,239,0,200,148,61,0,115,247,210,255,49,221,135,0,58,189,8,1,35,46,9,0,81,65,5,255,52,158,185,255,125,116,46,255,74,140,13,255,210,92,172,254,147,23,71,0,217,224,253,254,115,108,180,255,145,58,48,254,219,177,24,255,156,255,60,1,154,147,242,0,253,134,87,0,53,75,229,0,48,195,222,255,31,175,50,255,156,210,120,255,208,35,222,255,18,248,179,1,2,10,101,255,157,194,248,255,158,204,101,255,104,254,197,255,79,62,4,0,178,172,101,1,96,146,251,255,65,10,156,0,2,137,165,255,116,4,231,0,242,215,1,0,19,35,29,255,43,161,79,0,59,149,246,1,251,66,176,0,200,33,3,255,80,110,142,255,195,161,17,1,228,56,66,255,123,47,145,254,132,4,164,0,67,174,172,0,25,253,114,0,87,97,87,1,250,220,84,0,96,91,200,255,37,125,59,0,19,65,118,0,161,52,241,255,237,172,6,255,176,191,255,255,1,65,130,254,223,190,230,0,101,253,231,255,146,35,109,0,250,29,77,1,49,0,19,0,123,90,155,1,22,86,32,255,218,213,65,0,111,93,127,0,60,93,169,255,8,127,182,0,17,186,14,254,253,137,246,255,213,25,48,254,76,238,0,255,248,92,70,255,99,224,139,0,184,9,255,1,7,164,208,0,205,131,198,1,87,214,199,0,130,214,95,0,221,149,222,0,23,38,171,254,197,110,213,0,43,115,140,254,215,177,118,0,96,52,66,1,117,158,237,0,14,64,182,255,46,63,174,255,158,95,190,255,225,205,177,255,43,5,142,255,172,99,212,255,244,187,147,0,29,51,153,255,228,116,24,254,30,101,207,0,19,246,150,255,134,231,5,0,125,134,226,1,77,65,98,0,236,130,33,255,5,110,62,0,69,108,127,255,7,113,22,0,145,20,83,254,194,161,231,255,131,181,60,0,217,209,177,255,229,148,212,254,3,131,184,0,117,177,187,1,28,14,31,255,176,102,80,0,50,84,151,255,125,31,54,255,21,157,133,255,19,179,139,1,224,232,26,0,34,117,170,255,167,252,171,255,73,141,206,254,129,250,35,0,72,79,236,1,220,229,20,255,41,202,173,255,99,76,238,255,198,22,224,255,108,198,195,255,36,141,96,1,236,158,59,255,106,100,87,0,110,226,2,0,227,234,222,0,154,93,119,255,74,112,164,255,67,91,2,255,21,145,33,255,102,214,137,255,175,230,103,254,163,246,166,0,93,247,116,254,167,224,28,255,220,2,57,1,171,206,84,0,123,228,17,255,27,120,119,0,119,11,147,1,180,47,225,255,104,200,185,254,165,2,114,0,77,78,212,0,45,154,177,255,24,196,121,254,82,157,182,0,90,16,190,1,12,147,197,0,95,239,152,255,11,235,71,0,86,146,119,255,172,134,214,0,60,131,196,0,161,225,129,0,31,130,120,254,95,200,51,0,105,231,210,255,58,9,148,255,43,168,221,255,124,237,142,0,198,211,50,254,46,245,103,0,164,248,84,0,152,70,208,255,180,117,177,0,70,79,185,0,243,74,32,0,149,156,207,0,197,196,161,1,245,53,239,0,15,93,246,254,139,240,49,255,196,88,36,255,162,38,123,0,128,200,157,1,174,76,103,255,173,169,34,254,216,1,171,255,114,51,17,0,136,228,194,0,110,150,56,254,106,246,159,0,19,184,79,255,150,77,240,255,155,80,162,0,0,53,169,255,29,151,86,0,68,94,16,0,92,7,110,254,98,117,149,255,249,77,230,255,253,10,140,0,214,124,92,254,35,118,235,0,89,48,57,1,22,53,166,0,184,144,61,255,179,255,194,0,214,248,61,254,59,110,246,0,121,21,81,254,166,3,228,0,106,64,26,255,69,232,134,255,242,220,53,254,46,220,85,0,113,149,247,255,97,179,103,255,190,127,11,0,135,209,182,0,95,52,129,1,170,144,206,255,122,200,204,255,168,100,146,0,60,144,149,254,70,60,40,0,122,52,177,255,246,211,101,255,174,237,8,0,7,51,120,0,19,31,173,0,126,239,156,255,143,189,203,0,196,128,88,255,233,133,226,255,30,125,173,255,201,108,50,0,123,100,59,255,254,163,3,1,221,148,181,255,214,136,57,254,222,180,137,255,207,88,54,255,28,33,251,255,67,214,52,1,210,208,100,0,81,170,94,0,145,40,53,0,224,111,231,254,35,28,244,255,226,199,195,254,238,17,230,0,217,217,164,254,169,157,221,0,218,46,162,1,199,207,163,255,108,115,162,1,14,96,187,255,118,60,76,0,184,159,152,0,209,231,71,254,42,164,186,255,186,153,51,254,221,171,182,255,162,142,173,0,235,47,193,0,7,139,16,1,95,164,64,255,16,221,166,0,219,197,16,0,132,29,44,255,100,69,117,255,60,235,88,254,40,81,173,0,71,190,61,255,187,88,157,0,231,11,23,0,237,117,164,0,225,168,223,255,154,114,116,255,163,152,242,1,24,32,170,0,125,98,113,254,168,19,76,0,17,157,220,254,155,52,5,0,19,111,161,255,71,90,252,255,173,110,240,0,10,198,121,255,253,255,240,255,66,123,210,0,221,194,215,254,121,163,17,255,225,7,99,0,190,49,182,0,115,9,133,1,232,26,138,255,213,68,132,0,44,119,122,255,179,98,51,0,149,90,106,0,71,50,230,255,10,153,118,255,177,70,25,0,165,87,205,0,55,138,234,0,238,30,97,0,113,155,207,0,98,153,127,0,34,107,219,254,117,114,172,255,76,180,255,254,242,57,179,255,221,34,172,254,56,162,49,255,83,3,255,255,113,221,189,255,188,25,228,254,16,88,89,255,71,28,198,254,22,17,149,255,243,121,254,255,107,202,99,255,9,206,14,1,220,47,153,0,107,137,39,1,97,49,194,255,149,51,197,254,186,58,11,255,107,43,232,1,200,6,14,255,181,133,65,254,221,228,171,255,123,62,231,1,227,234,179,255,34,189,212,254,244,187,249,0,190,13,80,1,130,89,1,0,223,133,173,0,9,222,198,255,66,127,74,0,167,216,93,255,155,168,198,1,66,145,0,0,68,102,46,1,172,90,154,0,216,128,75,255,160,40,51,0,158,17,27,1,124,240,49,0,236,202,176,255,151,124,192,255,38,193,190,0,95,182,61,0,163,147,124,255,255,165,51,255,28,40,17,254,215,96,78,0,86,145,218,254,31,36,202,255,86,9,5,0,111,41,200,255,237,108,97,0,57,62,44,0,117,184,15,1,45,241,116,0,152,1,220,255,157,165,188,0,250,15,131,1,60,44,125,255,65,220,251,255,75,50,184,0,53,90,128,255,231,80,194,255,136,129,127,1,21,18,187,255,45,58,161,255,71,147,34,0,174,249,11,254,35,141,29,0,239,68,177,255,115,110,58,0,238,190,177,1,87,245,166,255,190,49,247,255,146,83,184,255,173,14,39,255,146,215,104,0,142,223,120,0,149,200,155,255,212,207,145,1,16,181,217,0,173,32,87,255,255,35,181,0,119,223,161,1,200,223,94,255,70,6,186,255,192,67,85,255,50,169,152,0,144,26,123,255,56,243,179,254,20,68,136,0,39,140,188,254,253,208,5,255,200,115,135,1,43,172,229,255,156,104,187,0,151,251,167,0,52,135,23,0,151,153,72,0,147,197,107,254,148,158,5,255,238,143,206,0,126,153,137,255,88,152,197,254,7,68,167,0,252,159,165,255,239,78,54,255,24,63,55,255,38,222,94,0,237,183,12,255,206,204,210,0,19,39,246,254,30,74,231,0,135,108,29,1,179,115,0,0,117,118,116,1,132,6,252,255,145,129,161,1,105,67,141,0,82,37,226,255,238,226,228,255,204,214,129,254,162,123,100,255,185,121,234,0,45,108,231,0,66,8,56,255,132,136,128,0,172,224,66,254,175,157,188,0,230,223,226,254,242,219,69,0,184,14,119,1,82,162,56,0,114,123,20,0,162,103,85,255,49,239,99,254,156,135,215,0,111,255,167,254,39,196,214,0,144,38,79,1,249,168,125,0,155,97,156,255,23,52,219,255,150,22,144,0,44,149,165,255,40,127,183,0,196,77,233,255,118,129,210,255,170,135,230,255,214,119,198,0,233,240,35,0,253,52,7,255,117,102,48,255,21,204,154,255,179,136,177,255,23,2,3,1,149,130,89,255,252,17,159,1,70,60,26,0,144,107,17,0,180,190,60,255,56,182,59,255,110,71,54,255,198,18,129,255,149,224,87,255,223,21,152,255,138,22,182,255,250,156,205,0,236,45,208,255,79,148,242,1,101,70,209,0,103,78,174,0,101,144,172,255,152,136,237,1,191,194,136,0,113,80,125,1,152,4,141,0,155,150,53,255,196,116,245,0,239,114,73,254,19,82,17,255,124,125,234,255,40,52,191,0,42,210,158,255,155,132,165,0,178,5,42,1,64,92,40,255,36,85,77,255,178,228,118,0,137,66,96,254,115,226,66,0,110,240,69,254,151,111,80,0,167,174,236,255,227,108,107,255,188,242,65,255,183,81,255,0,57,206,181,255,47,34,181,255,213,240,158,1,71,75,95,0,156,40,24,255,102,210,81,0,171,199,228,255,154,34,41,0,227,175,75,0,21,239,195,0,138,229,95,1,76,192,49,0,117,123,87,1,227,225,130,0,125,62,63,255,2,198,171,0,254,36,13,254,145,186,206,0,148,255,244,255,35,0,166,0,30,150,219,1,92,228,212,0,92,198,60,254,62,133,200,255,201,41,59,0,125,238,109,255,180,163,238,1,140,122,82,0,9,22,88,255,197,157,47,255,153,94,57,0,88,30,182,0,84,161,85,0,178,146,124,0,166,166,7,255,21,208,223,0,156,182,242,0,155,121,185,0,83,156,174,254,154,16,118,255,186,83,232,1,223,58,121,255,29,23,88,0,35,125,127,255,170,5,149,254,164,12,130,255,155,196,29,0,161,96,136,0,7,35,29,1,162,37,251,0,3,46,242,255,0,217,188,0,57,174,226,1,206,233,2,0,57,187,136,254,123,189,9,255,201,117,127,255,186,36,204,0,231,25,216,0,80,78,105,0,19,134,129,255,148,203,68,0,141,81,125,254,248,165,200,255,214,144,135,0,151,55,166,255,38,235,91,0,21,46,154,0,223,254,150,255,35,153,180,255,125,176,29,1,43,98,30,255,216,122,230,255,233,160,12,0,57,185,12,254,240,113,7,255,5,9,16,254,26,91,108,0,109,198,203,0,8,147,40,0,129,134,228,255,124,186,40,255,114,98,132,254,166,132,23,0,99,69,44,0,9,242,238,255,184,53,59,0,132,129,102,255,52,32,243,254,147,223,200,255,123,83,179,254,135,144,201,255,141,37,56,1,151,60,227,255,90,73,156,1,203,172,187,0,80,151,47,255,94,137,231,255,36,191,59,255,225,209,181,255,74,215,213,254,6,118,179,255,153,54,193,1,50,0,231,0,104,157,72,1,140,227,154,255,182,226,16,254,96,225,92,255,115,20,170,254,6,250,78,0,248,75,173,255,53,89,6,255,0,180,118,0,72,173,1,0,64,8,206,1,174,133,223,0,185,62,133,255,214,11,98,0,197,31,208,0,171,167,244,255,22,231,181,1,150,218,185,0,247,169,97,1,165,139,247,255,47,120,149,1,103,248,51,0,60,69,28,254,25,179,196,0,124,7,218,254,58,107,81,0,184,233,156,255,252,74,36,0,118,188,67,0,141,95,53,255,222,94,165,254,46,61,53,0,206,59,115,255,47,236,250,255,74,5,32,1,129,154,238,255,106,32,226,0,121,187,61,255,3,166,241,254,67,170,172,255,29,216,178,255,23,201,252,0,253,110,243,0,200,125,57,0,109,192,96,255,52,115,238,0,38,121,243,255,201,56,33,0,194,118,130,0,75,96,25,255,170,30,230,254,39,63,253,0,36,45,250,255,251,1,239,0,160,212,92,1,45,209,237,0,243,33,87,254,237,84,201,255,212,18,157,254,212,99,127,255,217,98,16,254,139,172,239,0,168,201,130,255,143,193,169,255,238,151,193,1,215,104,41,0,239,61,165,254,2,3,242,0,22,203,177,254,177,204,22,0,149,129,213,254,31,11,41,255,0,159,121,254,160,25,114,255,162,80,200,0,157,151,11,0,154,134,78,1,216,54,252,0,48,103,133,0,105,220,197,0,253,168,77,254,53,179,23,0,24,121,240,1,255,46,96,255,107,60,135,254,98,205,249,255,63,249,119,255,120,59,211,255,114,180,55,254,91,85,237,0,149,212,77,1,56,73,49,0,86,198,150,0,93,209,160,0,69,205,182,255,244,90,43,0,20,36,176,0,122,116,221,0,51,167,39,1,231,1,63,255,13,197,134,0,3,209,34,255,135,59,202,0,167,100,78,0,47,223,76,0,185,60,62,0,178,166,123,1,132,12,161,255,61,174,43,0,195,69,144,0,127,47,191,1,34,44,78,0,57,234,52,1,255,22,40,255,246,94,146,0,83,228,128,0,60,78,224,255,0,96,210,255,153,175,236,0,159,21,73,0,180,115,196,254,131,225,106,0,255,167,134,0,159,8,112,255,120,68,194,255,176,196,198,255,118,48,168,255,93,169,1,0,112,200,102,1,74,24,254,0,19,141,4,254,142,62,63,0,131,179,187,255,77,156,155,255,119,86,164,0,170,208,146,255,208,133,154,255,148,155,58,255,162,120,232,254,252,213,155,0,241,13,42,0,94,50,131,0,179,170,112,0,140,83,151,255,55,119,84,1,140,35,239,255,153,45,67,1,236,175,39,0,54,151,103,255,158,42,65,255,196,239,135,254,86,53,203,0,149,97,47,254,216,35,17,255,70,3,70,1,103,36,90,255,40,26,173,0,184,48,13,0,163,219,217,255,81,6,1,255,221,170,108,254,233,208,93,0,100,201,249,254,86,36,35,255,209,154,30,1,227,201,251,255,2,189,167,254,100,57,3,0,13,128,41,0,197,100,75,0,150,204,235,255,145,174,59,0,120,248,149,255,85,55,225,0,114,210,53,254,199,204,119,0,14,247,74,1,63,251,129,0,67,104,151,1,135,130,80,0,79,89,55,255,117,230,157,255,25,96,143,0,213,145,5,0,69,241,120,1,149,243,95,255,114,42,20,0,131,72,2,0,154,53,20,255,73,62,109,0,196,102,152,0,41,12,204,255,122,38,11,1,250,10,145,0,207,125,148,0,246,244,222,255,41,32,85,1,112,213,126,0,162,249,86,1,71,198,127,255,81,9,21,1,98,39,4,255,204,71,45,1,75,111,137,0,234,59,231,0,32,48,95,255,204,31,114,1,29,196,181,255,51,241,167,254,93,109,142,0,104,144,45,0,235,12,181,255,52,112,164,0,76,254,202,255,174,14,162,0,61,235,147,255,43,64,185,254,233,125,217,0,243,88,167,254,74,49,8,0,156,204,66,0,124,214,123,0,38,221,118,1,146,112,236,0,114,98,177,0,151,89,199,0,87,197,112,0,185,149,161,0,44,96,165,0,248,179,20,255,188,219,216,254,40,62,13,0,243,142,141,0,229,227,206,255,172,202,35,255,117,176,225,255,82,110,38,1,42,245,14,255,20,83,97,0,49,171,10,0,242,119,120,0,25,232,61,0,212,240,147,255,4,115,56,255,145,17,239,254,202,17,251,255,249,18,245,255,99,117,239,0,184,4,179,255,246,237,51,255,37,239,137,255,166,112,166,255,81,188,33,255,185,250,142,255,54,187,173,0,208,112,201,0,246,43,228,1,104,184,88,255,212,52,196,255,51,117,108,255,254,117,155,0,46,91,15,255,87,14,144,255,87,227,204,0,83,26,83,1,159,76,227,0,159,27,213,1,24,151,108,0,117,144,179,254,137,209,82,0,38,159,10,0,115,133,201,0,223,182,156,1,110,196,93,255,57,60,233,0,5,167,105,255,154,197,164,0,96,34,186,255,147,133,37,1,220,99,190,0,1,167,84,255,20,145,171,0,194,197,251,254,95,78,133,255,252,248,243,255,225,93,131,255,187,134,196,255,216,153,170,0,20,118,158,254,140,1,118,0,86,158,15,1,45,211,41,255,147,1,100,254,113,116,76,255,211,127,108,1,103,15,48,0,193,16,102,1,69,51,95,255,107,128,157,0,137,171,233,0,90,124,144,1,106,161,182,0,175,76,236,1,200,141,172,255,163,58,104,0,233,180,52,255,240,253,14,255,162,113,254,255,38,239,138,254,52,46,166,0,241,101,33,254,131,186,156,0,111,208,62,255,124,94,160,255,31,172,254,0,112,174,56,255,188,99,27,255,67,138,251,0,125,58,128,1,156,152,174,255,178,12,247,255,252,84,158,0,82,197,14,254,172,200,83,255,37,39,46,1,106,207,167,0,24,189,34,0,131,178,144,0,206,213,4,0,161,226,210,0,72,51,105,255,97,45,187,255,78,184,223,255,176,29,251,0,79,160,86,255,116,37,178,0,82,77,213,1,82,84,141,255,226,101,212,1,175,88,199,255,245,94,247,1,172,118,109,255,166,185,190,0,131,181,120,0,87,254,93,255,134,240,73,255,32,245,143,255,139,162,103,255,179,98,18,254,217,204,112,0,147,223,120,255,53,10,243,0,166,140,150,0,125,80,200,255,14,109,219,255,91,218,1,255,252,252,47,254,109,156,116,255,115,49,127,1,204,87,211,255,148,202,217,255,26,85,249,255,14,245,134,1,76,89,169,255,242,45,230,0,59,98,172,255,114,73,132,254,78,155,49,255,158,126,84,0,49,175,43,255,16,182,84,255,157,103,35,0,104,193,109,255,67,221,154,0,201,172,1,254,8,162,88,0,165,1,29,255,125,155,229,255,30,154,220,1,103,239,92,0,220,1,109,255,202,198,1,0,94,2,142,1,36,54,44,0,235,226,158,255,170,251,214,255,185,77,9,0,97,74,242,0,219,163,149,255,240,35,118,255,223,114,88,254,192,199,3,0,106,37,24,255,201,161,118,255,97,89,99,1,224,58,103,255,101,199,147,254,222,60,99,0,234,25,59,1,52,135,27,0,102,3,91,254,168,216,235,0,229,232,136,0,104,60,129,0,46,168,238,0,39,191,67,0,75,163,47,0,143,97,98,255,56,216,168,1,168,233,252,255,35,111,22,255,92,84,43,0,26,200,87,1,91,253,152,0,202,56,70,0,142,8,77,0,80,10,175,1,252,199,76,0,22,110,82,255,129,1,194,0,11,128,61,1,87,14,145,255,253,222,190,1,15,72,174,0,85,163,86,254,58,99,44,255,45,24,188,254,26,205,15,0,19,229,210,254,248,67,195,0,99,71,184,0,154,199,37,255,151,243,121,255,38,51,75,255,201,85,130,254,44,65,250,0,57,147,243,254,146,43,59,255,89,28,53,0,33,84,24,255,179,51,18,254,189,70,83,0,11,156,179,1,98,134,119,0,158,111,111,0,119,154,73,255,200,63,140,254,45,13,13,255,154,192,2,254,81,72,42,0,46,160,185,254,44,112,6,0,146,215,149,1,26,176,104,0,68,28,87,1,236,50,153,255,179,128,250,254,206,193,191,255,166,92,137,254,53,40,239,0,210,1,204,254,168,173,35,0,141,243,45,1,36,50,109,255,15,242,194,255,227,159,122,255,176,175,202,254,70,57,72,0,40,223,56,0,208,162,58,255,183,98,93,0,15,111,12,0,30,8,76,255,132,127,246,255,45,242,103,0,69,181,15,255,10,209,30,0,3,179,121,0,241,232,218,1,123,199,88,255,2,210,202,1,188,130,81,255,94,101,208,1,103,36,45,0,76,193,24,1,95,26,241,255,165,162,187,0,36,114,140,0,202,66,5,255,37,56,147,0,152,11,243,1,127,85,232,255,250,135,212,1,185,177,113,0,90,220,75,255,69,248,146,0,50,111,50,0,92,22,80,0,244,36,115,254,163,100,82,255,25,193,6,1,127,61,36,0,253,67,30,254,65,236,170,255,161,17,215,254,63,175,140,0,55,127,4,0,79,112,233,0,109,160,40,0,143,83,7,255,65,26,238,255,217,169,140,255,78,94,189,255,0,147,190,255,147,71,186,254,106,77,127,255,233,157,233,1,135,87,237,255,208,13,236,1,155,109,36,255,180,100,218,0,180,163,18,0,190,110,9,1,17,63,123,255,179,136,180,255,165,123,123,255,144,188,81,254,71,240,108,255,25,112,11,255,227,218,51,255,167,50,234,255,114,79,108,255,31,19,115,255,183,240,99,0,227,87,143,255,72,217,248,255,102,169,95,1,129,149,149,0,238,133,12,1,227,204,35,0,208,115,26,1,102,8,234,0,112,88,143,1,144,249,14,0,240,158,172,254,100,112,119,0,194,141,153,254,40,56,83,255,121,176,46,0,42,53,76,255,158,191,154,0,91,209,92,0,173,13,16,1,5,72,226,255,204,254,149,0,80,184,207,0,100,9,122,254,118,101,171,255,252,203,0,254,160,207,54,0,56,72,249,1,56,140,13,255,10,64,107,254,91,101,52,255,225,181,248,1,139,255,132,0,230,145,17,0,233,56,23,0,119,1,241,255,213,169,151,255,99,99,9,254,185,15,191,255,173,103,109,1,174,13,251,255,178,88,7,254,27,59,68,255,10,33,2,255,248,97,59,0,26,30,146,1,176,147,10,0,95,121,207,1,188,88,24,0,185,94,254,254,115,55,201,0,24,50,70,0,120,53,6,0,142,66,146,0,228,226,249,255,104,192,222,1,173,68,219,0,162,184,36,255,143,102,137,255,157,11,23,0,125,45,98,0,235,93,225,254,56,112,160,255,70,116,243,1,153,249,55,255,129,39,17,1,241,80,244,0,87,69,21,1,94,228,73,255,78,66,65,255,194,227,231,0,61,146,87,255,173,155,23,255,112,116,219,254,216,38,11,255,131,186,133,0,94,212,187,0,100,47,91,0,204,254,175,255,222,18,215,254,173,68,108,255,227,228,79,255,38,221,213,0,163,227,150,254,31,190,18,0,160,179,11,1,10,90,94,255,220,174,88,0,163,211,229,255,199,136,52,0,130,95,221,255,140,188,231,254,139,113,128,255,117,171,236,254,49,220,20,255,59,20,171,255,228,109,188,0,20,225,32,254,195,16,174,0,227,254,136,1,135,39,105,0,150,77,206,255,210,238,226],\"i8\",ALLOC_NONE,Runtime.GLOBAL_BASE+10240);allocate([55,212,132,254,239,57,124,0,170,194,93,255,249,16,247,255,24,151,62,255,10,151,10,0,79,139,178,255,120,242,202,0,26,219,213,0,62,125,35,255,144,2,108,255,230,33,83,255,81,45,216,1,224,62,17,0,214,217,125,0,98,153,153,255,179,176,106,254,131,93,138,255,109,62,36,255,178,121,32,255,120,252,70,0,220,248,37,0,204,88,103,1,128,220,251,255,236,227,7,1,106,49,198,255,60,56,107,0,99,114,238,0,220,204,94,1,73,187,1,0,89,154,34,0,78,217,165,255,14,195,249,255,9,230,253,255,205,135,245,0,26,252,7,255,84,205,27,1,134,2,112,0,37,158,32,0,231,91,237,255,191,170,204,255,152,7,222,0,109,192,49,0,193,166,146,255,232,19,181,255,105,142,52,255,103,16,27,1,253,200,165,0,195,217,4,255,52,189,144,255,123,155,160,254,87,130,54,255,78,120,61,255,14,56,41,0,25,41,125,255,87,168,245,0,214,165,70,0,212,169,6,255,219,211,194,254,72,93,164,255,197,33,103,255,43,142,141,0,131,225,172,0,244,105,28,0,68,68,225,0,136,84,13,255,130,57,40,254,139,77,56,0,84,150,53,0,54,95,157,0,144,13,177,254,95,115,186,0,117,23,118,255,244,166,241,255,11,186,135,0,178,106,203,255,97,218,93,0,43,253,45,0,164,152,4,0,139,118,239,0,96,1,24,254,235,153,211,255,168,110,20,255,50,239,176,0,114,41,232,0,193,250,53,0,254,160,111,254,136,122,41,255,97,108,67,0,215,152,23,255,140,209,212,0,42,189,163,0,202,42,50,255,106,106,189,255,190,68,217,255,233,58,117,0,229,220,243,1,197,3,4,0,37,120,54,254,4,156,134,255,36,61,171,254,165,136,100,255,212,232,14,0,90,174,10,0,216,198,65,255,12,3,64,0,116,113,115,255,248,103,8,0,231,125,18,255,160,28,197,0,30,184,35,1,223,73,249,255,123,20,46,254,135,56,37,255,173,13,229,1,119,161,34,255,245,61,73,0,205,125,112,0,137,104,134,0,217,246,30,255,237,142,143,0,65,159,102,255,108,164,190,0,219,117,173,255,34,37,120,254,200,69,80,0,31,124,218,254,74,27,160,255,186,154,199,255,71,199,252,0,104,81,159,1,17,200,39,0,211,61,192,1,26,238,91,0,148,217,12,0,59,91,213,255,11,81,183,255,129,230,122,255,114,203,145,1,119,180,66,255,72,138,180,0,224,149,106,0,119,82,104,255,208,140,43,0,98,9,182,255,205,101,134,255,18,101,38,0,95,197,166,255,203,241,147,0,62,208,145,255,133,246,251,0,2,169,14,0,13,247,184,0,142,7,254,0,36,200,23,255,88,205,223,0,91,129,52,255,21,186,30,0,143,228,210,1,247,234,248,255,230,69,31,254,176,186,135,255,238,205,52,1,139,79,43,0,17,176,217,254,32,243,67,0,242,111,233,0,44,35,9,255,227,114,81,1,4,71,12,255,38,105,191,0,7,117,50,255,81,79,16,0,63,68,65,255,157,36,110,255,77,241,3,255,226,45,251,1,142,25,206,0,120,123,209,1,28,254,238,255,5,128,126,255,91,222,215,255,162,15,191,0,86,240,73,0,135,185,81,254,44,241,163,0,212,219,210,255,112,162,155,0,207,101,118,0,168,72,56,255,196,5,52,0,72,172,242,255,126,22,157,255,146,96,59,255,162,121,152,254,140,16,95,0,195,254,200,254,82,150,162,0,119,43,145,254,204,172,78,255,166,224,159,0,104,19,237,255,245,126,208,255,226,59,213,0,117,217,197,0,152,72,237,0,220,31,23,254,14,90,231,255,188,212,64,1,60,101,246,255,85,24,86,0,1,177,109,0,146,83,32,1,75,182,192,0,119,241,224,0,185,237,27,255,184,101,82,1,235,37,77,255,253,134,19,0,232,246,122,0,60,106,179,0,195,11,12,0,109,66,235,1,125,113,59,0,61,40,164,0,175,104,240,0,2,47,187,255,50,12,141,0,194,139,181,255,135,250,104,0,97,92,222,255,217,149,201,255,203,241,118,255,79,151,67,0,122,142,218,255,149,245,239,0,138,42,200,254,80,37,97,255,124,112,167,255,36,138,87,255,130,29,147,255,241,87,78,255,204,97,19,1,177,209,22,255,247,227,127,254,99,119,83,255,212,25,198,1,16,179,179,0,145,77,172,254,89,153,14,255,218,189,167,0,107,233,59,255,35,33,243,254,44,112,112,255,161,127,79,1,204,175,10,0,40,21,138,254,104,116,228,0,199,95,137,255,133,190,168,255,146,165,234,1,183,99,39,0,183,220,54,254,255,222,133,0,162,219,121,254,63,239,6,0,225,102,54,255,251,18,246,0,4,34,129,1,135,36,131,0,206,50,59,1,15,97,183,0,171,216,135,255,101,152,43,255,150,251,91,0,38,145,95,0,34,204,38,254,178,140,83,255,25,129,243,255,76,144,37,0,106,36,26,254,118,144,172,255,68,186,229,255,107,161,213,255,46,163,68,255,149,170,253,0,187,17,15,0,218,160,165,255,171,35,246,1,96,13,19,0,165,203,117,0,214,107,192,255,244,123,177,1,100,3,104,0,178,242,97,255,251,76,130,255,211,77,42,1,250,79,70,255,63,244,80,1,105,101,246,0,61,136,58,1,238,91,213,0,14,59,98,255,167,84,77,0,17,132,46,254,57,175,197,255,185,62,184,0,76,64,207,0,172,175,208,254,175,74,37,0,138,27,211,254,148,125,194,0,10,89,81,0,168,203,101,255,43,213,209,1,235,245,54,0,30,35,226,255,9,126,70,0,226,125,94,254,156,117,20,255,57,248,112,1,230,48,64,255,164,92,166,1,224,214,230,255,36,120,143,0,55,8,43,255,251,1,245,1,106,98,165,0,74,107,106,254,53,4,54,255,90,178,150,1,3,120,123,255,244,5,89,1,114,250,61,255,254,153,82,1,77,15,17,0,57,238,90,1,95,223,230,0,236,52,47,254,103,148,164,255,121,207,36,1,18,16,185,255,75,20,74,0,187,11,101,0,46,48,129,255,22,239,210,255,77,236,129,255,111,77,204,255,61,72,97,255,199,217,251,255,42,215,204,0,133,145,201,255,57,230,146,1,235,100,198,0,146,73,35,254,108,198,20,255,182,79,210,255,82,103,136,0,246,108,176,0,34,17,60,255,19,74,114,254,168,170,78,255,157,239,20,255,149,41,168,0,58,121,28,0,79,179,134,255,231,121,135,255,174,209,98,255,243,122,190,0,171,166,205,0,212,116,48,0,29,108,66,255,162,222,182,1,14,119,21,0,213,39,249,255,254,223,228,255,183,165,198,0,133,190,48,0,124,208,109,255,119,175,85,255,9,209,121,1,48,171,189,255,195,71,134,1,136,219,51,255,182,91,141,254,49,159,72,0,35,118,245,255,112,186,227,255,59,137,31,0,137,44,163,0,114,103,60,254,8,213,150,0,162,10,113,255,194,104,72,0,220,131,116,255,178,79,92,0,203,250,213,254,93,193,189,255,130,255,34,254,212,188,151,0,136,17,20,255,20,101,83,255,212,206,166,0,229,238,73,255,151,74,3,255,168,87,215,0,155,188,133,255,166,129,73,0,240,79,133,255,178,211,81,255,203,72,163,254,193,168,165,0,14,164,199,254,30,255,204,0,65,72,91,1,166,74,102,255,200,42,0,255,194,113,227,255,66,23,208,0,229,216,100,255,24,239,26,0,10,233,62,255,123,10,178,1,26,36,174,255,119,219,199,1,45,163,190,0,16,168,42,0,166,57,198,255,28,26,26,0,126,165,231,0,251,108,100,255,61,229,121,255,58,118,138,0,76,207,17,0,13,34,112,254,89,16,168,0,37,208,105,255,35,201,215,255,40,106,101,254,6,239,114,0,40,103,226,254,246,127,110,255,63,167,58,0,132,240,142,0,5,158,88,255,129,73,158,255,94,89,146,0,230,54,146,0,8,45,173,0,79,169,1,0,115,186,247,0,84,64,131,0,67,224,253,255,207,189,64,0,154,28,81,1,45,184,54,255,87,212,224,255,0,96,73,255,129,33,235,1,52,66,80,255,251,174,155,255,4,179,37,0,234,164,93,254,93,175,253,0,198,69,87,255,224,106,46,0,99,29,210,0,62,188,114,255,44,234,8,0,169,175,247,255,23,109,137,255,229,182,39,0,192,165,94,254,245,101,217,0,191,88,96,0,196,94,99,255,106,238,11,254,53,126,243,0,94,1,101,255,46,147,2,0,201,124,124,255,141,12,218,0,13,166,157,1,48,251,237,255,155,250,124,255,106,148,146,255,182,13,202,0,28,61,167,0,217,152,8,254,220,130,45,255,200,230,255,1,55,65,87,255,93,191,97,254,114,251,14,0,32,105,92,1,26,207,141,0,24,207,13,254,21,50,48,255,186,148,116,255,211,43,225,0,37,34,162,254,164,210,42,255,68,23,96,255,182,214,8,255,245,117,137,255,66,195,50,0,75,12,83,254,80,140,164,0,9,165,36,1,228,110,227,0,241,17,90,1,25,52,212,0,6,223,12,255,139,243,57,0,12,113,75,1,246,183,191,255,213,191,69,255,230,15,142,0,1,195,196,255,138,171,47,255,64,63,106,1,16,169,214,255,207,174,56,1,88,73,133,255,182,133,140,0,177,14,25,255,147,184,53,255,10,227,161,255,120,216,244,255,73,77,233,0,157,238,139,1,59,65,233,0,70,251,216,1,41,184,153,255,32,203,112,0,146,147,253,0,87,101,109,1,44,82,133,255,244,150,53,255,94,152,232,255,59,93,39,255,88,147,220,255,78,81,13,1,32,47,252,255,160,19,114,255,93,107,39,255,118,16,211,1,185,119,209,255,227,219,127,254,88,105,236,255,162,110,23,255,36,166,110,255,91,236,221,255,66,234,116,0,111,19,244,254,10,233,26,0,32,183,6,254,2,191,242,0,218,156,53,254,41,60,70,255,168,236,111,0,121,185,126,255,238,142,207,255,55,126,52,0,220,129,208,254,80,204,164,255,67,23,144,254,218,40,108,255,127,202,164,0,203,33,3,255,2,158,0,0,37,96,188,255,192,49,74,0,109,4,0,0,111,167,10,254,91,218,135,255,203,66,173,255,150,194,226,0,201,253,6,255,174,102,121,0,205,191,110,0,53,194,4,0,81,40,45,254,35,102,143,255,12,108,198,255,16,27,232,255,252,71,186,1,176,110,114,0,142,3,117,1,113,77,142,0,19,156,197,1,92,47,252,0,53,232,22,1,54,18,235,0,46,35,189,255,236,212,129,0,2,96,208,254,200,238,199,255,59,175,164,255,146,43,231,0,194,217,52,255,3,223,12,0,138,54,178,254,85,235,207,0,232,207,34,0,49,52,50,255,166,113,89,255,10,45,216,255,62,173,28,0,111,165,246,0,118,115,91,255,128,84,60,0,167,144,203,0,87,13,243,0,22,30,228,1,177,113,146,255,129,170,230,254,252,153,129,255,145,225,43,0,70,231,5,255,122,105,126,254,86,246,148,255,110,37,154,254,209,3,91,0,68,145,62,0,228,16,165,255,55,221,249,254,178,210,91,0,83,146,226,254,69,146,186,0,93,210,104,254,16,25,173,0,231,186,38,0,189,122,140,255,251,13,112,255,105,110,93,0,251,72,170,0,192,23,223,255,24,3,202,1,225,93,228,0,153,147,199,254,109,170,22,0,248,101,246,255,178,124,12,255,178,254,102,254,55,4,65,0,125,214,180,0,183,96,147,0,45,117,23,254,132,191,249,0,143,176,203,254,136,183,54,255,146,234,177,0,146,101,86,255,44,123,143,1,33,209,152,0,192,90,41,254,83,15,125,255,213,172,82,0,215,169,144,0,16,13,34,0,32,209,100,255,84,18,249,1,197,17,236,255,217,186,230,0,49,160,176,255,111,118,97,255,237,104,235,0,79,59,92,254,69,249,11,255,35,172,74,1,19,118,68,0,222,124,165,255,180,66,35,255,86,174,246,0,43,74,111,255,126,144,86,255,228,234,91,0,242,213,24,254,69,44,235,255,220,180,35,0,8,248,7,255,102,47,92,255,240,205,102,255,113,230,171,1,31,185,201,255,194,246,70,255,122,17,187,0,134,70,199,255,149,3,150,255,117,63,103,0,65,104,123,255,212,54,19,1,6,141,88,0,83,134,243,255,136,53,103,0,169,27,180,0,177,49,24,0,111,54,167,0,195,61,215,255,31,1,108,1,60,42,70,0,185,3,162,255,194,149,40,255,246,127,38,254,190,119,38,255,61,119,8,1,96,161,219,255,42,203,221,1,177,242,164,255,245,159,10,0,116,196,0,0,5,93,205,254,128,127,179,0,125,237,246,255,149,162,217,255,87,37,20,254,140,238,192,0,9,9,193,0,97,1,226,0,29,38,10,0,0,136,63,255,229,72,210,254,38,134,92,255,78,218,208,1,104,36,84,255,12,5,193,255,242,175,61,255,191,169,46,1,179,147,147,255,113,190,139,254,125,172,31,0,3,75,252,254,215,36,15,0,193,27,24,1,255,69,149,255,110,129,118,0,203,93,249,0,138,137,64,254,38,70,6,0,153,116,222,0,161,74,123,0,193,99,79,255,118,59,94,255,61,12,43,1,146,177,157,0,46,147,191,0,16,255,38,0,11,51,31,1,60,58,98,255,111,194,77,1,154,91,244,0,140,40,144,1,173,10,251,0,203,209,50,254,108,130,78,0,228,180,90,0,174,7,250,0,31,174,60,0,41,171,30,0,116,99,82,255,118,193,139,255,187,173,198,254,218,111,56,0,185,123,216,0,249,158,52,0,52,180,93,255,201,9,91,255,56,45,166,254,132,155,203,255,58,232,110,0,52,211,89,255,253,0,162,1,9,87,183,0,145,136,44,1,94,122,245,0,85,188,171,1,147,92,198,0,0,8,104,0,30,95,174,0,221,230,52,1,247,247,235,255,137,174,53,255,35,21,204,255,71,227,214,1,232,82,194,0,11,48,227,255,170,73,184,255,198,251,252,254,44,112,34,0,131,101,131,255,72,168,187,0,132,135,125,255,138,104,97,255,238,184,168,255,243,104,84,255,135,216,226,255,139,144,237,0,188,137,150,1,80,56,140,255,86,169,167,255,194,78,25,255,220,17,180,255,17,13,193,0,117,137,212,255,141,224,151,0,49,244,175,0,193,99,175,255,19,99,154,1,255,65,62,255,156,210,55,255,242,244,3,255,250,14,149,0,158,88,217,255,157,207,134,254,251,232,28,0,46,156,251,255,171,56,184,255,239,51,234,0,142,138,131,255,25,254,243,1,10,201,194,0,63,97,75,0,210,239,162,0,192,200,31,1,117,214,243,0,24,71,222,254,54,40,232,255,76,183,111,254,144,14,87,255,214,79,136,255,216,196,212,0,132,27,140,254,131,5,253,0,124,108,19,255,28,215,75,0,76,222,55,254,233,182,63,0,68,171,191,254,52,111,222,255,10,105,77,255,80,170,235,0,143,24,88,255,45,231,121,0,148,129,224,1,61,246,84,0,253,46,219,255,239,76,33,0,49,148,18,254,230,37,69,0,67,134,22,254,142,155,94,0,31,157,211,254,213,42,30,255,4,228,247,254,252,176,13,255,39,0,31,254,241,244,255,255,170,45,10,254,253,222,249,0,222,114,132,0,255,47,6,255,180,163,179,1,84,94,151,255,89,209,82,254,229,52,169,255,213,236,0,1,214,56,228,255,135,119,151,255,112,201,193,0,83,160,53,254,6,151,66,0,18,162,17,0,233,97,91,0,131,5,78,1,181,120,53,255,117,95,63,255,237,117,185,0,191,126,136,255,144,119,233,0,183,57,97,1,47,201,187,255,167,165,119,1,45,100,126,0,21,98,6,254,145,150,95,255,120,54,152,0,209,98,104,0,143,111,30,254,184,148,249,0,235,216,46,0,248,202,148,255,57,95,22,0,242,225,163,0,233,247,232,255,71,171,19,255,103,244,49,255,84,103,93,255,68,121,244,1,82,224,13,0,41,79,43,255,249,206,167,255,215,52,21,254,192,32,22,255,247,111,60,0,101,74,38,255,22,91,84,254,29,28,13,255,198,231,215,254,244,154,200,0,223,137,237,0,211,132,14,0,95,64,206,255,17,62,247,255,233,131,121,1,93,23,77,0,205,204,52,254,81,189,136,0,180,219,138,1,143,18,94,0,204,43,140,254,188,175,219,0,111,98,143,255,151,63,162,255,211,50,71,254,19,146,53,0,146,45,83,254,178,82,238,255,16,133,84,255,226,198,93,255,201,97,20,255,120,118,35,255,114,50,231,255,162,229,156,255,211,26,12,0,114,39,115,255,206,212,134,0,197,217,160,255,116,129,94,254,199,215,219,255,75,223,249,1,253,116,181,255,232,215,104,255,228,130,246,255,185,117,86,0,14,5,8,0,239,29,61,1,237,87,133,255,125,146,137,254,204,168,223,0,46,168,245,0,154,105,22,0,220,212,161,255,107,69,24,255,137,218,181,255,241,84,198,255,130,122,211,255,141,8,153,255,190,177,118,0,96,89,178,0,255,16,48,254,122,96,105,255,117,54,232,255,34,126,105,255,204,67,166,0,232,52,138,255,211,147,12,0,25,54,7,0,44,15,215,254,51,236,45,0,190,68,129,1,106,147,225,0,28,93,45,254,236,141,15,255,17,61,161,0,220,115,192,0,236,145,24,254,111,168,169,0,224,58,63,255,127,164,188,0,82,234,75,1,224,158,134,0,209,68,110,1,217,166,217,0,70,225,166,1,187,193,143,255,16,7,88,255,10,205,140,0,117,192,156,1,17,56,38,0,27,124,108,1,171,215,55,255,95,253,212,0,155,135,168,255,246,178,153,254,154,68,74,0,232,61,96,254,105,132,59,0,33,76,199,1,189,176,130,255,9,104,25,254,75,198,102,255,233,1,112,0,108,220,20,255,114,230,70,0,140,194,133,255,57,158,164,254,146,6,80,255,169,196,97,1,85,183,130,0,70,158,222,1,59,237,234,255,96,25,26,255,232,175,97,255,11,121,248,254,88,35,194,0,219,180,252,254,74,8,227,0,195,227,73,1,184,110,161,255,49,233,164,1,128,53,47,0,82,14,121,255,193,190,58,0,48,174,117,255,132,23,32,0,40,10,134,1,22,51,25,255,240,11,176,255,110,57,146,0,117,143,239,1,157,101,118,255,54,84,76,0,205,184,18,255,47,4,72,255,78,112,85,255,193,50,66,1,93,16,52,255,8,105,134,0,12,109,72,255,58,156,251,0,144,35,204,0,44,160,117,254,50,107,194,0,1,68,165,255,111,110,162,0,158,83,40,254,76,214,234,0,58,216,205,255,171,96,147,255,40,227,114,1,176,227,241,0,70,249,183,1,136,84,139,255,60,122,247,254,143,9,117,255,177,174,137,254,73,247,143,0,236,185,126,255,62,25,247,255,45,64,56,255,161,244,6,0,34,57,56,1,105,202,83,0,128,147,208,0,6,103,10,255,74,138,65,255,97,80,100,255,214,174,33,255,50,134,74,255,110,151,130,254,111,84,172,0,84,199,75,254,248,59,112,255,8,216,178,1,9,183,95,0,238,27,8,254,170,205,220,0,195,229,135,0,98,76,237,255,226,91,26,1,82,219,39,255,225,190,199,1,217,200,121,255,81,179,8,255,140,65,206,0,178,207,87,254,250,252,46,255,104,89,110,1,253,189,158,255,144,214,158,255,160,245,54,255,53,183,92,1,21,200,194,255,146,33,113,1,209,1,255,0,235,106,43,255,167,52,232,0,157,229,221,0,51,30,25,0,250,221,27,1,65,147,87,255,79,123,196,0,65,196,223,255,76,44,17,1,85,241,68,0,202,183,249,255,65,212,212,255,9,33,154,1,71,59,80,0,175,194,59,255,141,72,9,0,100,160,244,0,230,208,56,0,59,25,75,254,80,194,194,0,18,3,200,254,160,159,115,0,132,143,247,1,111,93,57,255,58,237,11,1,134,222,135,255,122,163,108,1,123,43,190,255,251,189,206,254,80,182,72,255,208,246,224,1,17,60,9,0,161,207,38,0,141,109,91,0,216,15,211,255,136,78,110,0,98,163,104,255,21,80,121,255,173,178,183,1,127,143,4,0,104,60,82,254,214,16,13,255,96,238,33,1,158,148,230,255,127,129,62,255,51,255,210,255,62,141,236,254,157,55,224,255,114,39,244,0,192,188,250,255,228,76,53,0,98,84,81,255,173,203,61,254,147,50,55,255,204,235,191,0,52,197,244,0,88,43,211,254,27,191,119,0,188,231,154,0,66,81,161,0,92,193,160,1,250,227,120,0,123,55,226,0,184,17,72,0,133,168,10,254,22,135,156,255,41,25,103,255,48,202,58,0,186,149,81,255,188,134,239,0,235,181,189,254,217,139,188,255,74,48,82,0,46,218,229,0,189,253,251,0,50,229,12,255,211,141,191,1,128,244,25,255,169,231,122,254,86,47,189,255,132,183,23,255,37,178,150,255,51,137,253,0,200,78,31,0,22,105,50,0,130,60,0,0,132,163,91,254,23,231,187,0,192,79,239,0,157,102,164,255,192,82,20,1,24,181,103,255,240,9,234,0,1,123,164,255,133,233,0,255,202,242,242,0,60,186,245,0,241,16,199,255,224,116,158,254,191,125,91,255,224,86,207,0,121,37,231,255,227,9,198,255,15,153,239,255,121,232,217,254,75,112,82,0,95,12,57,254,51,214,105,255,148,220,97,1,199,98,36,0,156,209,12,254,10,212,52,0,217,180,55,254,212,170,232,255,216,20,84,255,157,250,135,0,157,99,127,254,1,206,41,0,149,36,70,1,54,196,201,255,87,116,0,254,235,171,150,0,27,163,234,0,202,135,180,0,208,95,0,254,123,156,93,0,183,62,75,0,137,235,182,0,204,225,255,255,214,139,210,255,2,115,8,255,29,12,111,0,52,156,1,0,253,21,251,255,37,165,31,254,12,130,211,0,106,18,53,254,42,99,154,0,14,217,61,254,216,11,92,255,200,197,112,254,147,38,199,0,36,252,120,254,107,169,77,0,1,123,159,255,207,75,102,0,163,175,196,0,44,1,240,0,120,186,176,254,13,98,76,255,237,124,241,255,232,146,188,255,200,96,224,0,204,31,41,0,208,200,13,0,21,225,96,255,175,156,196,0,247,208,126,0,62,184,244,254,2,171,81,0,85,115,158,0,54,64,45,255,19,138,114,0,135,71,205,0,227,47,147,1,218,231,66,0,253,209,28,0,244,15,173,255,6,15,118,254,16,150,208,255,185,22,50,255,86,112,207,255,75,113,215,1,63,146,43,255,4,225,19,254,227,23,62,255,14,255,214,254,45,8,205,255,87,197,151,254,210,82,215,255,245,248,247,255,128,248,70,0,225,247,87,0,90,120,70,0,213,245,92,0,13,133,226,0,47,181,5,1,92,163,105,255,6,30,133,254,232,178,61,255,230,149,24,255,18,49,158,0,228,100,61,254,116,243,251,255,77,75,92,1,81,219,147,255,76,163,254,254,141,213,246,0,232,37,152,254,97,44,100,0,201,37,50,1,212,244,57,0,174,171,183,255,249,74,112,0,166,156,30,0,222,221,97,255,243,93,73,254,251,101,100,255,216,217,93,255,254,138,187,255,142,190,52,255,59,203,177,255,200,94,52,0,115,114,158,255,165,152,104,1,126,99,226,255,118,157,244,1,107,200,16,0,193,90,229,0,121,6,88,0,156,32,93,254,125,241,211,255,14,237,157,255,165,154,21,255,184,224,22,255,250,24,152,255,113,77,31,0,247,171,23,255,237,177,204,255,52,137,145,255,194,182,114,0,224,234,149,0,10,111,103,1,201,129,4,0,238,142,78,0,52,6,40,255,110,213,165,254,60,207,253,0,62,215,69,0,96,97,0,255,49,45,202,0,120,121,22,255,235,139,48,1,198,45,34,255,182,50,27,1,131,210,91,255,46,54,128,0,175,123,105,255,198,141,78,254,67,244,239,255,245,54,103,254,78,38,242,255,2,92,249,254,251,174,87,255,139,63,144,0,24,108,27,255,34,102,18,1,34,22,152,0,66,229,118,254,50,143,99,0,144,169,149,1,118,30,152,0,178,8,121,1,8,159,18,0,90,101,230,255,129,29,119,0,68,36,11,1,232,183,55,0,23,255,96,255,161,41,193,255,63,139,222,0,15,179,243,0,255,100,15,255,82,53,135,0,137,57,149,1,99,240,170,255,22,230,228,254,49,180,82,255,61,82,43,0,110,245,217,0,199,125,61,0,46,253,52,0,141,197,219,0,211,159,193,0,55,121,105,254,183,20,129,0,169,119,170,255,203,178,139,255,135,40,182,255,172,13,202,255,65,178,148,0,8,207,43,0,122,53,127,1,74,161,48,0,227,214,128,254,86,11,243,255,100,86,7,1,245,68,134,255,61,43,21,1,152,84,94,255,190,60,250,254,239,118,232,255,214,136,37,1,113,76,107,255,93,104,100,1,144,206,23,255,110,150,154,1,228,103,185,0,218,49,50,254,135,77,139,255,185,1,78,0,0,161,148,255,97,29,233,255,207,148,149,255,160,168,0,0,91,128,171,255,6,28,19,254,11,111,247,0,39,187,150,255,138,232,149,0,117,62,68,255,63,216,188,255,235,234,32,254,29,57,160,255,25,12,241,1,169,60,191,0,32,131,141,255,237,159,123,255,94,197,94,254,116,254,3,255,92,179,97,254,121,97,92,255,170,112,14,0,21,149,248,0,248,227,3,0,80,96,109,0,75,192,74,1,12,90,226,255,161,106,68,1,208,114,127,255,114,42,255,254,74,26,74,255,247,179,150,254,121,140,60,0,147,70,200,255,214,40,161,255,161,188,201,255,141,65,135,255,242,115,252,0,62,47,202,0,180,149,255,254,130,55,237,0,165,17,186,255,10,169,194,0,156,109,218,255,112,140,123,255,104,128,223,254,177,142,108,255,121,37,219,255,128,77,18,255,111,108,23,1,91,192,75,0,174,245,22,255,4,236,62,255,43,64,153,1,227,173,254,0,237,122,132,1,127,89,186,255,142,82,128,254,252,84,174,0,90,179,177,1,243,214,87,255,103,60,162,255,208,130,14,255,11,130,139,0,206,129,219,255,94,217,157,255,239,230,230,255,116,115,159,254,164,107,95,0,51,218,2,1,216,125,198,255,140,202,128,254,11,95,68,255,55,9,93,254,174,153,6,255,204,172,96,0,69,160,110,0,213,38,49,254,27,80,213,0,118,125,114,0,70,70,67,255,15,142,73,255,131,122,185,255,243,20,50,254,130,237,40,0,210,159,140,1,197,151,65,255,84,153,66,0,195,126,90,0,16,238,236,1,118,187,102,255,3,24,133,255,187,69,230,0,56,197,92,1,213,69,94,255,80,138,229,1,206,7,230,0,222,111,230,1,91,233,119,255,9,89,7,1,2,98,1,0,148,74,133,255,51,246,180,255,228,177,112,1,58,189,108,255,194,203,237,254,21,209,195,0,147,10,35,1,86,157,226,0,31,163,139,254,56,7,75,255,62,90,116,0,181,60,169,0,138,162,212,254,81,167,31,0,205,90,112,255,33,112,227,0,83,151,117,1,177,224,73,255,174,144,217,255,230,204,79,255,22,77,232,255,114,78,234,0,224,57,126,254,9,49,141,0,242,147,165,1,104,182,140,255,167,132,12,1,123,68,127,0,225,87,39,1,251,108,8,0,198,193,143,1,121,135,207,255,172,22,70,0,50,68,116,255,101,175,40,255,248,105,233,0,166,203,7,0,110,197,218,0,215,254,26,254,168,226,253,0,31,143,96,0,11,103,41,0,183,129,203,254,100,247,74,255,213,126,132,0,210,147,44,0,199,234,27,1,148,47,181,0,155,91,158,1,54,105,175,255,2,78,145,254,102,154,95,0,128,207,127,254,52,124,236,255,130,84,71,0,221,243,211,0,152,170,207,0,222,106,199,0,183,84,94,254,92,200,56,255,138,182,115,1,142,96,146,0,133,136,228,0,97,18,150,0,55,251,66,0,140,102,4,0,202,103,151,0,30,19,248,255,51,184,207,0,202,198,89,0,55,197,225,254,169,95,249,255,66,65,68,255,188,234,126,0,166,223,100,1,112,239,244,0,144,23,194,0,58,39,182,0,244,44,24,254,175,68,179,255,152,118,154,1,176,162,130,0,217,114,204,254,173,126,78,255,33,222,30,255,36,2,91,255,2,143,243,0,9,235,215,0,3,171,151,1,24,215,245,255,168,47,164,254,241,146,207,0,69,129,180,0,68,243,113,0,144,53,72,254,251,45,14,0,23,110,168,0,68,68,79,255,110,70,95,254,174,91,144,255,33,206,95,255,137,41,7,255,19,187,153,254,35,255,112,255,9,145,185,254,50,157,37,0,11,112,49,1,102,8,190,255,234,243,169,1,60,85,23,0,74,39,189,0,116,49,239,0,173,213,210,0,46,161,108,255,159,150,37,0,196,120,185,255,34,98,6,255,153,195,62,255,97,230,71,255,102,61,76,0,26,212,236,255,164,97,16,0,198,59,146,0,163,23,196,0,56,24,61,0,181,98,193,0,251,147,229,255,98,189,24,255,46,54,206,255,234,82,246,0,183,103,38,1,109,62,204,0,10,240,224,0,146,22,117,255,142,154,120,0,69,212,35,0,208,99,118,1,121,255,3,255,72,6,194,0,117,17,197,255,125,15,23,0,154,79,153,0,214,94,197,255,185,55,147,255,62,254,78,254,127,82,153,0,110,102,63,255,108,82,161,255,105,187,212,1,80,138,39,0,60,255,93,255,72,12,186,0,210,251,31,1,190,167,144,255,228,44,19,254,128,67,232,0,214,249,107,254,136,145,86,255,132,46,176,0,189,187,227,255,208,22,140,0,217,211,116,0,50,81,186,254,139,250,31,0,30,64,198,1,135,155,100,0,160,206,23,254,187,162,211,255,16,188,63,0,254,208,49,0,85,84,191,0,241,192,242,255,153,126,145,1,234,162,162,255,230,97,216,1,64,135,126,0,190,148,223,1,52,0,43,255,28,39,189,1,64,136,238,0,175,196,185,0,98,226,213,255,127,159,244,1,226,175,60,0,160,233,142,1,180,243,207,255,69,152,89,1,31,101,21,0,144,25,164,254,139,191,209,0,91,25,121,0,32,147,5,0,39,186,123,255,63,115,230,255,93,167,198,255,143,213,220,255,179,156,19,255,25,66,122,0,214,160,217,255,2,45,62,255,106,79,146,254,51,137,99,255,87,100,231,255,175,145,232,255,101,184,1,255,174,9,125,0,82,37,161,1,36,114,141,255,48,222,142,255,245,186,154,0,5,174,221,254,63,114,155,255,135,55,160,1,80,31,135,0,126,250,179,1,236,218,45,0,20,28,145,1,16,147,73,0,249,189,132,1,17,189,192,255,223,142,198,255,72,20,15,255,250,53,237,254,15,11,18,0,27,211,113,254,213,107,56,255,174,147,146,255,96,126,48,0,23,193,109,1,37,162,94,0,199,157,249,254,24,128,187,255,205,49,178,254,93,164,42,255,43,119,235,1,88,183,237,255,218,210,1,255,107,254,42,0,230,10,99,255,162,0,226,0,219,237,91,0,129,178,203,0,208,50,95,254,206,208,95,255,247,191,89,254,110,234,79,255,165,61,243,0,20,122,112,255,246,246,185,254,103,4,123,0,233,99,230,1,219,91,252,255,199,222,22,255,179,245,233,255,211,241,234,0,111,250,192,255,85,84,136,0,101,58,50,255,131,173,156,254,119,45,51,255,118,233,16,254,242,90,214,0,94,159,219,1,3,3,234,255,98,76,92,254,80,54,230,0,5,228,231,254,53,24,223,255,113,56,118,1,20,132,1,255,171,210,236,0,56,241,158,255,186,115,19,255,8,229,174,0,48,44,0,1,114,114,166,255,6,73,226,255,205,89,244,0,137,227,75,1,248,173,56,0,74,120,246,254,119,3,11,255,81,120,198,255,136,122,98,255,146,241,221,1,109,194,78,255,223,241,70,1,214,200,169,255,97,190,47,255,47,103,174,255,99,92,72,254,118,233,180,255,193,35,233,254,26,229,32,255,222,252,198,0,204,43,71,255,199,84,172,0,134,102,190,0,111,238,97,254,230,40,230,0,227,205,64,254,200,12,225,0,166,25,222,0,113,69,51,255,143,159,24,0,167,184,74,0,29,224,116,254,158,208,233,0,193,116,126,255,212,11,133,255,22,58,140,1,204,36,51,255,232,30,43,0,235,70,181,255,64,56,146,254,169,18,84,255,226,1,13,255,200,50,176,255,52,213,245,254,168,209,97,0,191,71,55,0,34,78,156,0,232,144,58,1,185,74,189,0,186,142,149,254,64,69,127,255,161,203,147,255,176,151,191,0,136,231,203,254,163,182,137,0,161,126,251,254,233,32,66,0,68,207,66,0,30,28,37,0,93,114,96,1,254,92,247,255,44,171,69,0,202,119,11,255,188,118,50,1,255,83,136,255,71,82,26,0,70,227,2,0,32,235,121,1,181,41,154,0,71,134,229,254,202,255,36,0,41,152,5,0,154,63,73,255,34,182,124,0,121,221,150,255,26,204,213,1,41,172,87,0,90,157,146,255,109,130,20,0,71,107,200,255,243,102,189,0,1,195,145,254,46,88,117,0,8,206,227,0,191,110,253,255,109,128,20,254,134,85,51,255,137,177,112,1,216,34,22,255,131,16,208,255,121,149,170,0,114,19,23,1,166,80,31,255,113,240,122,0,232,179,250,0,68,110,180,254,210,170,119,0,223,108,164,255,207,79,233,255,27,229,226,254,209,98,81,255,79,68,7,0,131,185,100,0,170,29,162,255,17,162,107,255,57,21,11,1,100,200,181,255,127,65,166,1,165,134,204,0,104,167,168,0,1,164,79,0,146,135,59,1,70,50,128,255,102,119,13,254,227,6,135,0,162,142,179,255,160,100,222,0,27,224,219,1,158,93,195,255,234,141,137,0,16,24,125,255,238,206,47,255,97,17,98,255,116,110,12,255,96,115,77,0,91,227,232,255,248,254,79,255,92,229,6,254,88,198,139,0,206,75,129,0,250,77,206,255,141,244,123,1,138,69,220,0,32,151,6,1,131,167,22,255,237,68,167,254,199,189,150,0,163,171,138,255,51,188,6,255,95,29,137,254,148,226,179,0,181,107,208,255,134,31,82,255,151,101,45,255,129,202,225,0,224,72,147,0,48,138,151,255,195,64,206,254,237,218,158,0,106,29,137,254,253,189,233,255,103,15,17,255,194,97,255,0,178,45,169,254,198,225,155,0,39,48,117,255,135,106,115,0,97,38,181,0,150,47,65,255,83,130,229,254,246,38,129,0,92,239,154,254,91,99,127,0,161,111,33,255,238,217,242,255,131,185,195,255,213,191,158,255,41,150,218,0,132,169,131,0,89,84,252,1,171,70,128,255,163,248,203,254,1,50,180,255,124,76,85,1,251,111,80,0,99,66,239,255,154,237,182,255,221,126,133,254,74,204,99,255,65,147,119,255,99,56,167,255,79,248,149,255,116,155,228,255,237,43,14,254,69,137,11,255,22,250,241,1,91,122,143,255,205,249,243,0,212,26,60,255,48,182,176,1,48,23,191,255,203,121,152,254,45,74,213,255,62,90,18,254,245,163,230,255,185,106,116,255,83,35,159,0,12,33,2,255,80,34,62,0,16,87,174,255,173,101,85,0,202,36,81,254,160,69,204,255,64,225,187,0,58,206,94,0,86,144,47,0,229,86,245,0,63,145,190,1,37,5,39,0,109,251,26,0,137,147,234,0,162,121,145,255,144,116,206,255,197,232,185,255,183,190,140,255,73,12,254,255,139,20,242,255,170,90,239,255,97,66,187,255,245,181,135,254,222,136,52,0,245,5,51,254,203,47,78,0,152,101,216,0,73,23,125,0,254,96,33,1,235,210,73,255,43,209,88,1,7,129,109,0,122,104,228,254,170,242,203,0,242,204,135,255,202,28,233,255,65,6,127,0,159,144,71,0,100,140,95,0,78,150,13,0,251,107,118,1,182,58,125,255,1,38,108,255,141,189,209,255,8,155,125,1,113,163,91,255,121,79,190,255,134,239,108,255,76,47,248,0,163,228,239,0,17,111,10,0,88,149,75,255,215,235,239,0,167,159,24,255,47,151,108,255,107,209,188,0,233,231,99,254,28,202,148,255,174,35,138,255,110,24,68,255,2,69,181,0,107,102,82,0,102,237,7,0,92,36,237,255,221,162,83,1,55,202,6,255,135,234,135,255,24,250,222,0,65,94,168,254,245,248,210,255,167,108,201,254,255,161,111,0,205,8,254,0,136,13,116,0,100,176,132,255,43,215,126,255,177,133,130,255,158,79,148,0,67,224,37,1,12,206,21,255,62,34,110,1,237,104,175,255,80,132,111,255,142,174,72,0,84,229,180,254,105,179,140,0,64,248,15,255,233,138,16,0,245,67,123,254,218,121,212,255,63,95,218,1,213,133,137,255,143,182,82,255,48,28,11,0,244,114,141,1,209,175,76,255,157,181,150,255,186,229,3,255,164,157,111,1,231,189,139,0,119,202,190,255,218,106,64,255,68,235,63,254,96,26,172,255,187,47,11,1,215,18,251,255,81,84,89,0,68,58,128,0,94,113,5,1,92,129,208,255,97,15,83,254,9,28,188,0,239,9,164,0,60,205,152,0,192,163,98,255,184,18,60,0,217,182,139,0,109,59,120,255,4,192,251,0,169,210,240,255,37,172,92,254,148,211,245,255,179,65,52,0,253,13,115,0,185,174,206,1,114,188,149,255,237,90,173,0,43,199,192,255,88,108,113,0,52,35,76,0,66,25,148,255,221,4,7,255,151,241,114,255,190,209,232,0,98,50,199,0,151,150,213,255,18,74,36,1,53,40,7,0,19,135,65,255,26,172,69,0,174,237,85,0,99,95,41,0,3,56,16,0,39,160,177,255,200,106,218,254,185,68,84,255,91,186,61,254,67,143,141,255,13,244,166,255,99,114,198,0,199,110,163,255,193,18,186,0,124,239,246,1,110,68,22,0,2,235,46,1,212,60,107,0,105,42,105,1,14,230,152,0,7,5,131,0,141,104,154,255,213,3,6,0,131,228,162,255,179,100,28,1,231,123,85,255,206,14,223,1,253,96,230,0,38,152,149,1,98,137,122,0,214,205,3,255,226,152,179,255,6,133,137,0,158,69,140,255,113,162,154,255,180,243,172,255,27,189,115,255,143,46,220,255,213,134,225,255,126,29,69,0,188,43,137,1,242,70,9,0,90,204,255,255,231,170,147,0,23,56,19,254,56,125,157,255,48,179,218,255,79,182,253,255,38,212,191,1,41,235,124,0,96,151,28,0,135,148,190,0,205,249,39,254,52,96,136,255,212,44,136,255,67,209,131,255,252,130,23,255,219,128,20,255,198,129,118,0,108,101,11,0,178,5,146,1,62,7,100,255,181,236,94,254,28,26,164,0,76,22,112,255,120,102,79,0,202,192,229,1,200,176,215,0,41,64,244,255,206,184,78,0,167,45,63,1,160,35,0,255,59,12,142,255,204,9,144,255,219,94,229,1,122,27,112,0,189,105,109,255,64,208,74,255,251,127,55,1,2,226,198,0,44,76,209,0,151,152,77,255,210,23,46,1,201,171,69,255,44,211,231,0,190,37,224,255,245,196,62,255,169,181,222,255,34,211,17,0,119,241,197,255,229,35,152,1,21,69,40,255,178,226,161,0,148,179,193,0,219,194,254,1,40,206,51,255,231,92,250,1,67,153,170,0,21,148,241,0,170,69,82,255,121,18,231,255,92,114,3,0,184,62,230,0,225,201,87,255,146,96,162,255,181,242,220,0,173,187,221,1,226,62,170,255,56,126,217,1,117,13,227,255,179,44,239,0,157,141,155,255,144,221,83,0,235,209,208,0,42,17,165,1,251,81,133,0,124,245,201,254,97,211,24,255,83,214,166,0,154,36,9,255,248,47,127,0,90,219,140,255,161,217,38,254,212,147,63,255,66,84,148,1,207,3,1,0,230,134,89,1,127,78,122,255,224,155,1,255,82,136,74,0,178,156,208,255,186,25,49,255,222,3,210,1,229,150,190,255,85,162,52,255,41,84,141,255,73,123,84,254,93,17,150,0,119,19,28,1,32,22,215,255,28,23,204,255,142,241,52,255,228,52,125,0,29,76,207,0,215,167,250,254,175,164,230,0,55,207,105,1,109,187,245,255,161,44,220,1,41,101,128,255,167,16,94,0,93,214,107,255,118,72,0,254,80,61,234,255,121,175,125,0,139,169,251,0,97,39,147,254,250,196,49,255,165,179,110,254,223,70,187,255,22,142,125,1,154,179,138,255,118,176,42,1,10,174,153,0,156,92,102,0,168,13,161,255,143,16,32,0,250,197,180,255,203,163,44,1,87,32,36,0,161,153,20,255,123,252,15,0,25,227,80,0,60,88,142,0,17,22,201,1,154,205,77,255,39,63,47,0,8,122,141,0,128,23,182,254,204,39,19,255,4,112,29,255,23,36,140,255,210,234,116,254,53,50,63,255,121,171,104,255,160,219,94,0,87,82,14,254,231,42,5,0,165,139,127,254,86,78,38,0,130,60,66,254,203,30,45,255,46,196,122,1,249,53,162,255,136,143,103,254,215,210,114,0,231,7,160,254,169,152,42,255,111,45,246,0,142,131,135,255,131,71,204,255,36,226,11,0,0,28,242,255,225,138,213,255,247,46,216,254,245,3,183,0,108,252,74,1,206,26,48,255,205,54,246,255,211,198,36,255,121,35,50,0,52,216,202,255,38,139,129,254,242,73,148,0,67,231,141,255,42,47,204,0,78,116,25,1,4,225,191,255,6,147,228,0,58,88,177,0,122,165,229,255,252,83,201,255,224,167,96,1,177,184,158,255,242,105,179,1,248,198,240,0,133,66,203,1,254,36,47,0,45,24,115,255,119,62,254,0,196,225,186,254,123,141,172,0,26,85,41,255,226,111,183,0,213,231,151,0,4,59,7,255,238,138,148,0,66,147,33,255,31,246,141,255,209,141,116,255,104,112,31,0,88,161,172,0,83,215,230,254,47,111,151,0,45,38,52,1,132,45,204,0,138,128,109,254,233,117,134,255,243,190,173,254,241,236,240,0,82,127,236,254,40,223,161,255,110,182,225,255,123,174,239,0,135,242,145,1,51,209,154,0,150,3,115,254,217,164,252,255,55,156,69,1,84,94,255,255,232,73,45,1,20,19,212,255,96,197,59,254,96,251,33,0,38,199,73,1,64,172,247,255,117,116,56,255,228,17,18,0,62,138,103,1,246,229,164,255,244,118,201,254,86,32,159,255,109,34,137,1,85,211,186,0,10,193,193,254,122,194,177,0,122,238,102,255,162,218,171,0,108,217,161,1,158,170,34,0,176,47,155,1,181,228,11,255,8,156,0,0,16,75,93,0,206,98,255,1,58,154,35,0,12,243,184,254,67,117,66,255,230,229,123,0,201,42,110,0,134,228,178,254,186,108,118,255,58,19,154,255,82,169,62,255,114,143,115,1,239,196,50,255,173,48,193,255,147,2,84,255,150,134,147,254,95,232,73,0,109,227,52,254,191,137,10,0,40,204,30,254,76,52,97,255,164,235,126,0,254,124,188,0,74,182,21,1,121,29,35,255,241,30,7,254,85,218,214,255,7,84,150,254,81,27,117,255,160,159,152,254,66,24,221,255,227,10,60,1,141,135,102,0,208,189,150,1,117,179,92,0,132,22,136,255,120,199,28,0,21,129,79,254,182,9,65,0,218,163,169,0,246,147,198,255,107,38,144,1,78,175,205,255,214,5,250,254,47,88,29,255,164,47,204,255,43,55,6,255,131,134,207,254,116,100,214,0,96,140,75,1,106,220,144,0,195,32,28,1,172,81,5,255,199,179,52,255,37,84,203,0,170,112,174,0,11,4,91,0,69,244,27,1,117,131,92,0,33,152,175,255,140,153,107,255,251,135,43,254,87,138,4,255,198,234,147,254,121,152,84,255,205,101,155,1,157,9,25,0,72,106,17,254,108,153,0,255,189,229,186,0,193,8,176,255,174,149,209,0,238,130,29,0,233,214,126,1,61,226,102,0,57,163,4,1,198,111,51,255,45,79,78,1,115,210,10,255,218,9,25,255,158,139,198,255,211,82,187,254,80,133,83,0,157,129,230,1,243,133,134,255,40,136,16,0,77,107,79,255,183,85,92,1,177,204,202,0,163,71,147,255,152,69,190,0,172,51,188,1,250,210,172,255,211,242,113,1,89,89,26,255,64,66,111,254,116,152,42,0,161,39,27,255,54,80,254,0,106,209,115,1,103,124,97,0,221,230,98,255,31,231,6,0,178,192,120,254,15,217,203,255,124,158,79,0,112,145,247,0,92,250,48,1,163,181,193,255,37,47,142,254,144,189,165,255,46,146,240,0,6,75,128,0,41,157,200,254,87,121,213,0,1,113,236,0,5,45,250,0,144,12,82,0,31,108,231,0,225,239,119,255,167,7,189,255,187,228,132,255,110,189,34,0,94,44,204,1,162,52,197,0,78,188,241,254,57,20,141,0,244,146,47,1,206,100,51,0,125,107,148,254,27,195,77,0,152,253,90,1,7,143,144,255,51,37,31,0,34,119,38,255,7,197,118,0,153,188,211,0,151,20,116,254,245,65,52,255,180,253,110,1,47,177,209,0,161,99,17,255,118,222,202,0,125,179,252,1,123,54,126,255,145,57,191,0,55,186,121,0,10,243,138,0,205,211,229,255,125,156,241,254,148,156,185,255,227,19,188,255,124,41,32,255,31,34,206,254,17,57,83,0,204,22,37,255,42,96,98,0,119,102,184,1,3,190,28],\"i8\",ALLOC_NONE,Runtime.GLOBAL_BASE+20480);allocate([110,82,218,255,200,204,192,255,201,145,118,0,117,204,146,0,132,32,98,1,192,194,121,0,106,161,248,1,237,88,124,0,23,212,26,0,205,171,90,255,248,48,216,1,141,37,230,255,124,203,0,254,158,168,30,255,214,248,21,0,112,187,7,255,75,133,239,255,74,227,243,255,250,147,70,0,214,120,162,0,167,9,179,255,22,158,18,0,218,77,209,1,97,109,81,255,244,33,179,255,57,52,57,255,65,172,210,255,249,71,209,255,142,169,238,0,158,189,153,255,174,254,103,254,98,33,14,0,141,76,230,255,113,139,52,255,15,58,212,0,168,215,201,255,248,204,215,1,223,68,160,255,57,154,183,254,47,231,121,0,106,166,137,0,81,136,138,0,165,43,51,0,231,139,61,0,57,95,59,254,118,98,25,255,151,63,236,1,94,190,250,255,169,185,114,1,5,250,58,255,75,105,97,1,215,223,134,0,113,99,163,1,128,62,112,0,99,106,147,0,163,195,10,0,33,205,182,0,214,14,174,255,129,38,231,255,53,182,223,0,98,42,159,255,247,13,40,0,188,210,177,1,6,21,0,255,255,61,148,254,137,45,129,255,89,26,116,254,126,38,114,0,251,50,242,254,121,134,128,255,204,249,167,254,165,235,215,0,202,177,243,0,133,141,62,0,240,130,190,1,110,175,255,0,0,20,146,1,37,210,121,255,7,39,130,0,142,250,84,255,141,200,207,0,9,95,104,255,11,244,174,0,134,232,126,0,167,1,123,254,16,193,149,255,232,233,239,1,213,70,112,255,252,116,160,254,242,222,220,255,205,85,227,0,7,185,58,0,118,247,63,1,116,77,177,255,62,245,200,254,63,18,37,255,107,53,232,254,50,221,211,0,162,219,7,254,2,94,43,0,182,62,182,254,160,78,200,255,135,140,170,0,235,184,228,0,175,53,138,254,80,58,77,255,152,201,2,1,63,196,34,0,5,30,184,0,171,176,154,0,121,59,206,0,38,99,39,0,172,80,77,254,0,134,151,0,186,33,241,254,94,253,223,255,44,114,252,0,108,126,57,255,201,40,13,255,39,229,27,255,39,239,23,1,151,121,51,255,153,150,248,0,10,234,174,255,118,246,4,254,200,245,38,0,69,161,242,1,16,178,150,0,113,56,130,0,171,31,105,0,26,88,108,255,49,42,106,0,251,169,66,0,69,93,149,0,20,57,254,0,164,25,111,0,90,188,90,255,204,4,197,0,40,213,50,1,212,96,132,255,88,138,180,254,228,146,124,255,184,246,247,0,65,117,86,255,253,102,210,254,254,121,36,0,137,115,3,255,60,24,216,0,134,18,29,0,59,226,97,0,176,142,71,0,7,209,161,0,189,84,51,254,155,250,72,0,213,84,235,255,45,222,224,0,238,148,143,255,170,42,53,255,78,167,117,0,186,0,40,255,125,177,103,255,69,225,66,0,227,7,88,1,75,172,6,0,169,45,227,1,16,36,70,255,50,2,9,255,139,193,22,0,143,183,231,254,218,69,50,0,236,56,161,1,213,131,42,0,138,145,44,254,136,229,40,255,49,63,35,255,61,145,245,255,101,192,2,254,232,167,113,0,152,104,38,1,121,185,218,0,121,139,211,254,119,240,35,0,65,189,217,254,187,179,162,255,160,187,230,0,62,248,14,255,60,78,97,0,255,247,163,255,225,59,91,255,107,71,58,255,241,47,33,1,50,117,236,0,219,177,63,254,244,90,179,0,35,194,215,255,189,67,50,255,23,135,129,0,104,189,37,255,185,57,194,0,35,62,231,255,220,248,108,0,12,231,178,0,143,80,91,1,131,93,101,255,144,39,2,1,255,250,178,0,5,17,236,254,139,32,46,0,204,188,38,254,245,115,52,255,191,113,73,254,191,108,69,255,22,69,245,1,23,203,178,0,170,99,170,0,65,248,111,0,37,108,153,255,64,37,69,0,0,88,62,254,89,148,144,255,191,68,224,1,241,39,53,0,41,203,237,255,145,126,194,255,221,42,253,255,25,99,151,0,97,253,223,1,74,115,49,255,6,175,72,255,59,176,203,0,124,183,249,1,228,228,99,0,129,12,207,254,168,192,195,255,204,176,16,254,152,234,171,0,77,37,85,255,33,120,135,255,142,194,227,1,31,214,58,0,213,187,125,255,232,46,60,255,190,116,42,254,151,178,19,255,51,62,237,254,204,236,193,0,194,232,60,0,172,34,157,255,189,16,184,254,103,3,95,255,141,233,36,254,41,25,11,255,21,195,166,0,118,245,45,0,67,213,149,255,159,12,18,255,187,164,227,1,160,25,5,0,12,78,195,1,43,197,225,0,48,142,41,254,196,155,60,255,223,199,18,1,145,136,156,0,252,117,169,254,145,226,238,0,239,23,107,0,109,181,188,255,230,112,49,254,73,170,237,255,231,183,227,255,80,220,20,0,194,107,127,1,127,205,101,0,46,52,197,1,210,171,36,255,88,3,90,255,56,151,141,0,96,187,255,255,42,78,200,0,254,70,70,1,244,125,168,0,204,68,138,1,124,215,70,0,102,66,200,254,17,52,228,0,117,220,143,254,203,248,123,0,56,18,174,255,186,151,164,255,51,232,208,1,160,228,43,255,249,29,25,1,68,190,63,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,224,124,0,0,0,0,0,0,5,0,0,0,0,0,0,0,0,0,0,0,18,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,18,0,0,0,19,0,0,0,65,132,0,0,0,4,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,10,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,101,120,112,97,110,100,32,51,50,45,98,121,116,101,32,107,111,117,116,108,101,110,32,60,61,32,85,73,78,84,56,95,77,65,88,0,99,114,121,112,116,111,95,103,101,110,101,114,105,99,104,97,115,104,47,98,108,97,107,101,50,47,114,101,102,47,103,101,110,101,114,105,99,104,97,115,104,95,98,108,97,107,101,50,98,46,99,0,99,114,121,112,116,111,95,103,101,110,101,114,105,99,104,97,115,104,95,98,108,97,107,101,50,98,0,107,101,121,108,101,110,32,60,61,32,85,73,78,84,56,95,77,65,88,0,99,114,121,112,116,111,95,103,101,110,101,114,105,99,104,97,115,104,95,98,108,97,107,101,50,98,95,105,110,105,116,0,99,114,121,112,116,111,95,103,101,110,101,114,105,99,104,97,115,104,95,98,108,97,107,101,50,98,95,102,105,110,97,108,0,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,128,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,36,55,36,0,101,120,112,97,110,100,32,51,50,45,98,121,116,101,32,107,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,123,32,114,101,116,117,114,110,32,77,111,100,117,108,101,46,103,101,116,82,97,110,100,111,109,86,97,108,117,101,40,41,59,32,125,0,123,32,105,102,32,40,77,111,100,117,108,101,46,103,101,116,82,97,110,100,111,109,86,97,108,117,101,32,61,61,61,32,117,110,100,101,102,105,110,101,100,41,32,123,32,116,114,121,32,123,32,118,97,114,32,119,105,110,100,111,119,95,32,61,32,34,111,98,106,101,99,116,34,32,61,61,61,32,116,121,112,101,111,102,32,119,105,110,100,111,119,32,63,32,119,105,110,100,111,119,32,58,32,115,101,108,102,44,32,99,114,121,112,116,111,95,32,61,32,116,121,112,101,111,102,32,119,105,110,100,111,119,95,46,99,114,121,112,116,111,32,33,61,61,32,34,117,110,100,101,102,105,110,101,100,34,32,63,32,119,105,110,100,111,119,95,46,99,114,121,112,116,111,32,58,32,119,105,110,100,111,119,95,46,109,115,67,114,121,112,116,111,44,32,114,97,110,100,111,109,86,97,108,117,101,115,83,116,97,110,100,97,114,100,32,61,32,102,117,110,99,116,105,111,110,40,41,32,123,32,118,97,114,32,98,117,102,32,61,32,110,101,119,32,85,105,110,116,51,50,65,114,114,97,121,40,49,41,59,32,99,114,121,112,116,111,95,46,103,101,116,82,97,110,100,111,109,86,97,108,117,101,115,40,98,117,102,41,59,32,114,101,116,117,114,110,32,98,117,102,91,48,93,32,62,62,62,32,48,59,32,125,59,32,114,97,110,100,111,109,86,97,108,117,101,115,83,116,97,110,100,97,114,100,40,41,59,32,77,111,100,117,108,101,46,103,101,116,82,97,110,100,111,109,86,97,108,117,101,32,61,32,114,97,110,100,111,109,86,97,108,117,101,115,83,116,97,110,100,97,114,100,59,32,125,32,99,97,116,99,104,32,40,101,41,32,123,32,116,114,121,32,123,32,118,97,114,32,99,114,121,112,116,111,32,61,32,114,101,113,117,105,114,101,40,39,99,114,121,112,116,111,39,41,44,32,114,97,110,100,111,109,86,97,108,117,101,78,111,100,101,74,83,32,61,32,102,117,110,99,116,105,111,110,40,41,32,123,32,118,97,114,32,98,117,102,32,61,32,99,114,121,112,116,111,46,114,97,110,100,111,109,66,121,116,101,115,40,52,41,59,32,114,101,116,117,114,110,32,40,98,117,102,91,48,93,32,60,60,32,50,52,32,124,32,98,117,102,91,49,93,32,60,60,32,49,54,32,124,32,98,117,102,91,50,93,32,60,60,32,56,32,124,32,98,117,102,91,51,93,41,32,62,62,62,32,48,59,32,125,59,32,114,97,110,100,111,109,86,97,108,117,101,78,111,100,101,74,83,40,41,59,32,77,111,100,117,108,101,46,103,101,116,82,97,110,100,111,109,86,97,108,117,101,32,61,32,114,97,110,100,111,109,86,97,108,117,101,78,111,100,101,74,83,59,32,125,32,99,97,116,99,104,32,40,101,41,32,123,32,116,104,114,111,119,32,39,78,111,32,115,101,99,117,114,101,32,114,97,110,100,111,109,32,110,117,109,98,101,114,32,103,101,110,101,114,97,116,111,114,32,102,111,117,110,100,39,59,32,125,32,125,32,125,32,125,0,49,46,48,46,54,0,9,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,101,120,112,97,110,100,32,51,50,45,98,121,116,101,32,107,101,120,112,97,110,100,32,51,50,45,98,121,116,101,32,107],\"i8\",ALLOC_NONE,Runtime.GLOBAL_BASE+30720);allocate([46,47,48,49,50,51,52,53,54,55,56,57,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,0],\"i8\",ALLOC_NONE,Runtime.GLOBAL_BASE+34873);var tempDoublePtr=Runtime.alignMemory(allocate(12,\"i8\",ALLOC_STATIC),8);assert(tempDoublePtr%8==0);function copyTempFloat(ptr){HEAP8[tempDoublePtr]=HEAP8[ptr];HEAP8[tempDoublePtr+1]=HEAP8[ptr+1];HEAP8[tempDoublePtr+2]=HEAP8[ptr+2];HEAP8[tempDoublePtr+3]=HEAP8[ptr+3]}function copyTempDouble(ptr){HEAP8[tempDoublePtr]=HEAP8[ptr];HEAP8[tempDoublePtr+1]=HEAP8[ptr+1];HEAP8[tempDoublePtr+2]=HEAP8[ptr+2];HEAP8[tempDoublePtr+3]=HEAP8[ptr+3];HEAP8[tempDoublePtr+4]=HEAP8[ptr+4];HEAP8[tempDoublePtr+5]=HEAP8[ptr+5];HEAP8[tempDoublePtr+6]=HEAP8[ptr+6];HEAP8[tempDoublePtr+7]=HEAP8[ptr+7]}function ___setErrNo(value){if(Module[\"___errno_location\"])HEAP32[Module[\"___errno_location\"]()>>2]=value;return value}var ERRNO_CODES={EPERM:1,ENOENT:2,ESRCH:3,EINTR:4,EIO:5,ENXIO:6,E2BIG:7,ENOEXEC:8,EBADF:9,ECHILD:10,EAGAIN:11,EWOULDBLOCK:11,ENOMEM:12,EACCES:13,EFAULT:14,ENOTBLK:15,EBUSY:16,EEXIST:17,EXDEV:18,ENODEV:19,ENOTDIR:20,EISDIR:21,EINVAL:22,ENFILE:23,EMFILE:24,ENOTTY:25,ETXTBSY:26,EFBIG:27,ENOSPC:28,ESPIPE:29,EROFS:30,EMLINK:31,EPIPE:32,EDOM:33,ERANGE:34,ENOMSG:42,EIDRM:43,ECHRNG:44,EL2NSYNC:45,EL3HLT:46,EL3RST:47,ELNRNG:48,EUNATCH:49,ENOCSI:50,EL2HLT:51,EDEADLK:35,ENOLCK:37,EBADE:52,EBADR:53,EXFULL:54,ENOANO:55,EBADRQC:56,EBADSLT:57,EDEADLOCK:35,EBFONT:59,ENOSTR:60,ENODATA:61,ETIME:62,ENOSR:63,ENONET:64,ENOPKG:65,EREMOTE:66,ENOLINK:67,EADV:68,ESRMNT:69,ECOMM:70,EPROTO:71,EMULTIHOP:72,EDOTDOT:73,EBADMSG:74,ENOTUNIQ:76,EBADFD:77,EREMCHG:78,ELIBACC:79,ELIBBAD:80,ELIBSCN:81,ELIBMAX:82,ELIBEXEC:83,ENOSYS:38,ENOTEMPTY:39,ENAMETOOLONG:36,ELOOP:40,EOPNOTSUPP:95,EPFNOSUPPORT:96,ECONNRESET:104,ENOBUFS:105,EAFNOSUPPORT:97,EPROTOTYPE:91,ENOTSOCK:88,ENOPROTOOPT:92,ESHUTDOWN:108,ECONNREFUSED:111,EADDRINUSE:98,ECONNABORTED:103,ENETUNREACH:101,ENETDOWN:100,ETIMEDOUT:110,EHOSTDOWN:112,EHOSTUNREACH:113,EINPROGRESS:115,EALREADY:114,EDESTADDRREQ:89,EMSGSIZE:90,EPROTONOSUPPORT:93,ESOCKTNOSUPPORT:94,EADDRNOTAVAIL:99,ENETRESET:102,EISCONN:106,ENOTCONN:107,ETOOMANYREFS:109,EUSERS:87,EDQUOT:122,ESTALE:116,ENOTSUP:95,ENOMEDIUM:123,EILSEQ:84,EOVERFLOW:75,ECANCELED:125,ENOTRECOVERABLE:131,EOWNERDEAD:130,ESTRPIPE:86};function _sysconf(name){switch(name){case 30:return PAGE_SIZE;case 85:return totalMemory/PAGE_SIZE;case 132:case 133:case 12:case 137:case 138:case 15:case 235:case 16:case 17:case 18:case 19:case 20:case 149:case 13:case 10:case 236:case 153:case 9:case 21:case 22:case 159:case 154:case 14:case 77:case 78:case 139:case 80:case 81:case 82:case 68:case 67:case 164:case 11:case 29:case 47:case 48:case 95:case 52:case 51:case 46:return 200809;case 79:return 0;case 27:case 246:case 127:case 128:case 23:case 24:case 160:case 161:case 181:case 182:case 242:case 183:case 184:case 243:case 244:case 245:case 165:case 178:case 179:case 49:case 50:case 168:case 169:case 175:case 170:case 171:case 172:case 97:case 76:case 32:case 173:case 35:return-1;case 176:case 177:case 7:case 155:case 8:case 157:case 125:case 126:case 92:case 93:case 129:case 130:case 131:case 94:case 91:return 1;case 74:case 60:case 69:case 70:case 4:return 1024;case 31:case 42:case 72:return 32;case 87:case 26:case 33:return 2147483647;case 34:case 1:return 47839;case 38:case 36:return 99;case 43:case 37:return 2048;case 0:return 2097152;case 3:return 65536;case 28:return 32768;case 44:return 32767;case 75:return 16384;case 39:return 1e3;case 89:return 700;case 71:return 256;case 40:return 255;case 2:return 100;case 180:return 64;case 25:return 20;case 5:return 16;case 6:return 6;case 73:return 4;case 84:{if(typeof navigator===\"object\")return navigator[\"hardwareConcurrency\"]||1;return 1}}___setErrNo(ERRNO_CODES.EINVAL);return-1}Module[\"_i64Subtract\"]=_i64Subtract;Module[\"_i64Add\"]=_i64Add;Module[\"_bitshift64Ashr\"]=_bitshift64Ashr;Module[\"_memset\"]=_memset;function _pthread_cleanup_push(routine,arg){__ATEXIT__.push((function(){Runtime.dynCall(\"vi\",routine,[arg])}));_pthread_cleanup_push.level=__ATEXIT__.length}Module[\"_bitshift64Lshr\"]=_bitshift64Lshr;Module[\"_bitshift64Shl\"]=_bitshift64Shl;function _pthread_cleanup_pop(){assert(_pthread_cleanup_push.level==__ATEXIT__.length,\"cannot pop if something else added meanwhile!\");__ATEXIT__.pop();_pthread_cleanup_push.level=__ATEXIT__.length}function _abort(){Module[\"abort\"]()}function ___lock(){}function ___unlock(){}var ERRNO_MESSAGES={0:\"Success\",1:\"Not super-user\",2:\"No such file or directory\",3:\"No such process\",4:\"Interrupted system call\",5:\"I/O error\",6:\"No such device or address\",7:\"Arg list too long\",8:\"Exec format error\",9:\"Bad file number\",10:\"No children\",11:\"No more processes\",12:\"Not enough core\",13:\"Permission denied\",14:\"Bad address\",15:\"Block device required\",16:\"Mount device busy\",17:\"File exists\",18:\"Cross-device link\",19:\"No such device\",20:\"Not a directory\",21:\"Is a directory\",22:\"Invalid argument\",23:\"Too many open files in system\",24:\"Too many open files\",25:\"Not a typewriter\",26:\"Text file busy\",27:\"File too large\",28:\"No space left on device\",29:\"Illegal seek\",30:\"Read only file system\",31:\"Too many links\",32:\"Broken pipe\",33:\"Math arg out of domain of func\",34:\"Math result not representable\",35:\"File locking deadlock error\",36:\"File or path name too long\",37:\"No record locks available\",38:\"Function not implemented\",39:\"Directory not empty\",40:\"Too many symbolic links\",42:\"No message of desired type\",43:\"Identifier removed\",44:\"Channel number out of range\",45:\"Level 2 not synchronized\",46:\"Level 3 halted\",47:\"Level 3 reset\",48:\"Link number out of range\",49:\"Protocol driver not attached\",50:\"No CSI structure available\",51:\"Level 2 halted\",52:\"Invalid exchange\",53:\"Invalid request descriptor\",54:\"Exchange full\",55:\"No anode\",56:\"Invalid request code\",57:\"Invalid slot\",59:\"Bad font file fmt\",60:\"Device not a stream\",61:\"No data (for no delay io)\",62:\"Timer expired\",63:\"Out of streams resources\",64:\"Machine is not on the network\",65:\"Package not installed\",66:\"The object is remote\",67:\"The link has been severed\",68:\"Advertise error\",69:\"Srmount error\",70:\"Communication error on send\",71:\"Protocol error\",72:\"Multihop attempted\",73:\"Cross mount point (not really error)\",74:\"Trying to read unreadable message\",75:\"Value too large for defined data type\",76:\"Given log. name not unique\",77:\"f.d. invalid for this operation\",78:\"Remote address changed\",79:\"Can   access a needed shared lib\",80:\"Accessing a corrupted shared lib\",81:\".lib section in a.out corrupted\",82:\"Attempting to link in too many libs\",83:\"Attempting to exec a shared library\",84:\"Illegal byte sequence\",86:\"Streams pipe error\",87:\"Too many users\",88:\"Socket operation on non-socket\",89:\"Destination address required\",90:\"Message too long\",91:\"Protocol wrong type for socket\",92:\"Protocol not available\",93:\"Unknown protocol\",94:\"Socket type not supported\",95:\"Not supported\",96:\"Protocol family not supported\",97:\"Address family not supported by protocol family\",98:\"Address already in use\",99:\"Address not available\",100:\"Network interface is not configured\",101:\"Network is unreachable\",102:\"Connection reset by network\",103:\"Connection aborted\",104:\"Connection reset by peer\",105:\"No buffer space available\",106:\"Socket is already connected\",107:\"Socket is not connected\",108:\"Can't send after socket shutdown\",109:\"Too many references\",110:\"Connection timed out\",111:\"Connection refused\",112:\"Host is down\",113:\"Host is unreachable\",114:\"Socket already connected\",115:\"Connection already in progress\",116:\"Stale file handle\",122:\"Quota exceeded\",123:\"No medium (in tape drive)\",125:\"Operation canceled\",130:\"Previous owner died\",131:\"State not recoverable\"};var PATH={splitPath:(function(filename){var splitPathRe=/^(\\/?|)([\\s\\S]*?)((?:\\.{1,2}|[^\\/]+?|)(\\.[^.\\/]*|))(?:[\\/]*)$/;return splitPathRe.exec(filename).slice(1)}),normalizeArray:(function(parts,allowAboveRoot){var up=0;for(var i=parts.length-1;i>=0;i--){var last=parts[i];if(last===\".\"){parts.splice(i,1)}else if(last===\"..\"){parts.splice(i,1);up++}else if(up){parts.splice(i,1);up--}}if(allowAboveRoot){for(;up--;up){parts.unshift(\"..\")}}return parts}),normalize:(function(path){var isAbsolute=path.charAt(0)===\"/\",trailingSlash=path.substr(-1)===\"/\";path=PATH.normalizeArray(path.split(\"/\").filter((function(p){return!!p})),!isAbsolute).join(\"/\");if(!path&&!isAbsolute){path=\".\"}if(path&&trailingSlash){path+=\"/\"}return(isAbsolute?\"/\":\"\")+path}),dirname:(function(path){var result=PATH.splitPath(path),root=result[0],dir=result[1];if(!root&&!dir){return\".\"}if(dir){dir=dir.substr(0,dir.length-1)}return root+dir}),basename:(function(path){if(path===\"/\")return\"/\";var lastSlash=path.lastIndexOf(\"/\");if(lastSlash===-1)return path;return path.substr(lastSlash+1)}),extname:(function(path){return PATH.splitPath(path)[3]}),join:(function(){var paths=Array.prototype.slice.call(arguments,0);return PATH.normalize(paths.join(\"/\"))}),join2:(function(l,r){return PATH.normalize(l+\"/\"+r)}),resolve:(function(){var resolvedPath=\"\",resolvedAbsolute=false;for(var i=arguments.length-1;i>=-1&&!resolvedAbsolute;i--){var path=i>=0?arguments[i]:FS.cwd();if(typeof path!==\"string\"){throw new TypeError(\"Arguments to path.resolve must be strings\")}else if(!path){return\"\"}resolvedPath=path+\"/\"+resolvedPath;resolvedAbsolute=path.charAt(0)===\"/\"}resolvedPath=PATH.normalizeArray(resolvedPath.split(\"/\").filter((function(p){return!!p})),!resolvedAbsolute).join(\"/\");return(resolvedAbsolute?\"/\":\"\")+resolvedPath||\".\"}),relative:(function(from,to){from=PATH.resolve(from).substr(1);to=PATH.resolve(to).substr(1);function trim(arr){var start=0;for(;start<arr.length;start++){if(arr[start]!==\"\")break}var end=arr.length-1;for(;end>=0;end--){if(arr[end]!==\"\")break}if(start>end)return[];return arr.slice(start,end-start+1)}var fromParts=trim(from.split(\"/\"));var toParts=trim(to.split(\"/\"));var length=Math.min(fromParts.length,toParts.length);var samePartsLength=length;for(var i=0;i<length;i++){if(fromParts[i]!==toParts[i]){samePartsLength=i;break}}var outputParts=[];for(var i=samePartsLength;i<fromParts.length;i++){outputParts.push(\"..\")}outputParts=outputParts.concat(toParts.slice(samePartsLength));return outputParts.join(\"/\")})};var TTY={ttys:[],init:(function(){}),shutdown:(function(){}),register:(function(dev,ops){TTY.ttys[dev]={input:[],output:[],ops:ops};FS.registerDevice(dev,TTY.stream_ops)}),stream_ops:{open:(function(stream){var tty=TTY.ttys[stream.node.rdev];if(!tty){throw new FS.ErrnoError(ERRNO_CODES.ENODEV)}stream.tty=tty;stream.seekable=false}),close:(function(stream){stream.tty.ops.flush(stream.tty)}),flush:(function(stream){stream.tty.ops.flush(stream.tty)}),read:(function(stream,buffer,offset,length,pos){if(!stream.tty||!stream.tty.ops.get_char){throw new FS.ErrnoError(ERRNO_CODES.ENXIO)}var bytesRead=0;for(var i=0;i<length;i++){var result;try{result=stream.tty.ops.get_char(stream.tty)}catch(e){throw new FS.ErrnoError(ERRNO_CODES.EIO)}if(result===undefined&&bytesRead===0){throw new FS.ErrnoError(ERRNO_CODES.EAGAIN)}if(result===null||result===undefined)break;bytesRead++;buffer[offset+i]=result}if(bytesRead){stream.node.timestamp=Date.now()}return bytesRead}),write:(function(stream,buffer,offset,length,pos){if(!stream.tty||!stream.tty.ops.put_char){throw new FS.ErrnoError(ERRNO_CODES.ENXIO)}for(var i=0;i<length;i++){try{stream.tty.ops.put_char(stream.tty,buffer[offset+i])}catch(e){throw new FS.ErrnoError(ERRNO_CODES.EIO)}}if(length){stream.node.timestamp=Date.now()}return i})},default_tty_ops:{get_char:(function(tty){if(!tty.input.length){var result=null;if(ENVIRONMENT_IS_NODE){var BUFSIZE=256;var buf=new Buffer(BUFSIZE);var bytesRead=0;var fd=process.stdin.fd;var usingDevice=false;try{fd=fs.openSync(\"/dev/stdin\",\"r\");usingDevice=true}catch(e){}bytesRead=fs.readSync(fd,buf,0,BUFSIZE,null);if(usingDevice){fs.closeSync(fd)}if(bytesRead>0){result=buf.slice(0,bytesRead).toString(\"utf-8\")}else{result=null}}else if(typeof window!=\"undefined\"&&typeof window.prompt==\"function\"){result=window.prompt(\"Input: \");if(result!==null){result+=\"\\n\"}}else if(typeof readline==\"function\"){result=readline();if(result!==null){result+=\"\\n\"}}if(!result){return null}tty.input=intArrayFromString(result,true)}return tty.input.shift()}),put_char:(function(tty,val){if(val===null||val===10){Module[\"print\"](UTF8ArrayToString(tty.output,0));tty.output=[]}else{if(val!=0)tty.output.push(val)}}),flush:(function(tty){if(tty.output&&tty.output.length>0){Module[\"print\"](UTF8ArrayToString(tty.output,0));tty.output=[]}})},default_tty1_ops:{put_char:(function(tty,val){if(val===null||val===10){Module[\"printErr\"](UTF8ArrayToString(tty.output,0));tty.output=[]}else{if(val!=0)tty.output.push(val)}}),flush:(function(tty){if(tty.output&&tty.output.length>0){Module[\"printErr\"](UTF8ArrayToString(tty.output,0));tty.output=[]}})}};var MEMFS={ops_table:null,mount:(function(mount){return MEMFS.createNode(null,\"/\",16384|511,0)}),createNode:(function(parent,name,mode,dev){if(FS.isBlkdev(mode)||FS.isFIFO(mode)){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}if(!MEMFS.ops_table){MEMFS.ops_table={dir:{node:{getattr:MEMFS.node_ops.getattr,setattr:MEMFS.node_ops.setattr,lookup:MEMFS.node_ops.lookup,mknod:MEMFS.node_ops.mknod,rename:MEMFS.node_ops.rename,unlink:MEMFS.node_ops.unlink,rmdir:MEMFS.node_ops.rmdir,readdir:MEMFS.node_ops.readdir,symlink:MEMFS.node_ops.symlink},stream:{llseek:MEMFS.stream_ops.llseek}},file:{node:{getattr:MEMFS.node_ops.getattr,setattr:MEMFS.node_ops.setattr},stream:{llseek:MEMFS.stream_ops.llseek,read:MEMFS.stream_ops.read,write:MEMFS.stream_ops.write,allocate:MEMFS.stream_ops.allocate,mmap:MEMFS.stream_ops.mmap,msync:MEMFS.stream_ops.msync}},link:{node:{getattr:MEMFS.node_ops.getattr,setattr:MEMFS.node_ops.setattr,readlink:MEMFS.node_ops.readlink},stream:{}},chrdev:{node:{getattr:MEMFS.node_ops.getattr,setattr:MEMFS.node_ops.setattr},stream:FS.chrdev_stream_ops}}}var node=FS.createNode(parent,name,mode,dev);if(FS.isDir(node.mode)){node.node_ops=MEMFS.ops_table.dir.node;node.stream_ops=MEMFS.ops_table.dir.stream;node.contents={}}else if(FS.isFile(node.mode)){node.node_ops=MEMFS.ops_table.file.node;node.stream_ops=MEMFS.ops_table.file.stream;node.usedBytes=0;node.contents=null}else if(FS.isLink(node.mode)){node.node_ops=MEMFS.ops_table.link.node;node.stream_ops=MEMFS.ops_table.link.stream}else if(FS.isChrdev(node.mode)){node.node_ops=MEMFS.ops_table.chrdev.node;node.stream_ops=MEMFS.ops_table.chrdev.stream}node.timestamp=Date.now();if(parent){parent.contents[name]=node}return node}),getFileDataAsRegularArray:(function(node){if(node.contents&&node.contents.subarray){var arr=[];for(var i=0;i<node.usedBytes;++i)arr.push(node.contents[i]);return arr}return node.contents}),getFileDataAsTypedArray:(function(node){if(!node.contents)return new Uint8Array;if(node.contents.subarray)return node.contents.subarray(0,node.usedBytes);return new Uint8Array(node.contents)}),expandFileStorage:(function(node,newCapacity){if(node.contents&&node.contents.subarray&&newCapacity>node.contents.length){node.contents=MEMFS.getFileDataAsRegularArray(node);node.usedBytes=node.contents.length}if(!node.contents||node.contents.subarray){var prevCapacity=node.contents?node.contents.buffer.byteLength:0;if(prevCapacity>=newCapacity)return;var CAPACITY_DOUBLING_MAX=1024*1024;newCapacity=Math.max(newCapacity,prevCapacity*(prevCapacity<CAPACITY_DOUBLING_MAX?2:1.125)|0);if(prevCapacity!=0)newCapacity=Math.max(newCapacity,256);var oldContents=node.contents;node.contents=new Uint8Array(newCapacity);if(node.usedBytes>0)node.contents.set(oldContents.subarray(0,node.usedBytes),0);return}if(!node.contents&&newCapacity>0)node.contents=[];while(node.contents.length<newCapacity)node.contents.push(0)}),resizeFileStorage:(function(node,newSize){if(node.usedBytes==newSize)return;if(newSize==0){node.contents=null;node.usedBytes=0;return}if(!node.contents||node.contents.subarray){var oldContents=node.contents;node.contents=new Uint8Array(new ArrayBuffer(newSize));if(oldContents){node.contents.set(oldContents.subarray(0,Math.min(newSize,node.usedBytes)))}node.usedBytes=newSize;return}if(!node.contents)node.contents=[];if(node.contents.length>newSize)node.contents.length=newSize;else while(node.contents.length<newSize)node.contents.push(0);node.usedBytes=newSize}),node_ops:{getattr:(function(node){var attr={};attr.dev=FS.isChrdev(node.mode)?node.id:1;attr.ino=node.id;attr.mode=node.mode;attr.nlink=1;attr.uid=0;attr.gid=0;attr.rdev=node.rdev;if(FS.isDir(node.mode)){attr.size=4096}else if(FS.isFile(node.mode)){attr.size=node.usedBytes}else if(FS.isLink(node.mode)){attr.size=node.link.length}else{attr.size=0}attr.atime=new Date(node.timestamp);attr.mtime=new Date(node.timestamp);attr.ctime=new Date(node.timestamp);attr.blksize=4096;attr.blocks=Math.ceil(attr.size/attr.blksize);return attr}),setattr:(function(node,attr){if(attr.mode!==undefined){node.mode=attr.mode}if(attr.timestamp!==undefined){node.timestamp=attr.timestamp}if(attr.size!==undefined){MEMFS.resizeFileStorage(node,attr.size)}}),lookup:(function(parent,name){throw FS.genericErrors[ERRNO_CODES.ENOENT]}),mknod:(function(parent,name,mode,dev){return MEMFS.createNode(parent,name,mode,dev)}),rename:(function(old_node,new_dir,new_name){if(FS.isDir(old_node.mode)){var new_node;try{new_node=FS.lookupNode(new_dir,new_name)}catch(e){}if(new_node){for(var i in new_node.contents){throw new FS.ErrnoError(ERRNO_CODES.ENOTEMPTY)}}}delete old_node.parent.contents[old_node.name];old_node.name=new_name;new_dir.contents[new_name]=old_node;old_node.parent=new_dir}),unlink:(function(parent,name){delete parent.contents[name]}),rmdir:(function(parent,name){var node=FS.lookupNode(parent,name);for(var i in node.contents){throw new FS.ErrnoError(ERRNO_CODES.ENOTEMPTY)}delete parent.contents[name]}),readdir:(function(node){var entries=[\".\",\"..\"];for(var key in node.contents){if(!node.contents.hasOwnProperty(key)){continue}entries.push(key)}return entries}),symlink:(function(parent,newname,oldpath){var node=MEMFS.createNode(parent,newname,511|40960,0);node.link=oldpath;return node}),readlink:(function(node){if(!FS.isLink(node.mode)){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}return node.link})},stream_ops:{read:(function(stream,buffer,offset,length,position){var contents=stream.node.contents;if(position>=stream.node.usedBytes)return 0;var size=Math.min(stream.node.usedBytes-position,length);assert(size>=0);if(size>8&&contents.subarray){buffer.set(contents.subarray(position,position+size),offset)}else{for(var i=0;i<size;i++)buffer[offset+i]=contents[position+i]}return size}),write:(function(stream,buffer,offset,length,position,canOwn){if(!length)return 0;var node=stream.node;node.timestamp=Date.now();if(buffer.subarray&&(!node.contents||node.contents.subarray)){if(canOwn){node.contents=buffer.subarray(offset,offset+length);node.usedBytes=length;return length}else if(node.usedBytes===0&&position===0){node.contents=new Uint8Array(buffer.subarray(offset,offset+length));node.usedBytes=length;return length}else if(position+length<=node.usedBytes){node.contents.set(buffer.subarray(offset,offset+length),position);return length}}MEMFS.expandFileStorage(node,position+length);if(node.contents.subarray&&buffer.subarray)node.contents.set(buffer.subarray(offset,offset+length),position);else{for(var i=0;i<length;i++){node.contents[position+i]=buffer[offset+i]}}node.usedBytes=Math.max(node.usedBytes,position+length);return length}),llseek:(function(stream,offset,whence){var position=offset;if(whence===1){position+=stream.position}else if(whence===2){if(FS.isFile(stream.node.mode)){position+=stream.node.usedBytes}}if(position<0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}return position}),allocate:(function(stream,offset,length){MEMFS.expandFileStorage(stream.node,offset+length);stream.node.usedBytes=Math.max(stream.node.usedBytes,offset+length)}),mmap:(function(stream,buffer,offset,length,position,prot,flags){if(!FS.isFile(stream.node.mode)){throw new FS.ErrnoError(ERRNO_CODES.ENODEV)}var ptr;var allocated;var contents=stream.node.contents;if(!(flags&2)&&(contents.buffer===buffer||contents.buffer===buffer.buffer)){allocated=false;ptr=contents.byteOffset}else{if(position>0||position+length<stream.node.usedBytes){if(contents.subarray){contents=contents.subarray(position,position+length)}else{contents=Array.prototype.slice.call(contents,position,position+length)}}allocated=true;ptr=_malloc(length);if(!ptr){throw new FS.ErrnoError(ERRNO_CODES.ENOMEM)}buffer.set(contents,ptr)}return{ptr:ptr,allocated:allocated}}),msync:(function(stream,buffer,offset,length,mmapFlags){if(!FS.isFile(stream.node.mode)){throw new FS.ErrnoError(ERRNO_CODES.ENODEV)}if(mmapFlags&2){return 0}var bytesWritten=MEMFS.stream_ops.write(stream,buffer,0,length,offset,false);return 0})}};var IDBFS={dbs:{},indexedDB:(function(){if(typeof indexedDB!==\"undefined\")return indexedDB;var ret=null;if(typeof window===\"object\")ret=window.indexedDB||window.mozIndexedDB||window.webkitIndexedDB||window.msIndexedDB;assert(ret,\"IDBFS used, but indexedDB not supported\");return ret}),DB_VERSION:21,DB_STORE_NAME:\"FILE_DATA\",mount:(function(mount){return MEMFS.mount.apply(null,arguments)}),syncfs:(function(mount,populate,callback){IDBFS.getLocalSet(mount,(function(err,local){if(err)return callback(err);IDBFS.getRemoteSet(mount,(function(err,remote){if(err)return callback(err);var src=populate?remote:local;var dst=populate?local:remote;IDBFS.reconcile(src,dst,callback)}))}))}),getDB:(function(name,callback){var db=IDBFS.dbs[name];if(db){return callback(null,db)}var req;try{req=IDBFS.indexedDB().open(name,IDBFS.DB_VERSION)}catch(e){return callback(e)}req.onupgradeneeded=(function(e){var db=e.target.result;var transaction=e.target.transaction;var fileStore;if(db.objectStoreNames.contains(IDBFS.DB_STORE_NAME)){fileStore=transaction.objectStore(IDBFS.DB_STORE_NAME)}else{fileStore=db.createObjectStore(IDBFS.DB_STORE_NAME)}if(!fileStore.indexNames.contains(\"timestamp\")){fileStore.createIndex(\"timestamp\",\"timestamp\",{unique:false})}});req.onsuccess=(function(){db=req.result;IDBFS.dbs[name]=db;callback(null,db)});req.onerror=(function(e){callback(this.error);e.preventDefault()})}),getLocalSet:(function(mount,callback){var entries={};function isRealDir(p){return p!==\".\"&&p!==\"..\"}function toAbsolute(root){return(function(p){return PATH.join2(root,p)})}var check=FS.readdir(mount.mountpoint).filter(isRealDir).map(toAbsolute(mount.mountpoint));while(check.length){var path=check.pop();var stat;try{stat=FS.stat(path)}catch(e){return callback(e)}if(FS.isDir(stat.mode)){check.push.apply(check,FS.readdir(path).filter(isRealDir).map(toAbsolute(path)))}entries[path]={timestamp:stat.mtime}}return callback(null,{type:\"local\",entries:entries})}),getRemoteSet:(function(mount,callback){var entries={};IDBFS.getDB(mount.mountpoint,(function(err,db){if(err)return callback(err);var transaction=db.transaction([IDBFS.DB_STORE_NAME],\"readonly\");transaction.onerror=(function(e){callback(this.error);e.preventDefault()});var store=transaction.objectStore(IDBFS.DB_STORE_NAME);var index=store.index(\"timestamp\");index.openKeyCursor().onsuccess=(function(event){var cursor=event.target.result;if(!cursor){return callback(null,{type:\"remote\",db:db,entries:entries})}entries[cursor.primaryKey]={timestamp:cursor.key};cursor.continue()})}))}),loadLocalEntry:(function(path,callback){var stat,node;try{var lookup=FS.lookupPath(path);node=lookup.node;stat=FS.stat(path)}catch(e){return callback(e)}if(FS.isDir(stat.mode)){return callback(null,{timestamp:stat.mtime,mode:stat.mode})}else if(FS.isFile(stat.mode)){node.contents=MEMFS.getFileDataAsTypedArray(node);return callback(null,{timestamp:stat.mtime,mode:stat.mode,contents:node.contents})}else{return callback(new Error(\"node type not supported\"))}}),storeLocalEntry:(function(path,entry,callback){try{if(FS.isDir(entry.mode)){FS.mkdir(path,entry.mode)}else if(FS.isFile(entry.mode)){FS.writeFile(path,entry.contents,{encoding:\"binary\",canOwn:true})}else{return callback(new Error(\"node type not supported\"))}FS.chmod(path,entry.mode);FS.utime(path,entry.timestamp,entry.timestamp)}catch(e){return callback(e)}callback(null)}),removeLocalEntry:(function(path,callback){try{var lookup=FS.lookupPath(path);var stat=FS.stat(path);if(FS.isDir(stat.mode)){FS.rmdir(path)}else if(FS.isFile(stat.mode)){FS.unlink(path)}}catch(e){return callback(e)}callback(null)}),loadRemoteEntry:(function(store,path,callback){var req=store.get(path);req.onsuccess=(function(event){callback(null,event.target.result)});req.onerror=(function(e){callback(this.error);e.preventDefault()})}),storeRemoteEntry:(function(store,path,entry,callback){var req=store.put(entry,path);req.onsuccess=(function(){callback(null)});req.onerror=(function(e){callback(this.error);e.preventDefault()})}),removeRemoteEntry:(function(store,path,callback){var req=store.delete(path);req.onsuccess=(function(){callback(null)});req.onerror=(function(e){callback(this.error);e.preventDefault()})}),reconcile:(function(src,dst,callback){var total=0;var create=[];Object.keys(src.entries).forEach((function(key){var e=src.entries[key];var e2=dst.entries[key];if(!e2||e.timestamp>e2.timestamp){create.push(key);total++}}));var remove=[];Object.keys(dst.entries).forEach((function(key){var e=dst.entries[key];var e2=src.entries[key];if(!e2){remove.push(key);total++}}));if(!total){return callback(null)}var errored=false;var completed=0;var db=src.type===\"remote\"?src.db:dst.db;var transaction=db.transaction([IDBFS.DB_STORE_NAME],\"readwrite\");var store=transaction.objectStore(IDBFS.DB_STORE_NAME);function done(err){if(err){if(!done.errored){done.errored=true;return callback(err)}return}if(++completed>=total){return callback(null)}}transaction.onerror=(function(e){done(this.error);e.preventDefault()});create.sort().forEach((function(path){if(dst.type===\"local\"){IDBFS.loadRemoteEntry(store,path,(function(err,entry){if(err)return done(err);IDBFS.storeLocalEntry(path,entry,done)}))}else{IDBFS.loadLocalEntry(path,(function(err,entry){if(err)return done(err);IDBFS.storeRemoteEntry(store,path,entry,done)}))}}));remove.sort().reverse().forEach((function(path){if(dst.type===\"local\"){IDBFS.removeLocalEntry(path,done)}else{IDBFS.removeRemoteEntry(store,path,done)}}))})};var NODEFS={isWindows:false,staticInit:(function(){NODEFS.isWindows=!!process.platform.match(/^win/)}),mount:(function(mount){assert(ENVIRONMENT_IS_NODE);return NODEFS.createNode(null,\"/\",NODEFS.getMode(mount.opts.root),0)}),createNode:(function(parent,name,mode,dev){if(!FS.isDir(mode)&&!FS.isFile(mode)&&!FS.isLink(mode)){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var node=FS.createNode(parent,name,mode);node.node_ops=NODEFS.node_ops;node.stream_ops=NODEFS.stream_ops;return node}),getMode:(function(path){var stat;try{stat=fs.lstatSync(path);if(NODEFS.isWindows){stat.mode=stat.mode|(stat.mode&146)>>1}}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}return stat.mode}),realPath:(function(node){var parts=[];while(node.parent!==node){parts.push(node.name);node=node.parent}parts.push(node.mount.opts.root);parts.reverse();return PATH.join.apply(null,parts)}),flagsToPermissionStringMap:{0:\"r\",1:\"r+\",2:\"r+\",64:\"r\",65:\"r+\",66:\"r+\",129:\"rx+\",193:\"rx+\",514:\"w+\",577:\"w\",578:\"w+\",705:\"wx\",706:\"wx+\",1024:\"a\",1025:\"a\",1026:\"a+\",1089:\"a\",1090:\"a+\",1153:\"ax\",1154:\"ax+\",1217:\"ax\",1218:\"ax+\",4096:\"rs\",4098:\"rs+\"},flagsToPermissionString:(function(flags){flags&=~32768;if(flags in NODEFS.flagsToPermissionStringMap){return NODEFS.flagsToPermissionStringMap[flags]}else{throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}}),node_ops:{getattr:(function(node){var path=NODEFS.realPath(node);var stat;try{stat=fs.lstatSync(path)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}if(NODEFS.isWindows&&!stat.blksize){stat.blksize=4096}if(NODEFS.isWindows&&!stat.blocks){stat.blocks=(stat.size+stat.blksize-1)/stat.blksize|0}return{dev:stat.dev,ino:stat.ino,mode:stat.mode,nlink:stat.nlink,uid:stat.uid,gid:stat.gid,rdev:stat.rdev,size:stat.size,atime:stat.atime,mtime:stat.mtime,ctime:stat.ctime,blksize:stat.blksize,blocks:stat.blocks}}),setattr:(function(node,attr){var path=NODEFS.realPath(node);try{if(attr.mode!==undefined){fs.chmodSync(path,attr.mode);node.mode=attr.mode}if(attr.timestamp!==undefined){var date=new Date(attr.timestamp);fs.utimesSync(path,date,date)}if(attr.size!==undefined){fs.truncateSync(path,attr.size)}}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),lookup:(function(parent,name){var path=PATH.join2(NODEFS.realPath(parent),name);var mode=NODEFS.getMode(path);return NODEFS.createNode(parent,name,mode)}),mknod:(function(parent,name,mode,dev){var node=NODEFS.createNode(parent,name,mode,dev);var path=NODEFS.realPath(node);try{if(FS.isDir(node.mode)){fs.mkdirSync(path,node.mode)}else{fs.writeFileSync(path,\"\",{mode:node.mode})}}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}return node}),rename:(function(oldNode,newDir,newName){var oldPath=NODEFS.realPath(oldNode);var newPath=PATH.join2(NODEFS.realPath(newDir),newName);try{fs.renameSync(oldPath,newPath)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),unlink:(function(parent,name){var path=PATH.join2(NODEFS.realPath(parent),name);try{fs.unlinkSync(path)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),rmdir:(function(parent,name){var path=PATH.join2(NODEFS.realPath(parent),name);try{fs.rmdirSync(path)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),readdir:(function(node){var path=NODEFS.realPath(node);try{return fs.readdirSync(path)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),symlink:(function(parent,newName,oldPath){var newPath=PATH.join2(NODEFS.realPath(parent),newName);try{fs.symlinkSync(oldPath,newPath)}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),readlink:(function(node){var path=NODEFS.realPath(node);try{path=fs.readlinkSync(path);path=NODEJS_PATH.relative(NODEJS_PATH.resolve(node.mount.opts.root),path);return path}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}})},stream_ops:{open:(function(stream){var path=NODEFS.realPath(stream.node);try{if(FS.isFile(stream.node.mode)){stream.nfd=fs.openSync(path,NODEFS.flagsToPermissionString(stream.flags))}}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),close:(function(stream){try{if(FS.isFile(stream.node.mode)&&stream.nfd){fs.closeSync(stream.nfd)}}catch(e){if(!e.code)throw e;throw new FS.ErrnoError(ERRNO_CODES[e.code])}}),read:(function(stream,buffer,offset,length,position){if(length===0)return 0;var nbuffer=new Buffer(length);var res;try{res=fs.readSync(stream.nfd,nbuffer,0,length,position)}catch(e){throw new FS.ErrnoError(ERRNO_CODES[e.code])}if(res>0){for(var i=0;i<res;i++){buffer[offset+i]=nbuffer[i]}}return res}),write:(function(stream,buffer,offset,length,position){var nbuffer=new Buffer(buffer.subarray(offset,offset+length));var res;try{res=fs.writeSync(stream.nfd,nbuffer,0,length,position)}catch(e){throw new FS.ErrnoError(ERRNO_CODES[e.code])}return res}),llseek:(function(stream,offset,whence){var position=offset;if(whence===1){position+=stream.position}else if(whence===2){if(FS.isFile(stream.node.mode)){try{var stat=fs.fstatSync(stream.nfd);position+=stat.size}catch(e){throw new FS.ErrnoError(ERRNO_CODES[e.code])}}}if(position<0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}return position})}};var WORKERFS={DIR_MODE:16895,FILE_MODE:33279,reader:null,mount:(function(mount){assert(ENVIRONMENT_IS_WORKER);if(!WORKERFS.reader)WORKERFS.reader=new FileReaderSync;var root=WORKERFS.createNode(null,\"/\",WORKERFS.DIR_MODE,0);var createdParents={};function ensureParent(path){var parts=path.split(\"/\");var parent=root;for(var i=0;i<parts.length-1;i++){var curr=parts.slice(0,i+1).join(\"/\");if(!createdParents[curr]){createdParents[curr]=WORKERFS.createNode(parent,curr,WORKERFS.DIR_MODE,0)}parent=createdParents[curr]}return parent}function base(path){var parts=path.split(\"/\");return parts[parts.length-1]}Array.prototype.forEach.call(mount.opts[\"files\"]||[],(function(file){WORKERFS.createNode(ensureParent(file.name),base(file.name),WORKERFS.FILE_MODE,0,file,file.lastModifiedDate)}));(mount.opts[\"blobs\"]||[]).forEach((function(obj){WORKERFS.createNode(ensureParent(obj[\"name\"]),base(obj[\"name\"]),WORKERFS.FILE_MODE,0,obj[\"data\"])}));(mount.opts[\"packages\"]||[]).forEach((function(pack){pack[\"metadata\"].files.forEach((function(file){var name=file.filename.substr(1);WORKERFS.createNode(ensureParent(name),base(name),WORKERFS.FILE_MODE,0,pack[\"blob\"].slice(file.start,file.end))}))}));return root}),createNode:(function(parent,name,mode,dev,contents,mtime){var node=FS.createNode(parent,name,mode);node.mode=mode;node.node_ops=WORKERFS.node_ops;node.stream_ops=WORKERFS.stream_ops;node.timestamp=(mtime||new Date).getTime();assert(WORKERFS.FILE_MODE!==WORKERFS.DIR_MODE);if(mode===WORKERFS.FILE_MODE){node.size=contents.size;node.contents=contents}else{node.size=4096;node.contents={}}if(parent){parent.contents[name]=node}return node}),node_ops:{getattr:(function(node){return{dev:1,ino:undefined,mode:node.mode,nlink:1,uid:0,gid:0,rdev:undefined,size:node.size,atime:new Date(node.timestamp),mtime:new Date(node.timestamp),ctime:new Date(node.timestamp),blksize:4096,blocks:Math.ceil(node.size/4096)}}),setattr:(function(node,attr){if(attr.mode!==undefined){node.mode=attr.mode}if(attr.timestamp!==undefined){node.timestamp=attr.timestamp}}),lookup:(function(parent,name){throw new FS.ErrnoError(ERRNO_CODES.ENOENT)}),mknod:(function(parent,name,mode,dev){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}),rename:(function(oldNode,newDir,newName){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}),unlink:(function(parent,name){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}),rmdir:(function(parent,name){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}),readdir:(function(node){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}),symlink:(function(parent,newName,oldPath){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}),readlink:(function(node){throw new FS.ErrnoError(ERRNO_CODES.EPERM)})},stream_ops:{read:(function(stream,buffer,offset,length,position){if(position>=stream.node.size)return 0;var chunk=stream.node.contents.slice(position,position+length);var ab=WORKERFS.reader.readAsArrayBuffer(chunk);buffer.set(new Uint8Array(ab),offset);return chunk.size}),write:(function(stream,buffer,offset,length,position){throw new FS.ErrnoError(ERRNO_CODES.EIO)}),llseek:(function(stream,offset,whence){var position=offset;if(whence===1){position+=stream.position}else if(whence===2){if(FS.isFile(stream.node.mode)){position+=stream.node.size}}if(position<0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}return position})}};var _stdin=allocate(1,\"i32*\",ALLOC_STATIC);var _stdout=allocate(1,\"i32*\",ALLOC_STATIC);var _stderr=allocate(1,\"i32*\",ALLOC_STATIC);var FS={root:null,mounts:[],devices:[null],streams:[],nextInode:1,nameTable:null,currentPath:\"/\",initialized:false,ignorePermissions:true,trackingDelegate:{},tracking:{openFlags:{READ:1,WRITE:2}},ErrnoError:null,genericErrors:{},filesystems:null,handleFSError:(function(e){if(!(e instanceof FS.ErrnoError))throw e+\" : \"+stackTrace();return ___setErrNo(e.errno)}),lookupPath:(function(path,opts){path=PATH.resolve(FS.cwd(),path);opts=opts||{};if(!path)return{path:\"\",node:null};var defaults={follow_mount:true,recurse_count:0};for(var key in defaults){if(opts[key]===undefined){opts[key]=defaults[key]}}if(opts.recurse_count>8){throw new FS.ErrnoError(ERRNO_CODES.ELOOP)}var parts=PATH.normalizeArray(path.split(\"/\").filter((function(p){return!!p})),false);var current=FS.root;var current_path=\"/\";for(var i=0;i<parts.length;i++){var islast=i===parts.length-1;if(islast&&opts.parent){break}current=FS.lookupNode(current,parts[i]);current_path=PATH.join2(current_path,parts[i]);if(FS.isMountpoint(current)){if(!islast||islast&&opts.follow_mount){current=current.mounted.root}}if(!islast||opts.follow){var count=0;while(FS.isLink(current.mode)){var link=FS.readlink(current_path);current_path=PATH.resolve(PATH.dirname(current_path),link);var lookup=FS.lookupPath(current_path,{recurse_count:opts.recurse_count});current=lookup.node;if(count++>40){throw new FS.ErrnoError(ERRNO_CODES.ELOOP)}}}}return{path:current_path,node:current}}),getPath:(function(node){var path;while(true){if(FS.isRoot(node)){var mount=node.mount.mountpoint;if(!path)return mount;return mount[mount.length-1]!==\"/\"?mount+\"/\"+path:mount+path}path=path?node.name+\"/\"+path:node.name;node=node.parent}}),hashName:(function(parentid,name){var hash=0;for(var i=0;i<name.length;i++){hash=(hash<<5)-hash+name.charCodeAt(i)|0}return(parentid+hash>>>0)%FS.nameTable.length}),hashAddNode:(function(node){var hash=FS.hashName(node.parent.id,node.name);node.name_next=FS.nameTable[hash];FS.nameTable[hash]=node}),hashRemoveNode:(function(node){var hash=FS.hashName(node.parent.id,node.name);if(FS.nameTable[hash]===node){FS.nameTable[hash]=node.name_next}else{var current=FS.nameTable[hash];while(current){if(current.name_next===node){current.name_next=node.name_next;break}current=current.name_next}}}),lookupNode:(function(parent,name){var err=FS.mayLookup(parent);if(err){throw new FS.ErrnoError(err,parent)}var hash=FS.hashName(parent.id,name);for(var node=FS.nameTable[hash];node;node=node.name_next){var nodeName=node.name;if(node.parent.id===parent.id&&nodeName===name){return node}}return FS.lookup(parent,name)}),createNode:(function(parent,name,mode,rdev){if(!FS.FSNode){FS.FSNode=(function(parent,name,mode,rdev){if(!parent){parent=this}this.parent=parent;this.mount=parent.mount;this.mounted=null;this.id=FS.nextInode++;this.name=name;this.mode=mode;this.node_ops={};this.stream_ops={};this.rdev=rdev});FS.FSNode.prototype={};var readMode=292|73;var writeMode=146;Object.defineProperties(FS.FSNode.prototype,{read:{get:(function(){return(this.mode&readMode)===readMode}),set:(function(val){val?this.mode|=readMode:this.mode&=~readMode})},write:{get:(function(){return(this.mode&writeMode)===writeMode}),set:(function(val){val?this.mode|=writeMode:this.mode&=~writeMode})},isFolder:{get:(function(){return FS.isDir(this.mode)})},isDevice:{get:(function(){return FS.isChrdev(this.mode)})}})}var node=new FS.FSNode(parent,name,mode,rdev);FS.hashAddNode(node);return node}),destroyNode:(function(node){FS.hashRemoveNode(node)}),isRoot:(function(node){return node===node.parent}),isMountpoint:(function(node){return!!node.mounted}),isFile:(function(mode){return(mode&61440)===32768}),isDir:(function(mode){return(mode&61440)===16384}),isLink:(function(mode){return(mode&61440)===40960}),isChrdev:(function(mode){return(mode&61440)===8192}),isBlkdev:(function(mode){return(mode&61440)===24576}),isFIFO:(function(mode){return(mode&61440)===4096}),isSocket:(function(mode){return(mode&49152)===49152}),flagModes:{\"r\":0,\"rs\":1052672,\"r+\":2,\"w\":577,\"wx\":705,\"xw\":705,\"w+\":578,\"wx+\":706,\"xw+\":706,\"a\":1089,\"ax\":1217,\"xa\":1217,\"a+\":1090,\"ax+\":1218,\"xa+\":1218},modeStringToFlags:(function(str){var flags=FS.flagModes[str];if(typeof flags===\"undefined\"){throw new Error(\"Unknown file open mode: \"+str)}return flags}),flagsToPermissionString:(function(flag){var perms=[\"r\",\"w\",\"rw\"][flag&3];if(flag&512){perms+=\"w\"}return perms}),nodePermissions:(function(node,perms){if(FS.ignorePermissions){return 0}if(perms.indexOf(\"r\")!==-1&&!(node.mode&292)){return ERRNO_CODES.EACCES}else if(perms.indexOf(\"w\")!==-1&&!(node.mode&146)){return ERRNO_CODES.EACCES}else if(perms.indexOf(\"x\")!==-1&&!(node.mode&73)){return ERRNO_CODES.EACCES}return 0}),mayLookup:(function(dir){var err=FS.nodePermissions(dir,\"x\");if(err)return err;if(!dir.node_ops.lookup)return ERRNO_CODES.EACCES;return 0}),mayCreate:(function(dir,name){try{var node=FS.lookupNode(dir,name);return ERRNO_CODES.EEXIST}catch(e){}return FS.nodePermissions(dir,\"wx\")}),mayDelete:(function(dir,name,isdir){var node;try{node=FS.lookupNode(dir,name)}catch(e){return e.errno}var err=FS.nodePermissions(dir,\"wx\");if(err){return err}if(isdir){if(!FS.isDir(node.mode)){return ERRNO_CODES.ENOTDIR}if(FS.isRoot(node)||FS.getPath(node)===FS.cwd()){return ERRNO_CODES.EBUSY}}else{if(FS.isDir(node.mode)){return ERRNO_CODES.EISDIR}}return 0}),mayOpen:(function(node,flags){if(!node){return ERRNO_CODES.ENOENT}if(FS.isLink(node.mode)){return ERRNO_CODES.ELOOP}else if(FS.isDir(node.mode)){if((flags&2097155)!==0||flags&512){return ERRNO_CODES.EISDIR}}return FS.nodePermissions(node,FS.flagsToPermissionString(flags))}),MAX_OPEN_FDS:4096,nextfd:(function(fd_start,fd_end){fd_start=fd_start||0;fd_end=fd_end||FS.MAX_OPEN_FDS;for(var fd=fd_start;fd<=fd_end;fd++){if(!FS.streams[fd]){return fd}}throw new FS.ErrnoError(ERRNO_CODES.EMFILE)}),getStream:(function(fd){return FS.streams[fd]}),createStream:(function(stream,fd_start,fd_end){if(!FS.FSStream){FS.FSStream=(function(){});FS.FSStream.prototype={};Object.defineProperties(FS.FSStream.prototype,{object:{get:(function(){return this.node}),set:(function(val){this.node=val})},isRead:{get:(function(){return(this.flags&2097155)!==1})},isWrite:{get:(function(){return(this.flags&2097155)!==0})},isAppend:{get:(function(){return this.flags&1024})}})}var newStream=new FS.FSStream;for(var p in stream){newStream[p]=stream[p]}stream=newStream;var fd=FS.nextfd(fd_start,fd_end);stream.fd=fd;FS.streams[fd]=stream;return stream}),closeStream:(function(fd){FS.streams[fd]=null}),chrdev_stream_ops:{open:(function(stream){var device=FS.getDevice(stream.node.rdev);stream.stream_ops=device.stream_ops;if(stream.stream_ops.open){stream.stream_ops.open(stream)}}),llseek:(function(){throw new FS.ErrnoError(ERRNO_CODES.ESPIPE)})},major:(function(dev){return dev>>8}),minor:(function(dev){return dev&255}),makedev:(function(ma,mi){return ma<<8|mi}),registerDevice:(function(dev,ops){FS.devices[dev]={stream_ops:ops}}),getDevice:(function(dev){return FS.devices[dev]}),getMounts:(function(mount){var mounts=[];var check=[mount];while(check.length){var m=check.pop();mounts.push(m);check.push.apply(check,m.mounts)}return mounts}),syncfs:(function(populate,callback){if(typeof populate===\"function\"){callback=populate;populate=false}var mounts=FS.getMounts(FS.root.mount);var completed=0;function done(err){if(err){if(!done.errored){done.errored=true;return callback(err)}return}if(++completed>=mounts.length){callback(null)}}mounts.forEach((function(mount){if(!mount.type.syncfs){return done(null)}mount.type.syncfs(mount,populate,done)}))}),mount:(function(type,opts,mountpoint){var root=mountpoint===\"/\";var pseudo=!mountpoint;var node;if(root&&FS.root){throw new FS.ErrnoError(ERRNO_CODES.EBUSY)}else if(!root&&!pseudo){var lookup=FS.lookupPath(mountpoint,{follow_mount:false});mountpoint=lookup.path;node=lookup.node;if(FS.isMountpoint(node)){throw new FS.ErrnoError(ERRNO_CODES.EBUSY)}if(!FS.isDir(node.mode)){throw new FS.ErrnoError(ERRNO_CODES.ENOTDIR)}}var mount={type:type,opts:opts,mountpoint:mountpoint,mounts:[]};var mountRoot=type.mount(mount);mountRoot.mount=mount;mount.root=mountRoot;if(root){FS.root=mountRoot}else if(node){node.mounted=mount;if(node.mount){node.mount.mounts.push(mount)}}return mountRoot}),unmount:(function(mountpoint){var lookup=FS.lookupPath(mountpoint,{follow_mount:false});if(!FS.isMountpoint(lookup.node)){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var node=lookup.node;var mount=node.mounted;var mounts=FS.getMounts(mount);Object.keys(FS.nameTable).forEach((function(hash){var current=FS.nameTable[hash];while(current){var next=current.name_next;if(mounts.indexOf(current.mount)!==-1){FS.destroyNode(current)}current=next}}));node.mounted=null;var idx=node.mount.mounts.indexOf(mount);assert(idx!==-1);node.mount.mounts.splice(idx,1)}),lookup:(function(parent,name){return parent.node_ops.lookup(parent,name)}),mknod:(function(path,mode,dev){var lookup=FS.lookupPath(path,{parent:true});var parent=lookup.node;var name=PATH.basename(path);if(!name||name===\".\"||name===\"..\"){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var err=FS.mayCreate(parent,name);if(err){throw new FS.ErrnoError(err)}if(!parent.node_ops.mknod){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}return parent.node_ops.mknod(parent,name,mode,dev)}),create:(function(path,mode){mode=mode!==undefined?mode:438;mode&=4095;mode|=32768;return FS.mknod(path,mode,0)}),mkdir:(function(path,mode){mode=mode!==undefined?mode:511;mode&=511|512;mode|=16384;return FS.mknod(path,mode,0)}),mkdev:(function(path,mode,dev){if(typeof dev===\"undefined\"){dev=mode;mode=438}mode|=8192;return FS.mknod(path,mode,dev)}),symlink:(function(oldpath,newpath){if(!PATH.resolve(oldpath)){throw new FS.ErrnoError(ERRNO_CODES.ENOENT)}var lookup=FS.lookupPath(newpath,{parent:true});var parent=lookup.node;if(!parent){throw new FS.ErrnoError(ERRNO_CODES.ENOENT)}var newname=PATH.basename(newpath);var err=FS.mayCreate(parent,newname);if(err){throw new FS.ErrnoError(err)}if(!parent.node_ops.symlink){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}return parent.node_ops.symlink(parent,newname,oldpath)}),rename:(function(old_path,new_path){var old_dirname=PATH.dirname(old_path);var new_dirname=PATH.dirname(new_path);var old_name=PATH.basename(old_path);var new_name=PATH.basename(new_path);var lookup,old_dir,new_dir;try{lookup=FS.lookupPath(old_path,{parent:true});old_dir=lookup.node;lookup=FS.lookupPath(new_path,{parent:true});new_dir=lookup.node}catch(e){throw new FS.ErrnoError(ERRNO_CODES.EBUSY)}if(!old_dir||!new_dir)throw new FS.ErrnoError(ERRNO_CODES.ENOENT);if(old_dir.mount!==new_dir.mount){throw new FS.ErrnoError(ERRNO_CODES.EXDEV)}var old_node=FS.lookupNode(old_dir,old_name);var relative=PATH.relative(old_path,new_dirname);if(relative.charAt(0)!==\".\"){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}relative=PATH.relative(new_path,old_dirname);if(relative.charAt(0)!==\".\"){throw new FS.ErrnoError(ERRNO_CODES.ENOTEMPTY)}var new_node;try{new_node=FS.lookupNode(new_dir,new_name)}catch(e){}if(old_node===new_node){return}var isdir=FS.isDir(old_node.mode);var err=FS.mayDelete(old_dir,old_name,isdir);if(err){throw new FS.ErrnoError(err)}err=new_node?FS.mayDelete(new_dir,new_name,isdir):FS.mayCreate(new_dir,new_name);if(err){throw new FS.ErrnoError(err)}if(!old_dir.node_ops.rename){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}if(FS.isMountpoint(old_node)||new_node&&FS.isMountpoint(new_node)){throw new FS.ErrnoError(ERRNO_CODES.EBUSY)}if(new_dir!==old_dir){err=FS.nodePermissions(old_dir,\"w\");if(err){throw new FS.ErrnoError(err)}}try{if(FS.trackingDelegate[\"willMovePath\"]){FS.trackingDelegate[\"willMovePath\"](old_path,new_path)}}catch(e){console.log(\"FS.trackingDelegate['willMovePath']('\"+old_path+\"', '\"+new_path+\"') threw an exception: \"+e.message)}FS.hashRemoveNode(old_node);try{old_dir.node_ops.rename(old_node,new_dir,new_name)}catch(e){throw e}finally{FS.hashAddNode(old_node)}try{if(FS.trackingDelegate[\"onMovePath\"])FS.trackingDelegate[\"onMovePath\"](old_path,new_path)}catch(e){console.log(\"FS.trackingDelegate['onMovePath']('\"+old_path+\"', '\"+new_path+\"') threw an exception: \"+e.message)}}),rmdir:(function(path){var lookup=FS.lookupPath(path,{parent:true});var parent=lookup.node;var name=PATH.basename(path);var node=FS.lookupNode(parent,name);var err=FS.mayDelete(parent,name,true);if(err){throw new FS.ErrnoError(err)}if(!parent.node_ops.rmdir){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}if(FS.isMountpoint(node)){throw new FS.ErrnoError(ERRNO_CODES.EBUSY)}try{if(FS.trackingDelegate[\"willDeletePath\"]){FS.trackingDelegate[\"willDeletePath\"](path)}}catch(e){console.log(\"FS.trackingDelegate['willDeletePath']('\"+path+\"') threw an exception: \"+e.message)}parent.node_ops.rmdir(parent,name);FS.destroyNode(node);try{if(FS.trackingDelegate[\"onDeletePath\"])FS.trackingDelegate[\"onDeletePath\"](path)}catch(e){console.log(\"FS.trackingDelegate['onDeletePath']('\"+path+\"') threw an exception: \"+e.message)}}),readdir:(function(path){var lookup=FS.lookupPath(path,{follow:true});var node=lookup.node;if(!node.node_ops.readdir){throw new FS.ErrnoError(ERRNO_CODES.ENOTDIR)}return node.node_ops.readdir(node)}),unlink:(function(path){var lookup=FS.lookupPath(path,{parent:true});var parent=lookup.node;var name=PATH.basename(path);var node=FS.lookupNode(parent,name);var err=FS.mayDelete(parent,name,false);if(err){if(err===ERRNO_CODES.EISDIR)err=ERRNO_CODES.EPERM;throw new FS.ErrnoError(err)}if(!parent.node_ops.unlink){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}if(FS.isMountpoint(node)){throw new FS.ErrnoError(ERRNO_CODES.EBUSY)}try{if(FS.trackingDelegate[\"willDeletePath\"]){FS.trackingDelegate[\"willDeletePath\"](path)}}catch(e){console.log(\"FS.trackingDelegate['willDeletePath']('\"+path+\"') threw an exception: \"+e.message)}parent.node_ops.unlink(parent,name);FS.destroyNode(node);try{if(FS.trackingDelegate[\"onDeletePath\"])FS.trackingDelegate[\"onDeletePath\"](path)}catch(e){console.log(\"FS.trackingDelegate['onDeletePath']('\"+path+\"') threw an exception: \"+e.message)}}),readlink:(function(path){var lookup=FS.lookupPath(path);var link=lookup.node;if(!link){throw new FS.ErrnoError(ERRNO_CODES.ENOENT)}if(!link.node_ops.readlink){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}return PATH.resolve(FS.getPath(link.parent),link.node_ops.readlink(link))}),stat:(function(path,dontFollow){var lookup=FS.lookupPath(path,{follow:!dontFollow});var node=lookup.node;if(!node){throw new FS.ErrnoError(ERRNO_CODES.ENOENT)}if(!node.node_ops.getattr){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}return node.node_ops.getattr(node)}),lstat:(function(path){return FS.stat(path,true)}),chmod:(function(path,mode,dontFollow){var node;if(typeof path===\"string\"){var lookup=FS.lookupPath(path,{follow:!dontFollow});node=lookup.node}else{node=path}if(!node.node_ops.setattr){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}node.node_ops.setattr(node,{mode:mode&4095|node.mode&~4095,timestamp:Date.now()})}),lchmod:(function(path,mode){FS.chmod(path,mode,true)}),fchmod:(function(fd,mode){var stream=FS.getStream(fd);if(!stream){throw new FS.ErrnoError(ERRNO_CODES.EBADF)}FS.chmod(stream.node,mode)}),chown:(function(path,uid,gid,dontFollow){var node;if(typeof path===\"string\"){var lookup=FS.lookupPath(path,{follow:!dontFollow});node=lookup.node}else{node=path}if(!node.node_ops.setattr){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}node.node_ops.setattr(node,{timestamp:Date.now()})}),lchown:(function(path,uid,gid){FS.chown(path,uid,gid,true)}),fchown:(function(fd,uid,gid){var stream=FS.getStream(fd);if(!stream){throw new FS.ErrnoError(ERRNO_CODES.EBADF)}FS.chown(stream.node,uid,gid)}),truncate:(function(path,len){if(len<0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var node;if(typeof path===\"string\"){var lookup=FS.lookupPath(path,{follow:true});node=lookup.node}else{node=path}if(!node.node_ops.setattr){throw new FS.ErrnoError(ERRNO_CODES.EPERM)}if(FS.isDir(node.mode)){throw new FS.ErrnoError(ERRNO_CODES.EISDIR)}if(!FS.isFile(node.mode)){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var err=FS.nodePermissions(node,\"w\");if(err){throw new FS.ErrnoError(err)}node.node_ops.setattr(node,{size:len,timestamp:Date.now()})}),ftruncate:(function(fd,len){var stream=FS.getStream(fd);if(!stream){throw new FS.ErrnoError(ERRNO_CODES.EBADF)}if((stream.flags&2097155)===0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}FS.truncate(stream.node,len)}),utime:(function(path,atime,mtime){var lookup=FS.lookupPath(path,{follow:true});var node=lookup.node;node.node_ops.setattr(node,{timestamp:Math.max(atime,mtime)})}),open:(function(path,flags,mode,fd_start,fd_end){if(path===\"\"){throw new FS.ErrnoError(ERRNO_CODES.ENOENT)}flags=typeof flags===\"string\"?FS.modeStringToFlags(flags):flags;mode=typeof mode===\"undefined\"?438:mode;if(flags&64){mode=mode&4095|32768}else{mode=0}var node;if(typeof path===\"object\"){node=path}else{path=PATH.normalize(path);try{var lookup=FS.lookupPath(path,{follow:!(flags&131072)});node=lookup.node}catch(e){}}var created=false;if(flags&64){if(node){if(flags&128){throw new FS.ErrnoError(ERRNO_CODES.EEXIST)}}else{node=FS.mknod(path,mode,0);created=true}}if(!node){throw new FS.ErrnoError(ERRNO_CODES.ENOENT)}if(FS.isChrdev(node.mode)){flags&=~512}if(flags&65536&&!FS.isDir(node.mode)){throw new FS.ErrnoError(ERRNO_CODES.ENOTDIR)}if(!created){var err=FS.mayOpen(node,flags);if(err){throw new FS.ErrnoError(err)}}if(flags&512){FS.truncate(node,0)}flags&=~(128|512);var stream=FS.createStream({node:node,path:FS.getPath(node),flags:flags,seekable:true,position:0,stream_ops:node.stream_ops,ungotten:[],error:false},fd_start,fd_end);if(stream.stream_ops.open){stream.stream_ops.open(stream)}if(Module[\"logReadFiles\"]&&!(flags&1)){if(!FS.readFiles)FS.readFiles={};if(!(path in FS.readFiles)){FS.readFiles[path]=1;Module[\"printErr\"](\"read file: \"+path)}}try{if(FS.trackingDelegate[\"onOpenFile\"]){var trackingFlags=0;if((flags&2097155)!==1){trackingFlags|=FS.tracking.openFlags.READ}if((flags&2097155)!==0){trackingFlags|=FS.tracking.openFlags.WRITE}FS.trackingDelegate[\"onOpenFile\"](path,trackingFlags)}}catch(e){console.log(\"FS.trackingDelegate['onOpenFile']('\"+path+\"', flags) threw an exception: \"+e.message)}return stream}),close:(function(stream){if(stream.getdents)stream.getdents=null;try{if(stream.stream_ops.close){stream.stream_ops.close(stream)}}catch(e){throw e}finally{FS.closeStream(stream.fd)}}),llseek:(function(stream,offset,whence){if(!stream.seekable||!stream.stream_ops.llseek){throw new FS.ErrnoError(ERRNO_CODES.ESPIPE)}stream.position=stream.stream_ops.llseek(stream,offset,whence);stream.ungotten=[];return stream.position}),read:(function(stream,buffer,offset,length,position){if(length<0||position<0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}if((stream.flags&2097155)===1){throw new FS.ErrnoError(ERRNO_CODES.EBADF)}if(FS.isDir(stream.node.mode)){throw new FS.ErrnoError(ERRNO_CODES.EISDIR)}if(!stream.stream_ops.read){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}var seeking=true;if(typeof position===\"undefined\"){position=stream.position;seeking=false}else if(!stream.seekable){throw new FS.ErrnoError(ERRNO_CODES.ESPIPE)}var bytesRead=stream.stream_ops.read(stream,buffer,offset,length,position);if(!seeking)stream.position+=bytesRead;return bytesRead}),write:(function(stream,buffer,offset,length,position,canOwn){if(length<0||position<0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}if((stream.flags&2097155)===0){throw new FS.ErrnoError(ERRNO_CODES.EBADF)}if(FS.isDir(stream.node.mode)){throw new FS.ErrnoError(ERRNO_CODES.EISDIR)}if(!stream.stream_ops.write){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}if(stream.flags&1024){FS.llseek(stream,0,2)}var seeking=true;if(typeof position===\"undefined\"){position=stream.position;seeking=false}else if(!stream.seekable){throw new FS.ErrnoError(ERRNO_CODES.ESPIPE)}var bytesWritten=stream.stream_ops.write(stream,buffer,offset,length,position,canOwn);if(!seeking)stream.position+=bytesWritten;try{if(stream.path&&FS.trackingDelegate[\"onWriteToFile\"])FS.trackingDelegate[\"onWriteToFile\"](stream.path)}catch(e){console.log(\"FS.trackingDelegate['onWriteToFile']('\"+path+\"') threw an exception: \"+e.message)}return bytesWritten}),allocate:(function(stream,offset,length){if(offset<0||length<=0){throw new FS.ErrnoError(ERRNO_CODES.EINVAL)}if((stream.flags&2097155)===0){throw new FS.ErrnoError(ERRNO_CODES.EBADF)}if(!FS.isFile(stream.node.mode)&&!FS.isDir(node.mode)){throw new FS.ErrnoError(ERRNO_CODES.ENODEV)}if(!stream.stream_ops.allocate){throw new FS.ErrnoError(ERRNO_CODES.EOPNOTSUPP)}stream.stream_ops.allocate(stream,offset,length)}),mmap:(function(stream,buffer,offset,length,position,prot,flags){if((stream.flags&2097155)===1){throw new FS.ErrnoError(ERRNO_CODES.EACCES)}if(!stream.stream_ops.mmap){throw new FS.ErrnoError(ERRNO_CODES.ENODEV)}return stream.stream_ops.mmap(stream,buffer,offset,length,position,prot,flags)}),msync:(function(stream,buffer,offset,length,mmapFlags){if(!stream||!stream.stream_ops.msync){return 0}return stream.stream_ops.msync(stream,buffer,offset,length,mmapFlags)}),munmap:(function(stream){return 0}),ioctl:(function(stream,cmd,arg){if(!stream.stream_ops.ioctl){throw new FS.ErrnoError(ERRNO_CODES.ENOTTY)}return stream.stream_ops.ioctl(stream,cmd,arg)}),readFile:(function(path,opts){opts=opts||{};opts.flags=opts.flags||\"r\";opts.encoding=opts.encoding||\"binary\";if(opts.encoding!==\"utf8\"&&opts.encoding!==\"binary\"){throw new Error('Invalid encoding type \"'+opts.encoding+'\"')}var ret;var stream=FS.open(path,opts.flags);var stat=FS.stat(path);var length=stat.size;var buf=new Uint8Array(length);FS.read(stream,buf,0,length,0);if(opts.encoding===\"utf8\"){ret=UTF8ArrayToString(buf,0)}else if(opts.encoding===\"binary\"){ret=buf}FS.close(stream);return ret}),writeFile:(function(path,data,opts){opts=opts||{};opts.flags=opts.flags||\"w\";opts.encoding=opts.encoding||\"utf8\";if(opts.encoding!==\"utf8\"&&opts.encoding!==\"binary\"){throw new Error('Invalid encoding type \"'+opts.encoding+'\"')}var stream=FS.open(path,opts.flags,opts.mode);if(opts.encoding===\"utf8\"){var buf=new Uint8Array(lengthBytesUTF8(data)+1);var actualNumBytes=stringToUTF8Array(data,buf,0,buf.length);FS.write(stream,buf,0,actualNumBytes,0,opts.canOwn)}else if(opts.encoding===\"binary\"){FS.write(stream,data,0,data.length,0,opts.canOwn)}FS.close(stream)}),cwd:(function(){return FS.currentPath}),chdir:(function(path){var lookup=FS.lookupPath(path,{follow:true});if(!FS.isDir(lookup.node.mode)){throw new FS.ErrnoError(ERRNO_CODES.ENOTDIR)}var err=FS.nodePermissions(lookup.node,\"x\");if(err){throw new FS.ErrnoError(err)}FS.currentPath=lookup.path}),createDefaultDirectories:(function(){FS.mkdir(\"/tmp\");FS.mkdir(\"/home\");FS.mkdir(\"/home/web_user\")}),createDefaultDevices:(function(){FS.mkdir(\"/dev\");FS.registerDevice(FS.makedev(1,3),{read:(function(){return 0}),write:(function(stream,buffer,offset,length,pos){return length})});FS.mkdev(\"/dev/null\",FS.makedev(1,3));TTY.register(FS.makedev(5,0),TTY.default_tty_ops);TTY.register(FS.makedev(6,0),TTY.default_tty1_ops);FS.mkdev(\"/dev/tty\",FS.makedev(5,0));FS.mkdev(\"/dev/tty1\",FS.makedev(6,0));var random_device;if(typeof crypto!==\"undefined\"){var randomBuffer=new Uint8Array(1);random_device=(function(){crypto.getRandomValues(randomBuffer);return randomBuffer[0]})}else if(ENVIRONMENT_IS_NODE){random_device=(function(){return require(\"crypto\").randomBytes(1)[0]})}else{random_device=(function(){return Math.random()*256|0})}FS.createDevice(\"/dev\",\"random\",random_device);FS.createDevice(\"/dev\",\"urandom\",random_device);FS.mkdir(\"/dev/shm\");FS.mkdir(\"/dev/shm/tmp\")}),createSpecialDirectories:(function(){FS.mkdir(\"/proc\");FS.mkdir(\"/proc/self\");FS.mkdir(\"/proc/self/fd\");FS.mount({mount:(function(){var node=FS.createNode(\"/proc/self\",\"fd\",16384|511,73);node.node_ops={lookup:(function(parent,name){var fd=+name;var stream=FS.getStream(fd);if(!stream)throw new FS.ErrnoError(ERRNO_CODES.EBADF);var ret={parent:null,mount:{mountpoint:\"fake\"},node_ops:{readlink:(function(){return stream.path})}};ret.parent=ret;return ret})};return node})},{},\"/proc/self/fd\")}),createStandardStreams:(function(){if(Module[\"stdin\"]){FS.createDevice(\"/dev\",\"stdin\",Module[\"stdin\"])}else{FS.symlink(\"/dev/tty\",\"/dev/stdin\")}if(Module[\"stdout\"]){FS.createDevice(\"/dev\",\"stdout\",null,Module[\"stdout\"])}else{FS.symlink(\"/dev/tty\",\"/dev/stdout\")}if(Module[\"stderr\"]){FS.createDevice(\"/dev\",\"stderr\",null,Module[\"stderr\"])}else{FS.symlink(\"/dev/tty1\",\"/dev/stderr\")}var stdin=FS.open(\"/dev/stdin\",\"r\");assert(stdin.fd===0,\"invalid handle for stdin (\"+stdin.fd+\")\");var stdout=FS.open(\"/dev/stdout\",\"w\");assert(stdout.fd===1,\"invalid handle for stdout (\"+stdout.fd+\")\");var stderr=FS.open(\"/dev/stderr\",\"w\");assert(stderr.fd===2,\"invalid handle for stderr (\"+stderr.fd+\")\")}),ensureErrnoError:(function(){if(FS.ErrnoError)return;FS.ErrnoError=function ErrnoError(errno,node){this.node=node;this.setErrno=(function(errno){this.errno=errno;for(var key in ERRNO_CODES){if(ERRNO_CODES[key]===errno){this.code=key;break}}});this.setErrno(errno);this.message=ERRNO_MESSAGES[errno]};FS.ErrnoError.prototype=new Error;FS.ErrnoError.prototype.constructor=FS.ErrnoError;[ERRNO_CODES.ENOENT].forEach((function(code){FS.genericErrors[code]=new FS.ErrnoError(code);FS.genericErrors[code].stack=\"<generic error, no stack>\"}))}),staticInit:(function(){FS.ensureErrnoError();FS.nameTable=new Array(4096);FS.mount(MEMFS,{},\"/\");FS.createDefaultDirectories();FS.createDefaultDevices();FS.createSpecialDirectories();FS.filesystems={\"MEMFS\":MEMFS,\"IDBFS\":IDBFS,\"NODEFS\":NODEFS,\"WORKERFS\":WORKERFS}}),init:(function(input,output,error){assert(!FS.init.initialized,\"FS.init was previously called. If you want to initialize later with custom parameters, remove any earlier calls (note that one is automatically added to the generated code)\");FS.init.initialized=true;FS.ensureErrnoError();Module[\"stdin\"]=input||Module[\"stdin\"];Module[\"stdout\"]=output||Module[\"stdout\"];Module[\"stderr\"]=error||Module[\"stderr\"];FS.createStandardStreams()}),quit:(function(){FS.init.initialized=false;var fflush=Module[\"_fflush\"];if(fflush)fflush(0);for(var i=0;i<FS.streams.length;i++){var stream=FS.streams[i];if(!stream){continue}FS.close(stream)}}),getMode:(function(canRead,canWrite){var mode=0;if(canRead)mode|=292|73;if(canWrite)mode|=146;return mode}),joinPath:(function(parts,forceRelative){var path=PATH.join.apply(null,parts);if(forceRelative&&path[0]==\"/\")path=path.substr(1);return path}),absolutePath:(function(relative,base){return PATH.resolve(base,relative)}),standardizePath:(function(path){return PATH.normalize(path)}),findObject:(function(path,dontResolveLastLink){var ret=FS.analyzePath(path,dontResolveLastLink);if(ret.exists){return ret.object}else{___setErrNo(ret.error);return null}}),analyzePath:(function(path,dontResolveLastLink){try{var lookup=FS.lookupPath(path,{follow:!dontResolveLastLink});path=lookup.path}catch(e){}var ret={isRoot:false,exists:false,error:0,name:null,path:null,object:null,parentExists:false,parentPath:null,parentObject:null};try{var lookup=FS.lookupPath(path,{parent:true});ret.parentExists=true;ret.parentPath=lookup.path;ret.parentObject=lookup.node;ret.name=PATH.basename(path);lookup=FS.lookupPath(path,{follow:!dontResolveLastLink});ret.exists=true;ret.path=lookup.path;ret.object=lookup.node;ret.name=lookup.node.name;ret.isRoot=lookup.path===\"/\"}catch(e){ret.error=e.errno}return ret}),createFolder:(function(parent,name,canRead,canWrite){var path=PATH.join2(typeof parent===\"string\"?parent:FS.getPath(parent),name);var mode=FS.getMode(canRead,canWrite);return FS.mkdir(path,mode)}),createPath:(function(parent,path,canRead,canWrite){parent=typeof parent===\"string\"?parent:FS.getPath(parent);var parts=path.split(\"/\").reverse();while(parts.length){var part=parts.pop();if(!part)continue;var current=PATH.join2(parent,part);try{FS.mkdir(current)}catch(e){}parent=current}return current}),createFile:(function(parent,name,properties,canRead,canWrite){var path=PATH.join2(typeof parent===\"string\"?parent:FS.getPath(parent),name);var mode=FS.getMode(canRead,canWrite);return FS.create(path,mode)}),createDataFile:(function(parent,name,data,canRead,canWrite,canOwn){var path=name?PATH.join2(typeof parent===\"string\"?parent:FS.getPath(parent),name):parent;var mode=FS.getMode(canRead,canWrite);var node=FS.create(path,mode);if(data){if(typeof data===\"string\"){var arr=new Array(data.length);for(var i=0,len=data.length;i<len;++i)arr[i]=data.charCodeAt(i);data=arr}FS.chmod(node,mode|146);var stream=FS.open(node,\"w\");FS.write(stream,data,0,data.length,0,canOwn);FS.close(stream);FS.chmod(node,mode)}return node}),createDevice:(function(parent,name,input,output){var path=PATH.join2(typeof parent===\"string\"?parent:FS.getPath(parent),name);var mode=FS.getMode(!!input,!!output);if(!FS.createDevice.major)FS.createDevice.major=64;var dev=FS.makedev(FS.createDevice.major++,0);FS.registerDevice(dev,{open:(function(stream){stream.seekable=false}),close:(function(stream){if(output&&output.buffer&&output.buffer.length){output(10)}}),read:(function(stream,buffer,offset,length,pos){var bytesRead=0;for(var i=0;i<length;i++){var result;try{result=input()}catch(e){throw new FS.ErrnoError(ERRNO_CODES.EIO)}if(result===undefined&&bytesRead===0){throw new FS.ErrnoError(ERRNO_CODES.EAGAIN)}if(result===null||result===undefined)break;bytesRead++;buffer[offset+i]=result}if(bytesRead){stream.node.timestamp=Date.now()}return bytesRead}),write:(function(stream,buffer,offset,length,pos){for(var i=0;i<length;i++){try{output(buffer[offset+i])}catch(e){throw new FS.ErrnoError(ERRNO_CODES.EIO)}}if(length){stream.node.timestamp=Date.now()}return i})});return FS.mkdev(path,mode,dev)}),createLink:(function(parent,name,target,canRead,canWrite){var path=PATH.join2(typeof parent===\"string\"?parent:FS.getPath(parent),name);return FS.symlink(target,path)}),forceLoadFile:(function(obj){if(obj.isDevice||obj.isFolder||obj.link||obj.contents)return true;var success=true;if(typeof XMLHttpRequest!==\"undefined\"){throw new Error(\"Lazy loading should have been performed (contents set) in createLazyFile, but it was not. Lazy loading only works in web workers. Use --embed-file or --preload-file in emcc on the main thread.\")}else if(Module[\"read\"]){try{obj.contents=intArrayFromString(Module[\"read\"](obj.url),true);obj.usedBytes=obj.contents.length}catch(e){success=false}}else{throw new Error(\"Cannot load without read() or XMLHttpRequest.\")}if(!success)___setErrNo(ERRNO_CODES.EIO);return success}),createLazyFile:(function(parent,name,url,canRead,canWrite){function LazyUint8Array(){this.lengthKnown=false;this.chunks=[]}LazyUint8Array.prototype.get=function LazyUint8Array_get(idx){if(idx>this.length-1||idx<0){return undefined}var chunkOffset=idx%this.chunkSize;var chunkNum=idx/this.chunkSize|0;return this.getter(chunkNum)[chunkOffset]};LazyUint8Array.prototype.setDataGetter=function LazyUint8Array_setDataGetter(getter){this.getter=getter};LazyUint8Array.prototype.cacheLength=function LazyUint8Array_cacheLength(){var xhr=new XMLHttpRequest;xhr.open(\"HEAD\",url,false);xhr.send(null);if(!(xhr.status>=200&&xhr.status<300||xhr.status===304))throw new Error(\"Couldn't load \"+url+\". Status: \"+xhr.status);var datalength=Number(xhr.getResponseHeader(\"Content-length\"));var header;var hasByteServing=(header=xhr.getResponseHeader(\"Accept-Ranges\"))&&header===\"bytes\";var chunkSize=1024*1024;if(!hasByteServing)chunkSize=datalength;var doXHR=(function(from,to){if(from>to)throw new Error(\"invalid range (\"+from+\", \"+to+\") or no bytes requested!\");if(to>datalength-1)throw new Error(\"only \"+datalength+\" bytes available! programmer error!\");var xhr=new XMLHttpRequest;xhr.open(\"GET\",url,false);if(datalength!==chunkSize)xhr.setRequestHeader(\"Range\",\"bytes=\"+from+\"-\"+to);if(typeof Uint8Array!=\"undefined\")xhr.responseType=\"arraybuffer\";if(xhr.overrideMimeType){xhr.overrideMimeType(\"text/plain; charset=x-user-defined\")}xhr.send(null);if(!(xhr.status>=200&&xhr.status<300||xhr.status===304))throw new Error(\"Couldn't load \"+url+\". Status: \"+xhr.status);if(xhr.response!==undefined){return new Uint8Array(xhr.response||[])}else{return intArrayFromString(xhr.responseText||\"\",true)}});var lazyArray=this;lazyArray.setDataGetter((function(chunkNum){var start=chunkNum*chunkSize;var end=(chunkNum+1)*chunkSize-1;end=Math.min(end,datalength-1);if(typeof lazyArray.chunks[chunkNum]===\"undefined\"){lazyArray.chunks[chunkNum]=doXHR(start,end)}if(typeof lazyArray.chunks[chunkNum]===\"undefined\")throw new Error(\"doXHR failed!\");return lazyArray.chunks[chunkNum]}));this._length=datalength;this._chunkSize=chunkSize;this.lengthKnown=true};if(typeof XMLHttpRequest!==\"undefined\"){if(!ENVIRONMENT_IS_WORKER)throw\"Cannot do synchronous binary XHRs outside webworkers in modern browsers. Use --embed-file or --preload-file in emcc\";var lazyArray=new LazyUint8Array;Object.defineProperty(lazyArray,\"length\",{get:(function(){if(!this.lengthKnown){this.cacheLength()}return this._length})});Object.defineProperty(lazyArray,\"chunkSize\",{get:(function(){if(!this.lengthKnown){this.cacheLength()}return this._chunkSize})});var properties={isDevice:false,contents:lazyArray}}else{var properties={isDevice:false,url:url}}var node=FS.createFile(parent,name,properties,canRead,canWrite);if(properties.contents){node.contents=properties.contents}else if(properties.url){node.contents=null;node.url=properties.url}Object.defineProperty(node,\"usedBytes\",{get:(function(){return this.contents.length})});var stream_ops={};var keys=Object.keys(node.stream_ops);keys.forEach((function(key){var fn=node.stream_ops[key];stream_ops[key]=function forceLoadLazyFile(){if(!FS.forceLoadFile(node)){throw new FS.ErrnoError(ERRNO_CODES.EIO)}return fn.apply(null,arguments)}}));stream_ops.read=function stream_ops_read(stream,buffer,offset,length,position){if(!FS.forceLoadFile(node)){throw new FS.ErrnoError(ERRNO_CODES.EIO)}var contents=stream.node.contents;if(position>=contents.length)return 0;var size=Math.min(contents.length-position,length);assert(size>=0);if(contents.slice){for(var i=0;i<size;i++){buffer[offset+i]=contents[position+i]}}else{for(var i=0;i<size;i++){buffer[offset+i]=contents.get(position+i)}}return size};node.stream_ops=stream_ops;return node}),createPreloadedFile:(function(parent,name,url,canRead,canWrite,onload,onerror,dontCreateFile,canOwn,preFinish){Browser.init();var fullname=name?PATH.resolve(PATH.join2(parent,name)):parent;var dep=getUniqueRunDependency(\"cp \"+fullname);function processData(byteArray){function finish(byteArray){if(preFinish)preFinish();if(!dontCreateFile){FS.createDataFile(parent,name,byteArray,canRead,canWrite,canOwn)}if(onload)onload();removeRunDependency(dep)}var handled=false;Module[\"preloadPlugins\"].forEach((function(plugin){if(handled)return;if(plugin[\"canHandle\"](fullname)){plugin[\"handle\"](byteArray,fullname,finish,(function(){if(onerror)onerror();removeRunDependency(dep)}));handled=true}}));if(!handled)finish(byteArray)}addRunDependency(dep);if(typeof url==\"string\"){Browser.asyncLoad(url,(function(byteArray){processData(byteArray)}),onerror)}else{processData(url)}}),indexedDB:(function(){return window.indexedDB||window.mozIndexedDB||window.webkitIndexedDB||window.msIndexedDB}),DB_NAME:(function(){return\"EM_FS_\"+window.location.pathname}),DB_VERSION:20,DB_STORE_NAME:\"FILE_DATA\",saveFilesToDB:(function(paths,onload,onerror){onload=onload||(function(){});onerror=onerror||(function(){});var indexedDB=FS.indexedDB();try{var openRequest=indexedDB.open(FS.DB_NAME(),FS.DB_VERSION)}catch(e){return onerror(e)}openRequest.onupgradeneeded=function openRequest_onupgradeneeded(){console.log(\"creating db\");var db=openRequest.result;db.createObjectStore(FS.DB_STORE_NAME)};openRequest.onsuccess=function openRequest_onsuccess(){var db=openRequest.result;var transaction=db.transaction([FS.DB_STORE_NAME],\"readwrite\");var files=transaction.objectStore(FS.DB_STORE_NAME);var ok=0,fail=0,total=paths.length;function finish(){if(fail==0)onload();else onerror()}paths.forEach((function(path){var putRequest=files.put(FS.analyzePath(path).object.contents,path);putRequest.onsuccess=function putRequest_onsuccess(){ok++;if(ok+fail==total)finish()};putRequest.onerror=function putRequest_onerror(){fail++;if(ok+fail==total)finish()}}));transaction.onerror=onerror};openRequest.onerror=onerror}),loadFilesFromDB:(function(paths,onload,onerror){onload=onload||(function(){});onerror=onerror||(function(){});var indexedDB=FS.indexedDB();try{var openRequest=indexedDB.open(FS.DB_NAME(),FS.DB_VERSION)}catch(e){return onerror(e)}openRequest.onupgradeneeded=onerror;openRequest.onsuccess=function openRequest_onsuccess(){var db=openRequest.result;try{var transaction=db.transaction([FS.DB_STORE_NAME],\"readonly\")}catch(e){onerror(e);return}var files=transaction.objectStore(FS.DB_STORE_NAME);var ok=0,fail=0,total=paths.length;function finish(){if(fail==0)onload();else onerror()}paths.forEach((function(path){var getRequest=files.get(path);getRequest.onsuccess=function getRequest_onsuccess(){if(FS.analyzePath(path).exists){FS.unlink(path)}FS.createDataFile(PATH.dirname(path),PATH.basename(path),getRequest.result,true,true,true);ok++;if(ok+fail==total)finish()};getRequest.onerror=function getRequest_onerror(){fail++;if(ok+fail==total)finish()}}));transaction.onerror=onerror};openRequest.onerror=onerror})};var SYSCALLS={DEFAULT_POLLMASK:5,mappings:{},umask:511,calculateAt:(function(dirfd,path){if(path[0]!==\"/\"){var dir;if(dirfd===-100){dir=FS.cwd()}else{var dirstream=FS.getStream(dirfd);if(!dirstream)throw new FS.ErrnoError(ERRNO_CODES.EBADF);dir=dirstream.path}path=PATH.join2(dir,path)}return path}),doStat:(function(func,path,buf){try{var stat=func(path)}catch(e){if(e&&e.node&&PATH.normalize(path)!==PATH.normalize(FS.getPath(e.node))){return-ERRNO_CODES.ENOTDIR}throw e}HEAP32[buf>>2]=stat.dev;HEAP32[buf+4>>2]=0;HEAP32[buf+8>>2]=stat.ino;HEAP32[buf+12>>2]=stat.mode;HEAP32[buf+16>>2]=stat.nlink;HEAP32[buf+20>>2]=stat.uid;HEAP32[buf+24>>2]=stat.gid;HEAP32[buf+28>>2]=stat.rdev;HEAP32[buf+32>>2]=0;HEAP32[buf+36>>2]=stat.size;HEAP32[buf+40>>2]=4096;HEAP32[buf+44>>2]=stat.blocks;HEAP32[buf+48>>2]=stat.atime.getTime()/1e3|0;HEAP32[buf+52>>2]=0;HEAP32[buf+56>>2]=stat.mtime.getTime()/1e3|0;HEAP32[buf+60>>2]=0;HEAP32[buf+64>>2]=stat.ctime.getTime()/1e3|0;HEAP32[buf+68>>2]=0;HEAP32[buf+72>>2]=stat.ino;return 0}),doMsync:(function(addr,stream,len,flags){var buffer=new Uint8Array(HEAPU8.subarray(addr,addr+len));FS.msync(stream,buffer,0,len,flags)}),doMkdir:(function(path,mode){path=PATH.normalize(path);if(path[path.length-1]===\"/\")path=path.substr(0,path.length-1);FS.mkdir(path,mode,0);return 0}),doMknod:(function(path,mode,dev){switch(mode&61440){case 32768:case 8192:case 24576:case 4096:case 49152:break;default:return-ERRNO_CODES.EINVAL}FS.mknod(path,mode,dev);return 0}),doReadlink:(function(path,buf,bufsize){if(bufsize<=0)return-ERRNO_CODES.EINVAL;var ret=FS.readlink(path);ret=ret.slice(0,Math.max(0,bufsize));writeStringToMemory(ret,buf,true);return ret.length}),doAccess:(function(path,amode){if(amode&~7){return-ERRNO_CODES.EINVAL}var node;var lookup=FS.lookupPath(path,{follow:true});node=lookup.node;var perms=\"\";if(amode&4)perms+=\"r\";if(amode&2)perms+=\"w\";if(amode&1)perms+=\"x\";if(perms&&FS.nodePermissions(node,perms)){return-ERRNO_CODES.EACCES}return 0}),doDup:(function(path,flags,suggestFD){var suggest=FS.getStream(suggestFD);if(suggest)FS.close(suggest);return FS.open(path,flags,0,suggestFD,suggestFD).fd}),doReadv:(function(stream,iov,iovcnt,offset){var ret=0;for(var i=0;i<iovcnt;i++){var ptr=HEAP32[iov+i*8>>2];var len=HEAP32[iov+(i*8+4)>>2];var curr=FS.read(stream,HEAP8,ptr,len,offset);if(curr<0)return-1;ret+=curr;if(curr<len)break}return ret}),doWritev:(function(stream,iov,iovcnt,offset){var ret=0;for(var i=0;i<iovcnt;i++){var ptr=HEAP32[iov+i*8>>2];var len=HEAP32[iov+(i*8+4)>>2];var curr=FS.write(stream,HEAP8,ptr,len,offset);if(curr<0)return-1;ret+=curr}return ret}),varargs:0,get:(function(varargs){SYSCALLS.varargs+=4;var ret=HEAP32[SYSCALLS.varargs-4>>2];return ret}),getStr:(function(){var ret=Pointer_stringify(SYSCALLS.get());return ret}),getStreamFromFD:(function(){var stream=FS.getStream(SYSCALLS.get());if(!stream)throw new FS.ErrnoError(ERRNO_CODES.EBADF);return stream}),getSocketFromFD:(function(){var socket=SOCKFS.getSocket(SYSCALLS.get());if(!socket)throw new FS.ErrnoError(ERRNO_CODES.EBADF);return socket}),getSocketAddress:(function(allowNull){var addrp=SYSCALLS.get(),addrlen=SYSCALLS.get();if(allowNull&&addrp===0)return null;var info=__read_sockaddr(addrp,addrlen);if(info.errno)throw new FS.ErrnoError(info.errno);info.addr=DNS.lookup_addr(info.addr)||info.addr;return info}),get64:(function(){var low=SYSCALLS.get(),high=SYSCALLS.get();if(low>=0)assert(high===0);else assert(high===-1);return low}),getZero:(function(){assert(SYSCALLS.get()===0)})};function ___syscall6(which,varargs){SYSCALLS.varargs=varargs;try{var stream=SYSCALLS.getStreamFromFD();FS.close(stream);return 0}catch(e){if(typeof FS===\"undefined\"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}var _emscripten_asm_const=true;function ___assert_fail(condition,filename,line,func){ABORT=true;throw\"Assertion failed: \"+Pointer_stringify(condition)+\", at: \"+[filename?Pointer_stringify(filename):\"unknown filename\",line,func?Pointer_stringify(func):\"unknown function\"]+\" at \"+stackTrace()}function _sbrk(bytes){var self=_sbrk;if(!self.called){DYNAMICTOP=alignMemoryPage(DYNAMICTOP);self.called=true;assert(Runtime.dynamicAlloc);self.alloc=Runtime.dynamicAlloc;Runtime.dynamicAlloc=(function(){abort(\"cannot dynamically allocate, sbrk now has control\")})}var ret=DYNAMICTOP;if(bytes!=0){var success=self.alloc(bytes);if(!success)return-1>>>0}return ret}function _emscripten_memcpy_big(dest,src,num){HEAPU8.set(HEAPU8.subarray(src,src+num),dest);return dest}Module[\"_memcpy\"]=_memcpy;Module[\"_memmove\"]=_memmove;var _emscripten_asm_const_int=true;function _time(ptr){var ret=Date.now()/1e3|0;if(ptr){HEAP32[ptr>>2]=ret}return ret}function _pthread_self(){return 0}function ___syscall140(which,varargs){SYSCALLS.varargs=varargs;try{var stream=SYSCALLS.getStreamFromFD(),offset_high=SYSCALLS.get(),offset_low=SYSCALLS.get(),result=SYSCALLS.get(),whence=SYSCALLS.get();var offset=offset_low;assert(offset_high===0);FS.llseek(stream,offset,whence);HEAP32[result>>2]=stream.position;if(stream.getdents&&offset===0&&whence===0)stream.getdents=null;return 0}catch(e){if(typeof FS===\"undefined\"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___syscall146(which,varargs){SYSCALLS.varargs=varargs;try{var stream=SYSCALLS.getStreamFromFD(),iov=SYSCALLS.get(),iovcnt=SYSCALLS.get();return SYSCALLS.doWritev(stream,iov,iovcnt)}catch(e){if(typeof FS===\"undefined\"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}function ___syscall54(which,varargs){SYSCALLS.varargs=varargs;try{var stream=SYSCALLS.getStreamFromFD(),op=SYSCALLS.get();switch(op){case 21505:{if(!stream.tty)return-ERRNO_CODES.ENOTTY;return 0};case 21506:{if(!stream.tty)return-ERRNO_CODES.ENOTTY;return 0};case 21519:{if(!stream.tty)return-ERRNO_CODES.ENOTTY;var argp=SYSCALLS.get();HEAP32[argp>>2]=0;return 0};case 21520:{if(!stream.tty)return-ERRNO_CODES.ENOTTY;return-ERRNO_CODES.EINVAL};case 21531:{var argp=SYSCALLS.get();return FS.ioctl(stream,op,argp)};default:abort(\"bad ioctl syscall \"+op)}}catch(e){if(typeof FS===\"undefined\"||!(e instanceof FS.ErrnoError))abort(e);return-e.errno}}FS.staticInit();__ATINIT__.unshift((function(){if(!Module[\"noFSInit\"]&&!FS.init.initialized)FS.init()}));__ATMAIN__.push((function(){FS.ignorePermissions=false}));__ATEXIT__.push((function(){FS.quit()}));Module[\"FS_createFolder\"]=FS.createFolder;Module[\"FS_createPath\"]=FS.createPath;Module[\"FS_createDataFile\"]=FS.createDataFile;Module[\"FS_createPreloadedFile\"]=FS.createPreloadedFile;Module[\"FS_createLazyFile\"]=FS.createLazyFile;Module[\"FS_createLink\"]=FS.createLink;Module[\"FS_createDevice\"]=FS.createDevice;Module[\"FS_unlink\"]=FS.unlink;__ATINIT__.unshift((function(){TTY.init()}));__ATEXIT__.push((function(){TTY.shutdown()}));if(ENVIRONMENT_IS_NODE){var fs=require(\"fs\");var NODEJS_PATH=require(\"path\");NODEFS.staticInit()}STACK_BASE=STACKTOP=Runtime.alignMemory(STATICTOP);staticSealed=true;STACK_MAX=STACK_BASE+TOTAL_STACK;DYNAMIC_BASE=DYNAMICTOP=Runtime.alignMemory(STACK_MAX);assert(DYNAMIC_BASE<TOTAL_MEMORY,\"TOTAL_MEMORY not big enough for stack\");var cttz_i8=allocate([8,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,5,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,6,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,5,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,7,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,5,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,6,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,5,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0],\"i8\",ALLOC_DYNAMIC);function invoke_i(index){try{return Module[\"dynCall_i\"](index)}catch(e){if(typeof e!==\"number\"&&e!==\"longjmp\")throw e;asm[\"setThrew\"](1,0)}}function jsCall_i(index){return Runtime.functionPointers[index]()}function invoke_ii(index,a1){try{return Module[\"dynCall_ii\"](index,a1)}catch(e){if(typeof e!==\"number\"&&e!==\"longjmp\")throw e;asm[\"setThrew\"](1,0)}}function jsCall_ii(index,a1){return Runtime.functionPointers[index](a1)}function invoke_iiii(index,a1,a2,a3){try{return Module[\"dynCall_iiii\"](index,a1,a2,a3)}catch(e){if(typeof e!==\"number\"&&e!==\"longjmp\")throw e;asm[\"setThrew\"](1,0)}}function jsCall_iiii(index,a1,a2,a3){return Runtime.functionPointers[index](a1,a2,a3)}function invoke_vi(index,a1){try{Module[\"dynCall_vi\"](index,a1)}catch(e){if(typeof e!==\"number\"&&e!==\"longjmp\")throw e;asm[\"setThrew\"](1,0)}}function jsCall_vi(index,a1){Runtime.functionPointers[index](a1)}Module.asmGlobalArg={\"Math\":Math,\"Int8Array\":Int8Array,\"Int16Array\":Int16Array,\"Int32Array\":Int32Array,\"Uint8Array\":Uint8Array,\"Uint16Array\":Uint16Array,\"Uint32Array\":Uint32Array,\"Float32Array\":Float32Array,\"Float64Array\":Float64Array,\"NaN\":NaN,\"Infinity\":Infinity};Module.asmLibraryArg={\"abort\":abort,\"assert\":assert,\"invoke_i\":invoke_i,\"jsCall_i\":jsCall_i,\"invoke_ii\":invoke_ii,\"jsCall_ii\":jsCall_ii,\"invoke_iiii\":invoke_iiii,\"jsCall_iiii\":jsCall_iiii,\"invoke_vi\":invoke_vi,\"jsCall_vi\":jsCall_vi,\"_pthread_cleanup_pop\":_pthread_cleanup_pop,\"___lock\":___lock,\"_sysconf\":_sysconf,\"_pthread_self\":_pthread_self,\"___syscall6\":___syscall6,\"___setErrNo\":___setErrNo,\"_abort\":_abort,\"_sbrk\":_sbrk,\"_time\":_time,\"_pthread_cleanup_push\":_pthread_cleanup_push,\"_emscripten_memcpy_big\":_emscripten_memcpy_big,\"___syscall54\":___syscall54,\"___unlock\":___unlock,\"___syscall140\":___syscall140,\"___assert_fail\":___assert_fail,\"___syscall146\":___syscall146,\"_emscripten_asm_const_0\":_emscripten_asm_const_0,\"STACKTOP\":STACKTOP,\"STACK_MAX\":STACK_MAX,\"tempDoublePtr\":tempDoublePtr,\"ABORT\":ABORT,\"cttz_i8\":cttz_i8};// EMSCRIPTEN_START_ASM\nvar asm=(function(global,env,buffer) {\n\"use asm\";var a=new global.Int8Array(buffer);var b=new global.Int16Array(buffer);var c=new global.Int32Array(buffer);var d=new global.Uint8Array(buffer);var e=new global.Uint16Array(buffer);var f=new global.Uint32Array(buffer);var g=new global.Float32Array(buffer);var h=new global.Float64Array(buffer);var i=env.STACKTOP|0;var j=env.STACK_MAX|0;var k=env.tempDoublePtr|0;var l=env.ABORT|0;var m=env.cttz_i8|0;var n=0;var o=0;var p=0;var q=0;var r=global.NaN,s=global.Infinity;var t=0,u=0,v=0,w=0,x=0.0,y=0,z=0,A=0,B=0.0;var C=0;var D=0;var E=0;var F=0;var G=0;var H=0;var I=0;var J=0;var K=0;var L=0;var M=global.Math.floor;var N=global.Math.abs;var O=global.Math.sqrt;var P=global.Math.pow;var Q=global.Math.cos;var R=global.Math.sin;var S=global.Math.tan;var T=global.Math.acos;var U=global.Math.asin;var V=global.Math.atan;var W=global.Math.atan2;var X=global.Math.exp;var Y=global.Math.log;var Z=global.Math.ceil;var _=global.Math.imul;var $=global.Math.min;var aa=global.Math.clz32;var ba=env.abort;var ca=env.assert;var da=env.invoke_i;var ea=env.jsCall_i;var fa=env.invoke_ii;var ga=env.jsCall_ii;var ha=env.invoke_iiii;var ia=env.jsCall_iiii;var ja=env.invoke_vi;var ka=env.jsCall_vi;var la=env._pthread_cleanup_pop;var ma=env.___lock;var na=env._sysconf;var oa=env._pthread_self;var pa=env.___syscall6;var qa=env.___setErrNo;var ra=env._abort;var sa=env._sbrk;var ta=env._time;var ua=env._pthread_cleanup_push;var va=env._emscripten_memcpy_big;var wa=env.___syscall54;var xa=env.___unlock;var ya=env.___syscall140;var za=env.___assert_fail;var Aa=env.___syscall146;var Ba=env._emscripten_asm_const_0;var Ca=0.0;\n// EMSCRIPTEN_START_FUNCS\nfunction Nc(b,e){b=b|0;e=e|0;var f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0;R=i;P=i=i+63&-64;i=i+320|0;Q=P+280|0;k=P+240|0;j=P+200|0;q=P+160|0;l=P+120|0;m=P+80|0;o=P+40|0;O=b+40|0;T=d[e>>0]|0;M=Hd(d[e+1>>0]|0|0,0,8)|0;J=C;r=Hd(d[e+2>>0]|0|0,0,16)|0;J=J|C;s=Hd(d[e+3>>0]|0|0,0,24)|0;J=J|C;I=a[e+6>>0]|0;L=d[e+4>>0]|0;p=Hd(d[e+5>>0]|0|0,0,8)|0;K=C;I=Hd(I&255|0,0,16)|0;K=Hd(p|L|I|0,K|C|0,6)|0;I=C;L=a[e+9>>0]|0;p=d[e+7>>0]|0;f=Hd(d[e+8>>0]|0|0,0,8)|0;w=C;L=Hd(L&255|0,0,16)|0;w=Hd(f|p|L|0,w|C|0,5)|0;L=C;p=a[e+12>>0]|0;f=d[e+10>>0]|0;y=Hd(d[e+11>>0]|0|0,0,8)|0;n=C;p=Hd(p&255|0,0,16)|0;n=Hd(y|f|p|0,n|C|0,3)|0;p=C;f=a[e+15>>0]|0;y=d[e+13>>0]|0;F=Hd(d[e+14>>0]|0|0,0,8)|0;A=C;f=Hd(f&255|0,0,16)|0;A=Hd(F|y|f|0,A|C|0,2)|0;f=C;y=d[e+16>>0]|0;F=Hd(d[e+17>>0]|0|0,0,8)|0;u=C;h=Hd(d[e+18>>0]|0|0,0,16)|0;u=u|C;t=Hd(d[e+19>>0]|0|0,0,24)|0;t=F|y|h|t;u=u|C;h=a[e+22>>0]|0;y=d[e+20>>0]|0;F=Hd(d[e+21>>0]|0|0,0,8)|0;E=C;h=Hd(h&255|0,0,16)|0;E=Hd(F|y|h|0,E|C|0,7)|0;h=C;y=a[e+25>>0]|0;F=d[e+23>>0]|0;N=Hd(d[e+24>>0]|0|0,0,8)|0;x=C;y=Hd(y&255|0,0,16)|0;x=Hd(N|F|y|0,x|C|0,5)|0;y=C;F=a[e+28>>0]|0;N=d[e+26>>0]|0;g=Hd(d[e+27>>0]|0|0,0,8)|0;G=C;F=Hd(F&255|0,0,16)|0;G=Hd(g|N|F|0,G|C|0,4)|0;F=C;N=e+31|0;g=a[N>>0]|0;D=d[e+29>>0]|0;v=Hd(d[e+30>>0]|0|0,0,8)|0;B=C;g=Hd(g&255|0,0,16)|0;B=Hd(v|D|g|0,B|C|0,2)|0;B=B&33554428;g=Dd(B|0,0,16777216,0)|0;g=Gd(g|0,C|0,25)|0;D=C;v=Cd(0,0,g|0,D|0)|0;J=Dd(v&19|0,0,M|T|r|s|0,J|0)|0;s=C;D=Hd(g|0,D|0,25)|0;g=C;r=Dd(K|0,I|0,16777216,0)|0;r=Gd(r|0,C|0,25)|0;T=C;L=Dd(w|0,L|0,r|0,T|0)|0;w=C;T=Hd(r|0,T|0,25)|0;T=Cd(K|0,I|0,T|0,C|0)|0;I=C;K=Dd(n|0,p|0,16777216,0)|0;K=Gd(K|0,C|0,25)|0;r=C;f=Dd(A|0,f|0,K|0,r|0)|0;A=C;r=Hd(K|0,r|0,25)|0;K=C;M=Dd(t|0,u|0,16777216,0)|0;M=Gd(M|0,C|0,25)|0;v=C;h=Dd(E|0,h|0,M|0,v|0)|0;E=C;v=Hd(M|0,v|0,25)|0;M=C;e=Dd(x|0,y|0,16777216,0)|0;e=Gd(e|0,C|0,25)|0;z=C;F=Dd(G|0,F|0,e|0,z|0)|0;G=C;z=Hd(e|0,z|0,25)|0;e=C;S=Dd(J|0,s|0,33554432,0)|0;S=Ed(S|0,C|0,26)|0;H=C;I=Dd(T|0,I|0,S|0,H|0)|0;H=Hd(S|0,H|0,26)|0;H=Cd(J|0,s|0,H|0,C|0)|0;s=Dd(L|0,w|0,33554432,0)|0;s=Ed(s|0,C|0,26)|0;J=C;p=Dd(s|0,J|0,n|0,p|0)|0;K=Cd(p|0,C|0,r|0,K|0)|0;J=Hd(s|0,J|0,26)|0;J=Cd(L|0,w|0,J|0,C|0)|0;w=Dd(f|0,A|0,33554432,0)|0;w=Ed(w|0,C|0,26)|0;L=C;u=Dd(w|0,L|0,t|0,u|0)|0;M=Cd(u|0,C|0,v|0,M|0)|0;L=Hd(w|0,L|0,26)|0;L=Cd(f|0,A|0,L|0,C|0)|0;A=Dd(h|0,E|0,33554432,0)|0;A=Ed(A|0,C|0,26)|0;f=C;y=Dd(A|0,f|0,x|0,y|0)|0;e=Cd(y|0,C|0,z|0,e|0)|0;f=Hd(A|0,f|0,26)|0;f=Cd(h|0,E|0,f|0,C|0)|0;E=Dd(F|0,G|0,33554432,0)|0;E=Ed(E|0,C|0,26)|0;h=C;B=Dd(B|0,0,E|0,h|0)|0;g=Cd(B|0,C|0,D|0,g|0)|0;h=Hd(E|0,h|0,26)|0;h=Cd(F|0,G|0,h|0,C|0)|0;c[O>>2]=H;c[b+44>>2]=I;c[b+48>>2]=J;c[b+52>>2]=K;c[b+56>>2]=L;c[b+60>>2]=M;c[b+64>>2]=f;c[b+68>>2]=e;c[b+72>>2]=h;c[b+76>>2]=g;g=b+80|0;c[g>>2]=1;h=b+84|0;e=h;f=e+36|0;do{c[e>>2]=0;e=e+4|0}while((e|0)<(f|0));Kc(q,O);Jc(l,q,1064);f=q+4|0;n=q+8|0;p=q+12|0;r=q+16|0;s=q+20|0;v=q+24|0;x=q+28|0;z=q+32|0;B=q+36|0;g=c[g>>2]|0;t=c[h>>2]|0;w=c[b+88>>2]|0;A=c[b+92>>2]|0;E=c[b+96>>2]|0;G=c[b+100>>2]|0;I=c[b+104>>2]|0;K=c[b+108>>2]|0;M=c[b+112>>2]|0;T=c[b+116>>2]|0;e=(c[f>>2]|0)-t|0;S=(c[n>>2]|0)-w|0;L=(c[p>>2]|0)-A|0;J=(c[r>>2]|0)-E|0;H=(c[s>>2]|0)-G|0;F=(c[v>>2]|0)-I|0;D=(c[x>>2]|0)-K|0;y=(c[z>>2]|0)-M|0;u=(c[B>>2]|0)-T|0;c[q>>2]=(c[q>>2]|0)-g;c[f>>2]=e;c[n>>2]=S;c[p>>2]=L;c[r>>2]=J;c[s>>2]=H;c[v>>2]=F;c[x>>2]=D;c[z>>2]=y;c[B>>2]=u;u=l+4|0;y=l+8|0;D=l+12|0;F=l+16|0;H=l+20|0;J=l+24|0;L=l+28|0;S=l+32|0;e=l+36|0;t=t+(c[u>>2]|0)|0;w=w+(c[y>>2]|0)|0;A=A+(c[D>>2]|0)|0;E=E+(c[F>>2]|0)|0;G=G+(c[H>>2]|0)|0;I=I+(c[J>>2]|0)|0;K=K+(c[L>>2]|0)|0;M=M+(c[S>>2]|0)|0;T=T+(c[e>>2]|0)|0;c[l>>2]=g+(c[l>>2]|0);c[u>>2]=t;c[y>>2]=w;c[D>>2]=A;c[F>>2]=E;c[H>>2]=G;c[J>>2]=I;c[L>>2]=K;c[S>>2]=M;c[e>>2]=T;Kc(m,l);Jc(m,m,l);Kc(b,m);Jc(b,b,l);Jc(b,b,q);Kc(Q,b);Kc(k,Q);Kc(k,k);Jc(k,b,k);Jc(Q,Q,k);Kc(Q,Q);Jc(Q,k,Q);Kc(k,Q);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Jc(Q,k,Q);Kc(k,Q);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Jc(k,k,Q);Kc(j,k);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Kc(j,j);Jc(k,j,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Kc(k,k);Jc(Q,k,Q);Kc(k,Q);e=1;do{Kc(k,k);e=e+1|0}while((e|0)!=50);Jc(k,k,Q);Kc(j,k);e=1;do{Kc(j,j);e=e+1|0}while((e|0)!=100);Jc(k,j,k);Kc(k,k);e=1;do{Kc(k,k);e=e+1|0}while((e|0)!=50);Jc(Q,k,Q);Kc(Q,Q);Kc(Q,Q);Jc(b,Q,b);Jc(b,b,m);Jc(b,b,q);Kc(o,b);Jc(o,o,l);E=c[o>>2]|0;F=c[o+4>>2]|0;G=c[o+8>>2]|0;H=c[o+12>>2]|0;I=c[o+16>>2]|0;J=c[o+20>>2]|0;K=c[o+24>>2]|0;L=c[o+28>>2]|0;M=c[o+32>>2]|0;D=c[o+36>>2]|0;A=c[q>>2]|0;y=c[f>>2]|0;w=c[n>>2]|0;u=c[p>>2]|0;t=c[r>>2]|0;s=c[s>>2]|0;r=c[v>>2]|0;q=c[x>>2]|0;p=c[z>>2]|0;e=c[B>>2]|0;c[P>>2]=E-A;f=P+4|0;c[f>>2]=F-y;g=P+8|0;c[g>>2]=G-w;h=P+12|0;c[h>>2]=H-u;j=P+16|0;c[j>>2]=I-t;k=P+20|0;c[k>>2]=J-s;l=P+24|0;c[l>>2]=K-r;m=P+28|0;c[m>>2]=L-q;n=P+32|0;c[n>>2]=M-p;o=P+36|0;c[o>>2]=D-e;Lc(Q,P);do if(Yc(Q,33004)|0){c[P>>2]=A+E;c[f>>2]=y+F;c[g>>2]=w+G;c[h>>2]=u+H;c[j>>2]=t+I;c[k>>2]=s+J;c[l>>2]=r+K;c[m>>2]=q+L;c[n>>2]=p+M;c[o>>2]=e+D;Lc(Q,P);if(!(Yc(Q,33004)|0)){Jc(b,b,1104);break}else{T=-1;i=R;return T|0}}while(0);Lc(Q,b);if(((d[Q>>0]|0)&1|0)==((d[N>>0]|0)>>>7|0)){A=b+4|0;D=b+8|0;F=b+12|0;H=b+16|0;J=b+20|0;L=b+24|0;N=b+28|0;Q=b+32|0;T=b+36|0;z=0-(c[A>>2]|0)|0;B=0-(c[D>>2]|0)|0;E=0-(c[F>>2]|0)|0;G=0-(c[H>>2]|0)|0;I=0-(c[J>>2]|0)|0;K=0-(c[L>>2]|0)|0;M=0-(c[N>>2]|0)|0;P=0-(c[Q>>2]|0)|0;S=0-(c[T>>2]|0)|0;c[b>>2]=0-(c[b>>2]|0);c[A>>2]=z;c[D>>2]=B;c[F>>2]=E;c[H>>2]=G;c[J>>2]=I;c[L>>2]=K;c[N>>2]=M;c[Q>>2]=P;c[T>>2]=S}Jc(b+120|0,b,O);T=0;i=R;return T|0}function Oc(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0;V=b+40|0;j=b+44|0;m=b+48|0;p=b+52|0;s=b+56|0;v=b+60|0;y=b+64|0;B=b+68|0;E=b+72|0;C=b+76|0;S=b+4|0;P=b+8|0;e=b+12|0;l=b+16|0;n=b+20|0;u=b+24|0;w=b+28|0;D=b+32|0;O=b+36|0;ga=(c[S>>2]|0)+(c[j>>2]|0)|0;fa=(c[P>>2]|0)+(c[m>>2]|0)|0;ea=(c[e>>2]|0)+(c[p>>2]|0)|0;da=(c[l>>2]|0)+(c[s>>2]|0)|0;ca=(c[n>>2]|0)+(c[v>>2]|0)|0;ba=(c[u>>2]|0)+(c[y>>2]|0)|0;aa=(c[w>>2]|0)+(c[B>>2]|0)|0;$=(c[D>>2]|0)+(c[E>>2]|0)|0;Y=(c[O>>2]|0)+(c[C>>2]|0)|0;c[a>>2]=(c[b>>2]|0)+(c[V>>2]|0);ha=a+4|0;c[ha>>2]=ga;ga=a+8|0;c[ga>>2]=fa;fa=a+12|0;c[fa>>2]=ea;ea=a+16|0;c[ea>>2]=da;da=a+20|0;c[da>>2]=ca;ca=a+24|0;c[ca>>2]=ba;ba=a+28|0;c[ba>>2]=aa;aa=a+32|0;c[aa>>2]=$;$=a+36|0;c[$>>2]=Y;Y=a+40|0;S=(c[j>>2]|0)-(c[S>>2]|0)|0;P=(c[m>>2]|0)-(c[P>>2]|0)|0;e=(c[p>>2]|0)-(c[e>>2]|0)|0;l=(c[s>>2]|0)-(c[l>>2]|0)|0;n=(c[v>>2]|0)-(c[n>>2]|0)|0;u=(c[y>>2]|0)-(c[u>>2]|0)|0;w=(c[B>>2]|0)-(c[w>>2]|0)|0;D=(c[E>>2]|0)-(c[D>>2]|0)|0;O=(c[C>>2]|0)-(c[O>>2]|0)|0;c[Y>>2]=(c[V>>2]|0)-(c[b>>2]|0);V=a+44|0;c[V>>2]=S;S=a+48|0;c[S>>2]=P;P=a+52|0;c[P>>2]=e;e=a+56|0;c[e>>2]=l;l=a+60|0;c[l>>2]=n;n=a+64|0;c[n>>2]=u;u=a+68|0;c[u>>2]=w;w=a+72|0;c[w>>2]=D;D=a+76|0;c[D>>2]=O;O=a+80|0;Jc(O,a,d);Jc(Y,Y,d+40|0);C=a+120|0;Jc(C,d+80|0,b+120|0);E=c[b+80>>2]<<1;B=c[b+84>>2]<<1;y=c[b+88>>2]<<1;v=c[b+92>>2]<<1;s=c[b+96>>2]<<1;p=c[b+100>>2]<<1;m=c[b+104>>2]<<1;j=c[b+108>>2]<<1;g=c[b+112>>2]<<1;b=c[b+116>>2]<<1;Z=c[O>>2]|0;N=a+84|0;W=c[N>>2]|0;M=a+88|0;T=c[M>>2]|0;L=a+92|0;Q=c[L>>2]|0;K=a+96|0;f=c[K>>2]|0;J=a+100|0;h=c[J>>2]|0;I=a+104|0;o=c[I>>2]|0;H=a+108|0;q=c[H>>2]|0;G=a+112|0;x=c[G>>2]|0;F=a+116|0;z=c[F>>2]|0;_=c[Y>>2]|0;X=c[V>>2]|0;U=c[S>>2]|0;R=c[P>>2]|0;d=c[e>>2]|0;i=c[l>>2]|0;k=c[n>>2]|0;r=c[u>>2]|0;t=c[w>>2]|0;A=c[D>>2]|0;c[a>>2]=Z-_;c[ha>>2]=W-X;c[ga>>2]=T-U;c[fa>>2]=Q-R;c[ea>>2]=f-d;c[da>>2]=h-i;c[ca>>2]=o-k;c[ba>>2]=q-r;c[aa>>2]=x-t;c[$>>2]=z-A;c[Y>>2]=_+Z;c[V>>2]=X+W;c[S>>2]=U+T;c[P>>2]=R+Q;c[e>>2]=d+f;c[l>>2]=i+h;c[n>>2]=k+o;c[u>>2]=r+q;c[w>>2]=t+x;c[D>>2]=A+z;D=c[C>>2]|0;z=a+124|0;A=c[z>>2]|0;w=a+128|0;x=c[w>>2]|0;t=a+132|0;u=c[t>>2]|0;q=a+136|0;r=c[q>>2]|0;n=a+140|0;o=c[n>>2]|0;k=a+144|0;l=c[k>>2]|0;h=a+148|0;i=c[h>>2]|0;e=a+152|0;f=c[e>>2]|0;a=a+156|0;d=c[a>>2]|0;c[O>>2]=D+E;c[N>>2]=A+B;c[M>>2]=x+y;c[L>>2]=u+v;c[K>>2]=r+s;c[J>>2]=o+p;c[I>>2]=l+m;c[H>>2]=i+j;c[G>>2]=f+g;c[F>>2]=d+b;c[C>>2]=E-D;c[z>>2]=B-A;c[w>>2]=y-x;c[t>>2]=v-u;c[q>>2]=s-r;c[n>>2]=p-o;c[k>>2]=m-l;c[h>>2]=j-i;c[e>>2]=g-f;c[a>>2]=b-d;return}function Pc(a,b){a=a|0;b=b|0;var d=0,e=0,f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0,xa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha=0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa=0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0,db=0,eb=0,fb=0,gb=0,hb=0,ib=0,jb=0,kb=0,lb=0,mb=0,nb=0;d=i;S=i=i+63&-64;i=i+48|0;Kc(a,b);aa=a+80|0;ta=b+40|0;Kc(aa,ta);v=a+120|0;ib=c[b+80>>2]|0;Sa=c[b+84>>2]|0;p=c[b+88>>2]|0;x=c[b+92>>2]|0;f=c[b+96>>2]|0;kb=c[b+100>>2]|0;_=c[b+104>>2]|0;wa=c[b+108>>2]|0;l=c[b+112>>2]|0;ua=c[b+116>>2]|0;t=ib<<1;ra=Sa<<1;cb=p<<1;g=x<<1;Ma=f<<1;e=kb<<1;va=_<<1;n=wa<<1;bb=kb*38|0;Qa=_*19|0;Q=wa*38|0;H=l*19|0;nb=ua*38|0;jb=((ib|0)<0)<<31>>31;jb=Od(ib|0,jb|0,ib|0,jb|0)|0;ib=C;qa=((t|0)<0)<<31>>31;Ta=((Sa|0)<0)<<31>>31;$a=Od(t|0,qa|0,Sa|0,Ta|0)|0;_a=C;r=((p|0)<0)<<31>>31;Va=Od(p|0,r|0,t|0,qa|0)|0;Ua=C;R=((x|0)<0)<<31>>31;La=Od(x|0,R|0,t|0,qa|0)|0;Ka=C;ka=((f|0)<0)<<31>>31;za=Od(f|0,ka|0,t|0,qa|0)|0;ya=C;lb=((kb|0)<0)<<31>>31;K=Od(kb|0,lb|0,t|0,qa|0)|0;M=C;j=((_|0)<0)<<31>>31;k=Od(_|0,j|0,t|0,qa|0)|0;F=C;xa=((wa|0)<0)<<31>>31;u=Od(wa|0,xa|0,t|0,qa|0)|0;P=C;ma=((l|0)<0)<<31>>31;W=Od(l|0,ma|0,t|0,qa|0)|0;fa=C;oa=((ua|0)<0)<<31>>31;qa=Od(ua|0,oa|0,t|0,qa|0)|0;t=C;pa=((ra|0)<0)<<31>>31;Ta=Od(ra|0,pa|0,Sa|0,Ta|0)|0;Sa=C;Ja=Od(ra|0,pa|0,p|0,r|0)|0;Ia=C;ja=((g|0)<0)<<31>>31;Da=Od(g|0,ja|0,ra|0,pa|0)|0;Ca=C;B=Od(f|0,ka|0,ra|0,pa|0)|0;E=C;la=((e|0)<0)<<31>>31;h=Od(e|0,la|0,ra|0,pa|0)|0;D=C;s=Od(_|0,j|0,ra|0,pa|0)|0;N=C;$=((n|0)<0)<<31>>31;V=Od(n|0,$|0,ra|0,pa|0)|0;ea=C;sa=Od(l|0,ma|0,ra|0,pa|0)|0;na=C;mb=((nb|0)<0)<<31>>31;pa=Od(nb|0,mb|0,ra|0,pa|0)|0;ra=C;Ba=Od(p|0,r|0,p|0,r|0)|0;Aa=C;db=((cb|0)<0)<<31>>31;G=Od(cb|0,db|0,x|0,R|0)|0;I=C;y=Od(f|0,ka|0,cb|0,db|0)|0;A=C;o=Od(kb|0,lb|0,cb|0,db|0)|0;J=C;w=Od(_|0,j|0,cb|0,db|0)|0;ba=C;Z=Od(wa|0,xa|0,cb|0,db|0)|0;ia=C;m=((H|0)<0)<<31>>31;db=Od(H|0,m|0,cb|0,db|0)|0;cb=C;r=Od(nb|0,mb|0,p|0,r|0)|0;p=C;R=Od(g|0,ja|0,x|0,R|0)|0;x=C;q=Od(g|0,ja|0,f|0,ka|0)|0;L=C;U=Od(e|0,la|0,g|0,ja|0)|0;da=C;X=Od(_|0,j|0,g|0,ja|0)|0;ga=C;O=((Q|0)<0)<<31>>31;fb=Od(Q|0,O|0,g|0,ja|0)|0;eb=C;Xa=Od(H|0,m|0,g|0,ja|0)|0;Wa=C;ja=Od(nb|0,mb|0,g|0,ja|0)|0;g=C;T=Od(f|0,ka|0,f|0,ka|0)|0;ca=C;Na=((Ma|0)<0)<<31>>31;Y=Od(Ma|0,Na|0,kb|0,lb|0)|0;ha=C;Ra=((Qa|0)<0)<<31>>31;hb=Od(Qa|0,Ra|0,Ma|0,Na|0)|0;gb=C;Za=Od(Q|0,O|0,f|0,ka|0)|0;Ya=C;Na=Od(H|0,m|0,Ma|0,Na|0)|0;Ma=C;ka=Od(nb|0,mb|0,f|0,ka|0)|0;f=C;lb=Od(bb|0,((bb|0)<0)<<31>>31|0,kb|0,lb|0)|0;kb=C;bb=Od(Qa|0,Ra|0,e|0,la|0)|0;ab=C;Pa=Od(Q|0,O|0,e|0,la|0)|0;Oa=C;Fa=Od(H|0,m|0,e|0,la|0)|0;Ea=C;la=Od(nb|0,mb|0,e|0,la|0)|0;e=C;Ra=Od(Qa|0,Ra|0,_|0,j|0)|0;Qa=C;Ha=Od(Q|0,O|0,_|0,j|0)|0;Ga=C;va=Od(H|0,m|0,va|0,((va|0)<0)<<31>>31|0)|0;z=C;j=Od(nb|0,mb|0,_|0,j|0)|0;_=C;xa=Od(Q|0,O|0,wa|0,xa|0)|0;wa=C;O=Od(H|0,m|0,n|0,$|0)|0;Q=C;$=Od(nb|0,mb|0,n|0,$|0)|0;n=C;m=Od(H|0,m|0,l|0,ma|0)|0;H=C;ma=Od(nb|0,mb|0,l|0,ma|0)|0;l=C;oa=Od(nb|0,mb|0,ua|0,oa|0)|0;ua=C;ib=Dd(lb|0,kb|0,jb|0,ib|0)|0;gb=Dd(ib|0,C|0,hb|0,gb|0)|0;eb=Dd(gb|0,C|0,fb|0,eb|0)|0;cb=Dd(eb|0,C|0,db|0,cb|0)|0;ra=Dd(cb|0,C|0,pa|0,ra|0)|0;pa=C;_a=Dd(bb|0,ab|0,$a|0,_a|0)|0;Ya=Dd(_a|0,C|0,Za|0,Ya|0)|0;Wa=Dd(Ya|0,C|0,Xa|0,Wa|0)|0;p=Dd(Wa|0,C|0,r|0,p|0)|0;r=C;Sa=Dd(Va|0,Ua|0,Ta|0,Sa|0)|0;Qa=Dd(Sa|0,C|0,Ra|0,Qa|0)|0;Oa=Dd(Qa|0,C|0,Pa|0,Oa|0)|0;Ma=Dd(Oa|0,C|0,Na|0,Ma|0)|0;g=Dd(Ma|0,C|0,ja|0,g|0)|0;ja=C;Ia=Dd(La|0,Ka|0,Ja|0,Ia|0)|0;Ga=Dd(Ia|0,C|0,Ha|0,Ga|0)|0;Ea=Dd(Ga|0,C|0,Fa|0,Ea|0)|0;f=Dd(Ea|0,C|0,ka|0,f|0)|0;ka=C;Aa=Dd(Da|0,Ca|0,Ba|0,Aa|0)|0;ya=Dd(Aa|0,C|0,za|0,ya|0)|0;wa=Dd(ya|0,C|0,xa|0,wa|0)|0;z=Dd(wa|0,C|0,va|0,z|0)|0;e=Dd(z|0,C|0,la|0,e|0)|0;la=C;I=Dd(B|0,E|0,G|0,I|0)|0;M=Dd(I|0,C|0,K|0,M|0)|0;Q=Dd(M|0,C|0,O|0,Q|0)|0;_=Dd(Q|0,C|0,j|0,_|0)|0;j=C;A=Dd(R|0,x|0,y|0,A|0)|0;D=Dd(A|0,C|0,h|0,D|0)|0;F=Dd(D|0,C|0,k|0,F|0)|0;H=Dd(F|0,C|0,m|0,H|0)|0;n=Dd(H|0,C|0,$|0,n|0)|0;$=C;L=Dd(o|0,J|0,q|0,L|0)|0;N=Dd(L|0,C|0,s|0,N|0)|0;P=Dd(N|0,C|0,u|0,P|0)|0;l=Dd(P|0,C|0,ma|0,l|0)|0;ma=C;ca=Dd(w|0,ba|0,T|0,ca|0)|0;da=Dd(ca|0,C|0,U|0,da|0)|0;ea=Dd(da|0,C|0,V|0,ea|0)|0;fa=Dd(ea|0,C|0,W|0,fa|0)|0;ua=Dd(fa|0,C|0,oa|0,ua|0)|0;oa=C;ha=Dd(X|0,ga|0,Y|0,ha|0)|0;ia=Dd(ha|0,C|0,Z|0,ia|0)|0;na=Dd(ia|0,C|0,sa|0,na|0)|0;t=Dd(na|0,C|0,qa|0,t|0)|0;qa=C;pa=Hd(ra|0,pa|0,1)|0;ra=C;r=Hd(p|0,r|0,1)|0;p=C;ja=Hd(g|0,ja|0,1)|0;g=C;ka=Hd(f|0,ka|0,1)|0;f=C;la=Hd(e|0,la|0,1)|0;e=C;j=Hd(_|0,j|0,1)|0;_=C;$=Hd(n|0,$|0,1)|0;n=C;ma=Hd(l|0,ma|0,1)|0;l=C;oa=Hd(ua|0,oa|0,1)|0;ua=C;qa=Hd(t|0,qa|0,1)|0;t=C;na=Dd(pa|0,ra|0,33554432,0)|0;na=Ed(na|0,C|0,26)|0;sa=C;p=Dd(na|0,sa|0,r|0,p|0)|0;r=C;sa=Hd(na|0,sa|0,26)|0;sa=Cd(pa|0,ra|0,sa|0,C|0)|0;ra=C;pa=Dd(la|0,e|0,33554432,0)|0;pa=Ed(pa|0,C|0,26)|0;na=C;_=Dd(pa|0,na|0,j|0,_|0)|0;j=C;na=Hd(pa|0,na|0,26)|0;na=Cd(la|0,e|0,na|0,C|0)|0;e=C;la=Dd(p|0,r|0,16777216,0)|0;la=Ed(la|0,C|0,25)|0;pa=C;g=Dd(la|0,pa|0,ja|0,g|0)|0;ja=C;pa=Hd(la|0,pa|0,25)|0;pa=Cd(p|0,r|0,pa|0,C|0)|0;r=C;p=Dd(_|0,j|0,16777216,0)|0;p=Ed(p|0,C|0,25)|0;la=C;n=Dd(p|0,la|0,$|0,n|0)|0;$=C;la=Hd(p|0,la|0,25)|0;la=Cd(_|0,j|0,la|0,C|0)|0;j=C;_=Dd(g|0,ja|0,33554432,0)|0;_=Ed(_|0,C|0,26)|0;p=C;f=Dd(_|0,p|0,ka|0,f|0)|0;ka=C;p=Hd(_|0,p|0,26)|0;p=Cd(g|0,ja|0,p|0,C|0)|0;ja=Dd(n|0,$|0,33554432,0)|0;ja=Ed(ja|0,C|0,26)|0;g=C;l=Dd(ja|0,g|0,ma|0,l|0)|0;ma=C;g=Hd(ja|0,g|0,26)|0;g=Cd(n|0,$|0,g|0,C|0)|0;$=Dd(f|0,ka|0,16777216,0)|0;$=Ed($|0,C|0,25)|0;n=C;e=Dd($|0,n|0,na|0,e|0)|0;na=C;n=Hd($|0,n|0,25)|0;n=Cd(f|0,ka|0,n|0,C|0)|0;ka=Dd(l|0,ma|0,16777216,0)|0;ka=Ed(ka|0,C|0,25)|0;f=C;ua=Dd(ka|0,f|0,oa|0,ua|0)|0;oa=C;f=Hd(ka|0,f|0,25)|0;f=Cd(l|0,ma|0,f|0,C|0)|0;ma=Dd(e|0,na|0,33554432,0)|0;ma=Ed(ma|0,C|0,26)|0;l=C;j=Dd(la|0,j|0,ma|0,l|0)|0;l=Hd(ma|0,l|0,26)|0;l=Cd(e|0,na|0,l|0,C|0)|0;na=Dd(ua|0,oa|0,33554432,0)|0;na=Ed(na|0,C|0,26)|0;e=C;t=Dd(na|0,e|0,qa|0,t|0)|0;qa=C;e=Hd(na|0,e|0,26)|0;e=Cd(ua|0,oa|0,e|0,C|0)|0;oa=Dd(t|0,qa|0,16777216,0)|0;oa=Ed(oa|0,C|0,25)|0;ua=C;na=Od(oa|0,ua|0,19,0)|0;ra=Dd(na|0,C|0,sa|0,ra|0)|0;sa=C;ua=Hd(oa|0,ua|0,25)|0;ua=Cd(t|0,qa|0,ua|0,C|0)|0;qa=Dd(ra|0,sa|0,33554432,0)|0;qa=Ed(qa|0,C|0,26)|0;t=C;r=Dd(pa|0,r|0,qa|0,t|0)|0;t=Hd(qa|0,t|0,26)|0;t=Cd(ra|0,sa|0,t|0,C|0)|0;c[v>>2]=t;t=a+124|0;c[t>>2]=r;r=a+128|0;c[r>>2]=p;p=a+132|0;c[p>>2]=n;n=a+136|0;c[n>>2]=l;l=a+140|0;c[l>>2]=j;j=a+144|0;c[j>>2]=g;g=a+148|0;c[g>>2]=f;f=a+152|0;c[f>>2]=e;e=a+156|0;c[e>>2]=ua;ua=a+40|0;sa=(c[b+44>>2]|0)+(c[b+4>>2]|0)|0;ra=(c[b+48>>2]|0)+(c[b+8>>2]|0)|0;qa=(c[b+52>>2]|0)+(c[b+12>>2]|0)|0;pa=(c[b+56>>2]|0)+(c[b+16>>2]|0)|0;oa=(c[b+60>>2]|0)+(c[b+20>>2]|0)|0;na=(c[b+64>>2]|0)+(c[b+24>>2]|0)|0;ma=(c[b+68>>2]|0)+(c[b+28>>2]|0)|0;la=(c[b+72>>2]|0)+(c[b+32>>2]|0)|0;ka=(c[b+76>>2]|0)+(c[b+36>>2]|0)|0;c[ua>>2]=(c[ta>>2]|0)+(c[b>>2]|0);ta=a+44|0;c[ta>>2]=sa;sa=a+48|0;c[sa>>2]=ra;ra=a+52|0;c[ra>>2]=qa;qa=a+56|0;c[qa>>2]=pa;pa=a+60|0;c[pa>>2]=oa;oa=a+64|0;c[oa>>2]=na;na=a+68|0;c[na>>2]=ma;ma=a+72|0;c[ma>>2]=la;la=a+76|0;c[la>>2]=ka;Kc(S,ua);ka=c[aa>>2]|0;$=a+84|0;ja=c[$>>2]|0;_=a+88|0;ia=c[_>>2]|0;Z=a+92|0;ha=c[Z>>2]|0;Y=a+96|0;ga=c[Y>>2]|0;X=a+100|0;fa=c[X>>2]|0;W=a+104|0;ea=c[W>>2]|0;V=a+108|0;da=c[V>>2]|0;U=a+112|0;ca=c[U>>2]|0;T=a+116|0;ba=c[T>>2]|0;w=c[a>>2]|0;P=a+4|0;u=c[P>>2]|0;N=a+8|0;s=c[N>>2]|0;L=a+12|0;q=c[L>>2]|0;J=a+16|0;o=c[J>>2]|0;H=a+20|0;m=c[H>>2]|0;F=a+24|0;k=c[F>>2]|0;D=a+28|0;h=c[D>>2]|0;A=a+32|0;b=c[A>>2]|0;y=a+36|0;x=c[y>>2]|0;R=w+ka|0;Q=u+ja|0;O=s+ia|0;M=q+ha|0;K=o+ga|0;I=m+fa|0;G=k+ea|0;E=h+da|0;B=b+ca|0;z=x+ba|0;c[ua>>2]=R;c[ta>>2]=Q;c[sa>>2]=O;c[ra>>2]=M;c[qa>>2]=K;c[pa>>2]=I;c[oa>>2]=G;c[na>>2]=E;c[ma>>2]=B;c[la>>2]=z;w=ka-w|0;u=ja-u|0;s=ia-s|0;q=ha-q|0;o=ga-o|0;m=fa-m|0;k=ea-k|0;h=da-h|0;b=ca-b|0;x=ba-x|0;c[aa>>2]=w;c[$>>2]=u;c[_>>2]=s;c[Z>>2]=q;c[Y>>2]=o;c[X>>2]=m;c[W>>2]=k;c[V>>2]=h;c[U>>2]=b;c[T>>2]=x;Q=(c[S+4>>2]|0)-Q|0;O=(c[S+8>>2]|0)-O|0;M=(c[S+12>>2]|0)-M|0;K=(c[S+16>>2]|0)-K|0;I=(c[S+20>>2]|0)-I|0;G=(c[S+24>>2]|0)-G|0;E=(c[S+28>>2]|0)-E|0;B=(c[S+32>>2]|0)-B|0;z=(c[S+36>>2]|0)-z|0;c[a>>2]=(c[S>>2]|0)-R;c[P>>2]=Q;c[N>>2]=O;c[L>>2]=M;c[J>>2]=K;c[H>>2]=I;c[F>>2]=G;c[D>>2]=E;c[A>>2]=B;c[y>>2]=z;u=(c[t>>2]|0)-u|0;s=(c[r>>2]|0)-s|0;q=(c[p>>2]|0)-q|0;o=(c[n>>2]|0)-o|0;m=(c[l>>2]|0)-m|0;k=(c[j>>2]|0)-k|0;h=(c[g>>2]|0)-h|0;b=(c[f>>2]|0)-b|0;a=(c[e>>2]|0)-x|0;c[v>>2]=(c[v>>2]|0)-w;c[t>>2]=u;c[r>>2]=s;c[p>>2]=q;c[n>>2]=o;c[l>>2]=m;c[j>>2]=k;c[g>>2]=h;c[f>>2]=b;c[e>>2]=a;i=d;return}function Qc(a,b){a=a|0;b=b|0;var d=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0;m=b+40|0;v=b+44|0;u=b+48|0;t=b+52|0;s=b+56|0;r=b+60|0;q=b+64|0;p=b+68|0;o=b+72|0;n=b+76|0;d=b+4|0;e=b+8|0;f=b+12|0;g=b+16|0;h=b+20|0;i=b+24|0;j=b+28|0;k=b+32|0;l=b+36|0;E=(c[d>>2]|0)+(c[v>>2]|0)|0;D=(c[e>>2]|0)+(c[u>>2]|0)|0;C=(c[f>>2]|0)+(c[t>>2]|0)|0;B=(c[g>>2]|0)+(c[s>>2]|0)|0;A=(c[h>>2]|0)+(c[r>>2]|0)|0;z=(c[i>>2]|0)+(c[q>>2]|0)|0;y=(c[j>>2]|0)+(c[p>>2]|0)|0;x=(c[k>>2]|0)+(c[o>>2]|0)|0;w=(c[l>>2]|0)+(c[n>>2]|0)|0;c[a>>2]=(c[b>>2]|0)+(c[m>>2]|0);c[a+4>>2]=E;c[a+8>>2]=D;c[a+12>>2]=C;c[a+16>>2]=B;c[a+20>>2]=A;c[a+24>>2]=z;c[a+28>>2]=y;c[a+32>>2]=x;c[a+36>>2]=w;d=(c[v>>2]|0)-(c[d>>2]|0)|0;e=(c[u>>2]|0)-(c[e>>2]|0)|0;f=(c[t>>2]|0)-(c[f>>2]|0)|0;g=(c[s>>2]|0)-(c[g>>2]|0)|0;h=(c[r>>2]|0)-(c[h>>2]|0)|0;i=(c[q>>2]|0)-(c[i>>2]|0)|0;j=(c[p>>2]|0)-(c[j>>2]|0)|0;k=(c[o>>2]|0)-(c[k>>2]|0)|0;l=(c[n>>2]|0)-(c[l>>2]|0)|0;c[a+40>>2]=(c[m>>2]|0)-(c[b>>2]|0);c[a+44>>2]=d;c[a+48>>2]=e;c[a+52>>2]=f;c[a+56>>2]=g;c[a+60>>2]=h;c[a+64>>2]=i;c[a+68>>2]=j;c[a+72>>2]=k;c[a+76>>2]=l;l=c[b+84>>2]|0;k=c[b+88>>2]|0;j=c[b+92>>2]|0;i=c[b+96>>2]|0;h=c[b+100>>2]|0;g=c[b+104>>2]|0;f=c[b+108>>2]|0;e=c[b+112>>2]|0;d=c[b+116>>2]|0;c[a+80>>2]=c[b+80>>2];c[a+84>>2]=l;c[a+88>>2]=k;c[a+92>>2]=j;c[a+96>>2]=i;c[a+100>>2]=h;c[a+104>>2]=g;c[a+108>>2]=f;c[a+112>>2]=e;c[a+116>>2]=d;Jc(a+120|0,b+120|0,1144);return}function Rc(b,e){b=b|0;e=e|0;var f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0;u=i;t=i=i+63&-64;i=i+592|0;p=t+400|0;r=t+520|0;s=t+240|0;q=t+120|0;f=0;do{n=a[e+f>>0]|0;o=f<<1;a[r+o>>0]=n&15;a[r+(o|1)>>0]=(n&255)>>>4;f=f+1|0}while((f|0)!=32);e=0;f=0;do{o=r+f|0;n=(d[o>>0]|0)+e|0;e=(n<<24)+134217728>>28;a[o>>0]=n-(e<<4);f=f+1|0}while((f|0)!=63);f=r+63|0;a[f>>0]=(d[f>>0]|0)+e;e=b;f=e+40|0;do{c[e>>2]=0;e=e+4|0}while((e|0)<(f|0));j=b+40|0;c[j>>2]=1;g=b+44|0;e=g;f=e+36|0;do{c[e>>2]=0;e=e+4|0}while((e|0)<(f|0));k=b+80|0;c[k>>2]=1;h=b+84|0;l=b+120|0;m=s+120|0;n=s+40|0;o=s+80|0;e=h;f=e+76|0;do{c[e>>2]=0;e=e+4|0}while((e|0)<(f|0));e=1;do{Sc(t,(e|0)/2|0,a[r+e>>0]|0);Oc(s,b,t);Jc(b,s,m);Jc(j,n,o);Jc(k,o,m);Jc(l,s,n);e=e+2|0}while((e|0)<64);B=c[b+4>>2]|0;z=c[b+8>>2]|0;y=c[b+12>>2]|0;x=c[b+16>>2]|0;w=c[b+20>>2]|0;v=c[b+24>>2]|0;f=c[b+28>>2]|0;e=c[b+32>>2]|0;A=c[b+36>>2]|0;c[p>>2]=c[b>>2];c[p+4>>2]=B;c[p+8>>2]=z;c[p+12>>2]=y;c[p+16>>2]=x;c[p+20>>2]=w;c[p+24>>2]=v;c[p+28>>2]=f;c[p+32>>2]=e;c[p+36>>2]=A;A=c[g>>2]|0;e=c[b+48>>2]|0;g=c[b+52>>2]|0;f=c[b+56>>2]|0;v=c[b+60>>2]|0;w=c[b+64>>2]|0;x=c[b+68>>2]|0;y=c[b+72>>2]|0;z=c[b+76>>2]|0;c[p+40>>2]=c[j>>2];c[p+44>>2]=A;c[p+48>>2]=e;c[p+52>>2]=g;c[p+56>>2]=f;c[p+60>>2]=v;c[p+64>>2]=w;c[p+68>>2]=x;c[p+72>>2]=y;c[p+76>>2]=z;z=c[h>>2]|0;y=c[b+88>>2]|0;x=c[b+92>>2]|0;w=c[b+96>>2]|0;v=c[b+100>>2]|0;f=c[b+104>>2]|0;g=c[b+108>>2]|0;h=c[b+112>>2]|0;e=c[b+116>>2]|0;c[p+80>>2]=c[k>>2];c[p+84>>2]=z;c[p+88>>2]=y;c[p+92>>2]=x;c[p+96>>2]=w;c[p+100>>2]=v;c[p+104>>2]=f;c[p+108>>2]=g;c[p+112>>2]=h;c[p+116>>2]=e;Pc(s,p);Jc(q,s,m);p=q+40|0;Jc(p,n,o);e=q+80|0;Jc(e,o,m);Pc(s,q);Jc(q,s,m);Jc(p,n,o);Jc(e,o,m);Pc(s,q);Jc(q,s,m);Jc(p,n,o);Jc(e,o,m);Pc(s,q);Jc(b,s,m);Jc(j,n,o);Jc(k,o,m);Jc(l,s,n);e=0;do{Sc(t,(e|0)/2|0,a[r+e>>0]|0);Oc(s,b,t);Jc(b,s,m);Jc(j,n,o);Jc(k,o,m);Jc(l,s,n);e=e+2|0}while((e|0)<64);i=u;return}function Sc(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0;s=d<<24>>24;s=Gd(s|0,((s|0)<0)<<31>>31|0,63)|0;h=d<<24>>24;s=0-s|0;d=a+4|0;c[d>>2]=0;c[d+4>>2]=0;c[d+8>>2]=0;c[d+12>>2]=0;c[d+16>>2]=0;c[d+20>>2]=0;c[d+24>>2]=0;c[d+28>>2]=0;e=a+40|0;c[e>>2]=1;f=a+44|0;g=a+80|0;h=h-((h&s)<<1)&255;i=(h^1)+-1|0;j=1184+(b*960|0)|0;k=a+8|0;l=a+12|0;m=a+16|0;n=a+20|0;o=a+24|0;p=a+28|0;q=a+32|0;r=a+36|0;t=f;u=t+76|0;do{c[t>>2]=0;t=t+4|0}while((t|0)<(u|0));H=i>>31;A=c[1184+(b*960|0)+4>>2]&H;I=c[1184+(b*960|0)+8>>2]&H;K=c[1184+(b*960|0)+12>>2]&H;M=c[1184+(b*960|0)+16>>2]&H;O=c[1184+(b*960|0)+20>>2]&H;Q=c[1184+(b*960|0)+24>>2]&H;S=c[1184+(b*960|0)+28>>2]&H;U=c[1184+(b*960|0)+32>>2]&H;W=c[1184+(b*960|0)+36>>2]&H;c[a>>2]=(c[j>>2]^1)&H^1;c[d>>2]=A;c[k>>2]=I;c[l>>2]=K;c[m>>2]=M;c[n>>2]=O;c[o>>2]=Q;c[p>>2]=S;c[q>>2]=U;c[r>>2]=W;W=a+48|0;U=a+52|0;S=a+56|0;Q=a+60|0;O=a+64|0;M=a+68|0;K=a+72|0;I=a+76|0;A=c[1184+(b*960|0)+44>>2]&H;z=c[1184+(b*960|0)+48>>2]&H;w=c[1184+(b*960|0)+52>>2]&H;B=c[1184+(b*960|0)+56>>2]&H;ia=c[1184+(b*960|0)+60>>2]&H;D=c[1184+(b*960|0)+64>>2]&H;ea=c[1184+(b*960|0)+68>>2]&H;F=c[1184+(b*960|0)+72>>2]&H;ga=c[1184+(b*960|0)+76>>2]&H;c[e>>2]=(c[1184+(b*960|0)+40>>2]^1)&H^1;c[f>>2]=A;c[W>>2]=z;c[U>>2]=w;c[S>>2]=B;c[Q>>2]=ia;c[O>>2]=D;c[M>>2]=ea;c[K>>2]=F;c[I>>2]=ga;ga=c[g>>2]|0;F=a+84|0;ea=c[F>>2]|0;D=a+88|0;ia=c[D>>2]|0;B=a+92|0;w=c[B>>2]|0;z=a+96|0;A=c[z>>2]|0;x=a+100|0;fa=c[x>>2]|0;v=a+104|0;ba=c[v>>2]|0;i=a+108|0;G=c[i>>2]|0;t=a+112|0;_=c[t>>2]|0;u=a+116|0;da=c[u>>2]|0;$=(c[1184+(b*960|0)+84>>2]^ea)&H;aa=(c[1184+(b*960|0)+88>>2]^ia)&H;y=(c[1184+(b*960|0)+92>>2]^w)&H;j=(c[1184+(b*960|0)+96>>2]^A)&H;ha=(c[1184+(b*960|0)+100>>2]^fa)&H;Z=(c[1184+(b*960|0)+104>>2]^ba)&H;ca=(c[1184+(b*960|0)+108>>2]^G)&H;C=(c[1184+(b*960|0)+112>>2]^_)&H;E=(c[1184+(b*960|0)+116>>2]^da)&H;c[g>>2]=(c[1184+(b*960|0)+80>>2]^ga)&H^ga;c[F>>2]=$^ea;c[D>>2]=aa^ia;c[B>>2]=y^w;c[z>>2]=j^A;c[x>>2]=ha^fa;c[v>>2]=Z^ba;c[i>>2]=ca^G;c[t>>2]=C^_;c[u>>2]=E^da;da=c[a>>2]|0;E=c[d>>2]|0;_=c[k>>2]|0;C=c[l>>2]|0;G=c[m>>2]|0;ca=c[n>>2]|0;ba=c[o>>2]|0;Z=c[p>>2]|0;fa=c[q>>2]|0;ha=c[r>>2]|0;A=(h^2)+-1>>31;j=(c[1184+(b*960|0)+124>>2]^E)&A;w=(c[1184+(b*960|0)+128>>2]^_)&A;y=(c[1184+(b*960|0)+132>>2]^C)&A;ia=(c[1184+(b*960|0)+136>>2]^G)&A;aa=(c[1184+(b*960|0)+140>>2]^ca)&A;ea=(c[1184+(b*960|0)+144>>2]^ba)&A;$=(c[1184+(b*960|0)+148>>2]^Z)&A;ga=(c[1184+(b*960|0)+152>>2]^fa)&A;H=(c[1184+(b*960|0)+156>>2]^ha)&A;c[a>>2]=(c[1184+(b*960|0)+120>>2]^da)&A^da;c[d>>2]=j^E;c[k>>2]=w^_;c[l>>2]=y^C;c[m>>2]=ia^G;c[n>>2]=aa^ca;c[o>>2]=ea^ba;c[p>>2]=$^Z;c[q>>2]=ga^fa;c[r>>2]=H^ha;ha=c[e>>2]|0;H=c[f>>2]|0;fa=c[W>>2]|0;ga=c[U>>2]|0;Z=c[S>>2]|0;$=c[Q>>2]|0;ba=c[O>>2]|0;ea=c[M>>2]|0;ca=c[K>>2]|0;aa=c[I>>2]|0;G=(c[1184+(b*960|0)+164>>2]^H)&A;ia=(c[1184+(b*960|0)+168>>2]^fa)&A;C=(c[1184+(b*960|0)+172>>2]^ga)&A;y=(c[1184+(b*960|0)+176>>2]^Z)&A;_=(c[1184+(b*960|0)+180>>2]^$)&A;w=(c[1184+(b*960|0)+184>>2]^ba)&A;E=(c[1184+(b*960|0)+188>>2]^ea)&A;j=(c[1184+(b*960|0)+192>>2]^ca)&A;da=(c[1184+(b*960|0)+196>>2]^aa)&A;c[e>>2]=(c[1184+(b*960|0)+160>>2]^ha)&A^ha;c[f>>2]=G^H;c[W>>2]=ia^fa;c[U>>2]=C^ga;c[S>>2]=y^Z;c[Q>>2]=_^$;c[O>>2]=w^ba;c[M>>2]=E^ea;c[K>>2]=j^ca;c[I>>2]=da^aa;aa=c[g>>2]|0;da=c[F>>2]|0;ca=c[D>>2]|0;j=c[B>>2]|0;ea=c[z>>2]|0;E=c[x>>2]|0;ba=c[v>>2]|0;w=c[i>>2]|0;$=c[t>>2]|0;_=c[u>>2]|0;Z=(c[1184+(b*960|0)+204>>2]^da)&A;y=(c[1184+(b*960|0)+208>>2]^ca)&A;ga=(c[1184+(b*960|0)+212>>2]^j)&A;C=(c[1184+(b*960|0)+216>>2]^ea)&A;fa=(c[1184+(b*960|0)+220>>2]^E)&A;ia=(c[1184+(b*960|0)+224>>2]^ba)&A;H=(c[1184+(b*960|0)+228>>2]^w)&A;G=(c[1184+(b*960|0)+232>>2]^$)&A;ha=(c[1184+(b*960|0)+236>>2]^_)&A;c[g>>2]=(c[1184+(b*960|0)+200>>2]^aa)&A^aa;c[F>>2]=Z^da;c[D>>2]=y^ca;c[B>>2]=ga^j;c[z>>2]=C^ea;c[x>>2]=fa^E;c[v>>2]=ia^ba;c[i>>2]=H^w;c[t>>2]=G^$;c[u>>2]=ha^_;_=c[a>>2]|0;ha=c[d>>2]|0;$=c[k>>2]|0;G=c[l>>2]|0;w=c[m>>2]|0;H=c[n>>2]|0;ba=c[o>>2]|0;ia=c[p>>2]|0;E=c[q>>2]|0;fa=c[r>>2]|0;ea=(h^3)+-1>>31;C=(c[1184+(b*960|0)+244>>2]^ha)&ea;j=(c[1184+(b*960|0)+248>>2]^$)&ea;ga=(c[1184+(b*960|0)+252>>2]^G)&ea;ca=(c[1184+(b*960|0)+256>>2]^w)&ea;y=(c[1184+(b*960|0)+260>>2]^H)&ea;da=(c[1184+(b*960|0)+264>>2]^ba)&ea;Z=(c[1184+(b*960|0)+268>>2]^ia)&ea;aa=(c[1184+(b*960|0)+272>>2]^E)&ea;A=(c[1184+(b*960|0)+276>>2]^fa)&ea;c[a>>2]=(c[1184+(b*960|0)+240>>2]^_)&ea^_;c[d>>2]=C^ha;c[k>>2]=j^$;c[l>>2]=ga^G;c[m>>2]=ca^w;c[n>>2]=y^H;c[o>>2]=da^ba;c[p>>2]=Z^ia;c[q>>2]=aa^E;c[r>>2]=A^fa;fa=c[e>>2]|0;A=c[f>>2]|0;E=c[W>>2]|0;aa=c[U>>2]|0;ia=c[S>>2]|0;Z=c[Q>>2]|0;ba=c[O>>2]|0;da=c[M>>2]|0;H=c[K>>2]|0;y=c[I>>2]|0;w=(c[1184+(b*960|0)+284>>2]^A)&ea;ca=(c[1184+(b*960|0)+288>>2]^E)&ea;G=(c[1184+(b*960|0)+292>>2]^aa)&ea;ga=(c[1184+(b*960|0)+296>>2]^ia)&ea;$=(c[1184+(b*960|0)+300>>2]^Z)&ea;j=(c[1184+(b*960|0)+304>>2]^ba)&ea;ha=(c[1184+(b*960|0)+308>>2]^da)&ea;C=(c[1184+(b*960|0)+312>>2]^H)&ea;_=(c[1184+(b*960|0)+316>>2]^y)&ea;c[e>>2]=(c[1184+(b*960|0)+280>>2]^fa)&ea^fa;c[f>>2]=w^A;c[W>>2]=ca^E;c[U>>2]=G^aa;c[S>>2]=ga^ia;c[Q>>2]=$^Z;c[O>>2]=j^ba;c[M>>2]=ha^da;c[K>>2]=C^H;c[I>>2]=_^y;y=c[g>>2]|0;_=c[F>>2]|0;H=c[D>>2]|0;C=c[B>>2]|0;da=c[z>>2]|0;ha=c[x>>2]|0;ba=c[v>>2]|0;j=c[i>>2]|0;Z=c[t>>2]|0;$=c[u>>2]|0;ia=(c[1184+(b*960|0)+324>>2]^_)&ea;ga=(c[1184+(b*960|0)+328>>2]^H)&ea;aa=(c[1184+(b*960|0)+332>>2]^C)&ea;G=(c[1184+(b*960|0)+336>>2]^da)&ea;E=(c[1184+(b*960|0)+340>>2]^ha)&ea;ca=(c[1184+(b*960|0)+344>>2]^ba)&ea;A=(c[1184+(b*960|0)+348>>2]^j)&ea;w=(c[1184+(b*960|0)+352>>2]^Z)&ea;fa=(c[1184+(b*960|0)+356>>2]^$)&ea;c[g>>2]=(c[1184+(b*960|0)+320>>2]^y)&ea^y;c[F>>2]=ia^_;c[D>>2]=ga^H;c[B>>2]=aa^C;c[z>>2]=G^da;c[x>>2]=E^ha;c[v>>2]=ca^ba;c[i>>2]=A^j;c[t>>2]=w^Z;c[u>>2]=fa^$;$=c[a>>2]|0;fa=c[d>>2]|0;Z=c[k>>2]|0;w=c[l>>2]|0;j=c[m>>2]|0;A=c[n>>2]|0;ba=c[o>>2]|0;ca=c[p>>2]|0;ha=c[q>>2]|0;E=c[r>>2]|0;da=(h^4)+-1>>31;G=(c[1184+(b*960|0)+364>>2]^fa)&da;C=(c[1184+(b*960|0)+368>>2]^Z)&da;aa=(c[1184+(b*960|0)+372>>2]^w)&da;H=(c[1184+(b*960|0)+376>>2]^j)&da;ga=(c[1184+(b*960|0)+380>>2]^A)&da;_=(c[1184+(b*960|0)+384>>2]^ba)&da;ia=(c[1184+(b*960|0)+388>>2]^ca)&da;y=(c[1184+(b*960|0)+392>>2]^ha)&da;ea=(c[1184+(b*960|0)+396>>2]^E)&da;c[a>>2]=(c[1184+(b*960|0)+360>>2]^$)&da^$;c[d>>2]=G^fa;c[k>>2]=C^Z;c[l>>2]=aa^w;c[m>>2]=H^j;c[n>>2]=ga^A;c[o>>2]=_^ba;c[p>>2]=ia^ca;c[q>>2]=y^ha;c[r>>2]=ea^E;E=c[e>>2]|0;ea=c[f>>2]|0;ha=c[W>>2]|0;y=c[U>>2]|0;ca=c[S>>2]|0;ia=c[Q>>2]|0;ba=c[O>>2]|0;_=c[M>>2]|0;A=c[K>>2]|0;ga=c[I>>2]|0;j=(c[1184+(b*960|0)+404>>2]^ea)&da;H=(c[1184+(b*960|0)+408>>2]^ha)&da;w=(c[1184+(b*960|0)+412>>2]^y)&da;aa=(c[1184+(b*960|0)+416>>2]^ca)&da;Z=(c[1184+(b*960|0)+420>>2]^ia)&da;C=(c[1184+(b*960|0)+424>>2]^ba)&da;fa=(c[1184+(b*960|0)+428>>2]^_)&da;G=(c[1184+(b*960|0)+432>>2]^A)&da;$=(c[1184+(b*960|0)+436>>2]^ga)&da;c[e>>2]=(c[1184+(b*960|0)+400>>2]^E)&da^E;c[f>>2]=j^ea;c[W>>2]=H^ha;c[U>>2]=w^y;c[S>>2]=aa^ca;c[Q>>2]=Z^ia;c[O>>2]=C^ba;c[M>>2]=fa^_;c[K>>2]=G^A;c[I>>2]=$^ga;ga=c[g>>2]|0;$=c[F>>2]|0;A=c[D>>2]|0;G=c[B>>2]|0;_=c[z>>2]|0;fa=c[x>>2]|0;ba=c[v>>2]|0;C=c[i>>2]|0;ia=c[t>>2]|0;Z=c[u>>2]|0;ca=(c[1184+(b*960|0)+444>>2]^$)&da;aa=(c[1184+(b*960|0)+448>>2]^A)&da;y=(c[1184+(b*960|0)+452>>2]^G)&da;w=(c[1184+(b*960|0)+456>>2]^_)&da;ha=(c[1184+(b*960|0)+460>>2]^fa)&da;H=(c[1184+(b*960|0)+464>>2]^ba)&da;ea=(c[1184+(b*960|0)+468>>2]^C)&da;j=(c[1184+(b*960|0)+472>>2]^ia)&da;E=(c[1184+(b*960|0)+476>>2]^Z)&da;c[g>>2]=(c[1184+(b*960|0)+440>>2]^ga)&da^ga;c[F>>2]=ca^$;c[D>>2]=aa^A;c[B>>2]=y^G;c[z>>2]=w^_;c[x>>2]=ha^fa;c[v>>2]=H^ba;c[i>>2]=ea^C;c[t>>2]=j^ia;c[u>>2]=E^Z;Z=c[a>>2]|0;E=c[d>>2]|0;ia=c[k>>2]|0;j=c[l>>2]|0;C=c[m>>2]|0;ea=c[n>>2]|0;ba=c[o>>2]|0;H=c[p>>2]|0;fa=c[q>>2]|0;ha=c[r>>2]|0;_=(h^5)+-1>>31;w=(c[1184+(b*960|0)+484>>2]^E)&_;G=(c[1184+(b*960|0)+488>>2]^ia)&_;y=(c[1184+(b*960|0)+492>>2]^j)&_;A=(c[1184+(b*960|0)+496>>2]^C)&_;aa=(c[1184+(b*960|0)+500>>2]^ea)&_;$=(c[1184+(b*960|0)+504>>2]^ba)&_;ca=(c[1184+(b*960|0)+508>>2]^H)&_;ga=(c[1184+(b*960|0)+512>>2]^fa)&_;da=(c[1184+(b*960|0)+516>>2]^ha)&_;c[a>>2]=(c[1184+(b*960|0)+480>>2]^Z)&_^Z;c[d>>2]=w^E;c[k>>2]=G^ia;c[l>>2]=y^j;c[m>>2]=A^C;c[n>>2]=aa^ea;c[o>>2]=$^ba;c[p>>2]=ca^H;c[q>>2]=ga^fa;c[r>>2]=da^ha;ha=c[e>>2]|0;da=c[f>>2]|0;fa=c[W>>2]|0;ga=c[U>>2]|0;H=c[S>>2]|0;ca=c[Q>>2]|0;ba=c[O>>2]|0;$=c[M>>2]|0;ea=c[K>>2]|0;aa=c[I>>2]|0;C=(c[1184+(b*960|0)+524>>2]^da)&_;A=(c[1184+(b*960|0)+528>>2]^fa)&_;j=(c[1184+(b*960|0)+532>>2]^ga)&_;y=(c[1184+(b*960|0)+536>>2]^H)&_;ia=(c[1184+(b*960|0)+540>>2]^ca)&_;G=(c[1184+(b*960|0)+544>>2]^ba)&_;E=(c[1184+(b*960|0)+548>>2]^$)&_;w=(c[1184+(b*960|0)+552>>2]^ea)&_;Z=(c[1184+(b*960|0)+556>>2]^aa)&_;c[e>>2]=(c[1184+(b*960|0)+520>>2]^ha)&_^ha;c[f>>2]=C^da;c[W>>2]=A^fa;c[U>>2]=j^ga;c[S>>2]=y^H;c[Q>>2]=ia^ca;c[O>>2]=G^ba;c[M>>2]=E^$;c[K>>2]=w^ea;c[I>>2]=Z^aa;aa=c[g>>2]|0;Z=c[F>>2]|0;ea=c[D>>2]|0;w=c[B>>2]|0;$=c[z>>2]|0;E=c[x>>2]|0;ba=c[v>>2]|0;G=c[i>>2]|0;ca=c[t>>2]|0;ia=c[u>>2]|0;H=(c[1184+(b*960|0)+564>>2]^Z)&_;y=(c[1184+(b*960|0)+568>>2]^ea)&_;ga=(c[1184+(b*960|0)+572>>2]^w)&_;j=(c[1184+(b*960|0)+576>>2]^$)&_;fa=(c[1184+(b*960|0)+580>>2]^E)&_;A=(c[1184+(b*960|0)+584>>2]^ba)&_;da=(c[1184+(b*960|0)+588>>2]^G)&_;C=(c[1184+(b*960|0)+592>>2]^ca)&_;ha=(c[1184+(b*960|0)+596>>2]^ia)&_;c[g>>2]=(c[1184+(b*960|0)+560>>2]^aa)&_^aa;c[F>>2]=H^Z;c[D>>2]=y^ea;c[B>>2]=ga^w;c[z>>2]=j^$;c[x>>2]=fa^E;c[v>>2]=A^ba;c[i>>2]=da^G;c[t>>2]=C^ca;c[u>>2]=ha^ia;ia=c[a>>2]|0;ha=c[d>>2]|0;ca=c[k>>2]|0;C=c[l>>2]|0;G=c[m>>2]|0;da=c[n>>2]|0;ba=c[o>>2]|0;A=c[p>>2]|0;E=c[q>>2]|0;fa=c[r>>2]|0;$=(h^6)+-1>>31;j=(c[1184+(b*960|0)+604>>2]^ha)&$;w=(c[1184+(b*960|0)+608>>2]^ca)&$;ga=(c[1184+(b*960|0)+612>>2]^C)&$;ea=(c[1184+(b*960|0)+616>>2]^G)&$;y=(c[1184+(b*960|0)+620>>2]^da)&$;Z=(c[1184+(b*960|0)+624>>2]^ba)&$;H=(c[1184+(b*960|0)+628>>2]^A)&$;aa=(c[1184+(b*960|0)+632>>2]^E)&$;_=(c[1184+(b*960|0)+636>>2]^fa)&$;c[a>>2]=(c[1184+(b*960|0)+600>>2]^ia)&$^ia;c[d>>2]=j^ha;c[k>>2]=w^ca;c[l>>2]=ga^C;c[m>>2]=ea^G;c[n>>2]=y^da;c[o>>2]=Z^ba;c[p>>2]=H^A;c[q>>2]=aa^E;c[r>>2]=_^fa;fa=c[e>>2]|0;_=c[f>>2]|0;E=c[W>>2]|0;aa=c[U>>2]|0;A=c[S>>2]|0;H=c[Q>>2]|0;ba=c[O>>2]|0;Z=c[M>>2]|0;da=c[K>>2]|0;y=c[I>>2]|0;G=(c[1184+(b*960|0)+644>>2]^_)&$;ea=(c[1184+(b*960|0)+648>>2]^E)&$;C=(c[1184+(b*960|0)+652>>2]^aa)&$;ga=(c[1184+(b*960|0)+656>>2]^A)&$;ca=(c[1184+(b*960|0)+660>>2]^H)&$;w=(c[1184+(b*960|0)+664>>2]^ba)&$;ha=(c[1184+(b*960|0)+668>>2]^Z)&$;j=(c[1184+(b*960|0)+672>>2]^da)&$;ia=(c[1184+(b*960|0)+676>>2]^y)&$;c[e>>2]=(c[1184+(b*960|0)+640>>2]^fa)&$^fa;c[f>>2]=G^_;c[W>>2]=ea^E;c[U>>2]=C^aa;c[S>>2]=ga^A;c[Q>>2]=ca^H;c[O>>2]=w^ba;c[M>>2]=ha^Z;c[K>>2]=j^da;c[I>>2]=ia^y;y=c[g>>2]|0;ia=c[F>>2]|0;da=c[D>>2]|0;j=c[B>>2]|0;Z=c[z>>2]|0;ha=c[x>>2]|0;ba=c[v>>2]|0;w=c[i>>2]|0;H=c[t>>2]|0;ca=c[u>>2]|0;A=(c[1184+(b*960|0)+684>>2]^ia)&$;ga=(c[1184+(b*960|0)+688>>2]^da)&$;aa=(c[1184+(b*960|0)+692>>2]^j)&$;C=(c[1184+(b*960|0)+696>>2]^Z)&$;E=(c[1184+(b*960|0)+700>>2]^ha)&$;ea=(c[1184+(b*960|0)+704>>2]^ba)&$;_=(c[1184+(b*960|0)+708>>2]^w)&$;G=(c[1184+(b*960|0)+712>>2]^H)&$;fa=(c[1184+(b*960|0)+716>>2]^ca)&$;c[g>>2]=(c[1184+(b*960|0)+680>>2]^y)&$^y;c[F>>2]=A^ia;c[D>>2]=ga^da;c[B>>2]=aa^j;c[z>>2]=C^Z;c[x>>2]=E^ha;c[v>>2]=ea^ba;c[i>>2]=_^w;c[t>>2]=G^H;c[u>>2]=fa^ca;ca=c[a>>2]|0;fa=c[d>>2]|0;H=c[k>>2]|0;G=c[l>>2]|0;w=c[m>>2]|0;_=c[n>>2]|0;ba=c[o>>2]|0;ea=c[p>>2]|0;ha=c[q>>2]|0;E=c[r>>2]|0;Z=(h^7)+-1>>31;C=(c[1184+(b*960|0)+724>>2]^fa)&Z;j=(c[1184+(b*960|0)+728>>2]^H)&Z;aa=(c[1184+(b*960|0)+732>>2]^G)&Z;da=(c[1184+(b*960|0)+736>>2]^w)&Z;ga=(c[1184+(b*960|0)+740>>2]^_)&Z;ia=(c[1184+(b*960|0)+744>>2]^ba)&Z;A=(c[1184+(b*960|0)+748>>2]^ea)&Z;y=(c[1184+(b*960|0)+752>>2]^ha)&Z;$=(c[1184+(b*960|0)+756>>2]^E)&Z;c[a>>2]=(c[1184+(b*960|0)+720>>2]^ca)&Z^ca;c[d>>2]=C^fa;c[k>>2]=j^H;c[l>>2]=aa^G;c[m>>2]=da^w;c[n>>2]=ga^_;c[o>>2]=ia^ba;c[p>>2]=A^ea;c[q>>2]=y^ha;c[r>>2]=$^E;E=c[e>>2]|0;$=c[f>>2]|0;ha=c[W>>2]|0;y=c[U>>2]|0;ea=c[S>>2]|0;A=c[Q>>2]|0;ba=c[O>>2]|0;ia=c[M>>2]|0;_=c[K>>2]|0;ga=c[I>>2]|0;w=(c[1184+(b*960|0)+764>>2]^$)&Z;da=(c[1184+(b*960|0)+768>>2]^ha)&Z;G=(c[1184+(b*960|0)+772>>2]^y)&Z;aa=(c[1184+(b*960|0)+776>>2]^ea)&Z;H=(c[1184+(b*960|0)+780>>2]^A)&Z;j=(c[1184+(b*960|0)+784>>2]^ba)&Z;fa=(c[1184+(b*960|0)+788>>2]^ia)&Z;C=(c[1184+(b*960|0)+792>>2]^_)&Z;ca=(c[1184+(b*960|0)+796>>2]^ga)&Z;c[e>>2]=(c[1184+(b*960|0)+760>>2]^E)&Z^E;c[f>>2]=w^$;c[W>>2]=da^ha;c[U>>2]=G^y;c[S>>2]=aa^ea;c[Q>>2]=H^A;c[O>>2]=j^ba;c[M>>2]=fa^ia;c[K>>2]=C^_;c[I>>2]=ca^ga;ga=c[g>>2]|0;ca=c[F>>2]|0;_=c[D>>2]|0;C=c[B>>2]|0;ia=c[z>>2]|0;fa=c[x>>2]|0;ba=c[v>>2]|0;j=c[i>>2]|0;A=c[t>>2]|0;H=c[u>>2]|0;ea=(c[1184+(b*960|0)+804>>2]^ca)&Z;aa=(c[1184+(b*960|0)+808>>2]^_)&Z;y=(c[1184+(b*960|0)+812>>2]^C)&Z;G=(c[1184+(b*960|0)+816>>2]^ia)&Z;ha=(c[1184+(b*960|0)+820>>2]^fa)&Z;da=(c[1184+(b*960|0)+824>>2]^ba)&Z;$=(c[1184+(b*960|0)+828>>2]^j)&Z;w=(c[1184+(b*960|0)+832>>2]^A)&Z;E=(c[1184+(b*960|0)+836>>2]^H)&Z;c[g>>2]=(c[1184+(b*960|0)+800>>2]^ga)&Z^ga;c[F>>2]=ea^ca;c[D>>2]=aa^_;c[B>>2]=y^C;c[z>>2]=G^ia;c[x>>2]=ha^fa;c[v>>2]=da^ba;c[i>>2]=$^j;c[t>>2]=w^A;c[u>>2]=E^H;H=c[a>>2]|0;E=c[d>>2]|0;A=c[k>>2]|0;w=c[l>>2]|0;j=c[m>>2]|0;$=c[n>>2]|0;ba=c[o>>2]|0;da=c[p>>2]|0;fa=c[q>>2]|0;ha=c[r>>2]|0;ia=(h^8)+-1>>31;G=(c[1184+(b*960|0)+844>>2]^E)&ia;C=(c[1184+(b*960|0)+848>>2]^A)&ia;y=(c[1184+(b*960|0)+852>>2]^w)&ia;h=(c[1184+(b*960|0)+856>>2]^j)&ia;_=(c[1184+(b*960|0)+860>>2]^$)&ia;aa=(c[1184+(b*960|0)+864>>2]^ba)&ia;ca=(c[1184+(b*960|0)+868>>2]^da)&ia;ea=(c[1184+(b*960|0)+872>>2]^fa)&ia;ga=(c[1184+(b*960|0)+876>>2]^ha)&ia;c[a>>2]=(c[1184+(b*960|0)+840>>2]^H)&ia^H;c[d>>2]=G^E;c[k>>2]=C^A;c[l>>2]=y^w;c[m>>2]=h^j;c[n>>2]=_^$;c[o>>2]=aa^ba;c[p>>2]=ca^da;c[q>>2]=ea^fa;c[r>>2]=ga^ha;ha=c[e>>2]|0;ga=c[f>>2]|0;fa=c[W>>2]|0;ea=c[U>>2]|0;da=c[S>>2]|0;ca=c[Q>>2]|0;ba=c[O>>2]|0;aa=c[M>>2]|0;$=c[K>>2]|0;_=c[I>>2]|0;j=(c[1184+(b*960|0)+884>>2]^ga)&ia;h=(c[1184+(b*960|0)+888>>2]^fa)&ia;w=(c[1184+(b*960|0)+892>>2]^ea)&ia;y=(c[1184+(b*960|0)+896>>2]^da)&ia;A=(c[1184+(b*960|0)+900>>2]^ca)&ia;C=(c[1184+(b*960|0)+904>>2]^ba)&ia;E=(c[1184+(b*960|0)+908>>2]^aa)&ia;G=(c[1184+(b*960|0)+912>>2]^$)&ia;H=(c[1184+(b*960|0)+916>>2]^_)&ia;ha=(c[1184+(b*960|0)+880>>2]^ha)&ia^ha;c[e>>2]=ha;ga=j^ga;c[f>>2]=ga;fa=h^fa;c[W>>2]=fa;ea=w^ea;c[U>>2]=ea;da=y^da;c[S>>2]=da;ca=A^ca;c[Q>>2]=ca;ba=C^ba;c[O>>2]=ba;aa=E^aa;c[M>>2]=aa;$=G^$;c[K>>2]=$;_=H^_;c[I>>2]=_;H=c[g>>2]|0;G=c[F>>2]|0;E=c[D>>2]|0;C=c[B>>2]|0;A=c[z>>2]|0;y=c[x>>2]|0;w=c[v>>2]|0;h=c[i>>2]|0;j=c[t>>2]|0;Z=c[u>>2]|0;J=(c[1184+(b*960|0)+924>>2]^G)&ia;L=(c[1184+(b*960|0)+928>>2]^E)&ia;N=(c[1184+(b*960|0)+932>>2]^C)&ia;P=(c[1184+(b*960|0)+936>>2]^A)&ia;R=(c[1184+(b*960|0)+940>>2]^y)&ia;T=(c[1184+(b*960|0)+944>>2]^w)&ia;V=(c[1184+(b*960|0)+948>>2]^h)&ia;X=(c[1184+(b*960|0)+952>>2]^j)&ia;Y=(c[1184+(b*960|0)+956>>2]^Z)&ia;H=(c[1184+(b*960|0)+920>>2]^H)&ia^H;c[g>>2]=H;G=J^G;c[F>>2]=G;E=L^E;c[D>>2]=E;C=N^C;c[B>>2]=C;A=P^A;c[z>>2]=A;y=R^y;c[x>>2]=y;w=T^w;c[v>>2]=w;h=V^h;c[i>>2]=h;j=X^j;c[t>>2]=j;b=Y^Z;c[u>>2]=b;Z=c[a>>2]|0;Y=c[d>>2]|0;X=c[k>>2]|0;V=c[l>>2]|0;T=c[m>>2]|0;R=c[n>>2]|0;P=c[o>>2]|0;N=c[p>>2]|0;L=c[q>>2]|0;J=c[r>>2]|0;c[a>>2]=(ha^Z)&s^Z;c[d>>2]=(ga^Y)&s^Y;c[k>>2]=(fa^X)&s^X;c[l>>2]=(ea^V)&s^V;c[m>>2]=(da^T)&s^T;c[n>>2]=(ca^R)&s^R;c[o>>2]=(ba^P)&s^P;c[p>>2]=(aa^N)&s^N;c[q>>2]=($^L)&s^L;c[r>>2]=(_^J)&s^J;d=c[e>>2]|0;a=c[f>>2]|0;r=c[W>>2]|0;q=c[U>>2]|0;p=c[S>>2]|0;o=c[Q>>2]|0;n=c[O>>2]|0;m=c[M>>2]|0;l=c[K>>2]|0;k=c[I>>2]|0;c[e>>2]=(Z^d)&s^d;c[f>>2]=(Y^a)&s^a;c[W>>2]=(X^r)&s^r;c[U>>2]=(V^q)&s^q;c[S>>2]=(T^p)&s^p;c[Q>>2]=(R^o)&s^o;c[O>>2]=(P^n)&s^n;c[M>>2]=(N^m)&s^m;c[K>>2]=(L^l)&s^l;c[I>>2]=(J^k)&s^k;f=c[g>>2]|0;k=c[F>>2]|0;l=c[D>>2]|0;m=c[B>>2]|0;n=c[z>>2]|0;o=c[x>>2]|0;p=c[v>>2]|0;q=c[i>>2]|0;r=c[t>>2]|0;a=c[u>>2]|0;c[g>>2]=(f^0-H)&s^f;c[F>>2]=(k^0-G)&s^k;c[D>>2]=(l^0-E)&s^l;c[B>>2]=(m^0-C)&s^m;c[z>>2]=(n^0-A)&s^n;c[x>>2]=(o^0-y)&s^o;c[v>>2]=(p^0-w)&s^p;c[i>>2]=(q^0-h)&s^q;c[t>>2]=(r^0-j)&s^r;c[u>>2]=(a^0-b)&s^a;return}function Tc(a,b){a=a|0;b=b|0;var d=0,e=0,f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0;g=i;e=i=i+63&-64;i=i+240|0;d=e+80|0;f=e+40|0;if(Nc(d,b)|0){f=-1;i=g;return f|0}y=e+4|0;c[y>>2]=0;c[y+4>>2]=0;c[y+8>>2]=0;c[y+12>>2]=0;c[y+16>>2]=0;c[y+20>>2]=0;c[y+24>>2]=0;c[y+28>>2]=0;q=d+40|0;p=d+44|0;n=d+48|0;m=d+52|0;l=d+56|0;k=d+60|0;j=d+64|0;h=d+68|0;r=d+72|0;b=d+76|0;z=0-(c[p>>2]|0)|0;x=0-(c[n>>2]|0)|0;w=0-(c[m>>2]|0)|0;v=0-(c[l>>2]|0)|0;u=0-(c[k>>2]|0)|0;t=0-(c[j>>2]|0)|0;s=0-(c[h>>2]|0)|0;d=0-(c[r>>2]|0)|0;o=0-(c[b>>2]|0)|0;c[e>>2]=1-(c[q>>2]|0);c[y>>2]=z;c[e+8>>2]=x;c[e+12>>2]=w;c[e+16>>2]=v;c[e+20>>2]=u;c[e+24>>2]=t;c[e+28>>2]=s;c[e+32>>2]=d;c[e+36>>2]=o;Ic(e,e);o=f+4|0;c[o>>2]=0;c[o+4>>2]=0;c[o+8>>2]=0;c[o+12>>2]=0;c[o+16>>2]=0;c[o+20>>2]=0;c[o+24>>2]=0;c[o+28>>2]=0;p=c[p>>2]|0;n=c[n>>2]|0;m=c[m>>2]|0;l=c[l>>2]|0;k=c[k>>2]|0;j=c[j>>2]|0;h=c[h>>2]|0;d=c[r>>2]|0;b=c[b>>2]|0;c[f>>2]=(c[q>>2]|0)+1;c[o>>2]=p;c[f+8>>2]=n;c[f+12>>2]=m;c[f+16>>2]=l;c[f+20>>2]=k;c[f+24>>2]=j;c[f+28>>2]=h;c[f+32>>2]=d;c[f+36>>2]=b;Jc(f,f,e);Lc(a,f);f=0;i=g;return f|0}function Uc(b,e){b=b|0;e=e|0;var f=0,g=0,h=0,j=0,k=0,l=0,m=0;k=i;g=i=i+63&-64;i=i+272|0;h=g;g=g+208|0;f=h+64|0;j=h;l=8;m=j+64|0;do{c[j>>2]=c[l>>2];j=j+4|0;l=l+4|0}while((j|0)<(m|0));j=h+72|0;c[j>>2]=256;c[j+4>>2]=0;j=f;c[j>>2]=0;c[j+4>>2]=0;j=h+80|0;l=e;m=j+32|0;do{a[j>>0]=a[l>>0]|0;j=j+1|0;l=l+1|0}while((j|0)<(m|0));Gb(h,g);a[g>>0]=(d[g>>0]|0)&248;j=g+31|0;a[j>>0]=(d[j>>0]|0)&63|64;j=b;l=g;m=j+32|0;do{a[j>>0]=a[l>>0]|0;j=j+1|0;l=l+1|0}while((j|0)<(m|0));i=k;return 0}function Vc(b,e,f,g,h){b=b|0;e=e|0;f=f|0;g=g|0;h=h|0;var j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0,xa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha=0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa=0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0,db=0,eb=0,fb=0,gb=0,hb=0,ib=0,jb=0,kb=0,lb=0,mb=0,nb=0,ob=0,pb=0,qb=0,rb=0;Qa=i;j=i=i+63&-64;i=i+3024|0;Ma=j+2800|0;Na=j+2544|0;Oa=j+2288|0;k=j+2248|0;Ja=j+968|0;Ka=j+808|0;La=j+648|0;t=j+488|0;n=j;p=j+2952|0;Pa=j+2920|0;s=j+328|0;j=j+208|0;if((d[b+63>>0]|0)>31){b=-1;i=Qa;return b|0}if(Nc(s,h)|0){b=-1;i=Qa;return b|0}if(!((a[h+31>>0]|(a[h+30>>0]|(a[h+29>>0]|(a[h+28>>0]|(a[h+27>>0]|(a[h+26>>0]|(a[h+25>>0]|(a[h+24>>0]|(a[h+23>>0]|(a[h+22>>0]|(a[h+21>>0]|(a[h+20>>0]|(a[h+19>>0]|(a[h+18>>0]|(a[h+17>>0]|(a[h+16>>0]|(a[h+15>>0]|(a[h+14>>0]|(a[h+13>>0]|(a[h+12>>0]|(a[h+11>>0]|(a[h+10>>0]|(a[h+9>>0]|(a[h+8>>0]|(a[h+7>>0]|(a[h+6>>0]|(a[h+5>>0]|(a[h+4>>0]|(a[h+3>>0]|(a[h+2>>0]|(a[h+1>>0]|a[h>>0])))))))))))))))))))))))))))))))<<24>>24)){b=-1;i=Qa;return b|0}l=n+64|0;q=l;c[q>>2]=0;c[q+4>>2]=0;q=n;o=8;r=q+64|0;do{c[q>>2]=c[o>>2];q=q+4|0;o=o+4|0}while((q|0)<(r|0));m=n+72|0;q=m;c[q>>2]=256;c[q+4>>2]=0;q=l;c[q>>2]=0;c[q+4>>2]=0;q=n+80|0;o=b;r=q+32|0;do{a[q>>0]=a[o>>0]|0;q=q+1|0;o=o+1|0}while((q|0)<(r|0));q=m;c[q>>2]=512;c[q+4>>2]=0;q=l;c[q>>2]=0;c[q+4>>2]=0;q=n+112|0;o=h;r=q+32|0;do{a[q>>0]=a[o>>0]|0;q=q+1|0;o=o+1|0}while((q|0)<(r|0));Fb(n,e,f,g);Gb(n,p);Wc(p);f=0;do{a[Na+f>>0]=(d[p+(f>>3)>>0]|0)>>>(f&7)&1;f=f+1|0}while((f|0)!=256);p=b+32|0;o=0;while(1){e=Na+o|0;a:do if(a[e>>0]|0){h=1;do{g=h+o|0;if((g|0)>=256)break a;m=Na+g|0;f=a[m>>0]|0;b:do if(f<<24>>24){n=a[e>>0]|0;f=f<<24>>24<<h;l=n+f|0;if((l|0)<16){a[e>>0]=l;a[m>>0]=0;break}f=n-f|0;if((f|0)<=-16)break a;a[e>>0]=f;while(1){f=Na+g|0;if(!(a[f>>0]|0))break;a[f>>0]=0;g=g+1|0;if((g|0)>=256)break b}a[f>>0]=1}while(0);h=h+1|0}while((h|0)<7)}while(0);o=o+1|0;if((o|0)==256){f=0;break}}do{a[Oa+f>>0]=(d[p+(f>>3)>>0]|0)>>>(f&7)&1;f=f+1|0}while((f|0)!=256);o=0;do{e=Oa+o|0;c:do if(a[e>>0]|0){h=1;do{g=h+o|0;if((g|0)>=256)break c;m=Oa+g|0;f=a[m>>0]|0;d:do if(f<<24>>24){n=a[e>>0]|0;f=f<<24>>24<<h;l=n+f|0;if((l|0)<16){a[e>>0]=l;a[m>>0]=0;break}f=n-f|0;if((f|0)<=-16)break c;a[e>>0]=f;while(1){f=Oa+g|0;if(!(a[f>>0]|0))break;a[f>>0]=0;g=g+1|0;if((g|0)>=256)break d}a[f>>0]=1}while(0);h=h+1|0}while((h|0)<7)}while(0);o=o+1|0}while((o|0)!=256);Qc(Ja,s);Ia=c[s+4>>2]|0;r=c[s+8>>2]|0;q=c[s+12>>2]|0;Ga=c[s+16>>2]|0;Fa=c[s+20>>2]|0;Ea=c[s+24>>2]|0;Da=c[s+28>>2]|0;Ca=c[s+32>>2]|0;Ba=c[s+36>>2]|0;c[Ma>>2]=c[s>>2];c[Ma+4>>2]=Ia;c[Ma+8>>2]=r;c[Ma+12>>2]=q;c[Ma+16>>2]=Ga;c[Ma+20>>2]=Fa;c[Ma+24>>2]=Ea;c[Ma+28>>2]=Da;c[Ma+32>>2]=Ca;c[Ma+36>>2]=Ba;Ba=c[s+44>>2]|0;Ca=c[s+48>>2]|0;Da=c[s+52>>2]|0;Ea=c[s+56>>2]|0;Fa=c[s+60>>2]|0;Ga=c[s+64>>2]|0;q=c[s+68>>2]|0;r=c[s+72>>2]|0;Ia=c[s+76>>2]|0;c[Ma+40>>2]=c[s+40>>2];c[Ma+44>>2]=Ba;c[Ma+48>>2]=Ca;c[Ma+52>>2]=Da;c[Ma+56>>2]=Ea;c[Ma+60>>2]=Fa;c[Ma+64>>2]=Ga;c[Ma+68>>2]=q;c[Ma+72>>2]=r;c[Ma+76>>2]=Ia;Ia=c[s+84>>2]|0;r=c[s+88>>2]|0;q=c[s+92>>2]|0;Ga=c[s+96>>2]|0;Fa=c[s+100>>2]|0;Ea=c[s+104>>2]|0;Da=c[s+108>>2]|0;Ca=c[s+112>>2]|0;Ba=c[s+116>>2]|0;c[Ma+80>>2]=c[s+80>>2];c[Ma+84>>2]=Ia;c[Ma+88>>2]=r;c[Ma+92>>2]=q;c[Ma+96>>2]=Ga;c[Ma+100>>2]=Fa;c[Ma+104>>2]=Ea;c[Ma+108>>2]=Da;c[Ma+112>>2]=Ca;c[Ma+116>>2]=Ba;Pc(Ka,Ma);Ba=Ka+120|0;Jc(t,Ka,Ba);Ca=Ka+40|0;Da=Ka+80|0;Jc(t+40|0,Ca,Da);Jc(t+80|0,Da,Ba);Jc(t+120|0,Ka,Ca);Mc(Ka,t,Ja);Jc(La,Ka,Ba);Ea=La+40|0;Jc(Ea,Ca,Da);Fa=La+80|0;Jc(Fa,Da,Ba);Ga=La+120|0;Jc(Ga,Ka,Ca);q=Ja+160|0;Qc(q,La);Mc(Ka,t,q);Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);q=Ja+320|0;Qc(q,La);Mc(Ka,t,q);Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);q=Ja+480|0;Qc(q,La);Mc(Ka,t,q);Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);q=Ja+640|0;Qc(q,La);Mc(Ka,t,q);Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);q=Ja+800|0;Qc(q,La);Mc(Ka,t,q);Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);q=Ja+960|0;Qc(q,La);Mc(Ka,t,q);Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);Qc(Ja+1120|0,La);q=j;r=q+40|0;do{c[q>>2]=0;q=q+4|0}while((q|0)<(r|0));Ha=j+40|0;c[Ha>>2]=1;q=j+44|0;r=q+36|0;do{c[q>>2]=0;q=q+4|0}while((q|0)<(r|0));Ia=j+80|0;c[Ia>>2]=1;q=j+84|0;r=q+36|0;do{c[q>>2]=0;q=q+4|0}while((q|0)<(r|0));g=255;while(1){if(a[Na+g>>0]|0){f=g;break}if(a[Oa+g>>0]|0){f=g;break}f=g+-1|0;if((g|0)>0)g=f;else break}if((f|0)>-1){l=La+44|0;m=La+48|0;n=La+52|0;e=La+56|0;h=La+60|0;o=La+64|0;p=La+68|0;q=La+72|0;r=La+76|0;s=La+4|0;t=La+8|0;u=La+12|0;v=La+16|0;w=La+20|0;x=La+24|0;y=La+28|0;z=La+32|0;A=La+36|0;B=Ka+4|0;C=Ka+8|0;D=Ka+12|0;E=Ka+16|0;F=Ka+20|0;G=Ka+24|0;H=Ka+28|0;I=Ka+32|0;J=Ka+36|0;K=Ka+44|0;L=Ka+48|0;M=Ka+52|0;N=Ka+56|0;O=Ka+60|0;P=Ka+64|0;Q=Ka+68|0;R=Ka+72|0;S=Ka+76|0;T=La+84|0;U=La+88|0;V=La+92|0;W=La+96|0;X=La+100|0;Y=La+104|0;Z=La+108|0;_=La+112|0;$=La+116|0;aa=k+4|0;ba=k+8|0;ca=k+12|0;da=k+16|0;ea=k+20|0;fa=k+24|0;ga=k+28|0;ha=k+32|0;ia=k+36|0;ja=Ka+84|0;ka=Ka+88|0;la=Ka+92|0;ma=Ka+96|0;na=Ka+100|0;oa=Ka+104|0;pa=Ka+108|0;qa=Ka+112|0;ra=Ka+116|0;sa=Ka+124|0;ta=Ka+128|0;ua=Ka+132|0;va=Ka+136|0;wa=Ka+140|0;xa=Ka+144|0;ya=Ka+148|0;za=Ka+152|0;Aa=Ka+156|0;while(1){Pc(Ka,j);g=a[Na+f>>0]|0;if(g<<24>>24<=0){if(g<<24>>24<0){Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);hb=(g<<24>>24|0)/-2|0;rb=c[Ea>>2]|0;Xa=c[l>>2]|0;Ta=c[m>>2]|0;ib=c[n>>2]|0;mb=c[e>>2]|0;qb=c[h>>2]|0;$a=c[o>>2]|0;bb=c[p>>2]|0;db=c[q>>2]|0;fb=c[r>>2]|0;Za=c[La>>2]|0;Va=c[s>>2]|0;Ra=c[t>>2]|0;kb=c[u>>2]|0;ob=c[v>>2]|0;_a=c[w>>2]|0;ab=c[x>>2]|0;cb=c[y>>2]|0;eb=c[z>>2]|0;gb=c[A>>2]|0;c[Ka>>2]=Za+rb;c[B>>2]=Va+Xa;c[C>>2]=Ra+Ta;c[D>>2]=kb+ib;c[E>>2]=ob+mb;c[F>>2]=_a+qb;c[G>>2]=ab+$a;c[H>>2]=cb+bb;c[I>>2]=eb+db;c[J>>2]=gb+fb;c[Ca>>2]=rb-Za;c[K>>2]=Xa-Va;c[L>>2]=Ta-Ra;c[M>>2]=ib-kb;c[N>>2]=mb-ob;c[O>>2]=qb-_a;c[P>>2]=$a-ab;c[Q>>2]=bb-cb;c[R>>2]=db-eb;c[S>>2]=fb-gb;Jc(Da,Ka,Ja+(hb*160|0)+40|0);Jc(Ca,Ca,Ja+(hb*160|0)|0);Jc(Ba,Ja+(hb*160|0)+120|0,Ga);Jc(Ka,Fa,Ja+(hb*160|0)+80|0);hb=c[Ka>>2]<<1;gb=c[B>>2]<<1;fb=c[C>>2]<<1;eb=c[D>>2]<<1;db=c[E>>2]<<1;cb=c[F>>2]<<1;bb=c[G>>2]<<1;ab=c[H>>2]<<1;$a=c[I>>2]<<1;_a=c[J>>2]<<1;c[k>>2]=hb;c[aa>>2]=gb;c[ba>>2]=fb;c[ca>>2]=eb;c[da>>2]=db;c[ea>>2]=cb;c[fa>>2]=bb;c[ga>>2]=ab;c[ha>>2]=$a;c[ia>>2]=_a;qb=c[Da>>2]|0;ob=c[ja>>2]|0;mb=c[ka>>2]|0;kb=c[la>>2]|0;ib=c[ma>>2]|0;Ra=c[na>>2]|0;Ta=c[oa>>2]|0;Va=c[pa>>2]|0;Xa=c[qa>>2]|0;Za=c[ra>>2]|0;rb=c[Ca>>2]|0;pb=c[K>>2]|0;nb=c[L>>2]|0;lb=c[M>>2]|0;jb=c[N>>2]|0;g=c[O>>2]|0;Sa=c[P>>2]|0;Ua=c[Q>>2]|0;Wa=c[R>>2]|0;Ya=c[S>>2]|0;c[Ka>>2]=qb-rb;c[B>>2]=ob-pb;c[C>>2]=mb-nb;c[D>>2]=kb-lb;c[E>>2]=ib-jb;c[F>>2]=Ra-g;c[G>>2]=Ta-Sa;c[H>>2]=Va-Ua;c[I>>2]=Xa-Wa;c[J>>2]=Za-Ya;c[Ca>>2]=rb+qb;c[K>>2]=pb+ob;c[L>>2]=nb+mb;c[M>>2]=lb+kb;c[N>>2]=jb+ib;c[O>>2]=g+Ra;c[P>>2]=Sa+Ta;c[Q>>2]=Ua+Va;c[R>>2]=Wa+Xa;c[S>>2]=Ya+Za;Za=c[Ba>>2]|0;Ya=c[sa>>2]|0;Xa=c[ta>>2]|0;Wa=c[ua>>2]|0;Va=c[va>>2]|0;Ua=c[wa>>2]|0;Ta=c[xa>>2]|0;Sa=c[ya>>2]|0;Ra=c[za>>2]|0;g=c[Aa>>2]|0;c[Da>>2]=hb-Za;c[ja>>2]=gb-Ya;c[ka>>2]=fb-Xa;c[la>>2]=eb-Wa;c[ma>>2]=db-Va;c[na>>2]=cb-Ua;c[oa>>2]=bb-Ta;c[pa>>2]=ab-Sa;c[qa>>2]=$a-Ra;c[ra>>2]=_a-g;Ya=Ya+(c[aa>>2]|0)|0;Xa=Xa+(c[ba>>2]|0)|0;Wa=Wa+(c[ca>>2]|0)|0;Va=Va+(c[da>>2]|0)|0;Ua=Ua+(c[ea>>2]|0)|0;Ta=Ta+(c[fa>>2]|0)|0;Sa=Sa+(c[ga>>2]|0)|0;Ra=Ra+(c[ha>>2]|0)|0;g=g+(c[ia>>2]|0)|0;c[Ba>>2]=Za+(c[k>>2]|0);c[sa>>2]=Ya;c[ta>>2]=Xa;c[ua>>2]=Wa;c[va>>2]=Va;c[wa>>2]=Ua;c[xa>>2]=Ta;c[ya>>2]=Sa;c[za>>2]=Ra;c[Aa>>2]=g}}else{Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);Mc(Ka,La,Ja+(((g<<24>>24|0)/2|0)*160|0)|0)}g=a[Oa+f>>0]|0;if(g<<24>>24<=0){if(g<<24>>24<0){Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);_a=(g<<24>>24|0)/-2|0;g=c[Ea>>2]|0;kb=c[l>>2]|0;ob=c[m>>2]|0;Za=c[n>>2]|0;Va=c[e>>2]|0;Ra=c[h>>2]|0;gb=c[o>>2]|0;eb=c[p>>2]|0;cb=c[q>>2]|0;ab=c[r>>2]|0;ib=c[La>>2]|0;mb=c[s>>2]|0;qb=c[t>>2]|0;Xa=c[u>>2]|0;Ta=c[v>>2]|0;hb=c[w>>2]|0;fb=c[x>>2]|0;db=c[y>>2]|0;bb=c[z>>2]|0;$a=c[A>>2]|0;c[Ka>>2]=ib+g;c[B>>2]=mb+kb;c[C>>2]=qb+ob;c[D>>2]=Xa+Za;c[E>>2]=Ta+Va;c[F>>2]=hb+Ra;c[G>>2]=fb+gb;c[H>>2]=db+eb;c[I>>2]=bb+cb;c[J>>2]=$a+ab;c[Ca>>2]=g-ib;c[K>>2]=kb-mb;c[L>>2]=ob-qb;c[M>>2]=Za-Xa;c[N>>2]=Va-Ta;c[O>>2]=Ra-hb;c[P>>2]=gb-fb;c[Q>>2]=eb-db;c[R>>2]=cb-bb;c[S>>2]=ab-$a;Jc(Da,Ka,104+(_a*120|0)+40|0);Jc(Ca,Ca,104+(_a*120|0)|0);Jc(Ba,104+(_a*120|0)+80|0,Ga);_a=c[Fa>>2]<<1;$a=c[T>>2]<<1;ab=c[U>>2]<<1;bb=c[V>>2]<<1;cb=c[W>>2]<<1;db=c[X>>2]<<1;eb=c[Y>>2]<<1;fb=c[Z>>2]<<1;gb=c[_>>2]<<1;hb=c[$>>2]<<1;c[k>>2]=_a;c[aa>>2]=$a;c[ba>>2]=ab;c[ca>>2]=bb;c[da>>2]=cb;c[ea>>2]=db;c[fa>>2]=eb;c[ga>>2]=fb;c[ha>>2]=gb;c[ia>>2]=hb;Ra=c[Da>>2]|0;Ta=c[ja>>2]|0;Va=c[ka>>2]|0;Xa=c[la>>2]|0;Za=c[ma>>2]|0;qb=c[na>>2]|0;ob=c[oa>>2]|0;mb=c[pa>>2]|0;kb=c[qa>>2]|0;ib=c[ra>>2]|0;g=c[Ca>>2]|0;Sa=c[K>>2]|0;Ua=c[L>>2]|0;Wa=c[M>>2]|0;Ya=c[N>>2]|0;rb=c[O>>2]|0;pb=c[P>>2]|0;nb=c[Q>>2]|0;lb=c[R>>2]|0;jb=c[S>>2]|0;c[Ka>>2]=Ra-g;c[B>>2]=Ta-Sa;c[C>>2]=Va-Ua;c[D>>2]=Xa-Wa;c[E>>2]=Za-Ya;c[F>>2]=qb-rb;c[G>>2]=ob-pb;c[H>>2]=mb-nb;c[I>>2]=kb-lb;c[J>>2]=ib-jb;c[Ca>>2]=g+Ra;c[K>>2]=Sa+Ta;c[L>>2]=Ua+Va;c[M>>2]=Wa+Xa;c[N>>2]=Ya+Za;c[O>>2]=rb+qb;c[P>>2]=pb+ob;c[Q>>2]=nb+mb;c[R>>2]=lb+kb;c[S>>2]=jb+ib;ib=c[Ba>>2]|0;jb=c[sa>>2]|0;kb=c[ta>>2]|0;lb=c[ua>>2]|0;mb=c[va>>2]|0;nb=c[wa>>2]|0;ob=c[xa>>2]|0;pb=c[ya>>2]|0;qb=c[za>>2]|0;rb=c[Aa>>2]|0;c[Da>>2]=_a-ib;c[ja>>2]=$a-jb;c[ka>>2]=ab-kb;c[la>>2]=bb-lb;c[ma>>2]=cb-mb;c[na>>2]=db-nb;c[oa>>2]=eb-ob;c[pa>>2]=fb-pb;c[qa>>2]=gb-qb;c[ra>>2]=hb-rb;jb=jb+(c[aa>>2]|0)|0;kb=kb+(c[ba>>2]|0)|0;lb=lb+(c[ca>>2]|0)|0;mb=mb+(c[da>>2]|0)|0;nb=nb+(c[ea>>2]|0)|0;ob=ob+(c[fa>>2]|0)|0;pb=pb+(c[ga>>2]|0)|0;qb=qb+(c[ha>>2]|0)|0;rb=rb+(c[ia>>2]|0)|0;c[Ba>>2]=ib+(c[k>>2]|0);c[sa>>2]=jb;c[ta>>2]=kb;c[ua>>2]=lb;c[va>>2]=mb;c[wa>>2]=nb;c[xa>>2]=ob;c[ya>>2]=pb;c[za>>2]=qb;c[Aa>>2]=rb}}else{Jc(La,Ka,Ba);Jc(Ea,Ca,Da);Jc(Fa,Da,Ba);Jc(Ga,Ka,Ca);Oc(Ka,La,104+(((g<<24>>24|0)/2|0)*120|0)|0)}Jc(j,Ka,Ba);Jc(Ha,Ca,Da);Jc(Ia,Da,Ba);if((f|0)>0)f=f+-1|0;else break}}Ic(k,Ia);Jc(Na,j,k);Jc(Oa,Ha,k);Lc(Pa,Oa);Lc(Ma,Na);j=Pa+31|0;a[j>>0]=d[j>>0]^d[Ma>>0]<<7;j=Yc(Pa,b)|0;k=(Pa|0)==(b|0);f=0;g=0;do{f=a[Pa+g>>0]^a[b+g>>0]|f;g=g+1|0}while((g|0)!=32);rb=(k?-1:j)|(((f&255)+511|0)>>>8&1)+-1;i=Qa;return rb|0}function Wc(b){b=b|0;var c=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0,xa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha=0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa=0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0,db=0,eb=0,fb=0,gb=0;ea=b+1|0;ba=b+2|0;D=a[ba>>0]|0;f=d[b>>0]|0;n=Hd(d[ea>>0]|0|0,0,8)|0;va=C;D=D&255;V=Hd(D|0,0,16)|0;aa=b+3|0;y=Hd(d[aa>>0]|0|0,0,8)|0;ga=C;$=b+4|0;U=Hd(d[$>>0]|0|0,0,16)|0;ga=ga|C;Y=b+5|0;N=d[Y>>0]|0;X=Hd(N|0,0,24)|0;ga=Gd(y|D|U|X|0,ga|C|0,5)|0;X=b+6|0;U=b+7|0;D=a[U>>0]|0;y=Hd(d[X>>0]|0|0,0,8)|0;Ba=C;D=D&255;T=Hd(D|0,0,16)|0;Ba=Gd(y|N|T|0,Ba|C|0,2)|0;T=b+8|0;N=Hd(d[T>>0]|0|0,0,8)|0;y=C;S=b+9|0;Ca=Hd(d[S>>0]|0|0,0,16)|0;y=y|C;P=b+10|0;Sa=d[P>>0]|0;O=Hd(Sa|0,0,24)|0;y=Gd(N|D|Ca|O|0,y|C|0,7)|0;O=b+11|0;Ca=Hd(d[O>>0]|0|0,0,8)|0;D=C;N=b+12|0;G=Hd(d[N>>0]|0|0,0,16)|0;D=D|C;K=b+13|0;u=d[K>>0]|0;J=Hd(u|0,0,24)|0;D=Gd(Ca|Sa|G|J|0,D|C|0,4)|0;J=b+14|0;G=b+15|0;Sa=a[G>>0]|0;Ca=Hd(d[J>>0]|0|0,0,8)|0;Da=C;Sa=Sa&255;F=Hd(Sa|0,0,16)|0;Da=Gd(Ca|u|F|0,Da|C|0,1)|0;F=b+16|0;u=Hd(d[F>>0]|0|0,0,8)|0;Ca=C;E=b+17|0;w=Hd(d[E>>0]|0|0,0,16)|0;Ca=Ca|C;A=b+18|0;v=d[A>>0]|0;z=Hd(v|0,0,24)|0;Ca=Gd(u|Sa|w|z|0,Ca|C|0,6)|0;z=b+19|0;w=b+20|0;Sa=a[w>>0]|0;u=Hd(d[z>>0]|0|0,0,8)|0;Ta=C;Sa=Hd(Sa&255|0,0,16)|0;Ta=Gd(u|v|Sa|0,Ta|C|0,3)|0;Sa=C;v=b+21|0;u=b+22|0;r=b+23|0;na=a[r>>0]|0;ab=d[v>>0]|0;bb=Hd(d[u>>0]|0|0,0,8)|0;_a=C;na=na&255;$a=Hd(na|0,0,16)|0;q=b+24|0;Ka=Hd(d[q>>0]|0|0,0,8)|0;Pa=C;p=b+25|0;i=Hd(d[p>>0]|0|0,0,16)|0;Pa=Pa|C;m=b+26|0;xa=d[m>>0]|0;l=Hd(xa|0,0,24)|0;Pa=Gd(Ka|na|i|l|0,Pa|C|0,5)|0;l=b+27|0;i=b+28|0;na=a[i>>0]|0;Ka=Hd(d[l>>0]|0|0,0,8)|0;Za=C;na=na&255;h=Hd(na|0,0,16)|0;Za=Gd(Ka|xa|h|0,Za|C|0,2)|0;h=b+29|0;xa=Hd(d[h>>0]|0|0,0,8)|0;Ka=C;g=b+30|0;fb=Hd(d[g>>0]|0|0,0,16)|0;Ka=Ka|C;c=b+31|0;qa=d[c>>0]|0;oa=Hd(qa|0,0,24)|0;Ka=Gd(xa|na|fb|oa|0,Ka|C|0,7)|0;oa=Hd(d[b+32>>0]|0|0,0,8)|0;fb=C;na=Hd(d[b+33>>0]|0|0,0,16)|0;fb=fb|C;xa=d[b+34>>0]|0;la=Hd(xa|0,0,24)|0;fb=Gd(oa|qa|na|la|0,fb|C|0,4)|0;la=a[b+36>>0]|0;na=Hd(d[b+35>>0]|0|0,0,8)|0;qa=C;la=la&255;oa=Hd(la|0,0,16)|0;qa=Gd(na|xa|oa|0,qa|C|0,1)|0;oa=Hd(d[b+37>>0]|0|0,0,8)|0;xa=C;na=Hd(d[b+38>>0]|0|0,0,16)|0;xa=xa|C;Ma=d[b+39>>0]|0;fa=Hd(Ma|0,0,24)|0;xa=Gd(oa|la|na|fa|0,xa|C|0,6)|0;fa=a[b+41>>0]|0;na=Hd(d[b+40>>0]|0|0,0,8)|0;la=C;fa=Hd(fa&255|0,0,16)|0;la=Gd(na|Ma|fa|0,la|C|0,3)|0;fa=C;Ma=a[b+44>>0]|0;na=d[b+42>>0]|0;oa=Hd(d[b+43>>0]|0|0,0,8)|0;j=C;Ma=Ma&255;za=Hd(Ma|0,0,16)|0;ja=Hd(d[b+45>>0]|0|0,0,8)|0;L=C;W=Hd(d[b+46>>0]|0|0,0,16)|0;L=L|C;gb=d[b+47>>0]|0;o=Hd(gb|0,0,24)|0;L=Gd(ja|Ma|W|o|0,L|C|0,5)|0;o=a[b+49>>0]|0;W=Hd(d[b+48>>0]|0|0,0,8)|0;Ma=C;o=o&255;ja=Hd(o|0,0,16)|0;Ma=Gd(W|gb|ja|0,Ma|C|0,2)|0;Ma=Ma&2097151;ja=Hd(d[b+50>>0]|0|0,0,8)|0;gb=C;W=Hd(d[b+51>>0]|0|0,0,16)|0;gb=gb|C;Aa=d[b+52>>0]|0;M=Hd(Aa|0,0,24)|0;gb=Gd(ja|o|W|M|0,gb|C|0,7)|0;gb=gb&2097151;M=Hd(d[b+53>>0]|0|0,0,8)|0;W=C;o=Hd(d[b+54>>0]|0|0,0,16)|0;W=W|C;ja=d[b+55>>0]|0;R=Hd(ja|0,0,24)|0;W=Gd(M|Aa|o|R|0,W|C|0,4)|0;W=W&2097151;R=a[b+57>>0]|0;o=Hd(d[b+56>>0]|0|0,0,8)|0;Aa=C;R=R&255;M=Hd(R|0,0,16)|0;Aa=Gd(o|ja|M|0,Aa|C|0,1)|0;Aa=Aa&2097151;M=Hd(d[b+58>>0]|0|0,0,8)|0;ja=C;o=Hd(d[b+59>>0]|0|0,0,16)|0;ja=ja|C;ha=d[b+60>>0]|0;Q=Hd(ha|0,0,24)|0;ja=Gd(M|R|o|Q|0,ja|C|0,6)|0;ja=ja&2097151;Q=Hd(d[b+61>>0]|0|0,0,8)|0;o=C;R=Hd(d[b+62>>0]|0|0,0,16)|0;o=o|C;M=Hd(d[b+63>>0]|0|0,0,24)|0;o=Gd(Q|ha|R|M|0,o|C|0,3)|0;M=C;R=Od(o|0,M|0,666643,0)|0;ha=C;Q=Od(o|0,M|0,470296,0)|0;I=C;ca=Od(o|0,M|0,654183,0)|0;ta=C;Ea=Od(o|0,M|0,-997805,-1)|0;t=C;k=Od(o|0,M|0,136657,0)|0;B=C;M=Od(o|0,M|0,-683901,-1)|0;j=Dd(M|0,C|0,oa|na|za&2031616|0,j|0)|0;za=C;na=Od(ja|0,0,666643,0)|0;oa=C;M=Od(ja|0,0,470296,0)|0;o=C;Va=Od(ja|0,0,654183,0)|0;s=C;ma=Od(ja|0,0,-997805,-1)|0;_=C;ya=Od(ja|0,0,136657,0)|0;sa=C;ja=Od(ja|0,0,-683901,-1)|0;H=C;e=Od(Aa|0,0,666643,0)|0;ra=C;wa=Od(Aa|0,0,470296,0)|0;La=C;Fa=Od(Aa|0,0,654183,0)|0;da=C;cb=Od(Aa|0,0,-997805,-1)|0;Ua=C;ka=Od(Aa|0,0,136657,0)|0;x=C;Aa=Od(Aa|0,0,-683901,-1)|0;xa=Dd(Aa|0,C|0,xa&2097151|0,0)|0;sa=Dd(xa|0,C|0,ya|0,sa|0)|0;t=Dd(sa|0,C|0,Ea|0,t|0)|0;Ea=C;sa=Od(W|0,0,666643,0)|0;ya=C;xa=Od(W|0,0,470296,0)|0;Aa=C;Wa=Od(W|0,0,654183,0)|0;Z=C;Ha=Od(W|0,0,-997805,-1)|0;Ga=C;eb=Od(W|0,0,136657,0)|0;db=C;W=Od(W|0,0,-683901,-1)|0;pa=C;ia=Od(gb|0,0,666643,0)|0;ua=C;Qa=Od(gb|0,0,470296,0)|0;Ra=C;Oa=Od(gb|0,0,654183,0)|0;Na=C;Ya=Od(gb|0,0,-997805,-1)|0;Xa=C;Ja=Od(gb|0,0,136657,0)|0;Ia=C;gb=Od(gb|0,0,-683901,-1)|0;fb=Dd(gb|0,C|0,fb&2097151|0,0)|0;db=Dd(fb|0,C|0,eb|0,db|0)|0;Ua=Dd(db|0,C|0,cb|0,Ua|0)|0;s=Dd(Ua|0,C|0,Va|0,s|0)|0;I=Dd(s|0,C|0,Q|0,I|0)|0;Q=C;s=Od(Ma|0,0,666643,0)|0;Ca=Dd(s|0,C|0,Ca&2097151|0,0)|0;s=C;Va=Od(Ma|0,0,470296,0)|0;Ua=C;cb=Od(Ma|0,0,654183,0)|0;_a=Dd(cb|0,C|0,bb|ab|$a&2031616|0,_a|0)|0;Ra=Dd(_a|0,C|0,Qa|0,Ra|0)|0;ya=Dd(Ra|0,C|0,sa|0,ya|0)|0;sa=C;Ra=Od(Ma|0,0,-997805,-1)|0;Qa=C;_a=Od(Ma|0,0,136657,0)|0;Za=Dd(_a|0,C|0,Za&2097151|0,0)|0;Xa=Dd(Za|0,C|0,Ya|0,Xa|0)|0;Z=Dd(Xa|0,C|0,Wa|0,Z|0)|0;La=Dd(Z|0,C|0,wa|0,La|0)|0;oa=Dd(La|0,C|0,na|0,oa|0)|0;na=C;Ma=Od(Ma|0,0,-683901,-1)|0;La=C;wa=Dd(Ca|0,s|0,1048576,0)|0;wa=Gd(wa|0,C|0,21)|0;Z=C;Sa=Dd(Va|0,Ua|0,Ta|0,Sa|0)|0;Sa=Dd(Sa|0,C|0,wa|0,Z|0)|0;ua=Dd(Sa|0,C|0,ia|0,ua|0)|0;ia=C;Z=Hd(wa|0,Z|0,21)|0;Z=Cd(Ca|0,s|0,Z|0,C|0)|0;s=C;Ca=Dd(ya|0,sa|0,1048576,0)|0;Ca=Gd(Ca|0,C|0,21)|0;wa=C;Pa=Dd(Ra|0,Qa|0,Pa&2097151|0,0)|0;Na=Dd(Pa|0,C|0,Oa|0,Na|0)|0;Aa=Dd(Na|0,C|0,xa|0,Aa|0)|0;ra=Dd(Aa|0,C|0,e|0,ra|0)|0;ra=Dd(ra|0,C|0,Ca|0,wa|0)|0;e=C;wa=Hd(Ca|0,wa|0,21)|0;Ca=C;Aa=Dd(oa|0,na|0,1048576,0)|0;Aa=Ed(Aa|0,C|0,21)|0;xa=C;Ka=Dd(Ma|0,La|0,Ka&2097151|0,0)|0;Ia=Dd(Ka|0,C|0,Ja|0,Ia|0)|0;Ga=Dd(Ia|0,C|0,Ha|0,Ga|0)|0;da=Dd(Ga|0,C|0,Fa|0,da|0)|0;o=Dd(da|0,C|0,M|0,o|0)|0;ha=Dd(o|0,C|0,R|0,ha|0)|0;ha=Dd(ha|0,C|0,Aa|0,xa|0)|0;R=C;xa=Hd(Aa|0,xa|0,21)|0;Aa=C;o=Dd(I|0,Q|0,1048576,0)|0;o=Ed(o|0,C|0,21)|0;M=C;qa=Dd(W|0,pa|0,qa&2097151|0,0)|0;x=Dd(qa|0,C|0,ka|0,x|0)|0;_=Dd(x|0,C|0,ma|0,_|0)|0;ta=Dd(_|0,C|0,ca|0,ta|0)|0;ta=Dd(ta|0,C|0,o|0,M|0)|0;ca=C;M=Hd(o|0,M|0,21)|0;M=Cd(I|0,Q|0,M|0,C|0)|0;Q=C;I=Dd(t|0,Ea|0,1048576,0)|0;I=Ed(I|0,C|0,21)|0;o=C;fa=Dd(ja|0,H|0,la|0,fa|0)|0;B=Dd(fa|0,C|0,k|0,B|0)|0;B=Dd(B|0,C|0,I|0,o|0)|0;k=C;o=Hd(I|0,o|0,21)|0;o=Cd(t|0,Ea|0,o|0,C|0)|0;Ea=C;t=Dd(j|0,za|0,1048576,0)|0;t=Ed(t|0,C|0,21)|0;I=C;L=Dd(t|0,I|0,L&2097151|0,0)|0;fa=C;I=Hd(t|0,I|0,21)|0;I=Cd(j|0,za|0,I|0,C|0)|0;za=C;j=Dd(ua|0,ia|0,1048576,0)|0;j=Gd(j|0,C|0,21)|0;t=C;la=Hd(j|0,t|0,21)|0;la=Cd(ua|0,ia|0,la|0,C|0)|0;ia=C;ua=Dd(ra|0,e|0,1048576,0)|0;ua=Ed(ua|0,C|0,21)|0;H=C;ja=Hd(ua|0,H|0,21)|0;ja=Cd(ra|0,e|0,ja|0,C|0)|0;e=C;ra=Dd(ha|0,R|0,1048576,0)|0;ra=Ed(ra|0,C|0,21)|0;_=C;Q=Dd(M|0,Q|0,ra|0,_|0)|0;M=C;_=Hd(ra|0,_|0,21)|0;_=Cd(ha|0,R|0,_|0,C|0)|0;R=C;ha=Dd(ta|0,ca|0,1048576,0)|0;ha=Ed(ha|0,C|0,21)|0;ra=C;Ea=Dd(ha|0,ra|0,o|0,Ea|0)|0;o=C;ra=Hd(ha|0,ra|0,21)|0;ra=Cd(ta|0,ca|0,ra|0,C|0)|0;ca=C;ta=Dd(B|0,k|0,1048576,0)|0;ta=Ed(ta|0,C|0,21)|0;ha=C;za=Dd(ta|0,ha|0,I|0,za|0)|0;I=C;ha=Hd(ta|0,ha|0,21)|0;ha=Cd(B|0,k|0,ha|0,C|0)|0;k=C;B=Od(L|0,fa|0,666643,0)|0;Da=Dd(B|0,C|0,Da&2097151|0,0)|0;B=C;ta=Od(L|0,fa|0,470296,0)|0;ta=Dd(Z|0,s|0,ta|0,C|0)|0;s=C;Z=Od(L|0,fa|0,654183,0)|0;Z=Dd(la|0,ia|0,Z|0,C|0)|0;ia=C;la=Od(L|0,fa|0,-997805,-1)|0;ma=C;x=Od(L|0,fa|0,136657,0)|0;x=Dd(ja|0,e|0,x|0,C|0)|0;e=C;fa=Od(L|0,fa|0,-683901,-1)|0;L=C;H=Dd(oa|0,na|0,ua|0,H|0)|0;Aa=Cd(H|0,C|0,xa|0,Aa|0)|0;L=Dd(Aa|0,C|0,fa|0,L|0)|0;fa=C;Aa=Od(za|0,I|0,666643,0)|0;D=Dd(Aa|0,C|0,D&2097151|0,0)|0;Aa=C;xa=Od(za|0,I|0,470296,0)|0;xa=Dd(Da|0,B|0,xa|0,C|0)|0;B=C;Da=Od(za|0,I|0,654183,0)|0;Da=Dd(ta|0,s|0,Da|0,C|0)|0;s=C;ta=Od(za|0,I|0,-997805,-1)|0;ta=Dd(Z|0,ia|0,ta|0,C|0)|0;ia=C;Z=Od(za|0,I|0,136657,0)|0;H=C;I=Od(za|0,I|0,-683901,-1)|0;I=Dd(x|0,e|0,I|0,C|0)|0;e=C;x=Od(ha|0,k|0,666643,0)|0;y=Dd(x|0,C|0,y&2097151|0,0)|0;x=C;za=Od(ha|0,k|0,470296,0)|0;za=Dd(D|0,Aa|0,za|0,C|0)|0;Aa=C;D=Od(ha|0,k|0,654183,0)|0;D=Dd(xa|0,B|0,D|0,C|0)|0;B=C;xa=Od(ha|0,k|0,-997805,-1)|0;xa=Dd(Da|0,s|0,xa|0,C|0)|0;s=C;Da=Od(ha|0,k|0,136657,0)|0;Da=Dd(ta|0,ia|0,Da|0,C|0)|0;ia=C;k=Od(ha|0,k|0,-683901,-1)|0;ha=C;t=Dd(ya|0,sa|0,j|0,t|0)|0;Ca=Cd(t|0,C|0,wa|0,Ca|0)|0;ma=Dd(Ca|0,C|0,la|0,ma|0)|0;H=Dd(ma|0,C|0,Z|0,H|0)|0;ha=Dd(H|0,C|0,k|0,ha|0)|0;k=C;H=Od(Ea|0,o|0,666643,0)|0;Z=C;ma=Od(Ea|0,o|0,470296,0)|0;la=C;Ca=Od(Ea|0,o|0,654183,0)|0;wa=C;t=Od(Ea|0,o|0,-997805,-1)|0;j=C;sa=Od(Ea|0,o|0,136657,0)|0;sa=Dd(xa|0,s|0,sa|0,C|0)|0;s=C;o=Od(Ea|0,o|0,-683901,-1)|0;o=Dd(Da|0,ia|0,o|0,C|0)|0;ia=C;Da=Od(ra|0,ca|0,666643,0)|0;Ea=C;xa=Od(ra|0,ca|0,470296,0)|0;ya=C;ta=Od(ra|0,ca|0,654183,0)|0;ua=C;na=Od(ra|0,ca|0,-997805,-1)|0;oa=C;ja=Od(ra|0,ca|0,136657,0)|0;ka=C;ca=Od(ra|0,ca|0,-683901,-1)|0;ca=Dd(sa|0,s|0,ca|0,C|0)|0;s=C;sa=Od(Q|0,M|0,666643,0)|0;va=Dd(sa|0,C|0,n|f|V&2031616|0,va|0)|0;V=C;f=Od(Q|0,M|0,470296,0)|0;n=C;sa=Od(Q|0,M|0,654183,0)|0;Ba=Dd(sa|0,C|0,Ba&2097151|0,0)|0;Z=Dd(Ba|0,C|0,H|0,Z|0)|0;ya=Dd(Z|0,C|0,xa|0,ya|0)|0;xa=C;Z=Od(Q|0,M|0,-997805,-1)|0;H=C;Ba=Od(Q|0,M|0,136657,0)|0;Ba=Dd(za|0,Aa|0,Ba|0,C|0)|0;wa=Dd(Ba|0,C|0,Ca|0,wa|0)|0;oa=Dd(wa|0,C|0,na|0,oa|0)|0;na=C;M=Od(Q|0,M|0,-683901,-1)|0;Q=C;wa=Dd(va|0,V|0,1048576,0)|0;wa=Ed(wa|0,C|0,21)|0;Ca=C;ga=Dd(f|0,n|0,ga&2097151|0,0)|0;Ea=Dd(ga|0,C|0,Da|0,Ea|0)|0;Ea=Dd(Ea|0,C|0,wa|0,Ca|0)|0;Da=C;Ca=Hd(wa|0,Ca|0,21)|0;Ca=Cd(va|0,V|0,Ca|0,C|0)|0;V=C;va=Dd(ya|0,xa|0,1048576,0)|0;va=Ed(va|0,C|0,21)|0;wa=C;H=Dd(y|0,x|0,Z|0,H|0)|0;la=Dd(H|0,C|0,ma|0,la|0)|0;ua=Dd(la|0,C|0,ta|0,ua|0)|0;ua=Dd(ua|0,C|0,va|0,wa|0)|0;ta=C;wa=Hd(va|0,wa|0,21)|0;va=C;la=Dd(oa|0,na|0,1048576,0)|0;la=Ed(la|0,C|0,21)|0;ma=C;Q=Dd(D|0,B|0,M|0,Q|0)|0;j=Dd(Q|0,C|0,t|0,j|0)|0;ka=Dd(j|0,C|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,la|0,ma|0)|0;ja=C;ma=Hd(la|0,ma|0,21)|0;la=C;j=Dd(ca|0,s|0,1048576,0)|0;j=Ed(j|0,C|0,21)|0;t=C;ia=Dd(o|0,ia|0,j|0,t|0)|0;o=C;t=Hd(j|0,t|0,21)|0;t=Cd(ca|0,s|0,t|0,C|0)|0;s=C;ca=Dd(ha|0,k|0,1048576,0)|0;ca=Ed(ca|0,C|0,21)|0;j=C;e=Dd(I|0,e|0,ca|0,j|0)|0;I=C;j=Hd(ca|0,j|0,21)|0;j=Cd(ha|0,k|0,j|0,C|0)|0;k=C;ha=Dd(L|0,fa|0,1048576,0)|0;ha=Ed(ha|0,C|0,21)|0;ca=C;R=Dd(_|0,R|0,ha|0,ca|0)|0;_=C;ca=Hd(ha|0,ca|0,21)|0;ca=Cd(L|0,fa|0,ca|0,C|0)|0;fa=C;L=Dd(Ea|0,Da|0,1048576,0)|0;L=Ed(L|0,C|0,21)|0;ha=C;Q=Hd(L|0,ha|0,21)|0;M=C;B=Dd(ua|0,ta|0,1048576,0)|0;B=Ed(B|0,C|0,21)|0;D=C;H=Hd(B|0,D|0,21)|0;Z=C;x=Dd(ka|0,ja|0,1048576,0)|0;x=Ed(x|0,C|0,21)|0;y=C;s=Dd(t|0,s|0,x|0,y|0)|0;t=C;y=Hd(x|0,y|0,21)|0;x=C;ga=Dd(ia|0,o|0,1048576,0)|0;ga=Ed(ga|0,C|0,21)|0;n=C;k=Dd(j|0,k|0,ga|0,n|0)|0;j=C;n=Hd(ga|0,n|0,21)|0;n=Cd(ia|0,o|0,n|0,C|0)|0;o=C;ia=Dd(e|0,I|0,1048576,0)|0;ia=Ed(ia|0,C|0,21)|0;ga=C;fa=Dd(ca|0,fa|0,ia|0,ga|0)|0;ca=C;ga=Hd(ia|0,ga|0,21)|0;ga=Cd(e|0,I|0,ga|0,C|0)|0;I=C;e=Dd(R|0,_|0,1048576,0)|0;e=Ed(e|0,C|0,21)|0;ia=C;f=Hd(e|0,ia|0,21)|0;f=Cd(R|0,_|0,f|0,C|0)|0;_=C;R=Od(e|0,ia|0,666643,0)|0;R=Dd(Ca|0,V|0,R|0,C|0)|0;V=C;Ca=Od(e|0,ia|0,470296,0)|0;Ba=C;Aa=Od(e|0,ia|0,654183,0)|0;za=C;sa=Od(e|0,ia|0,-997805,-1)|0;ra=C;qa=Od(e|0,ia|0,136657,0)|0;pa=C;ia=Od(e|0,ia|0,-683901,-1)|0;e=C;W=Ed(R|0,V|0,21)|0;da=C;Ba=Dd(Ea|0,Da|0,Ca|0,Ba|0)|0;Ba=Dd(Ba|0,C|0,W|0,da|0)|0;M=Cd(Ba|0,C|0,Q|0,M|0)|0;Q=C;da=Hd(W|0,da|0,21)|0;da=Cd(R|0,V|0,da|0,C|0)|0;V=C;R=Ed(M|0,Q|0,21)|0;W=C;xa=Dd(Aa|0,za|0,ya|0,xa|0)|0;va=Cd(xa|0,C|0,wa|0,va|0)|0;ha=Dd(va|0,C|0,L|0,ha|0)|0;ha=Dd(ha|0,C|0,R|0,W|0)|0;L=C;W=Hd(R|0,W|0,21)|0;W=Cd(M|0,Q|0,W|0,C|0)|0;Q=C;M=Ed(ha|0,L|0,21)|0;R=C;ra=Dd(ua|0,ta|0,sa|0,ra|0)|0;Z=Cd(ra|0,C|0,H|0,Z|0)|0;Z=Dd(Z|0,C|0,M|0,R|0)|0;H=C;R=Hd(M|0,R|0,21)|0;R=Cd(ha|0,L|0,R|0,C|0)|0;L=C;ha=Ed(Z|0,H|0,21)|0;M=C;na=Dd(qa|0,pa|0,oa|0,na|0)|0;la=Cd(na|0,C|0,ma|0,la|0)|0;D=Dd(la|0,C|0,B|0,D|0)|0;D=Dd(D|0,C|0,ha|0,M|0)|0;B=C;M=Hd(ha|0,M|0,21)|0;M=Cd(Z|0,H|0,M|0,C|0)|0;H=C;Z=Ed(D|0,B|0,21)|0;ha=C;e=Dd(ka|0,ja|0,ia|0,e|0)|0;x=Cd(e|0,C|0,y|0,x|0)|0;x=Dd(x|0,C|0,Z|0,ha|0)|0;y=C;ha=Hd(Z|0,ha|0,21)|0;ha=Cd(D|0,B|0,ha|0,C|0)|0;B=C;D=Ed(x|0,y|0,21)|0;Z=C;t=Dd(s|0,t|0,D|0,Z|0)|0;s=C;Z=Hd(D|0,Z|0,21)|0;Z=Cd(x|0,y|0,Z|0,C|0)|0;y=C;x=Ed(t|0,s|0,21)|0;D=C;o=Dd(x|0,D|0,n|0,o|0)|0;n=C;D=Hd(x|0,D|0,21)|0;D=Cd(t|0,s|0,D|0,C|0)|0;s=C;t=Ed(o|0,n|0,21)|0;x=C;j=Dd(k|0,j|0,t|0,x|0)|0;k=C;x=Hd(t|0,x|0,21)|0;x=Cd(o|0,n|0,x|0,C|0)|0;n=C;o=Ed(j|0,k|0,21)|0;t=C;I=Dd(o|0,t|0,ga|0,I|0)|0;ga=C;t=Hd(o|0,t|0,21)|0;t=Cd(j|0,k|0,t|0,C|0)|0;k=C;j=Ed(I|0,ga|0,21)|0;o=C;ca=Dd(fa|0,ca|0,j|0,o|0)|0;fa=C;o=Hd(j|0,o|0,21)|0;o=Cd(I|0,ga|0,o|0,C|0)|0;ga=C;I=Ed(ca|0,fa|0,21)|0;j=C;_=Dd(I|0,j|0,f|0,_|0)|0;f=C;j=Hd(I|0,j|0,21)|0;j=Cd(ca|0,fa|0,j|0,C|0)|0;fa=C;ca=Ed(_|0,f|0,21)|0;I=C;e=Hd(ca|0,I|0,21)|0;e=Cd(_|0,f|0,e|0,C|0)|0;f=C;_=Od(ca|0,I|0,666643,0)|0;V=Dd(_|0,C|0,da|0,V|0)|0;da=C;_=Od(ca|0,I|0,470296,0)|0;_=Dd(W|0,Q|0,_|0,C|0)|0;Q=C;W=Od(ca|0,I|0,654183,0)|0;W=Dd(R|0,L|0,W|0,C|0)|0;L=C;R=Od(ca|0,I|0,-997805,-1)|0;R=Dd(M|0,H|0,R|0,C|0)|0;H=C;M=Od(ca|0,I|0,136657,0)|0;M=Dd(ha|0,B|0,M|0,C|0)|0;B=C;I=Od(ca|0,I|0,-683901,-1)|0;I=Dd(Z|0,y|0,I|0,C|0)|0;y=C;Z=Ed(V|0,da|0,21)|0;ca=C;Q=Dd(_|0,Q|0,Z|0,ca|0)|0;_=C;ca=Hd(Z|0,ca|0,21)|0;ca=Cd(V|0,da|0,ca|0,C|0)|0;da=C;V=Ed(Q|0,_|0,21)|0;Z=C;L=Dd(W|0,L|0,V|0,Z|0)|0;W=C;Z=Hd(V|0,Z|0,21)|0;Z=Cd(Q|0,_|0,Z|0,C|0)|0;_=C;Q=Ed(L|0,W|0,21)|0;V=C;H=Dd(R|0,H|0,Q|0,V|0)|0;R=C;V=Hd(Q|0,V|0,21)|0;V=Cd(L|0,W|0,V|0,C|0)|0;W=C;L=Ed(H|0,R|0,21)|0;Q=C;B=Dd(M|0,B|0,L|0,Q|0)|0;M=C;Q=Hd(L|0,Q|0,21)|0;Q=Cd(H|0,R|0,Q|0,C|0)|0;R=C;H=Ed(B|0,M|0,21)|0;L=C;y=Dd(I|0,y|0,H|0,L|0)|0;I=C;L=Hd(H|0,L|0,21)|0;L=Cd(B|0,M|0,L|0,C|0)|0;M=C;B=Ed(y|0,I|0,21)|0;H=C;s=Dd(B|0,H|0,D|0,s|0)|0;D=C;H=Hd(B|0,H|0,21)|0;H=Cd(y|0,I|0,H|0,C|0)|0;I=C;y=Ed(s|0,D|0,21)|0;B=C;n=Dd(y|0,B|0,x|0,n|0)|0;x=C;B=Hd(y|0,B|0,21)|0;B=Cd(s|0,D|0,B|0,C|0)|0;D=C;s=Ed(n|0,x|0,21)|0;y=C;k=Dd(s|0,y|0,t|0,k|0)|0;t=C;y=Hd(s|0,y|0,21)|0;y=Cd(n|0,x|0,y|0,C|0)|0;x=C;n=Ed(k|0,t|0,21)|0;s=C;ga=Dd(n|0,s|0,o|0,ga|0)|0;o=C;s=Hd(n|0,s|0,21)|0;s=Cd(k|0,t|0,s|0,C|0)|0;t=C;k=Ed(ga|0,o|0,21)|0;n=C;fa=Dd(k|0,n|0,j|0,fa|0)|0;j=C;n=Hd(k|0,n|0,21)|0;n=Cd(ga|0,o|0,n|0,C|0)|0;o=C;ga=Ed(fa|0,j|0,21)|0;k=C;f=Dd(ga|0,k|0,e|0,f|0)|0;e=C;k=Hd(ga|0,k|0,21)|0;k=Cd(fa|0,j|0,k|0,C|0)|0;j=C;a[b>>0]=ca;b=Gd(ca|0,da|0,8)|0;a[ea>>0]=b;b=Gd(ca|0,da|0,16)|0;da=C;ca=Hd(Z|0,_|0,5)|0;a[ba>>0]=ca|b;b=Gd(Z|0,_|0,3)|0;a[aa>>0]=b;b=Gd(Z|0,_|0,11)|0;a[$>>0]=b;b=Gd(Z|0,_|0,19)|0;_=C;Z=Hd(V|0,W|0,2)|0;a[Y>>0]=Z|b;b=Gd(V|0,W|0,6)|0;a[X>>0]=b;b=Gd(V|0,W|0,14)|0;W=C;V=Hd(Q|0,R|0,7)|0;a[U>>0]=V|b;b=Gd(Q|0,R|0,1)|0;a[T>>0]=b;b=Gd(Q|0,R|0,9)|0;a[S>>0]=b;b=Gd(Q|0,R|0,17)|0;R=C;Q=Hd(L|0,M|0,4)|0;a[P>>0]=Q|b;b=Gd(L|0,M|0,4)|0;a[O>>0]=b;b=Gd(L|0,M|0,12)|0;a[N>>0]=b;b=Gd(L|0,M|0,20)|0;M=C;L=Hd(H|0,I|0,1)|0;a[K>>0]=L|b;b=Gd(H|0,I|0,7)|0;a[J>>0]=b;b=Gd(H|0,I|0,15)|0;I=C;H=Hd(B|0,D|0,6)|0;a[G>>0]=H|b;b=Gd(B|0,D|0,2)|0;a[F>>0]=b;b=Gd(B|0,D|0,10)|0;a[E>>0]=b;b=Gd(B|0,D|0,18)|0;D=C;B=Hd(y|0,x|0,3)|0;a[A>>0]=B|b;b=Gd(y|0,x|0,5)|0;a[z>>0]=b;b=Gd(y|0,x|0,13)|0;a[w>>0]=b;a[v>>0]=s;b=Gd(s|0,t|0,8)|0;a[u>>0]=b;b=Gd(s|0,t|0,16)|0;t=C;s=Hd(n|0,o|0,5)|0;a[r>>0]=s|b;b=Gd(n|0,o|0,3)|0;a[q>>0]=b;b=Gd(n|0,o|0,11)|0;a[p>>0]=b;b=Gd(n|0,o|0,19)|0;o=C;n=Hd(k|0,j|0,2)|0;a[m>>0]=n|b;b=Gd(k|0,j|0,6)|0;a[l>>0]=b;j=Gd(k|0,j|0,14)|0;k=C;b=Hd(f|0,e|0,7)|0;a[i>>0]=j|b;b=Gd(f|0,e|0,1)|0;a[h>>0]=b;b=Gd(f|0,e|0,9)|0;a[g>>0]=b;b=Gd(f|0,e|0,17)|0;a[c>>0]=b;return}function Xc(b,e,f,g,h,j){b=b|0;e=e|0;f=f|0;g=g|0;h=h|0;j=j|0;var k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0,xa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha=0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa=0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0,db=0,eb=0,fb=0,gb=0,hb=0,ib=0,jb=0,kb=0,lb=0,mb=0,nb=0,ob=0,pb=0,qb=0,rb=0,sb=0,tb=0,ub=0,vb=0,wb=0,xb=0,yb=0,zb=0,Ab=0,Bb=0,Cb=0,Db=0,Eb=0,Hb=0,Ib=0,Jb=0,Kb=0,Lb=0,Mb=0,Nb=0,Ob=0,Pb=0,Qb=0,Rb=0,Sb=0,Tb=0,Ub=0,Vb=0,Wb=0,Xb=0,Yb=0,Zb=0,_b=0,$b=0,ac=0,bc=0,cc=0,dc=0,ec=0,fc=0,gc=0,hc=0,ic=0,jc=0,kc=0,lc=0,mc=0,nc=0,oc=0,pc=0,qc=0,rc=0,sc=0,tc=0,uc=0,vc=0,wc=0,xc=0,yc=0,zc=0,Ac=0,Bc=0,Cc=0,Dc=0,Ec=0;z=i;p=i=i+63&-64;i=i+896|0;v=p+208|0;u=p+656|0;w=p+616|0;x=p+576|0;s=p;q=p+824|0;t=p+760|0;r=p+696|0;p=p+416|0;k=v+64|0;y=v;A=8;B=y+64|0;do{c[y>>2]=c[A>>2];y=y+4|0;A=A+4|0}while((y|0)<(B|0));y=v+72|0;c[y>>2]=256;c[y+4>>2]=0;y=k;c[y>>2]=0;c[y+4>>2]=0;y=v+80|0;A=j;B=y+32|0;do{a[y>>0]=a[A>>0]|0;y=y+1|0;A=A+1|0}while((y|0)<(B|0));Gb(v,q);a[q>>0]=(d[q>>0]|0)&248;k=q+31|0;a[k>>0]=(d[k>>0]|0)&63|64;l=s+64|0;y=l;c[y>>2]=0;c[y+4>>2]=0;y=s;A=8;B=y+64|0;do{c[y>>2]=c[A>>2];y=y+4|0;A=A+4|0}while((y|0)<(B|0));m=s+72|0;n=m;c[n>>2]=256;c[n+4>>2]=0;n=l;c[n>>2]=0;c[n+4>>2]=0;n=s+80|0;y=n;A=q+32|0;B=y+32|0;do{a[y>>0]=a[A>>0]|0;y=y+1|0;A=A+1|0}while((y|0)<(B|0));Fb(s,f,g,h);Gb(s,t);o=b+32|0;Jd(o|0,j+32|0,32)|0;Wc(t);Rc(p,t);Ic(u,p+80|0);Jc(w,p,u);Jc(x,p+40|0,u);Lc(b,x);Lc(v,w);y=b+31|0;a[y>>0]=(d[y>>0]|0)^(d[v>>0]|0)<<7;y=l;c[y>>2]=0;c[y+4>>2]=0;y=s;A=8;B=y+64|0;do{c[y>>2]=c[A>>2];y=y+4|0;A=A+4|0}while((y|0)<(B|0));y=m;c[y>>2]=512;c[y+4>>2]=0;y=l;c[y>>2]=0;c[y+4>>2]=0;y=n;A=b;B=y+64|0;do{a[y>>0]=a[A>>0]|0;y=y+1|0;A=A+1|0}while((y|0)<(B|0));Fb(s,f,g,h);Gb(s,r);Wc(r);J=a[r+2>>0]|0;Ta=d[r>>0]|0;xb=Hd(d[r+1>>0]|0|0,0,8)|0;qb=C;J=J&255;kb=Hd(J|0,0,16)|0;kb=xb|Ta|kb&2031616;Ta=Hd(d[r+3>>0]|0|0,0,8)|0;xb=C;F=Hd(d[r+4>>0]|0|0,0,16)|0;xb=xb|C;ub=d[r+5>>0]|0;db=Hd(ub|0,0,24)|0;xb=Gd(Ta|J|F|db|0,xb|C|0,5)|0;xb=xb&2097151;db=a[r+7>>0]|0;F=Hd(d[r+6>>0]|0|0,0,8)|0;J=C;db=db&255;Ta=Hd(db|0,0,16)|0;J=Gd(F|ub|Ta|0,J|C|0,2)|0;J=J&2097151;Ta=Hd(d[r+8>>0]|0|0,0,8)|0;ub=C;F=Hd(d[r+9>>0]|0|0,0,16)|0;ub=ub|C;v=d[r+10>>0]|0;Sa=Hd(v|0,0,24)|0;ub=Gd(Ta|db|F|Sa|0,ub|C|0,7)|0;ub=ub&2097151;Sa=Hd(d[r+11>>0]|0|0,0,8)|0;F=C;db=Hd(d[r+12>>0]|0|0,0,16)|0;F=F|C;Ta=d[r+13>>0]|0;y=Hd(Ta|0,0,24)|0;F=Gd(Sa|v|db|y|0,F|C|0,4)|0;F=F&2097151;y=a[r+15>>0]|0;db=Hd(d[r+14>>0]|0|0,0,8)|0;v=C;y=y&255;Sa=Hd(y|0,0,16)|0;v=Gd(db|Ta|Sa|0,v|C|0,1)|0;v=v&2097151;Sa=Hd(d[r+16>>0]|0|0,0,8)|0;Ta=C;db=Hd(d[r+17>>0]|0|0,0,16)|0;Ta=Ta|C;Bc=d[r+18>>0]|0;ja=Hd(Bc|0,0,24)|0;Ta=Gd(Sa|y|db|ja|0,Ta|C|0,6)|0;Ta=Ta&2097151;ja=a[r+20>>0]|0;db=Hd(d[r+19>>0]|0|0,0,8)|0;y=C;ja=Hd(ja&255|0,0,16)|0;y=Gd(db|Bc|ja|0,y|C|0,3)|0;ja=C;Bc=a[r+23>>0]|0;db=d[r+21>>0]|0;Sa=Hd(d[r+22>>0]|0|0,0,8)|0;sb=C;Bc=Bc&255;Qa=Hd(Bc|0,0,16)|0;Qa=Sa|db|Qa&2031616;db=Hd(d[r+24>>0]|0|0,0,8)|0;Sa=C;m=Hd(d[r+25>>0]|0|0,0,16)|0;Sa=Sa|C;p=d[r+26>>0]|0;s=Hd(p|0,0,24)|0;Sa=Gd(db|Bc|m|s|0,Sa|C|0,5)|0;Sa=Sa&2097151;s=a[r+28>>0]|0;m=Hd(d[r+27>>0]|0|0,0,8)|0;Bc=C;s=s&255;db=Hd(s|0,0,16)|0;Bc=Gd(m|p|db|0,Bc|C|0,2)|0;Bc=Bc&2097151;db=Hd(d[r+29>>0]|0|0,0,8)|0;p=C;m=Hd(d[r+30>>0]|0|0,0,16)|0;p=p|C;Ka=Hd(d[r+31>>0]|0|0,0,24)|0;p=Gd(db|s|m|Ka|0,p|C|0,7)|0;Ka=C;m=a[q+2>>0]|0;s=d[q>>0]|0;db=Hd(d[q+1>>0]|0|0,0,8)|0;ia=C;m=m&255;ha=Hd(m|0,0,16)|0;ha=db|s|ha&2031616;s=Hd(d[q+3>>0]|0|0,0,8)|0;db=C;la=Hd(d[q+4>>0]|0|0,0,16)|0;db=db|C;h=d[q+5>>0]|0;yc=Hd(h|0,0,24)|0;db=Gd(s|m|la|yc|0,db|C|0,5)|0;db=db&2097151;yc=a[q+7>>0]|0;la=Hd(d[q+6>>0]|0|0,0,8)|0;m=C;yc=yc&255;s=Hd(yc|0,0,16)|0;m=Gd(la|h|s|0,m|C|0,2)|0;m=m&2097151;s=Hd(d[q+8>>0]|0|0,0,8)|0;h=C;la=Hd(d[q+9>>0]|0|0,0,16)|0;h=h|C;_a=d[q+10>>0]|0;Pa=Hd(_a|0,0,24)|0;h=Gd(s|yc|la|Pa|0,h|C|0,7)|0;h=h&2097151;Pa=Hd(d[q+11>>0]|0|0,0,8)|0;la=C;yc=Hd(d[q+12>>0]|0|0,0,16)|0;la=la|C;s=d[q+13>>0]|0;Ec=Hd(s|0,0,24)|0;la=Gd(Pa|_a|yc|Ec|0,la|C|0,4)|0;la=la&2097151;Ec=a[q+15>>0]|0;yc=Hd(d[q+14>>0]|0|0,0,8)|0;_a=C;Ec=Ec&255;Pa=Hd(Ec|0,0,16)|0;_a=Gd(yc|s|Pa|0,_a|C|0,1)|0;_a=_a&2097151;Pa=Hd(d[q+16>>0]|0|0,0,8)|0;s=C;yc=Hd(d[q+17>>0]|0|0,0,16)|0;s=s|C;R=d[q+18>>0]|0;Bb=Hd(R|0,0,24)|0;s=Gd(Pa|Ec|yc|Bb|0,s|C|0,6)|0;s=s&2097151;Bb=a[q+20>>0]|0;yc=Hd(d[q+19>>0]|0|0,0,8)|0;Ec=C;Bb=Hd(Bb&255|0,0,16)|0;Ec=Gd(yc|R|Bb|0,Ec|C|0,3)|0;Bb=C;R=a[q+23>>0]|0;yc=d[q+21>>0]|0;Pa=Hd(d[q+22>>0]|0|0,0,8)|0;Da=C;R=R&255;ua=Hd(R|0,0,16)|0;ua=Pa|yc|ua&2031616;yc=Hd(d[q+24>>0]|0|0,0,8)|0;Pa=C;Ma=Hd(d[q+25>>0]|0|0,0,16)|0;Pa=Pa|C;D=d[q+26>>0]|0;zc=Hd(D|0,0,24)|0;Pa=Gd(yc|R|Ma|zc|0,Pa|C|0,5)|0;Pa=Pa&2097151;zc=a[q+28>>0]|0;Ma=Hd(d[q+27>>0]|0|0,0,8)|0;R=C;zc=zc&255;yc=Hd(zc|0,0,16)|0;R=Gd(Ma|D|yc|0,R|C|0,2)|0;R=R&2097151;yc=Hd(d[q+29>>0]|0|0,0,8)|0;D=C;Ma=Hd(d[q+30>>0]|0|0,0,16)|0;D=D|C;Ia=Hd(d[k>>0]|0|0,0,24)|0;D=Gd(yc|zc|Ma|Ia|0,D|C|0,7)|0;Ia=C;Ma=a[t+2>>0]|0;zc=d[t>>0]|0;yc=Hd(d[t+1>>0]|0|0,0,8)|0;ba=C;Ma=Ma&255;Ac=Hd(Ma|0,0,16)|0;Xa=Hd(d[t+3>>0]|0|0,0,8)|0;Ea=C;Ga=Hd(d[t+4>>0]|0|0,0,16)|0;Ea=Ea|C;pb=d[t+5>>0]|0;za=Hd(pb|0,0,24)|0;Ea=Gd(Xa|Ma|Ga|za|0,Ea|C|0,5)|0;za=a[t+7>>0]|0;Ga=Hd(d[t+6>>0]|0|0,0,8)|0;Ma=C;za=za&255;Xa=Hd(za|0,0,16)|0;Ma=Gd(Ga|pb|Xa|0,Ma|C|0,2)|0;Xa=Hd(d[t+8>>0]|0|0,0,8)|0;pb=C;Ga=Hd(d[t+9>>0]|0|0,0,16)|0;pb=pb|C;X=d[t+10>>0]|0;O=Hd(X|0,0,24)|0;pb=Gd(Xa|za|Ga|O|0,pb|C|0,7)|0;O=Hd(d[t+11>>0]|0|0,0,8)|0;Ga=C;za=Hd(d[t+12>>0]|0|0,0,16)|0;Ga=Ga|C;Xa=d[t+13>>0]|0;H=Hd(Xa|0,0,24)|0;Ga=Gd(O|X|za|H|0,Ga|C|0,4)|0;H=a[t+15>>0]|0;za=Hd(d[t+14>>0]|0|0,0,8)|0;X=C;H=H&255;O=Hd(H|0,0,16)|0;X=Gd(za|Xa|O|0,X|C|0,1)|0;O=Hd(d[t+16>>0]|0|0,0,8)|0;Xa=C;za=Hd(d[t+17>>0]|0|0,0,16)|0;Xa=Xa|C;U=d[t+18>>0]|0;w=Hd(U|0,0,24)|0;Xa=Gd(O|H|za|w|0,Xa|C|0,6)|0;w=a[t+20>>0]|0;za=Hd(d[t+19>>0]|0|0,0,8)|0;H=C;w=Hd(w&255|0,0,16)|0;H=Gd(za|U|w|0,H|C|0,3)|0;w=C;U=a[t+23>>0]|0;za=d[t+21>>0]|0;O=Hd(d[t+22>>0]|0|0,0,8)|0;da=C;U=U&255;ea=Hd(U|0,0,16)|0;Ba=Hd(d[t+24>>0]|0|0,0,8)|0;N=C;Ha=Hd(d[t+25>>0]|0|0,0,16)|0;N=N|C;A=d[t+26>>0]|0;ta=Hd(A|0,0,24)|0;N=Gd(Ba|U|Ha|ta|0,N|C|0,5)|0;ta=a[t+28>>0]|0;Ha=Hd(d[t+27>>0]|0|0,0,8)|0;U=C;ta=ta&255;Ba=Hd(ta|0,0,16)|0;U=Gd(Ha|A|Ba|0,U|C|0,2)|0;Ba=Hd(d[t+29>>0]|0|0,0,8)|0;A=C;Ha=Hd(d[t+30>>0]|0|0,0,16)|0;A=A|C;j=Hd(d[t+31>>0]|0|0,0,24)|0;A=Gd(Ba|ta|Ha|j|0,A|C|0,7)|0;j=C;Ha=Od(ha|0,ia|0,kb|0,qb|0)|0;Ha=Dd(yc|zc|Ac&2031616|0,ba|0,Ha|0,C|0)|0;ba=C;Ac=Od(db|0,0,kb|0,qb|0)|0;zc=C;yc=Od(ha|0,ia|0,xb|0,0)|0;ta=C;Ba=Od(m|0,0,kb|0,qb|0)|0;La=C;Ca=Od(db|0,0,xb|0,0)|0;tc=C;pa=Od(ha|0,ia|0,J|0,0)|0;pa=Dd(Ca|0,tc|0,pa|0,C|0)|0;La=Dd(pa|0,C|0,Ba|0,La|0)|0;Ma=Dd(La|0,C|0,Ma&2097151|0,0)|0;La=C;Ba=Od(h|0,0,kb|0,qb|0)|0;pa=C;tc=Od(m|0,0,xb|0,0)|0;Ca=C;xc=Od(db|0,0,J|0,0)|0;wc=C;vc=Od(ha|0,ia|0,ub|0,0)|0;uc=C;Oa=Od(la|0,0,kb|0,qb|0)|0;Fa=C;kc=Od(h|0,0,xb|0,0)|0;Y=C;mc=Od(m|0,0,J|0,0)|0;Na=C;nc=Od(db|0,0,ub|0,0)|0;oc=C;lc=Od(ha|0,ia|0,F|0,0)|0;lc=Dd(nc|0,oc|0,lc|0,C|0)|0;Na=Dd(lc|0,C|0,mc|0,Na|0)|0;Y=Dd(Na|0,C|0,kc|0,Y|0)|0;Fa=Dd(Y|0,C|0,Oa|0,Fa|0)|0;Ga=Dd(Fa|0,C|0,Ga&2097151|0,0)|0;Fa=C;Oa=Od(_a|0,0,kb|0,qb|0)|0;Y=C;kc=Od(la|0,0,xb|0,0)|0;Na=C;mc=Od(h|0,0,J|0,0)|0;lc=C;oc=Od(m|0,0,ub|0,0)|0;nc=C;sc=Od(db|0,0,F|0,0)|0;rc=C;qc=Od(ha|0,ia|0,v|0,0)|0;pc=C;ca=Od(s|0,0,kb|0,qb|0)|0;Ya=C;Zb=Od(_a|0,0,xb|0,0)|0;ka=C;$b=Od(la|0,0,J|0,0)|0;Yb=C;bc=Od(h|0,0,ub|0,0)|0;_b=C;dc=Od(m|0,0,F|0,0)|0;ac=C;ec=Od(db|0,0,v|0,0)|0;fc=C;cc=Od(ha|0,ia|0,Ta|0,0)|0;cc=Dd(ec|0,fc|0,cc|0,C|0)|0;ac=Dd(cc|0,C|0,dc|0,ac|0)|0;_b=Dd(ac|0,C|0,bc|0,_b|0)|0;Yb=Dd(_b|0,C|0,$b|0,Yb|0)|0;ka=Dd(Yb|0,C|0,Zb|0,ka|0)|0;Ya=Dd(ka|0,C|0,ca|0,Ya|0)|0;Xa=Dd(Ya|0,C|0,Xa&2097151|0,0)|0;Ya=C;ca=Od(Ec|0,Bb|0,kb|0,qb|0)|0;ka=C;Zb=Od(s|0,0,xb|0,0)|0;Yb=C;$b=Od(_a|0,0,J|0,0)|0;_b=C;bc=Od(la|0,0,ub|0,0)|0;ac=C;dc=Od(h|0,0,F|0,0)|0;cc=C;fc=Od(m|0,0,v|0,0)|0;ec=C;jc=Od(db|0,0,Ta|0,0)|0;ic=C;hc=Od(ha|0,ia|0,y|0,ja|0)|0;gc=C;Aa=Od(ua|0,Da|0,kb|0,qb|0)|0;Hb=C;Ib=Od(Ec|0,Bb|0,xb|0,0)|0;Jb=C;Kb=Od(s|0,0,J|0,0)|0;Lb=C;Mb=Od(_a|0,0,ub|0,0)|0;Nb=C;Ob=Od(la|0,0,F|0,0)|0;Pb=C;Qb=Od(h|0,0,v|0,0)|0;Rb=C;Sb=Od(m|0,0,Ta|0,0)|0;Tb=C;Vb=Od(db|0,0,y|0,ja|0)|0;Wb=C;Xb=Od(ha|0,ia|0,Qa|0,sb|0)|0;Xb=Dd(Vb|0,Wb|0,Xb|0,C|0)|0;Tb=Dd(Xb|0,C|0,Sb|0,Tb|0)|0;Rb=Dd(Tb|0,C|0,Qb|0,Rb|0)|0;Pb=Dd(Rb|0,C|0,Ob|0,Pb|0)|0;Nb=Dd(Pb|0,C|0,Mb|0,Nb|0)|0;Lb=Dd(Nb|0,C|0,Kb|0,Lb|0)|0;Jb=Dd(Lb|0,C|0,Ib|0,Jb|0)|0;Hb=Dd(Jb|0,C|0,Aa|0,Hb|0)|0;da=Dd(Hb|0,C|0,O|za|ea&2031616|0,da|0)|0;ea=C;za=Od(Pa|0,0,kb|0,qb|0)|0;O=C;Hb=Od(ua|0,Da|0,xb|0,0)|0;Aa=C;Jb=Od(Ec|0,Bb|0,J|0,0)|0;Ib=C;Lb=Od(s|0,0,ub|0,0)|0;Kb=C;Nb=Od(_a|0,0,F|0,0)|0;Mb=C;Pb=Od(la|0,0,v|0,0)|0;Ob=C;Rb=Od(h|0,0,Ta|0,0)|0;Qb=C;Tb=Od(m|0,0,y|0,ja|0)|0;Sb=C;Xb=Od(db|0,0,Qa|0,sb|0)|0;Wb=C;Vb=Od(ha|0,ia|0,Sa|0,0)|0;Ub=C;V=Od(R|0,0,kb|0,qb|0)|0;T=C;hb=Od(Pa|0,0,xb|0,0)|0;W=C;I=Od(ua|0,Da|0,J|0,0)|0;ib=C;vb=Od(Ec|0,Bb|0,ub|0,0)|0;E=C;Q=Od(s|0,0,F|0,0)|0;wb=C;Va=Od(_a|0,0,v|0,0)|0;K=C;nb=Od(la|0,0,Ta|0,0)|0;Wa=C;$=Od(h|0,0,y|0,ja|0)|0;ob=C;bb=Od(m|0,0,Qa|0,sb|0)|0;aa=C;Db=Od(db|0,0,Sa|0,0)|0;Eb=C;cb=Od(ha|0,ia|0,Bc|0,0)|0;cb=Dd(Db|0,Eb|0,cb|0,C|0)|0;aa=Dd(cb|0,C|0,bb|0,aa|0)|0;ob=Dd(aa|0,C|0,$|0,ob|0)|0;Wa=Dd(ob|0,C|0,nb|0,Wa|0)|0;K=Dd(Wa|0,C|0,Va|0,K|0)|0;wb=Dd(K|0,C|0,Q|0,wb|0)|0;E=Dd(wb|0,C|0,vb|0,E|0)|0;ib=Dd(E|0,C|0,I|0,ib|0)|0;W=Dd(ib|0,C|0,hb|0,W|0)|0;T=Dd(W|0,C|0,V|0,T|0)|0;U=Dd(T|0,C|0,U&2097151|0,0)|0;T=C;qb=Od(D|0,Ia|0,kb|0,qb|0)|0;kb=C;V=Od(R|0,0,xb|0,0)|0;W=C;hb=Od(Pa|0,0,J|0,0)|0;ib=C;I=Od(ua|0,Da|0,ub|0,0)|0;E=C;vb=Od(Ec|0,Bb|0,F|0,0)|0;wb=C;Q=Od(s|0,0,v|0,0)|0;K=C;Va=Od(_a|0,0,Ta|0,0)|0;Wa=C;nb=Od(la|0,0,y|0,ja|0)|0;ob=C;$=Od(h|0,0,Qa|0,sb|0)|0;aa=C;bb=Od(m|0,0,Sa|0,0)|0;cb=C;Eb=Od(db|0,0,Bc|0,0)|0;Db=C;ia=Od(ha|0,ia|0,p|0,Ka|0)|0;ha=C;xb=Od(D|0,Ia|0,xb|0,0)|0;yb=C;lb=Od(R|0,0,J|0,0)|0;G=C;ma=Od(Pa|0,0,ub|0,0)|0;mb=C;oa=Od(ua|0,Da|0,F|0,0)|0;ga=C;zb=Od(Ec|0,Bb|0,v|0,0)|0;rb=C;sa=Od(s|0,0,Ta|0,0)|0;Ab=C;xa=Od(_a|0,0,y|0,ja|0)|0;ra=C;Ua=Od(la|0,0,Qa|0,sb|0)|0;wa=C;eb=Od(h|0,0,Sa|0,0)|0;na=C;tb=Od(m|0,0,Bc|0,0)|0;l=C;db=Od(db|0,0,p|0,Ka|0)|0;db=Dd(tb|0,l|0,db|0,C|0)|0;na=Dd(db|0,C|0,eb|0,na|0)|0;wa=Dd(na|0,C|0,Ua|0,wa|0)|0;ra=Dd(wa|0,C|0,xa|0,ra|0)|0;Ab=Dd(ra|0,C|0,sa|0,Ab|0)|0;rb=Dd(Ab|0,C|0,zb|0,rb|0)|0;ga=Dd(rb|0,C|0,oa|0,ga|0)|0;mb=Dd(ga|0,C|0,ma|0,mb|0)|0;G=Dd(mb|0,C|0,lb|0,G|0)|0;yb=Dd(G|0,C|0,xb|0,yb|0)|0;xb=C;J=Od(D|0,Ia|0,J|0,0)|0;G=C;lb=Od(R|0,0,ub|0,0)|0;mb=C;ma=Od(Pa|0,0,F|0,0)|0;ga=C;oa=Od(ua|0,Da|0,v|0,0)|0;rb=C;zb=Od(Ec|0,Bb|0,Ta|0,0)|0;Ab=C;sa=Od(s|0,0,y|0,ja|0)|0;ra=C;xa=Od(_a|0,0,Qa|0,sb|0)|0;wa=C;Ua=Od(la|0,0,Sa|0,0)|0;na=C;eb=Od(h|0,0,Bc|0,0)|0;db=C;m=Od(m|0,0,p|0,Ka|0)|0;l=C;ub=Od(D|0,Ia|0,ub|0,0)|0;tb=C;fb=Od(R|0,0,F|0,0)|0;g=C;L=Od(Pa|0,0,v|0,0)|0;gb=C;r=Od(ua|0,Da|0,Ta|0,0)|0;n=C;fa=Od(Ec|0,Bb|0,y|0,ja|0)|0;x=C;qa=Od(s|0,0,Qa|0,sb|0)|0;k=C;va=Od(_a|0,0,Sa|0,0)|0;M=C;Cb=Od(la|0,0,Bc|0,0)|0;f=C;h=Od(h|0,0,p|0,Ka|0)|0;h=Dd(Cb|0,f|0,h|0,C|0)|0;M=Dd(h|0,C|0,va|0,M|0)|0;k=Dd(M|0,C|0,qa|0,k|0)|0;x=Dd(k|0,C|0,fa|0,x|0)|0;n=Dd(x|0,C|0,r|0,n|0)|0;gb=Dd(n|0,C|0,L|0,gb|0)|0;g=Dd(gb|0,C|0,fb|0,g|0)|0;tb=Dd(g|0,C|0,ub|0,tb|0)|0;ub=C;F=Od(D|0,Ia|0,F|0,0)|0;g=C;fb=Od(R|0,0,v|0,0)|0;gb=C;L=Od(Pa|0,0,Ta|0,0)|0;n=C;r=Od(ua|0,Da|0,y|0,ja|0)|0;x=C;fa=Od(Ec|0,Bb|0,Qa|0,sb|0)|0;k=C;qa=Od(s|0,0,Sa|0,0)|0;M=C;va=Od(_a|0,0,Bc|0,0)|0;h=C;la=Od(la|0,0,p|0,Ka|0)|0;f=C;v=Od(D|0,Ia|0,v|0,0)|0;Cb=C;B=Od(R|0,0,Ta|0,0)|0;S=C;_=Od(Pa|0,0,y|0,ja|0)|0;Ra=C;ab=Od(ua|0,Da|0,Qa|0,sb|0)|0;Z=C;Za=Od(Ec|0,Bb|0,Sa|0,0)|0;$a=C;P=Od(s|0,0,Bc|0,0)|0;u=C;_a=Od(_a|0,0,p|0,Ka|0)|0;_a=Dd(P|0,u|0,_a|0,C|0)|0;$a=Dd(_a|0,C|0,Za|0,$a|0)|0;Z=Dd($a|0,C|0,ab|0,Z|0)|0;Ra=Dd(Z|0,C|0,_|0,Ra|0)|0;S=Dd(Ra|0,C|0,B|0,S|0)|0;Cb=Dd(S|0,C|0,v|0,Cb|0)|0;v=C;Ta=Od(D|0,Ia|0,Ta|0,0)|0;S=C;B=Od(R|0,0,y|0,ja|0)|0;Ra=C;_=Od(Pa|0,0,Qa|0,sb|0)|0;Z=C;ab=Od(ua|0,Da|0,Sa|0,0)|0;$a=C;Za=Od(Ec|0,Bb|0,Bc|0,0)|0;_a=C;s=Od(s|0,0,p|0,Ka|0)|0;u=C;ja=Od(D|0,Ia|0,y|0,ja|0)|0;y=C;P=Od(R|0,0,Qa|0,sb|0)|0;Ja=C;ya=Od(Pa|0,0,Sa|0,0)|0;jb=C;Cc=Od(ua|0,Da|0,Bc|0,0)|0;Dc=C;Bb=Od(Ec|0,Bb|0,p|0,Ka|0)|0;Bb=Dd(Cc|0,Dc|0,Bb|0,C|0)|0;jb=Dd(Bb|0,C|0,ya|0,jb|0)|0;Ja=Dd(jb|0,C|0,P|0,Ja|0)|0;y=Dd(Ja|0,C|0,ja|0,y|0)|0;ja=C;sb=Od(D|0,Ia|0,Qa|0,sb|0)|0;Qa=C;Ja=Od(R|0,0,Sa|0,0)|0;P=C;jb=Od(Pa|0,0,Bc|0,0)|0;ya=C;Da=Od(ua|0,Da|0,p|0,Ka|0)|0;ua=C;Sa=Od(D|0,Ia|0,Sa|0,0)|0;Bb=C;Dc=Od(R|0,0,Bc|0,0)|0;Cc=C;Pa=Od(Pa|0,0,p|0,Ka|0)|0;Pa=Dd(Dc|0,Cc|0,Pa|0,C|0)|0;Bb=Dd(Pa|0,C|0,Sa|0,Bb|0)|0;Sa=C;Bc=Od(D|0,Ia|0,Bc|0,0)|0;Pa=C;R=Od(R|0,0,p|0,Ka|0)|0;R=Dd(Bc|0,Pa|0,R|0,C|0)|0;Pa=C;Ka=Od(D|0,Ia|0,p|0,Ka|0)|0;p=C;Ia=Dd(Ha|0,ba|0,1048576,0)|0;Ia=Gd(Ia|0,C|0,21)|0;D=C;ta=Dd(Ac|0,zc|0,yc|0,ta|0)|0;ta=Dd(ta|0,C|0,Ia|0,D|0)|0;Ea=Dd(ta|0,C|0,Ea&2097151|0,0)|0;ta=C;D=Hd(Ia|0,D|0,21)|0;D=Cd(Ha|0,ba|0,D|0,C|0)|0;ba=C;Ha=Dd(Ma|0,La|0,1048576,0)|0;Ha=Gd(Ha|0,C|0,21)|0;Ia=C;uc=Dd(xc|0,wc|0,vc|0,uc|0)|0;Ca=Dd(uc|0,C|0,tc|0,Ca|0)|0;pa=Dd(Ca|0,C|0,Ba|0,pa|0)|0;pb=Dd(pa|0,C|0,pb&2097151|0,0)|0;pb=Dd(pb|0,C|0,Ha|0,Ia|0)|0;pa=C;Ia=Hd(Ha|0,Ia|0,21)|0;Ha=C;Ba=Dd(Ga|0,Fa|0,1048576,0)|0;Ba=Ed(Ba|0,C|0,21)|0;Ca=C;pc=Dd(sc|0,rc|0,qc|0,pc|0)|0;nc=Dd(pc|0,C|0,oc|0,nc|0)|0;lc=Dd(nc|0,C|0,mc|0,lc|0)|0;Na=Dd(lc|0,C|0,kc|0,Na|0)|0;Y=Dd(Na|0,C|0,Oa|0,Y|0)|0;X=Dd(Y|0,C|0,X&2097151|0,0)|0;X=Dd(X|0,C|0,Ba|0,Ca|0)|0;Y=C;Ca=Hd(Ba|0,Ca|0,21)|0;Ba=C;Oa=Dd(Xa|0,Ya|0,1048576,0)|0;Oa=Ed(Oa|0,C|0,21)|0;Na=C;gc=Dd(jc|0,ic|0,hc|0,gc|0)|0;ec=Dd(gc|0,C|0,fc|0,ec|0)|0;cc=Dd(ec|0,C|0,dc|0,cc|0)|0;ac=Dd(cc|0,C|0,bc|0,ac|0)|0;_b=Dd(ac|0,C|0,$b|0,_b|0)|0;Yb=Dd(_b|0,C|0,Zb|0,Yb|0)|0;ka=Dd(Yb|0,C|0,ca|0,ka|0)|0;w=Dd(ka|0,C|0,H|0,w|0)|0;w=Dd(w|0,C|0,Oa|0,Na|0)|0;H=C;Na=Hd(Oa|0,Na|0,21)|0;Oa=C;ka=Dd(da|0,ea|0,1048576,0)|0;ka=Ed(ka|0,C|0,21)|0;ca=C;Ub=Dd(Xb|0,Wb|0,Vb|0,Ub|0)|0;Sb=Dd(Ub|0,C|0,Tb|0,Sb|0)|0;Qb=Dd(Sb|0,C|0,Rb|0,Qb|0)|0;Ob=Dd(Qb|0,C|0,Pb|0,Ob|0)|0;Mb=Dd(Ob|0,C|0,Nb|0,Mb|0)|0;Kb=Dd(Mb|0,C|0,Lb|0,Kb|0)|0;Ib=Dd(Kb|0,C|0,Jb|0,Ib|0)|0;Aa=Dd(Ib|0,C|0,Hb|0,Aa|0)|0;O=Dd(Aa|0,C|0,za|0,O|0)|0;N=Dd(O|0,C|0,N&2097151|0,0)|0;N=Dd(N|0,C|0,ka|0,ca|0)|0;O=C;ca=Hd(ka|0,ca|0,21)|0;ka=C;za=Dd(U|0,T|0,1048576,0)|0;za=Ed(za|0,C|0,21)|0;Aa=C;ha=Dd(Eb|0,Db|0,ia|0,ha|0)|0;cb=Dd(ha|0,C|0,bb|0,cb|0)|0;aa=Dd(cb|0,C|0,$|0,aa|0)|0;ob=Dd(aa|0,C|0,nb|0,ob|0)|0;Wa=Dd(ob|0,C|0,Va|0,Wa|0)|0;K=Dd(Wa|0,C|0,Q|0,K|0)|0;wb=Dd(K|0,C|0,vb|0,wb|0)|0;E=Dd(wb|0,C|0,I|0,E|0)|0;ib=Dd(E|0,C|0,hb|0,ib|0)|0;W=Dd(ib|0,C|0,V|0,W|0)|0;kb=Dd(W|0,C|0,qb|0,kb|0)|0;j=Dd(kb|0,C|0,A|0,j|0)|0;j=Dd(j|0,C|0,za|0,Aa|0)|0;A=C;Aa=Hd(za|0,Aa|0,21)|0;za=C;kb=Dd(yb|0,xb|0,1048576,0)|0;kb=Ed(kb|0,C|0,21)|0;qb=C;l=Dd(eb|0,db|0,m|0,l|0)|0;na=Dd(l|0,C|0,Ua|0,na|0)|0;wa=Dd(na|0,C|0,xa|0,wa|0)|0;ra=Dd(wa|0,C|0,sa|0,ra|0)|0;Ab=Dd(ra|0,C|0,zb|0,Ab|0)|0;rb=Dd(Ab|0,C|0,oa|0,rb|0)|0;ga=Dd(rb|0,C|0,ma|0,ga|0)|0;mb=Dd(ga|0,C|0,lb|0,mb|0)|0;G=Dd(mb|0,C|0,J|0,G|0)|0;G=Dd(G|0,C|0,kb|0,qb|0)|0;J=C;qb=Hd(kb|0,qb|0,21)|0;kb=C;mb=Dd(tb|0,ub|0,1048576,0)|0;mb=Ed(mb|0,C|0,21)|0;lb=C;f=Dd(va|0,h|0,la|0,f|0)|0;M=Dd(f|0,C|0,qa|0,M|0)|0;k=Dd(M|0,C|0,fa|0,k|0)|0;x=Dd(k|0,C|0,r|0,x|0)|0;n=Dd(x|0,C|0,L|0,n|0)|0;gb=Dd(n|0,C|0,fb|0,gb|0)|0;g=Dd(gb|0,C|0,F|0,g|0)|0;g=Dd(g|0,C|0,mb|0,lb|0)|0;F=C;lb=Hd(mb|0,lb|0,21)|0;mb=C;gb=Dd(Cb|0,v|0,1048576,0)|0;gb=Ed(gb|0,C|0,21)|0;fb=C;u=Dd(Za|0,_a|0,s|0,u|0)|0;$a=Dd(u|0,C|0,ab|0,$a|0)|0;Z=Dd($a|0,C|0,_|0,Z|0)|0;Ra=Dd(Z|0,C|0,B|0,Ra|0)|0;S=Dd(Ra|0,C|0,Ta|0,S|0)|0;S=Dd(S|0,C|0,gb|0,fb|0)|0;Ta=C;fb=Hd(gb|0,fb|0,21)|0;gb=C;Ra=Dd(y|0,ja|0,1048576,0)|0;Ra=Ed(Ra|0,C|0,21)|0;B=C;ua=Dd(jb|0,ya|0,Da|0,ua|0)|0;P=Dd(ua|0,C|0,Ja|0,P|0)|0;Qa=Dd(P|0,C|0,sb|0,Qa|0)|0;Qa=Dd(Qa|0,C|0,Ra|0,B|0)|0;sb=C;B=Hd(Ra|0,B|0,21)|0;B=Cd(y|0,ja|0,B|0,C|0)|0;ja=C;y=Dd(Bb|0,Sa|0,1048576,0)|0;y=Ed(y|0,C|0,21)|0;Ra=C;Pa=Dd(R|0,Pa|0,y|0,Ra|0)|0;R=C;Ra=Hd(y|0,Ra|0,21)|0;Ra=Cd(Bb|0,Sa|0,Ra|0,C|0)|0;Sa=C;Bb=Dd(Ka|0,p|0,1048576,0)|0;Bb=Ed(Bb|0,C|0,21)|0;y=C;P=Hd(Bb|0,y|0,21)|0;P=Cd(Ka|0,p|0,P|0,C|0)|0;p=C;Ka=Dd(Ea|0,ta|0,1048576,0)|0;Ka=Gd(Ka|0,C|0,21)|0;Ja=C;ua=Hd(Ka|0,Ja|0,21)|0;ua=Cd(Ea|0,ta|0,ua|0,C|0)|0;ta=C;Ea=Dd(pb|0,pa|0,1048576,0)|0;Ea=Ed(Ea|0,C|0,21)|0;Da=C;ya=Hd(Ea|0,Da|0,21)|0;ya=Cd(pb|0,pa|0,ya|0,C|0)|0;pa=C;pb=Dd(X|0,Y|0,1048576,0)|0;pb=Ed(pb|0,C|0,21)|0;jb=C;Z=Hd(pb|0,jb|0,21)|0;_=C;$a=Dd(w|0,H|0,1048576,0)|0;$a=Ed($a|0,C|0,21)|0;ab=C;u=Hd($a|0,ab|0,21)|0;s=C;_a=Dd(N|0,O|0,1048576,0)|0;_a=Ed(_a|0,C|0,21)|0;Za=C;n=Hd(_a|0,Za|0,21)|0;L=C;x=Dd(j|0,A|0,1048576,0)|0;x=Ed(x|0,C|0,21)|0;r=C;k=Hd(x|0,r|0,21)|0;fa=C;M=Dd(G|0,J|0,1048576,0)|0;M=Ed(M|0,C|0,21)|0;qa=C;f=Hd(M|0,qa|0,21)|0;la=C;h=Dd(g|0,F|0,1048576,0)|0;h=Ed(h|0,C|0,21)|0;va=C;ga=Hd(h|0,va|0,21)|0;ma=C;rb=Dd(S|0,Ta|0,1048576,0)|0;rb=Ed(rb|0,C|0,21)|0;oa=C;ja=Dd(rb|0,oa|0,B|0,ja|0)|0;B=C;oa=Hd(rb|0,oa|0,21)|0;oa=Cd(S|0,Ta|0,oa|0,C|0)|0;Ta=C;S=Dd(Qa|0,sb|0,1048576,0)|0;S=Ed(S|0,C|0,21)|0;rb=C;Sa=Dd(S|0,rb|0,Ra|0,Sa|0)|0;Ra=C;rb=Hd(S|0,rb|0,21)|0;rb=Cd(Qa|0,sb|0,rb|0,C|0)|0;sb=C;Qa=Dd(Pa|0,R|0,1048576,0)|0;Qa=Ed(Qa|0,C|0,21)|0;S=C;p=Dd(Qa|0,S|0,P|0,p|0)|0;P=C;S=Hd(Qa|0,S|0,21)|0;S=Cd(Pa|0,R|0,S|0,C|0)|0;R=C;Pa=Od(Bb|0,y|0,666643,0)|0;Qa=C;Ab=Od(Bb|0,y|0,470296,0)|0;zb=C;ra=Od(Bb|0,y|0,654183,0)|0;sa=C;wa=Od(Bb|0,y|0,-997805,-1)|0;xa=C;na=Od(Bb|0,y|0,136657,0)|0;Ua=C;y=Od(Bb|0,y|0,-683901,-1)|0;y=Dd(Cb|0,v|0,y|0,C|0)|0;gb=Cd(y|0,C|0,fb|0,gb|0)|0;va=Dd(gb|0,C|0,h|0,va|0)|0;h=C;gb=Od(p|0,P|0,666643,0)|0;fb=C;y=Od(p|0,P|0,470296,0)|0;v=C;Cb=Od(p|0,P|0,654183,0)|0;Bb=C;l=Od(p|0,P|0,-997805,-1)|0;m=C;db=Od(p|0,P|0,136657,0)|0;eb=C;P=Od(p|0,P|0,-683901,-1)|0;p=C;W=Od(S|0,R|0,666643,0)|0;V=C;ib=Od(S|0,R|0,470296,0)|0;hb=C;E=Od(S|0,R|0,654183,0)|0;I=C;wb=Od(S|0,R|0,-997805,-1)|0;vb=C;K=Od(S|0,R|0,136657,0)|0;Q=C;R=Od(S|0,R|0,-683901,-1)|0;S=C;xa=Dd(tb|0,ub|0,wa|0,xa|0)|0;eb=Dd(xa|0,C|0,db|0,eb|0)|0;S=Dd(eb|0,C|0,R|0,S|0)|0;mb=Cd(S|0,C|0,lb|0,mb|0)|0;qa=Dd(mb|0,C|0,M|0,qa|0)|0;M=C;mb=Od(Sa|0,Ra|0,666643,0)|0;lb=C;S=Od(Sa|0,Ra|0,470296,0)|0;R=C;eb=Od(Sa|0,Ra|0,654183,0)|0;db=C;xa=Od(Sa|0,Ra|0,-997805,-1)|0;wa=C;ub=Od(Sa|0,Ra|0,136657,0)|0;tb=C;Ra=Od(Sa|0,Ra|0,-683901,-1)|0;Sa=C;Wa=Od(rb|0,sb|0,666643,0)|0;Va=C;ob=Od(rb|0,sb|0,470296,0)|0;nb=C;aa=Od(rb|0,sb|0,654183,0)|0;$=C;cb=Od(rb|0,sb|0,-997805,-1)|0;bb=C;ha=Od(rb|0,sb|0,136657,0)|0;ia=C;sb=Od(rb|0,sb|0,-683901,-1)|0;rb=C;zb=Dd(Cb|0,Bb|0,Ab|0,zb|0)|0;xb=Dd(zb|0,C|0,yb|0,xb|0)|0;vb=Dd(xb|0,C|0,wb|0,vb|0)|0;tb=Dd(vb|0,C|0,ub|0,tb|0)|0;rb=Dd(tb|0,C|0,sb|0,rb|0)|0;kb=Cd(rb|0,C|0,qb|0,kb|0)|0;r=Dd(kb|0,C|0,x|0,r|0)|0;x=C;kb=Od(ja|0,B|0,666643,0)|0;kb=Dd(pb|0,jb|0,kb|0,C|0)|0;Ya=Dd(kb|0,C|0,Xa|0,Ya|0)|0;Oa=Cd(Ya|0,C|0,Na|0,Oa|0)|0;Na=C;Ya=Od(ja|0,B|0,470296,0)|0;Xa=C;kb=Od(ja|0,B|0,654183,0)|0;jb=C;lb=Dd(ob|0,nb|0,mb|0,lb|0)|0;jb=Dd(lb|0,C|0,kb|0,jb|0)|0;ab=Dd(jb|0,C|0,$a|0,ab|0)|0;ea=Dd(ab|0,C|0,da|0,ea|0)|0;ka=Cd(ea|0,C|0,ca|0,ka|0)|0;ca=C;ea=Od(ja|0,B|0,-997805,-1)|0;da=C;ab=Od(ja|0,B|0,136657,0)|0;$a=C;fb=Dd(ib|0,hb|0,gb|0,fb|0)|0;db=Dd(fb|0,C|0,eb|0,db|0)|0;bb=Dd(db|0,C|0,cb|0,bb|0)|0;$a=Dd(bb|0,C|0,ab|0,$a|0)|0;Za=Dd($a|0,C|0,_a|0,Za|0)|0;T=Dd(Za|0,C|0,U|0,T|0)|0;za=Cd(T|0,C|0,Aa|0,za|0)|0;Aa=C;B=Od(ja|0,B|0,-683901,-1)|0;ja=C;T=Dd(Oa|0,Na|0,1048576,0)|0;T=Ed(T|0,C|0,21)|0;U=C;Va=Dd(Ya|0,Xa|0,Wa|0,Va|0)|0;H=Dd(Va|0,C|0,w|0,H|0)|0;s=Cd(H|0,C|0,u|0,s|0)|0;s=Dd(s|0,C|0,T|0,U|0)|0;u=C;U=Hd(T|0,U|0,21)|0;T=C;H=Dd(ka|0,ca|0,1048576,0)|0;H=Ed(H|0,C|0,21)|0;w=C;V=Dd(S|0,R|0,W|0,V|0)|0;$=Dd(V|0,C|0,aa|0,$|0)|0;da=Dd($|0,C|0,ea|0,da|0)|0;O=Dd(da|0,C|0,N|0,O|0)|0;L=Cd(O|0,C|0,n|0,L|0)|0;L=Dd(L|0,C|0,H|0,w|0)|0;n=C;w=Hd(H|0,w|0,21)|0;H=C;O=Dd(za|0,Aa|0,1048576,0)|0;O=Ed(O|0,C|0,21)|0;N=C;Qa=Dd(y|0,v|0,Pa|0,Qa|0)|0;I=Dd(Qa|0,C|0,E|0,I|0)|0;wa=Dd(I|0,C|0,xa|0,wa|0)|0;ia=Dd(wa|0,C|0,ha|0,ia|0)|0;ja=Dd(ia|0,C|0,B|0,ja|0)|0;A=Dd(ja|0,C|0,j|0,A|0)|0;fa=Cd(A|0,C|0,k|0,fa|0)|0;fa=Dd(fa|0,C|0,O|0,N|0)|0;k=C;N=Hd(O|0,N|0,21)|0;O=C;A=Dd(r|0,x|0,1048576,0)|0;A=Ed(A|0,C|0,21)|0;j=C;sa=Dd(l|0,m|0,ra|0,sa|0)|0;Q=Dd(sa|0,C|0,K|0,Q|0)|0;Sa=Dd(Q|0,C|0,Ra|0,Sa|0)|0;J=Dd(Sa|0,C|0,G|0,J|0)|0;la=Cd(J|0,C|0,f|0,la|0)|0;la=Dd(la|0,C|0,A|0,j|0)|0;f=C;j=Hd(A|0,j|0,21)|0;j=Cd(r|0,x|0,j|0,C|0)|0;x=C;r=Dd(qa|0,M|0,1048576,0)|0;r=Ed(r|0,C|0,21)|0;A=C;Ua=Dd(P|0,p|0,na|0,Ua|0)|0;F=Dd(Ua|0,C|0,g|0,F|0)|0;ma=Cd(F|0,C|0,ga|0,ma|0)|0;ma=Dd(ma|0,C|0,r|0,A|0)|0;ga=C;A=Hd(r|0,A|0,21)|0;A=Cd(qa|0,M|0,A|0,C|0)|0;M=C;qa=Dd(va|0,h|0,1048576,0)|0;qa=Ed(qa|0,C|0,21)|0;r=C;Ta=Dd(qa|0,r|0,oa|0,Ta|0)|0;oa=C;r=Hd(qa|0,r|0,21)|0;r=Cd(va|0,h|0,r|0,C|0)|0;h=C;va=Dd(s|0,u|0,1048576,0)|0;va=Ed(va|0,C|0,21)|0;qa=C;F=Hd(va|0,qa|0,21)|0;g=C;Ua=Dd(L|0,n|0,1048576,0)|0;Ua=Ed(Ua|0,C|0,21)|0;na=C;p=Hd(Ua|0,na|0,21)|0;P=C;J=Dd(fa|0,k|0,1048576,0)|0;J=Ed(J|0,C|0,21)|0;G=C;x=Dd(J|0,G|0,j|0,x|0)|0;j=C;G=Hd(J|0,G|0,21)|0;G=Cd(fa|0,k|0,G|0,C|0)|0;k=C;fa=Dd(la|0,f|0,1048576,0)|0;fa=Ed(fa|0,C|0,21)|0;J=C;M=Dd(fa|0,J|0,A|0,M|0)|0;A=C;J=Hd(fa|0,J|0,21)|0;J=Cd(la|0,f|0,J|0,C|0)|0;f=C;la=Dd(ma|0,ga|0,1048576,0)|0;la=Ed(la|0,C|0,21)|0;fa=C;h=Dd(la|0,fa|0,r|0,h|0)|0;r=C;fa=Hd(la|0,fa|0,21)|0;fa=Cd(ma|0,ga|0,fa|0,C|0)|0;ga=C;ma=Od(Ta|0,oa|0,666643,0)|0;la=C;Sa=Od(Ta|0,oa|0,470296,0)|0;Ra=C;Q=Od(Ta|0,oa|0,654183,0)|0;K=C;sa=Od(Ta|0,oa|0,-997805,-1)|0;ra=C;m=Od(Ta|0,oa|0,136657,0)|0;l=C;oa=Od(Ta|0,oa|0,-683901,-1)|0;oa=Dd(Ua|0,na|0,oa|0,C|0)|0;Aa=Dd(oa|0,C|0,za|0,Aa|0)|0;O=Cd(Aa|0,C|0,N|0,O|0)|0;N=C;Aa=Od(h|0,r|0,666643,0)|0;za=C;oa=Od(h|0,r|0,470296,0)|0;na=C;Ua=Od(h|0,r|0,654183,0)|0;Ta=C;ja=Od(h|0,r|0,-997805,-1)|0;B=C;ia=Od(h|0,r|0,136657,0)|0;ha=C;r=Od(h|0,r|0,-683901,-1)|0;h=C;wa=Od(fa|0,ga|0,666643,0)|0;wa=Dd(ya|0,pa|0,wa|0,C|0)|0;pa=C;ya=Od(fa|0,ga|0,470296,0)|0;xa=C;I=Od(fa|0,ga|0,654183,0)|0;E=C;Qa=Od(fa|0,ga|0,-997805,-1)|0;Pa=C;v=Od(fa|0,ga|0,136657,0)|0;y=C;ga=Od(fa|0,ga|0,-683901,-1)|0;fa=C;ra=Dd(ia|0,ha|0,sa|0,ra|0)|0;fa=Dd(ra|0,C|0,ga|0,fa|0)|0;qa=Dd(fa|0,C|0,va|0,qa|0)|0;ca=Dd(qa|0,C|0,ka|0,ca|0)|0;H=Cd(ca|0,C|0,w|0,H|0)|0;w=C;ca=Od(M|0,A|0,666643,0)|0;ka=C;qa=Od(M|0,A|0,470296,0)|0;qa=Dd(wa|0,pa|0,qa|0,C|0)|0;pa=C;wa=Od(M|0,A|0,654183,0)|0;va=C;fa=Od(M|0,A|0,-997805,-1)|0;ga=C;ra=Od(M|0,A|0,136657,0)|0;sa=C;A=Od(M|0,A|0,-683901,-1)|0;M=C;ha=Od(J|0,f|0,666643,0)|0;ia=C;da=Od(J|0,f|0,470296,0)|0;ea=C;$=Od(J|0,f|0,654183,0)|0;aa=C;V=Od(J|0,f|0,-997805,-1)|0;W=C;R=Od(J|0,f|0,136657,0)|0;S=C;f=Od(J|0,f|0,-683901,-1)|0;J=C;Ra=Dd(Ua|0,Ta|0,Sa|0,Ra|0)|0;Pa=Dd(Ra|0,C|0,Qa|0,Pa|0)|0;Na=Dd(Pa|0,C|0,Oa|0,Na|0)|0;T=Cd(Na|0,C|0,U|0,T|0)|0;sa=Dd(T|0,C|0,ra|0,sa|0)|0;J=Dd(sa|0,C|0,f|0,J|0)|0;f=C;sa=Od(x|0,j|0,666643,0)|0;ba=Dd(sa|0,C|0,D|0,ba|0)|0;D=C;sa=Od(x|0,j|0,470296,0)|0;ra=C;T=Od(x|0,j|0,654183,0)|0;U=C;Ja=Dd(Ma|0,La|0,Ka|0,Ja|0)|0;Ha=Cd(Ja|0,C|0,Ia|0,Ha|0)|0;ka=Dd(Ha|0,C|0,ca|0,ka|0)|0;U=Dd(ka|0,C|0,T|0,U|0)|0;ea=Dd(U|0,C|0,da|0,ea|0)|0;da=C;U=Od(x|0,j|0,-997805,-1)|0;T=C;ka=Od(x|0,j|0,136657,0)|0;ca=C;Da=Dd(Ga|0,Fa|0,Ea|0,Da|0)|0;Ba=Cd(Da|0,C|0,Ca|0,Ba|0)|0;za=Dd(Ba|0,C|0,Aa|0,za|0)|0;xa=Dd(za|0,C|0,ya|0,xa|0)|0;va=Dd(xa|0,C|0,wa|0,va|0)|0;ca=Dd(va|0,C|0,ka|0,ca|0)|0;W=Dd(ca|0,C|0,V|0,W|0)|0;V=C;j=Od(x|0,j|0,-683901,-1)|0;x=C;ca=Dd(ba|0,D|0,1048576,0)|0;ca=Ed(ca|0,C|0,21)|0;ka=C;ra=Dd(ua|0,ta|0,sa|0,ra|0)|0;ia=Dd(ra|0,C|0,ha|0,ia|0)|0;ia=Dd(ia|0,C|0,ca|0,ka|0)|0;ha=C;ka=Hd(ca|0,ka|0,21)|0;ka=Cd(ba|0,D|0,ka|0,C|0)|0;D=C;ba=Dd(ea|0,da|0,1048576,0)|0;ba=Ed(ba|0,C|0,21)|0;ca=C;T=Dd(qa|0,pa|0,U|0,T|0)|0;aa=Dd(T|0,C|0,$|0,aa|0)|0;aa=Dd(aa|0,C|0,ba|0,ca|0)|0;$=C;ca=Hd(ba|0,ca|0,21)|0;ba=C;T=Dd(W|0,V|0,1048576,0)|0;T=Ed(T|0,C|0,21)|0;U=C;la=Dd(oa|0,na|0,ma|0,la|0)|0;E=Dd(la|0,C|0,I|0,E|0)|0;Y=Dd(E|0,C|0,X|0,Y|0)|0;_=Cd(Y|0,C|0,Z|0,_|0)|0;ga=Dd(_|0,C|0,fa|0,ga|0)|0;x=Dd(ga|0,C|0,j|0,x|0)|0;S=Dd(x|0,C|0,R|0,S|0)|0;S=Dd(S|0,C|0,T|0,U|0)|0;R=C;U=Hd(T|0,U|0,21)|0;T=C;x=Dd(J|0,f|0,1048576,0)|0;x=Ed(x|0,C|0,21)|0;j=C;K=Dd(ja|0,B|0,Q|0,K|0)|0;y=Dd(K|0,C|0,v|0,y|0)|0;u=Dd(y|0,C|0,s|0,u|0)|0;g=Cd(u|0,C|0,F|0,g|0)|0;M=Dd(g|0,C|0,A|0,M|0)|0;M=Dd(M|0,C|0,x|0,j|0)|0;A=C;j=Hd(x|0,j|0,21)|0;j=Cd(J|0,f|0,j|0,C|0)|0;f=C;J=Dd(H|0,w|0,1048576,0)|0;J=Ed(J|0,C|0,21)|0;x=C;l=Dd(r|0,h|0,m|0,l|0)|0;n=Dd(l|0,C|0,L|0,n|0)|0;n=Dd(n|0,C|0,J|0,x|0)|0;P=Cd(n|0,C|0,p|0,P|0)|0;p=C;x=Hd(J|0,x|0,21)|0;x=Cd(H|0,w|0,x|0,C|0)|0;w=C;H=Dd(O|0,N|0,1048576,0)|0;H=Ed(H|0,C|0,21)|0;J=C;k=Dd(G|0,k|0,H|0,J|0)|0;G=C;J=Hd(H|0,J|0,21)|0;H=C;n=Dd(ia|0,ha|0,1048576,0)|0;n=Ed(n|0,C|0,21)|0;L=C;l=Hd(n|0,L|0,21)|0;m=C;h=Dd(aa|0,$|0,1048576,0)|0;h=Ed(h|0,C|0,21)|0;r=C;g=Hd(h|0,r|0,21)|0;F=C;u=Dd(S|0,R|0,1048576,0)|0;u=Ed(u|0,C|0,21)|0;s=C;f=Dd(j|0,f|0,u|0,s|0)|0;j=C;s=Hd(u|0,s|0,21)|0;u=C;y=Dd(M|0,A|0,1048576,0)|0;y=Ed(y|0,C|0,21)|0;v=C;w=Dd(x|0,w|0,y|0,v|0)|0;x=C;v=Hd(y|0,v|0,21)|0;v=Cd(M|0,A|0,v|0,C|0)|0;A=C;M=Dd(P|0,p|0,1048576,0)|0;M=Ed(M|0,C|0,21)|0;y=C;K=Hd(M|0,y|0,21)|0;K=Cd(P|0,p|0,K|0,C|0)|0;p=C;P=Dd(k|0,G|0,1048576,0)|0;P=Ed(P|0,C|0,21)|0;Q=C;B=Hd(P|0,Q|0,21)|0;B=Cd(k|0,G|0,B|0,C|0)|0;G=C;k=Od(P|0,Q|0,666643,0)|0;k=Dd(ka|0,D|0,k|0,C|0)|0;D=C;ka=Od(P|0,Q|0,470296,0)|0;ja=C;ga=Od(P|0,Q|0,654183,0)|0;fa=C;_=Od(P|0,Q|0,-997805,-1)|0;Z=C;Y=Od(P|0,Q|0,136657,0)|0;X=C;Q=Od(P|0,Q|0,-683901,-1)|0;P=C;E=Ed(k|0,D|0,21)|0;I=C;ha=Dd(ka|0,ja|0,ia|0,ha|0)|0;m=Cd(ha|0,C|0,l|0,m|0)|0;m=Dd(m|0,C|0,E|0,I|0)|0;l=C;I=Hd(E|0,I|0,21)|0;I=Cd(k|0,D|0,I|0,C|0)|0;D=C;k=Ed(m|0,l|0,21)|0;E=C;da=Dd(ga|0,fa|0,ea|0,da|0)|0;ba=Cd(da|0,C|0,ca|0,ba|0)|0;L=Dd(ba|0,C|0,n|0,L|0)|0;L=Dd(L|0,C|0,k|0,E|0)|0;n=C;E=Hd(k|0,E|0,21)|0;E=Cd(m|0,l|0,E|0,C|0)|0;l=C;m=Ed(L|0,n|0,21)|0;k=C;Z=Dd(aa|0,$|0,_|0,Z|0)|0;F=Cd(Z|0,C|0,g|0,F|0)|0;F=Dd(F|0,C|0,m|0,k|0)|0;g=C;k=Hd(m|0,k|0,21)|0;k=Cd(L|0,n|0,k|0,C|0)|0;n=C;L=Ed(F|0,g|0,21)|0;m=C;V=Dd(Y|0,X|0,W|0,V|0)|0;T=Cd(V|0,C|0,U|0,T|0)|0;r=Dd(T|0,C|0,h|0,r|0)|0;r=Dd(r|0,C|0,L|0,m|0)|0;h=C;m=Hd(L|0,m|0,21)|0;m=Cd(F|0,g|0,m|0,C|0)|0;g=C;F=Ed(r|0,h|0,21)|0;L=C;P=Dd(S|0,R|0,Q|0,P|0)|0;u=Cd(P|0,C|0,s|0,u|0)|0;u=Dd(u|0,C|0,F|0,L|0)|0;s=C;L=Hd(F|0,L|0,21)|0;L=Cd(r|0,h|0,L|0,C|0)|0;h=C;r=Ed(u|0,s|0,21)|0;F=C;j=Dd(f|0,j|0,r|0,F|0)|0;f=C;F=Hd(r|0,F|0,21)|0;F=Cd(u|0,s|0,F|0,C|0)|0;s=C;u=Ed(j|0,f|0,21)|0;r=C;A=Dd(u|0,r|0,v|0,A|0)|0;v=C;r=Hd(u|0,r|0,21)|0;r=Cd(j|0,f|0,r|0,C|0)|0;f=C;j=Ed(A|0,v|0,21)|0;u=C;x=Dd(w|0,x|0,j|0,u|0)|0;w=C;u=Hd(j|0,u|0,21)|0;u=Cd(A|0,v|0,u|0,C|0)|0;v=C;A=Ed(x|0,w|0,21)|0;j=C;p=Dd(A|0,j|0,K|0,p|0)|0;K=C;j=Hd(A|0,j|0,21)|0;j=Cd(x|0,w|0,j|0,C|0)|0;w=C;x=Ed(p|0,K|0,21)|0;A=C;y=Dd(O|0,N|0,M|0,y|0)|0;H=Cd(y|0,C|0,J|0,H|0)|0;H=Dd(H|0,C|0,x|0,A|0)|0;J=C;A=Hd(x|0,A|0,21)|0;A=Cd(p|0,K|0,A|0,C|0)|0;K=C;p=Ed(H|0,J|0,21)|0;x=C;G=Dd(p|0,x|0,B|0,G|0)|0;B=C;x=Hd(p|0,x|0,21)|0;x=Cd(H|0,J|0,x|0,C|0)|0;J=C;H=Ed(G|0,B|0,21)|0;p=C;y=Hd(H|0,p|0,21)|0;y=Cd(G|0,B|0,y|0,C|0)|0;B=C;G=Od(H|0,p|0,666643,0)|0;D=Dd(G|0,C|0,I|0,D|0)|0;I=C;G=Od(H|0,p|0,470296,0)|0;G=Dd(E|0,l|0,G|0,C|0)|0;l=C;E=Od(H|0,p|0,654183,0)|0;E=Dd(k|0,n|0,E|0,C|0)|0;n=C;k=Od(H|0,p|0,-997805,-1)|0;k=Dd(m|0,g|0,k|0,C|0)|0;g=C;m=Od(H|0,p|0,136657,0)|0;m=Dd(L|0,h|0,m|0,C|0)|0;h=C;p=Od(H|0,p|0,-683901,-1)|0;p=Dd(F|0,s|0,p|0,C|0)|0;s=C;F=Ed(D|0,I|0,21)|0;H=C;l=Dd(G|0,l|0,F|0,H|0)|0;G=C;H=Hd(F|0,H|0,21)|0;H=Cd(D|0,I|0,H|0,C|0)|0;I=C;D=Ed(l|0,G|0,21)|0;F=C;n=Dd(E|0,n|0,D|0,F|0)|0;E=C;F=Hd(D|0,F|0,21)|0;F=Cd(l|0,G|0,F|0,C|0)|0;G=C;l=Ed(n|0,E|0,21)|0;D=C;g=Dd(k|0,g|0,l|0,D|0)|0;k=C;D=Hd(l|0,D|0,21)|0;D=Cd(n|0,E|0,D|0,C|0)|0;E=C;n=Ed(g|0,k|0,21)|0;l=C;h=Dd(m|0,h|0,n|0,l|0)|0;m=C;l=Hd(n|0,l|0,21)|0;l=Cd(g|0,k|0,l|0,C|0)|0;k=C;g=Ed(h|0,m|0,21)|0;n=C;s=Dd(p|0,s|0,g|0,n|0)|0;p=C;n=Hd(g|0,n|0,21)|0;n=Cd(h|0,m|0,n|0,C|0)|0;m=C;h=Ed(s|0,p|0,21)|0;g=C;f=Dd(h|0,g|0,r|0,f|0)|0;r=C;g=Hd(h|0,g|0,21)|0;g=Cd(s|0,p|0,g|0,C|0)|0;p=C;s=Ed(f|0,r|0,21)|0;h=C;v=Dd(s|0,h|0,u|0,v|0)|0;u=C;h=Hd(s|0,h|0,21)|0;h=Cd(f|0,r|0,h|0,C|0)|0;r=C;f=Ed(v|0,u|0,21)|0;s=C;w=Dd(f|0,s|0,j|0,w|0)|0;j=C;s=Hd(f|0,s|0,21)|0;s=Cd(v|0,u|0,s|0,C|0)|0;u=C;v=Ed(w|0,j|0,21)|0;f=C;K=Dd(v|0,f|0,A|0,K|0)|0;A=C;f=Hd(v|0,f|0,21)|0;f=Cd(w|0,j|0,f|0,C|0)|0;j=C;w=Ed(K|0,A|0,21)|0;v=C;J=Dd(w|0,v|0,x|0,J|0)|0;x=C;v=Hd(w|0,v|0,21)|0;v=Cd(K|0,A|0,v|0,C|0)|0;A=C;K=Ed(J|0,x|0,21)|0;w=C;B=Dd(K|0,w|0,y|0,B|0)|0;y=C;w=Hd(K|0,w|0,21)|0;w=Cd(J|0,x|0,w|0,C|0)|0;x=C;a[o>>0]=H;o=Gd(H|0,I|0,8)|0;a[b+33>>0]=o;o=Gd(H|0,I|0,16)|0;I=C;H=Hd(F|0,G|0,5)|0;a[b+34>>0]=H|o;o=Gd(F|0,G|0,3)|0;a[b+35>>0]=o;o=Gd(F|0,G|0,11)|0;a[b+36>>0]=o;o=Gd(F|0,G|0,19)|0;G=C;F=Hd(D|0,E|0,2)|0;a[b+37>>0]=F|o;o=Gd(D|0,E|0,6)|0;a[b+38>>0]=o;o=Gd(D|0,E|0,14)|0;E=C;D=Hd(l|0,k|0,7)|0;a[b+39>>0]=D|o;o=Gd(l|0,k|0,1)|0;a[b+40>>0]=o;o=Gd(l|0,k|0,9)|0;a[b+41>>0]=o;o=Gd(l|0,k|0,17)|0;k=C;l=Hd(n|0,m|0,4)|0;a[b+42>>0]=l|o;o=Gd(n|0,m|0,4)|0;a[b+43>>0]=o;o=Gd(n|0,m|0,12)|0;a[b+44>>0]=o;o=Gd(n|0,m|0,20)|0;m=C;n=Hd(g|0,p|0,1)|0;a[b+45>>0]=n|o;o=Gd(g|0,p|0,7)|0;a[b+46>>0]=o;p=Gd(g|0,p|0,15)|0;o=C;g=Hd(h|0,r|0,6)|0;a[b+47>>0]=g|p;p=Gd(h|0,r|0,2)|0;a[b+48>>0]=p;p=Gd(h|0,r|0,10)|0;a[b+49>>0]=p;r=Gd(h|0,r|0,18)|0;h=C;p=Hd(s|0,u|0,3)|0;a[b+50>>0]=p|r;r=Gd(s|0,u|0,5)|0;a[b+51>>0]=r;u=Gd(s|0,u|0,13)|0;a[b+52>>0]=u;a[b+53>>0]=f;u=Gd(f|0,j|0,8)|0;a[b+54>>0]=u;j=Gd(f|0,j|0,16)|0;f=C;u=Hd(v|0,A|0,5)|0;a[b+55>>0]=u|j;j=Gd(v|0,A|0,3)|0;a[b+56>>0]=j;j=Gd(v|0,A|0,11)|0;a[b+57>>0]=j;A=Gd(v|0,A|0,19)|0;v=C;j=Hd(w|0,x|0,2)|0;a[b+58>>0]=j|A;A=Gd(w|0,x|0,6)|0;a[b+59>>0]=A;x=Gd(w|0,x|0,14)|0;w=C;A=Hd(B|0,y|0,7)|0;a[b+60>>0]=x|A;A=Gd(B|0,y|0,1)|0;a[b+61>>0]=A;A=Gd(B|0,y|0,9)|0;a[b+62>>0]=A;y=Gd(B|0,y|0,17)|0;a[b+63>>0]=y;y=q;B=y+64|0;do{a[y>>0]=0;y=y+1|0}while((y|0)<(B|0));y=t;B=y+64|0;do{a[y>>0]=0;y=y+1|0}while((y|0)<(B|0));if(!e){i=z;return}Ec=e;c[Ec>>2]=64;c[Ec+4>>2]=0;i=z;return}function Yc(b,c){b=b|0;c=c|0;return ((((a[c+1>>0]^a[b+1>>0]|a[c>>0]^a[b>>0]|a[c+2>>0]^a[b+2>>0]|a[c+3>>0]^a[b+3>>0]|a[c+4>>0]^a[b+4>>0]|a[c+5>>0]^a[b+5>>0]|a[c+6>>0]^a[b+6>>0]|a[c+7>>0]^a[b+7>>0]|a[c+8>>0]^a[b+8>>0]|a[c+9>>0]^a[b+9>>0]|a[c+10>>0]^a[b+10>>0]|a[c+11>>0]^a[b+11>>0]|a[c+12>>0]^a[b+12>>0]|a[c+13>>0]^a[b+13>>0]|a[c+14>>0]^a[b+14>>0]|a[c+15>>0]^a[b+15>>0]|a[c+16>>0]^a[b+16>>0]|a[c+17>>0]^a[b+17>>0]|a[c+18>>0]^a[b+18>>0]|a[c+19>>0]^a[b+19>>0]|a[c+20>>0]^a[b+20>>0]|a[c+21>>0]^a[b+21>>0]|a[c+22>>0]^a[b+22>>0]|a[c+23>>0]^a[b+23>>0]|a[c+24>>0]^a[b+24>>0]|a[c+25>>0]^a[b+25>>0]|a[c+26>>0]^a[b+26>>0]|a[c+27>>0]^a[b+27>>0]|a[c+28>>0]^a[b+28>>0]|a[c+29>>0]^a[b+29>>0]|a[c+30>>0]^a[b+30>>0]|a[c+31>>0]^a[b+31>>0])&255)+511|0)>>>8&1)+-1|0}function Zc(a){a=a|0;c[7976]=a;return 0}function _c(){return Ba(0)|0}function $c(){Ba(1);return}function ad(a){a=a|0;var b=0,d=0;b=c[7976]|0;if((b|0)!=0?(d=c[b+12>>2]|0,(d|0)!=0):0){a=Ea[d&31](a)|0;return a|0}if(a>>>0<2){a=0;return a|0}b=((0-a|0)>>>0)%(a>>>0)|0;do d=Ba(0)|0;while(d>>>0<b>>>0);a=(d>>>0)%(a>>>0)|0;return a|0}function bd(b,c){b=b|0;c=c|0;var d=0;if(!c)return;else d=0;do{a[b+d>>0]=Ba(0)|0;d=d+1|0}while((d|0)!=(c|0));return}function cd(){var a=0;a=c[7976]|0;if(!a){a=0;return a|0}a=c[a+20>>2]|0;if(!a){a=0;return a|0}a=Da[a&31]()|0;return a|0}function dd(){var a=0,b=0;if(c[7977]|0){b=1;return b|0}Ba(1);a=na(30)|0;if((a|0)>0)c[7978]=a;else a=c[7978]|0;if(a>>>0<16)ra();else b=0;do{Ba(0)|0;b=b+1|0}while((b|0)!=16);c[7977]=1;b=0;return b|0}function ed(a,b){a=a|0;b=b|0;Fd(a|0,0,b|0)|0;return}function fd(b,c,e,f){b=b|0;c=c|0;e=e|0;f=f|0;var g=0,h=0,i=0,j=0;g=f<<1;if(!(f>>>0<2147483647&g>>>0<c>>>0))ra();if(!f){f=0;f=b+f|0;a[f>>0]=0;return b|0}else c=0;do{j=d[e+c>>0]|0;i=j&15;j=j>>>4;h=c<<1;a[b+h>>0]=j+87+((j+65526|0)>>>8&217);a[b+(h|1)>>0]=((i<<8)+22272+(i+65526&55552)|0)>>>8;c=c+1|0}while((c|0)!=(f|0));j=b+g|0;a[j>>0]=0;return b|0}function gd(b,e,f,g,h,i,j){b=b|0;e=e|0;f=f|0;g=g|0;h=h|0;i=i|0;j=j|0;var k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0;a:do if(!g){n=0;l=0;o=0;k=0}else{b:do if(!h){n=0;r=0;l=0;k=0;while(1){p=d[f+l>>0]|0;m=p^48;o=(m+65526|0)>>>8;p=(p&223)+201|0;q=p&255;q=(q+65526^q+65520)>>>8;if(!((q|o)&255)){o=0;break a}m=q&p|o&m;if(n>>>0>=e>>>0){m=k;break b}if(!(k<<24>>24))m=m<<4&255;else{a[b+n>>0]=m|r&255;n=n+1|0;m=r}k=(k&255^255)&255;l=l+1|0;if(l>>>0<g>>>0)r=m;else{o=0;break a}}}else{n=0;u=0;l=0;k=0;while(1){t=k<<24>>24==0;c:do if(!t){q=d[f+l>>0]|0;m=q^48;o=(m+65526|0)>>>8;q=(q&223)+201|0;p=q&255;p=(p+65526^p+65520)>>>8;if(!((p|o)&255)){o=0;break a}}else while(1){q=a[f+l>>0]|0;r=q&255;m=r^48;o=(m+65526|0)>>>8;s=(r&223)+201|0;p=s&255;p=(p+65526^p+65520)>>>8;if((p|o)&255){q=s;break c}s=ud(h,r)|0;if((s|0)==0?1:(a[s>>0]|0)!=q<<24>>24){o=0;k=0;break a}l=l+1|0;if(l>>>0>=g>>>0){o=0;k=0;break a}}while(0);m=p&q|o&m;if(n>>>0>=e>>>0){m=k;break b}if(t)m=m<<4&255;else{a[b+n>>0]=m|u&255;n=n+1|0;m=u}k=(k&255^255)&255;l=l+1|0;if(l>>>0<g>>>0)u=m;else{o=0;break a}}}while(0);if(!(c[7979]|0))k=31964;else k=c[(oa()|0)+60>>2]|0;c[k>>2]=34;o=-1;k=m}while(0);if(j)c[j>>2]=f+(((k<<24>>24!=0)<<31>>31)+l);if(!i)return o|0;c[i>>2]=n;return o|0}function hd(){return 33779}function id(){return 8}function jd(){return 0}function kd(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0,xa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha=0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa=0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0,db=0,eb=0,fb=0,gb=0,hb=0,ib=0,jb=0,kb=0,lb=0,mb=0,nb=0,ob=0,pb=0,qb=0,rb=0,sb=0,tb=0,ub=0,vb=0,wb=0,xb=0,yb=0,zb=0,Ab=0,Bb=0,Cb=0,Db=0,Eb=0,Fb=0,Gb=0,Hb=0,Ib=0,Jb=0,Kb=0,Lb=0,Mb=0,Nb=0,Ob=0,Pb=0,Qb=0,Rb=0,Sb=0,Tb=0,Ub=0,Vb=0,Wb=0,Xb=0,Yb=0,Zb=0,_b=0,$b=0,ac=0,bc=0,cc=0,dc=0,ec=0,fc=0,gc=0,hc=0,ic=0,jc=0,kc=0,lc=0,mc=0,nc=0,oc=0,pc=0,qc=0,rc=0,sc=0,tc=0,uc=0,vc=0,wc=0,xc=0,yc=0,zc=0,Ac=0,Bc=0,Cc=0,Dc=0,Ec=0,Fc=0,Gc=0,Hc=0,Ic=0,Jc=0,Kc=0,Lc=0,Mc=0,Nc=0,Oc=0,Pc=0,Qc=0,Rc=0,Sc=0;l=c[b>>2]|0;s=c[b+4>>2]|0;j=c[b+8>>2]|0;Rb=c[b+12>>2]|0;e=c[b+16>>2]|0;za=c[b+20>>2]|0;ya=c[b+24>>2]|0;zb=c[b+28>>2]|0;h=c[b+32>>2]|0;ga=c[b+36>>2]|0;H=c[d>>2]|0;J=c[d+4>>2]|0;F=c[d+8>>2]|0;D=c[d+12>>2]|0;A=c[d+16>>2]|0;y=c[d+20>>2]|0;w=c[d+24>>2]|0;u=c[d+28>>2]|0;k=c[d+32>>2]|0;t=c[d+36>>2]|0;Oc=J*19|0;bc=F*19|0;rb=D*19|0;Ha=A*19|0;jc=y*19|0;Db=w*19|0;Ta=u*19|0;Sc=k*19|0;Qc=t*19|0;p=s<<1;f=Rb<<1;M=za<<1;i=zb<<1;d=ga<<1;o=((l|0)<0)<<31>>31;I=((H|0)<0)<<31>>31;Mc=Od(H|0,I|0,l|0,o|0)|0;Lc=C;K=((J|0)<0)<<31>>31;wc=Od(J|0,K|0,l|0,o|0)|0;vc=C;G=((F|0)<0)<<31>>31;ub=Od(F|0,G|0,l|0,o|0)|0;tb=C;E=((D|0)<0)<<31>>31;Ka=Od(D|0,E|0,l|0,o|0)|0;Ja=C;B=((A|0)<0)<<31>>31;mc=Od(A|0,B|0,l|0,o|0)|0;lc=C;z=((y|0)<0)<<31>>31;Gb=Od(y|0,z|0,l|0,o|0)|0;Fb=C;x=((w|0)<0)<<31>>31;Wa=Od(w|0,x|0,l|0,o|0)|0;Va=C;v=((u|0)<0)<<31>>31;ja=Od(u|0,v|0,l|0,o|0)|0;ia=C;Pc=((k|0)<0)<<31>>31;P=Od(k|0,Pc|0,l|0,o|0)|0;O=C;o=Od(t|0,((t|0)<0)<<31>>31|0,l|0,o|0)|0;l=C;t=((s|0)<0)<<31>>31;dc=Od(H|0,I|0,s|0,t|0)|0;ec=C;n=((p|0)<0)<<31>>31;yb=Od(J|0,K|0,p|0,n|0)|0;xb=C;Ma=Od(F|0,G|0,s|0,t|0)|0;La=C;oc=Od(D|0,E|0,p|0,n|0)|0;nc=C;Ib=Od(A|0,B|0,s|0,t|0)|0;Hb=C;Ya=Od(y|0,z|0,p|0,n|0)|0;Xa=C;la=Od(w|0,x|0,s|0,t|0)|0;ka=C;R=Od(u|0,v|0,p|0,n|0)|0;Q=C;t=Od(k|0,Pc|0,s|0,t|0)|0;s=C;Pc=((Qc|0)<0)<<31>>31;n=Od(Qc|0,Pc|0,p|0,n|0)|0;p=C;k=((j|0)<0)<<31>>31;wb=Od(H|0,I|0,j|0,k|0)|0;vb=C;Qa=Od(J|0,K|0,j|0,k|0)|0;Pa=C;qc=Od(F|0,G|0,j|0,k|0)|0;pc=C;Kb=Od(D|0,E|0,j|0,k|0)|0;Jb=C;_a=Od(A|0,B|0,j|0,k|0)|0;Za=C;na=Od(y|0,z|0,j|0,k|0)|0;ma=C;T=Od(w|0,x|0,j|0,k|0)|0;S=C;v=Od(u|0,v|0,j|0,k|0)|0;u=C;Rc=((Sc|0)<0)<<31>>31;yc=Od(Sc|0,Rc|0,j|0,k|0)|0;xc=C;k=Od(Qc|0,Pc|0,j|0,k|0)|0;j=C;Sb=((Rb|0)<0)<<31>>31;Oa=Od(H|0,I|0,Rb|0,Sb|0)|0;Na=C;fa=((f|0)<0)<<31>>31;uc=Od(J|0,K|0,f|0,fa|0)|0;tc=C;Mb=Od(F|0,G|0,Rb|0,Sb|0)|0;Lb=C;ab=Od(D|0,E|0,f|0,fa|0)|0;$a=C;pa=Od(A|0,B|0,Rb|0,Sb|0)|0;oa=C;V=Od(y|0,z|0,f|0,fa|0)|0;U=C;x=Od(w|0,x|0,Rb|0,Sb|0)|0;w=C;Ua=((Ta|0)<0)<<31>>31;Ac=Od(Ta|0,Ua|0,f|0,fa|0)|0;zc=C;Sb=Od(Sc|0,Rc|0,Rb|0,Sb|0)|0;Rb=C;fa=Od(Qc|0,Pc|0,f|0,fa|0)|0;f=C;N=((e|0)<0)<<31>>31;sc=Od(H|0,I|0,e|0,N|0)|0;rc=C;Qb=Od(J|0,K|0,e|0,N|0)|0;Pb=C;cb=Od(F|0,G|0,e|0,N|0)|0;bb=C;ra=Od(D|0,E|0,e|0,N|0)|0;qa=C;X=Od(A|0,B|0,e|0,N|0)|0;W=C;z=Od(y|0,z|0,e|0,N|0)|0;y=C;Eb=((Db|0)<0)<<31>>31;Cc=Od(Db|0,Eb|0,e|0,N|0)|0;Bc=C;Ub=Od(Ta|0,Ua|0,e|0,N|0)|0;Tb=C;ib=Od(Sc|0,Rc|0,e|0,N|0)|0;hb=C;N=Od(Qc|0,Pc|0,e|0,N|0)|0;e=C;Aa=((za|0)<0)<<31>>31;Ob=Od(H|0,I|0,za|0,Aa|0)|0;Nb=C;b=((M|0)<0)<<31>>31;gb=Od(J|0,K|0,M|0,b|0)|0;fb=C;ta=Od(F|0,G|0,za|0,Aa|0)|0;sa=C;Z=Od(D|0,E|0,M|0,b|0)|0;Y=C;B=Od(A|0,B|0,za|0,Aa|0)|0;A=C;kc=((jc|0)<0)<<31>>31;Ec=Od(jc|0,kc|0,M|0,b|0)|0;Dc=C;Wb=Od(Db|0,Eb|0,za|0,Aa|0)|0;Vb=C;kb=Od(Ta|0,Ua|0,M|0,b|0)|0;jb=C;Aa=Od(Sc|0,Rc|0,za|0,Aa|0)|0;za=C;b=Od(Qc|0,Pc|0,M|0,b|0)|0;M=C;g=((ya|0)<0)<<31>>31;eb=Od(H|0,I|0,ya|0,g|0)|0;db=C;xa=Od(J|0,K|0,ya|0,g|0)|0;wa=C;$=Od(F|0,G|0,ya|0,g|0)|0;_=C;E=Od(D|0,E|0,ya|0,g|0)|0;D=C;Ia=((Ha|0)<0)<<31>>31;Gc=Od(Ha|0,Ia|0,ya|0,g|0)|0;Fc=C;Yb=Od(jc|0,kc|0,ya|0,g|0)|0;Xb=C;mb=Od(Db|0,Eb|0,ya|0,g|0)|0;lb=C;Ca=Od(Ta|0,Ua|0,ya|0,g|0)|0;Ba=C;m=Od(Sc|0,Rc|0,ya|0,g|0)|0;r=C;g=Od(Qc|0,Pc|0,ya|0,g|0)|0;ya=C;Ab=((zb|0)<0)<<31>>31;va=Od(H|0,I|0,zb|0,Ab|0)|0;ua=C;ea=((i|0)<0)<<31>>31;da=Od(J|0,K|0,i|0,ea|0)|0;ca=C;G=Od(F|0,G|0,zb|0,Ab|0)|0;F=C;sb=((rb|0)<0)<<31>>31;Ic=Od(rb|0,sb|0,i|0,ea|0)|0;Hc=C;_b=Od(Ha|0,Ia|0,zb|0,Ab|0)|0;Zb=C;ob=Od(jc|0,kc|0,i|0,ea|0)|0;nb=C;Ea=Od(Db|0,Eb|0,zb|0,Ab|0)|0;Da=C;gc=Od(Ta|0,Ua|0,i|0,ea|0)|0;fc=C;Ab=Od(Sc|0,Rc|0,zb|0,Ab|0)|0;zb=C;ea=Od(Qc|0,Pc|0,i|0,ea|0)|0;i=C;L=((h|0)<0)<<31>>31;ba=Od(H|0,I|0,h|0,L|0)|0;aa=C;K=Od(J|0,K|0,h|0,L|0)|0;J=C;cc=((bc|0)<0)<<31>>31;Kc=Od(bc|0,cc|0,h|0,L|0)|0;Jc=C;ac=Od(rb|0,sb|0,h|0,L|0)|0;$b=C;qb=Od(Ha|0,Ia|0,h|0,L|0)|0;pb=C;Ga=Od(jc|0,kc|0,h|0,L|0)|0;Fa=C;ic=Od(Db|0,Eb|0,h|0,L|0)|0;hc=C;Cb=Od(Ta|0,Ua|0,h|0,L|0)|0;Bb=C;Sa=Od(Sc|0,Rc|0,h|0,L|0)|0;Ra=C;L=Od(Qc|0,Pc|0,h|0,L|0)|0;h=C;ha=((ga|0)<0)<<31>>31;I=Od(H|0,I|0,ga|0,ha|0)|0;H=C;q=((d|0)<0)<<31>>31;Oc=Od(Oc|0,((Oc|0)<0)<<31>>31|0,d|0,q|0)|0;Nc=C;cc=Od(bc|0,cc|0,ga|0,ha|0)|0;bc=C;sb=Od(rb|0,sb|0,d|0,q|0)|0;rb=C;Ia=Od(Ha|0,Ia|0,ga|0,ha|0)|0;Ha=C;kc=Od(jc|0,kc|0,d|0,q|0)|0;jc=C;Eb=Od(Db|0,Eb|0,ga|0,ha|0)|0;Db=C;Ua=Od(Ta|0,Ua|0,d|0,q|0)|0;Ta=C;ha=Od(Sc|0,Rc|0,ga|0,ha|0)|0;ga=C;q=Od(Qc|0,Pc|0,d|0,q|0)|0;d=C;Lc=Dd(Oc|0,Nc|0,Mc|0,Lc|0)|0;Jc=Dd(Lc|0,C|0,Kc|0,Jc|0)|0;Hc=Dd(Jc|0,C|0,Ic|0,Hc|0)|0;Fc=Dd(Hc|0,C|0,Gc|0,Fc|0)|0;Dc=Dd(Fc|0,C|0,Ec|0,Dc|0)|0;Bc=Dd(Dc|0,C|0,Cc|0,Bc|0)|0;zc=Dd(Bc|0,C|0,Ac|0,zc|0)|0;xc=Dd(zc|0,C|0,yc|0,xc|0)|0;p=Dd(xc|0,C|0,n|0,p|0)|0;n=C;ec=Dd(wc|0,vc|0,dc|0,ec|0)|0;dc=C;rc=Dd(uc|0,tc|0,sc|0,rc|0)|0;pc=Dd(rc|0,C|0,qc|0,pc|0)|0;nc=Dd(pc|0,C|0,oc|0,nc|0)|0;lc=Dd(nc|0,C|0,mc|0,lc|0)|0;jc=Dd(lc|0,C|0,kc|0,jc|0)|0;hc=Dd(jc|0,C|0,ic|0,hc|0)|0;fc=Dd(hc|0,C|0,gc|0,fc|0)|0;r=Dd(fc|0,C|0,m|0,r|0)|0;M=Dd(r|0,C|0,b|0,M|0)|0;b=C;r=Dd(p|0,n|0,33554432,0)|0;r=Ed(r|0,C|0,26)|0;m=C;bc=Dd(ec|0,dc|0,cc|0,bc|0)|0;$b=Dd(bc|0,C|0,ac|0,$b|0)|0;Zb=Dd($b|0,C|0,_b|0,Zb|0)|0;Xb=Dd(Zb|0,C|0,Yb|0,Xb|0)|0;Vb=Dd(Xb|0,C|0,Wb|0,Vb|0)|0;Tb=Dd(Vb|0,C|0,Ub|0,Tb|0)|0;Rb=Dd(Tb|0,C|0,Sb|0,Rb|0)|0;j=Dd(Rb|0,C|0,k|0,j|0)|0;j=Dd(j|0,C|0,r|0,m|0)|0;k=C;m=Hd(r|0,m|0,26)|0;m=Cd(p|0,n|0,m|0,C|0)|0;n=C;p=Dd(M|0,b|0,33554432,0)|0;p=Ed(p|0,C|0,26)|0;r=C;Nb=Dd(Qb|0,Pb|0,Ob|0,Nb|0)|0;Lb=Dd(Nb|0,C|0,Mb|0,Lb|0)|0;Jb=Dd(Lb|0,C|0,Kb|0,Jb|0)|0;Hb=Dd(Jb|0,C|0,Ib|0,Hb|0)|0;Fb=Dd(Hb|0,C|0,Gb|0,Fb|0)|0;Db=Dd(Fb|0,C|0,Eb|0,Db|0)|0;Bb=Dd(Db|0,C|0,Cb|0,Bb|0)|0;zb=Dd(Bb|0,C|0,Ab|0,zb|0)|0;ya=Dd(zb|0,C|0,g|0,ya|0)|0;ya=Dd(ya|0,C|0,p|0,r|0)|0;g=C;r=Hd(p|0,r|0,26)|0;r=Cd(M|0,b|0,r|0,C|0)|0;b=C;M=Dd(j|0,k|0,16777216,0)|0;M=Ed(M|0,C|0,25)|0;p=C;vb=Dd(yb|0,xb|0,wb|0,vb|0)|0;tb=Dd(vb|0,C|0,ub|0,tb|0)|0;rb=Dd(tb|0,C|0,sb|0,rb|0)|0;pb=Dd(rb|0,C|0,qb|0,pb|0)|0;nb=Dd(pb|0,C|0,ob|0,nb|0)|0;lb=Dd(nb|0,C|0,mb|0,lb|0)|0;jb=Dd(lb|0,C|0,kb|0,jb|0)|0;hb=Dd(jb|0,C|0,ib|0,hb|0)|0;f=Dd(hb|0,C|0,fa|0,f|0)|0;f=Dd(f|0,C|0,M|0,p|0)|0;fa=C;p=Hd(M|0,p|0,25)|0;p=Cd(j|0,k|0,p|0,C|0)|0;k=C;j=Dd(ya|0,g|0,16777216,0)|0;j=Ed(j|0,C|0,25)|0;M=C;db=Dd(gb|0,fb|0,eb|0,db|0)|0;bb=Dd(db|0,C|0,cb|0,bb|0)|0;$a=Dd(bb|0,C|0,ab|0,$a|0)|0;Za=Dd($a|0,C|0,_a|0,Za|0)|0;Xa=Dd(Za|0,C|0,Ya|0,Xa|0)|0;Va=Dd(Xa|0,C|0,Wa|0,Va|0)|0;Ta=Dd(Va|0,C|0,Ua|0,Ta|0)|0;Ra=Dd(Ta|0,C|0,Sa|0,Ra|0)|0;i=Dd(Ra|0,C|0,ea|0,i|0)|0;i=Dd(i|0,C|0,j|0,M|0)|0;ea=C;M=Hd(j|0,M|0,25)|0;M=Cd(ya|0,g|0,M|0,C|0)|0;g=C;ya=Dd(f|0,fa|0,33554432,0)|0;ya=Ed(ya|0,C|0,26)|0;j=C;Na=Dd(Qa|0,Pa|0,Oa|0,Na|0)|0;La=Dd(Na|0,C|0,Ma|0,La|0)|0;Ja=Dd(La|0,C|0,Ka|0,Ja|0)|0;Ha=Dd(Ja|0,C|0,Ia|0,Ha|0)|0;Fa=Dd(Ha|0,C|0,Ga|0,Fa|0)|0;Da=Dd(Fa|0,C|0,Ea|0,Da|0)|0;Ba=Dd(Da|0,C|0,Ca|0,Ba|0)|0;za=Dd(Ba|0,C|0,Aa|0,za|0)|0;e=Dd(za|0,C|0,N|0,e|0)|0;e=Dd(e|0,C|0,ya|0,j|0)|0;N=C;j=Hd(ya|0,j|0,26)|0;j=Cd(f|0,fa|0,j|0,C|0)|0;fa=Dd(i|0,ea|0,33554432,0)|0;fa=Ed(fa|0,C|0,26)|0;f=C;ua=Dd(xa|0,wa|0,va|0,ua|0)|0;sa=Dd(ua|0,C|0,ta|0,sa|0)|0;qa=Dd(sa|0,C|0,ra|0,qa|0)|0;oa=Dd(qa|0,C|0,pa|0,oa|0)|0;ma=Dd(oa|0,C|0,na|0,ma|0)|0;ka=Dd(ma|0,C|0,la|0,ka|0)|0;ia=Dd(ka|0,C|0,ja|0,ia|0)|0;ga=Dd(ia|0,C|0,ha|0,ga|0)|0;h=Dd(ga|0,C|0,L|0,h|0)|0;h=Dd(h|0,C|0,fa|0,f|0)|0;L=C;f=Hd(fa|0,f|0,26)|0;f=Cd(i|0,ea|0,f|0,C|0)|0;ea=Dd(e|0,N|0,16777216,0)|0;ea=Ed(ea|0,C|0,25)|0;i=C;b=Dd(ea|0,i|0,r|0,b|0)|0;r=C;i=Hd(ea|0,i|0,25)|0;i=Cd(e|0,N|0,i|0,C|0)|0;N=Dd(h|0,L|0,16777216,0)|0;N=Ed(N|0,C|0,25)|0;e=C;aa=Dd(da|0,ca|0,ba|0,aa|0)|0;_=Dd(aa|0,C|0,$|0,_|0)|0;Y=Dd(_|0,C|0,Z|0,Y|0)|0;W=Dd(Y|0,C|0,X|0,W|0)|0;U=Dd(W|0,C|0,V|0,U|0)|0;S=Dd(U|0,C|0,T|0,S|0)|0;Q=Dd(S|0,C|0,R|0,Q|0)|0;O=Dd(Q|0,C|0,P|0,O|0)|0;d=Dd(O|0,C|0,q|0,d|0)|0;d=Dd(d|0,C|0,N|0,e|0)|0;q=C;e=Hd(N|0,e|0,25)|0;e=Cd(h|0,L|0,e|0,C|0)|0;L=Dd(b|0,r|0,33554432,0)|0;L=Ed(L|0,C|0,26)|0;h=C;g=Dd(M|0,g|0,L|0,h|0)|0;h=Hd(L|0,h|0,26)|0;h=Cd(b|0,r|0,h|0,C|0)|0;r=Dd(d|0,q|0,33554432,0)|0;r=Ed(r|0,C|0,26)|0;b=C;H=Dd(K|0,J|0,I|0,H|0)|0;F=Dd(H|0,C|0,G|0,F|0)|0;D=Dd(F|0,C|0,E|0,D|0)|0;A=Dd(D|0,C|0,B|0,A|0)|0;y=Dd(A|0,C|0,z|0,y|0)|0;w=Dd(y|0,C|0,x|0,w|0)|0;u=Dd(w|0,C|0,v|0,u|0)|0;s=Dd(u|0,C|0,t|0,s|0)|0;l=Dd(s|0,C|0,o|0,l|0)|0;l=Dd(l|0,C|0,r|0,b|0)|0;o=C;b=Hd(r|0,b|0,26)|0;b=Cd(d|0,q|0,b|0,C|0)|0;q=Dd(l|0,o|0,16777216,0)|0;q=Ed(q|0,C|0,25)|0;d=C;r=Od(q|0,d|0,19,0)|0;n=Dd(r|0,C|0,m|0,n|0)|0;m=C;d=Hd(q|0,d|0,25)|0;d=Cd(l|0,o|0,d|0,C|0)|0;o=Dd(n|0,m|0,33554432,0)|0;o=Ed(o|0,C|0,26)|0;l=C;k=Dd(p|0,k|0,o|0,l|0)|0;l=Hd(o|0,l|0,26)|0;l=Cd(n|0,m|0,l|0,C|0)|0;c[a>>2]=l;c[a+4>>2]=k;c[a+8>>2]=j;c[a+12>>2]=i;c[a+16>>2]=h;c[a+20>>2]=g;c[a+24>>2]=f;c[a+28>>2]=e;c[a+32>>2]=b;c[a+36>>2]=d;return}function ld(a,b){a=a|0;b=b|0;var d=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0,xa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha=0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa=0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0,db=0,eb=0,fb=0,gb=0;bb=c[b>>2]|0;ua=c[b+4>>2]|0;j=c[b+8>>2]|0;la=c[b+12>>2]|0;e=c[b+16>>2]|0;db=c[b+20>>2]|0;Y=c[b+24>>2]|0;La=c[b+28>>2]|0;h=c[b+32>>2]|0;b=c[b+36>>2]|0;l=bb<<1;p=ua<<1;Xa=j<<1;f=la<<1;na=e<<1;B=db<<1;m=Y<<1;i=La<<1;Ka=db*38|0;ra=Y*19|0;va=La*38|0;da=h*19|0;gb=b*38|0;cb=((bb|0)<0)<<31>>31;cb=Od(bb|0,cb|0,bb|0,cb|0)|0;bb=C;o=((l|0)<0)<<31>>31;ta=((ua|0)<0)<<31>>31;Ia=Od(l|0,o|0,ua|0,ta|0)|0;Ha=C;k=((j|0)<0)<<31>>31;Wa=Od(j|0,k|0,l|0,o|0)|0;Va=C;ma=((la|0)<0)<<31>>31;Ua=Od(la|0,ma|0,l|0,o|0)|0;Ta=C;D=((e|0)<0)<<31>>31;Oa=Od(e|0,D|0,l|0,o|0)|0;Na=C;eb=((db|0)<0)<<31>>31;ya=Od(db|0,eb|0,l|0,o|0)|0;xa=C;g=((Y|0)<0)<<31>>31;ga=Od(Y|0,g|0,l|0,o|0)|0;fa=C;Ma=((La|0)<0)<<31>>31;R=Od(La|0,Ma|0,l|0,o|0)|0;Q=C;A=((h|0)<0)<<31>>31;F=Od(h|0,A|0,l|0,o|0)|0;E=C;q=((b|0)<0)<<31>>31;o=Od(b|0,q|0,l|0,o|0)|0;l=C;n=((p|0)<0)<<31>>31;ta=Od(p|0,n|0,ua|0,ta|0)|0;ua=C;ba=Od(p|0,n|0,j|0,k|0)|0;ca=C;P=((f|0)<0)<<31>>31;Sa=Od(f|0,P|0,p|0,n|0)|0;Ra=C;Ca=Od(e|0,D|0,p|0,n|0)|0;Ba=C;d=((B|0)<0)<<31>>31;ia=Od(B|0,d|0,p|0,n|0)|0;ha=C;T=Od(Y|0,g|0,p|0,n|0)|0;S=C;O=((i|0)<0)<<31>>31;H=Od(i|0,O|0,p|0,n|0)|0;G=C;t=Od(h|0,A|0,p|0,n|0)|0;s=C;fb=((gb|0)<0)<<31>>31;n=Od(gb|0,fb|0,p|0,n|0)|0;p=C;Qa=Od(j|0,k|0,j|0,k|0)|0;Pa=C;Ya=((Xa|0)<0)<<31>>31;Aa=Od(Xa|0,Ya|0,la|0,ma|0)|0;za=C;ka=Od(e|0,D|0,Xa|0,Ya|0)|0;ja=C;X=Od(db|0,eb|0,Xa|0,Ya|0)|0;W=C;N=Od(Y|0,g|0,Xa|0,Ya|0)|0;M=C;v=Od(La|0,Ma|0,Xa|0,Ya|0)|0;u=C;ea=((da|0)<0)<<31>>31;Ya=Od(da|0,ea|0,Xa|0,Ya|0)|0;Xa=C;k=Od(gb|0,fb|0,j|0,k|0)|0;j=C;ma=Od(f|0,P|0,la|0,ma|0)|0;la=C;V=Od(f|0,P|0,e|0,D|0)|0;U=C;J=Od(B|0,d|0,f|0,P|0)|0;I=C;z=Od(Y|0,g|0,f|0,P|0)|0;y=C;wa=((va|0)<0)<<31>>31;_a=Od(va|0,wa|0,f|0,P|0)|0;Za=C;Ea=Od(da|0,ea|0,f|0,P|0)|0;Da=C;P=Od(gb|0,fb|0,f|0,P|0)|0;f=C;L=Od(e|0,D|0,e|0,D|0)|0;K=C;oa=((na|0)<0)<<31>>31;x=Od(na|0,oa|0,db|0,eb|0)|0;w=C;sa=((ra|0)<0)<<31>>31;ab=Od(ra|0,sa|0,na|0,oa|0)|0;$a=C;Ga=Od(va|0,wa|0,e|0,D|0)|0;Fa=C;oa=Od(da|0,ea|0,na|0,oa|0)|0;na=C;D=Od(gb|0,fb|0,e|0,D|0)|0;e=C;eb=Od(Ka|0,((Ka|0)<0)<<31>>31|0,db|0,eb|0)|0;db=C;Ka=Od(ra|0,sa|0,B|0,d|0)|0;Ja=C;qa=Od(va|0,wa|0,B|0,d|0)|0;pa=C;_=Od(da|0,ea|0,B|0,d|0)|0;Z=C;d=Od(gb|0,fb|0,B|0,d|0)|0;B=C;sa=Od(ra|0,sa|0,Y|0,g|0)|0;ra=C;aa=Od(va|0,wa|0,Y|0,g|0)|0;$=C;m=Od(da|0,ea|0,m|0,((m|0)<0)<<31>>31|0)|0;r=C;g=Od(gb|0,fb|0,Y|0,g|0)|0;Y=C;Ma=Od(va|0,wa|0,La|0,Ma|0)|0;La=C;wa=Od(da|0,ea|0,i|0,O|0)|0;va=C;O=Od(gb|0,fb|0,i|0,O|0)|0;i=C;ea=Od(da|0,ea|0,h|0,A|0)|0;da=C;A=Od(gb|0,fb|0,h|0,A|0)|0;h=C;q=Od(gb|0,fb|0,b|0,q|0)|0;b=C;bb=Dd(eb|0,db|0,cb|0,bb|0)|0;$a=Dd(bb|0,C|0,ab|0,$a|0)|0;Za=Dd($a|0,C|0,_a|0,Za|0)|0;Xa=Dd(Za|0,C|0,Ya|0,Xa|0)|0;p=Dd(Xa|0,C|0,n|0,p|0)|0;n=C;ua=Dd(Wa|0,Va|0,ta|0,ua|0)|0;ta=C;ca=Dd(Ua|0,Ta|0,ba|0,ca|0)|0;ba=C;Pa=Dd(Sa|0,Ra|0,Qa|0,Pa|0)|0;Na=Dd(Pa|0,C|0,Oa|0,Na|0)|0;La=Dd(Na|0,C|0,Ma|0,La|0)|0;r=Dd(La|0,C|0,m|0,r|0)|0;B=Dd(r|0,C|0,d|0,B|0)|0;d=C;r=Dd(p|0,n|0,33554432,0)|0;r=Ed(r|0,C|0,26)|0;m=C;Ha=Dd(Ka|0,Ja|0,Ia|0,Ha|0)|0;Fa=Dd(Ha|0,C|0,Ga|0,Fa|0)|0;Da=Dd(Fa|0,C|0,Ea|0,Da|0)|0;j=Dd(Da|0,C|0,k|0,j|0)|0;j=Dd(j|0,C|0,r|0,m|0)|0;k=C;m=Hd(r|0,m|0,26)|0;m=Cd(p|0,n|0,m|0,C|0)|0;n=C;p=Dd(B|0,d|0,33554432,0)|0;p=Ed(p|0,C|0,26)|0;r=C;za=Dd(Ca|0,Ba|0,Aa|0,za|0)|0;xa=Dd(za|0,C|0,ya|0,xa|0)|0;va=Dd(xa|0,C|0,wa|0,va|0)|0;Y=Dd(va|0,C|0,g|0,Y|0)|0;Y=Dd(Y|0,C|0,p|0,r|0)|0;g=C;r=Hd(p|0,r|0,26)|0;r=Cd(B|0,d|0,r|0,C|0)|0;d=C;B=Dd(j|0,k|0,16777216,0)|0;B=Ed(B|0,C|0,25)|0;p=C;ra=Dd(ua|0,ta|0,sa|0,ra|0)|0;pa=Dd(ra|0,C|0,qa|0,pa|0)|0;na=Dd(pa|0,C|0,oa|0,na|0)|0;f=Dd(na|0,C|0,P|0,f|0)|0;f=Dd(f|0,C|0,B|0,p|0)|0;P=C;p=Hd(B|0,p|0,25)|0;p=Cd(j|0,k|0,p|0,C|0)|0;k=C;j=Dd(Y|0,g|0,16777216,0)|0;j=Ed(j|0,C|0,25)|0;B=C;ja=Dd(ma|0,la|0,ka|0,ja|0)|0;ha=Dd(ja|0,C|0,ia|0,ha|0)|0;fa=Dd(ha|0,C|0,ga|0,fa|0)|0;da=Dd(fa|0,C|0,ea|0,da|0)|0;i=Dd(da|0,C|0,O|0,i|0)|0;i=Dd(i|0,C|0,j|0,B|0)|0;O=C;B=Hd(j|0,B|0,25)|0;B=Cd(Y|0,g|0,B|0,C|0)|0;g=C;Y=Dd(f|0,P|0,33554432,0)|0;Y=Ed(Y|0,C|0,26)|0;j=C;$=Dd(ca|0,ba|0,aa|0,$|0)|0;Z=Dd($|0,C|0,_|0,Z|0)|0;e=Dd(Z|0,C|0,D|0,e|0)|0;e=Dd(e|0,C|0,Y|0,j|0)|0;D=C;j=Hd(Y|0,j|0,26)|0;j=Cd(f|0,P|0,j|0,C|0)|0;P=Dd(i|0,O|0,33554432,0)|0;P=Ed(P|0,C|0,26)|0;f=C;U=Dd(X|0,W|0,V|0,U|0)|0;S=Dd(U|0,C|0,T|0,S|0)|0;Q=Dd(S|0,C|0,R|0,Q|0)|0;h=Dd(Q|0,C|0,A|0,h|0)|0;h=Dd(h|0,C|0,P|0,f|0)|0;A=C;f=Hd(P|0,f|0,26)|0;f=Cd(i|0,O|0,f|0,C|0)|0;O=Dd(e|0,D|0,16777216,0)|0;O=Ed(O|0,C|0,25)|0;i=C;d=Dd(O|0,i|0,r|0,d|0)|0;r=C;i=Hd(O|0,i|0,25)|0;i=Cd(e|0,D|0,i|0,C|0)|0;D=Dd(h|0,A|0,16777216,0)|0;D=Ed(D|0,C|0,25)|0;e=C;K=Dd(N|0,M|0,L|0,K|0)|0;I=Dd(K|0,C|0,J|0,I|0)|0;G=Dd(I|0,C|0,H|0,G|0)|0;E=Dd(G|0,C|0,F|0,E|0)|0;b=Dd(E|0,C|0,q|0,b|0)|0;b=Dd(b|0,C|0,D|0,e|0)|0;q=C;e=Hd(D|0,e|0,25)|0;e=Cd(h|0,A|0,e|0,C|0)|0;A=Dd(d|0,r|0,33554432,0)|0;A=Ed(A|0,C|0,26)|0;h=C;g=Dd(B|0,g|0,A|0,h|0)|0;h=Hd(A|0,h|0,26)|0;h=Cd(d|0,r|0,h|0,C|0)|0;r=Dd(b|0,q|0,33554432,0)|0;r=Ed(r|0,C|0,26)|0;d=C;w=Dd(z|0,y|0,x|0,w|0)|0;u=Dd(w|0,C|0,v|0,u|0)|0;s=Dd(u|0,C|0,t|0,s|0)|0;l=Dd(s|0,C|0,o|0,l|0)|0;l=Dd(l|0,C|0,r|0,d|0)|0;o=C;d=Hd(r|0,d|0,26)|0;d=Cd(b|0,q|0,d|0,C|0)|0;q=Dd(l|0,o|0,16777216,0)|0;q=Ed(q|0,C|0,25)|0;b=C;r=Od(q|0,b|0,19,0)|0;n=Dd(r|0,C|0,m|0,n|0)|0;m=C;b=Hd(q|0,b|0,25)|0;b=Cd(l|0,o|0,b|0,C|0)|0;o=Dd(n|0,m|0,33554432,0)|0;o=Ed(o|0,C|0,26)|0;l=C;k=Dd(p|0,k|0,o|0,l|0)|0;l=Hd(o|0,l|0,26)|0;l=Cd(n|0,m|0,l|0,C|0)|0;c[a>>2]=l;c[a+4>>2]=k;c[a+8>>2]=j;c[a+12>>2]=i;c[a+16>>2]=h;c[a+20>>2]=g;c[a+24>>2]=f;c[a+28>>2]=e;c[a+32>>2]=d;c[a+36>>2]=b;return}function md(b,e,f){b=b|0;e=e|0;f=f|0;var g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0,xa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha=0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa=0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0,db=0,eb=0,fb=0,gb=0,hb=0,ib=0,jb=0,kb=0,lb=0,mb=0,nb=0;Ya=i;Oa=i=i+63&-64;i=i+480|0;Ta=Oa+400|0;Ua=Oa+360|0;Va=Oa+320|0;Sa=Oa+280|0;Ma=Oa+440|0;Pa=Oa+240|0;Wa=Oa+200|0;Xa=Oa+160|0;Qa=Oa+120|0;Ra=Oa+80|0;Na=Oa+40|0;h=Ma;g=h+32|0;do{a[h>>0]=a[e>>0]|0;h=h+1|0;e=e+1|0}while((h|0)<(g|0));a[Ma>>0]=(d[Ma>>0]|0)&248;m=Ma+31|0;a[m>>0]=(d[m>>0]|0)&63|64;m=d[f>>0]|0;Da=Hd(d[f+1>>0]|0|0,0,8)|0;j=C;va=Hd(d[f+2>>0]|0|0,0,16)|0;j=j|C;Aa=Hd(d[f+3>>0]|0|0,0,24)|0;j=j|C;k=a[f+6>>0]|0;l=d[f+4>>0]|0;ya=Hd(d[f+5>>0]|0|0,0,8)|0;za=C;k=Hd(k&255|0,0,16)|0;za=Hd(ya|l|k|0,za|C|0,6)|0;k=C;l=a[f+9>>0]|0;ya=d[f+7>>0]|0;n=Hd(d[f+8>>0]|0|0,0,8)|0;Ea=C;l=Hd(l&255|0,0,16)|0;Ea=Hd(n|ya|l|0,Ea|C|0,5)|0;l=C;ya=a[f+12>>0]|0;n=d[f+10>>0]|0;Ga=Hd(d[f+11>>0]|0|0,0,8)|0;xa=C;ya=Hd(ya&255|0,0,16)|0;xa=Hd(Ga|n|ya|0,xa|C|0,3)|0;ya=C;n=a[f+15>>0]|0;Ga=d[f+13>>0]|0;h=Hd(d[f+14>>0]|0|0,0,8)|0;Ia=C;n=Hd(n&255|0,0,16)|0;Ia=Hd(h|Ga|n|0,Ia|C|0,2)|0;n=C;Ga=d[f+16>>0]|0;h=Hd(d[f+17>>0]|0|0,0,8)|0;Ca=C;p=Hd(d[f+18>>0]|0|0,0,16)|0;Ca=Ca|C;Ba=Hd(d[f+19>>0]|0|0,0,24)|0;Ba=h|Ga|p|Ba;Ca=Ca|C;p=a[f+22>>0]|0;Ga=d[f+20>>0]|0;h=Hd(d[f+21>>0]|0|0,0,8)|0;g=C;p=Hd(p&255|0,0,16)|0;g=Hd(h|Ga|p|0,g|C|0,7)|0;p=C;Ga=a[f+25>>0]|0;h=d[f+23>>0]|0;q=Hd(d[f+24>>0]|0|0,0,8)|0;Fa=C;Ga=Hd(Ga&255|0,0,16)|0;Fa=Hd(q|h|Ga|0,Fa|C|0,5)|0;Ga=C;h=a[f+28>>0]|0;q=d[f+26>>0]|0;Ka=Hd(d[f+27>>0]|0|0,0,8)|0;La=C;h=Hd(h&255|0,0,16)|0;La=Hd(Ka|q|h|0,La|C|0,4)|0;h=C;q=a[f+31>>0]|0;Ka=d[f+29>>0]|0;f=Hd(d[f+30>>0]|0|0,0,8)|0;Ja=C;q=Hd(q&255|0,0,16)|0;Ja=Hd(f|Ka|q|0,Ja|C|0,2)|0;Ja=Ja&33554428;q=Dd(Ja|0,0,16777216,0)|0;q=Gd(q|0,C|0,25)|0;Ka=C;f=Cd(0,0,q|0,Ka|0)|0;j=Dd(f&19|0,0,Da|m|va|Aa|0,j|0)|0;Aa=C;Ka=Hd(q|0,Ka|0,25)|0;q=C;f=Dd(za|0,k|0,16777216,0)|0;f=Gd(f|0,C|0,25)|0;va=C;l=Dd(Ea|0,l|0,f|0,va|0)|0;Ea=C;va=Hd(f|0,va|0,25)|0;va=Cd(za|0,k|0,va|0,C|0)|0;f=C;k=Dd(xa|0,ya|0,16777216,0)|0;k=Gd(k|0,C|0,25)|0;za=C;n=Dd(Ia|0,n|0,k|0,za|0)|0;Ia=C;za=Hd(k|0,za|0,25)|0;k=C;m=Dd(Ba|0,Ca|0,16777216,0)|0;m=Gd(m|0,C|0,25)|0;Da=C;p=Dd(g|0,p|0,m|0,Da|0)|0;g=C;Da=Hd(m|0,Da|0,25)|0;m=C;o=Dd(Fa|0,Ga|0,16777216,0)|0;o=Gd(o|0,C|0,25)|0;Ha=C;h=Dd(La|0,h|0,o|0,Ha|0)|0;La=C;Ha=Hd(o|0,Ha|0,25)|0;o=C;wa=Dd(j|0,Aa|0,33554432,0)|0;wa=Ed(wa|0,C|0,26)|0;e=C;f=Dd(va|0,f|0,wa|0,e|0)|0;e=Hd(wa|0,e|0,26)|0;e=Cd(j|0,Aa|0,e|0,C|0)|0;Aa=Dd(l|0,Ea|0,33554432,0)|0;Aa=Ed(Aa|0,C|0,26)|0;j=C;ya=Dd(Aa|0,j|0,xa|0,ya|0)|0;k=Cd(ya|0,C|0,za|0,k|0)|0;j=Hd(Aa|0,j|0,26)|0;j=Cd(l|0,Ea|0,j|0,C|0)|0;Ea=Dd(n|0,Ia|0,33554432,0)|0;Ea=Ed(Ea|0,C|0,26)|0;l=C;Ca=Dd(Ea|0,l|0,Ba|0,Ca|0)|0;m=Cd(Ca|0,C|0,Da|0,m|0)|0;l=Hd(Ea|0,l|0,26)|0;l=Cd(n|0,Ia|0,l|0,C|0)|0;Ia=Dd(p|0,g|0,33554432,0)|0;Ia=Ed(Ia|0,C|0,26)|0;n=C;Ga=Dd(Ia|0,n|0,Fa|0,Ga|0)|0;o=Cd(Ga|0,C|0,Ha|0,o|0)|0;n=Hd(Ia|0,n|0,26)|0;n=Cd(p|0,g|0,n|0,C|0)|0;g=Dd(h|0,La|0,33554432,0)|0;g=Ed(g|0,C|0,26)|0;p=C;Ja=Dd(Ja|0,0,g|0,p|0)|0;q=Cd(Ja|0,C|0,Ka|0,q|0)|0;p=Hd(g|0,p|0,26)|0;p=Cd(h|0,La|0,p|0,C|0)|0;c[Pa>>2]=e;c[Pa+4>>2]=f;c[Pa+8>>2]=j;c[Pa+12>>2]=k;c[Pa+16>>2]=l;c[Pa+20>>2]=m;c[Pa+24>>2]=n;c[Pa+28>>2]=o;c[Pa+32>>2]=p;c[Pa+36>>2]=q;c[Wa>>2]=1;La=Wa+4|0;h=La;g=h+36|0;do{c[h>>2]=0;h=h+4|0}while((h|0)<(g|0));h=Xa;g=h+40|0;do{c[h>>2]=0;h=h+4|0}while((h|0)<(g|0));c[Qa>>2]=e;ta=Qa+4|0;c[ta>>2]=f;ua=Qa+8|0;c[ua>>2]=j;va=Qa+12|0;c[va>>2]=k;wa=Qa+16|0;c[wa>>2]=l;xa=Qa+20|0;c[xa>>2]=m;ya=Qa+24|0;c[ya>>2]=n;za=Qa+28|0;c[za>>2]=o;Aa=Qa+32|0;c[Aa>>2]=p;Ba=Qa+36|0;c[Ba>>2]=q;c[Ra>>2]=1;Ca=Ra+4|0;h=Ca;g=h+36|0;do{c[h>>2]=0;h=h+4|0}while((h|0)<(g|0));Da=Wa+8|0;Ea=Wa+12|0;Fa=Wa+16|0;Ga=Wa+20|0;Ha=Wa+24|0;Ia=Wa+28|0;Ja=Wa+32|0;Ka=Wa+36|0;M=Xa+4|0;N=Xa+8|0;O=Xa+12|0;P=Xa+16|0;Q=Xa+20|0;R=Xa+24|0;S=Xa+28|0;T=Xa+32|0;U=Xa+36|0;V=Ra+8|0;W=Ra+12|0;X=Ra+16|0;Y=Ra+20|0;Z=Ra+24|0;_=Ra+28|0;$=Ra+32|0;aa=Ra+36|0;ba=Na+4|0;ca=Na+8|0;da=Na+12|0;ea=Na+16|0;fa=Na+20|0;ga=Na+24|0;ha=Na+28|0;ia=Na+32|0;ja=Na+36|0;ka=Oa+4|0;la=Oa+8|0;ma=Oa+12|0;na=Oa+16|0;oa=Oa+20|0;pa=Oa+24|0;qa=Oa+28|0;ra=Oa+32|0;sa=Oa+36|0;L=1;K=0;J=0;I=0;H=0;G=0;F=0;E=0;D=0;h=0;r=0;s=0;t=0;u=0;v=0;w=0;x=0;y=0;z=0;A=254;B=0;while(1){g=(d[Ma+((A|0)/8|0)>>0]|0)>>>(A&7)&1;nb=0-(g^B)|0;bb=(e^L)&nb;ab=(f^K)&nb;$a=(j^J)&nb;_a=(k^I)&nb;Za=(l^H)&nb;kb=(m^G)&nb;mb=(n^F)&nb;B=(o^E)&nb;jb=(p^D)&nb;lb=(q^h)&nb;c[Wa>>2]=bb^L;c[La>>2]=ab^K;c[Da>>2]=$a^J;c[Ea>>2]=_a^I;c[Fa>>2]=Za^H;c[Ga>>2]=kb^G;c[Ha>>2]=mb^F;c[Ia>>2]=B^E;c[Ja>>2]=jb^D;c[Ka>>2]=lb^h;bb=bb^e;c[Qa>>2]=bb;ab=ab^f;c[ta>>2]=ab;$a=$a^j;c[ua>>2]=$a;_a=_a^k;c[va>>2]=_a;Za=Za^l;c[wa>>2]=Za;I=kb^m;c[xa>>2]=I;E=mb^n;c[ya>>2]=E;l=B^o;c[za>>2]=l;j=jb^p;c[Aa>>2]=j;f=lb^q;c[Ba>>2]=f;K=c[U>>2]|0;lb=c[Ra>>2]|0;jb=c[Ca>>2]|0;B=c[V>>2]|0;p=c[W>>2]|0;q=c[X>>2]|0;D=c[Y>>2]|0;F=c[Z>>2]|0;H=c[_>>2]|0;J=c[$>>2]|0;L=c[aa>>2]|0;mb=(lb^r)&nb;kb=(jb^s)&nb;ib=(B^t)&nb;hb=(p^u)&nb;gb=(q^v)&nb;fb=(D^w)&nb;eb=(F^x)&nb;db=(H^y)&nb;cb=(J^z)&nb;o=(L^K)&nb;e=mb^r;c[Xa>>2]=e;h=kb^s;c[M>>2]=h;k=ib^t;c[N>>2]=k;m=hb^u;c[O>>2]=m;n=gb^v;c[P>>2]=n;r=fb^w;c[Q>>2]=r;v=eb^x;c[R>>2]=v;x=db^y;c[S>>2]=x;G=cb^z;c[T>>2]=G;K=o^K;c[U>>2]=K;s=mb^lb;c[Ra>>2]=s;u=kb^jb;c[Ca>>2]=u;B=ib^B;c[V>>2]=B;p=hb^p;c[W>>2]=p;q=gb^q;c[X>>2]=q;D=fb^D;c[Y>>2]=D;F=eb^F;c[Z>>2]=F;H=db^H;c[_>>2]=H;J=cb^J;c[$>>2]=J;L=o^L;c[aa>>2]=L;c[Na>>2]=bb-s;c[ba>>2]=ab-u;c[ca>>2]=$a-B;c[da>>2]=_a-p;c[ea>>2]=Za-q;c[fa>>2]=I-D;c[ga>>2]=E-F;c[ha>>2]=l-H;c[ia>>2]=j-J;c[ja>>2]=f-L;f=c[Wa>>2]|0;j=c[La>>2]|0;l=c[Da>>2]|0;w=c[Ea>>2]|0;o=c[Fa>>2]|0;t=c[Ga>>2]|0;z=c[Ha>>2]|0;E=c[Ia>>2]|0;I=c[Ja>>2]|0;y=c[Ka>>2]|0;c[Oa>>2]=f-e;c[ka>>2]=j-h;c[la>>2]=l-k;c[ma>>2]=w-m;c[na>>2]=o-n;c[oa>>2]=t-r;c[pa>>2]=z-v;c[qa>>2]=E-x;c[ra>>2]=I-G;c[sa>>2]=y-K;c[Wa>>2]=e+f;c[La>>2]=h+j;c[Da>>2]=k+l;c[Ea>>2]=m+w;c[Fa>>2]=n+o;c[Ga>>2]=r+t;c[Ha>>2]=v+z;c[Ia>>2]=x+E;c[Ja>>2]=G+I;c[Ka>>2]=K+y;u=u+(c[ta>>2]|0)|0;B=B+(c[ua>>2]|0)|0;p=p+(c[va>>2]|0)|0;q=q+(c[wa>>2]|0)|0;D=D+(c[xa>>2]|0)|0;F=F+(c[ya>>2]|0)|0;H=H+(c[za>>2]|0)|0;J=J+(c[Aa>>2]|0)|0;L=L+(c[Ba>>2]|0)|0;c[Xa>>2]=s+(c[Qa>>2]|0);c[M>>2]=u;c[N>>2]=B;c[O>>2]=p;c[P>>2]=q;c[Q>>2]=D;c[R>>2]=F;c[S>>2]=H;c[T>>2]=J;c[U>>2]=L;kd(Ra,Na,Wa);kd(Xa,Xa,Oa);ld(Na,Oa);ld(Oa,Wa);L=c[Ra>>2]|0;J=c[Ca>>2]|0;H=c[V>>2]|0;F=c[W>>2]|0;D=c[X>>2]|0;q=c[Y>>2]|0;p=c[Z>>2]|0;B=c[_>>2]|0;u=c[$>>2]|0;s=c[aa>>2]|0;y=c[Xa>>2]|0;K=c[M>>2]|0;I=c[N>>2]|0;G=c[O>>2]|0;E=c[P>>2]|0;z=c[Q>>2]|0;x=c[R>>2]|0;v=c[S>>2]|0;t=c[T>>2]|0;r=c[U>>2]|0;c[Qa>>2]=y+L;c[ta>>2]=K+J;c[ua>>2]=I+H;c[va>>2]=G+F;c[wa>>2]=E+D;c[xa>>2]=z+q;c[ya>>2]=x+p;c[za>>2]=v+B;c[Aa>>2]=t+u;c[Ba>>2]=r+s;c[Xa>>2]=L-y;c[M>>2]=J-K;c[N>>2]=H-I;c[O>>2]=F-G;c[P>>2]=D-E;c[Q>>2]=q-z;c[R>>2]=p-x;c[S>>2]=B-v;c[T>>2]=u-t;c[U>>2]=s-r;kd(Wa,Oa,Na);r=(c[Oa>>2]|0)-(c[Na>>2]|0)|0;s=(c[ka>>2]|0)-(c[ba>>2]|0)|0;t=(c[la>>2]|0)-(c[ca>>2]|0)|0;u=(c[ma>>2]|0)-(c[da>>2]|0)|0;v=(c[na>>2]|0)-(c[ea>>2]|0)|0;B=(c[oa>>2]|0)-(c[fa>>2]|0)|0;x=(c[pa>>2]|0)-(c[ga>>2]|0)|0;p=(c[qa>>2]|0)-(c[ha>>2]|0)|0;z=(c[ra>>2]|0)-(c[ia>>2]|0)|0;q=(c[sa>>2]|0)-(c[ja>>2]|0)|0;c[Oa>>2]=r;c[ka>>2]=s;c[la>>2]=t;c[ma>>2]=u;c[na>>2]=v;c[oa>>2]=B;c[pa>>2]=x;c[qa>>2]=p;c[ra>>2]=z;c[sa>>2]=q;ld(Xa,Xa);r=Od(r|0,((r|0)<0)<<31>>31|0,121666,0)|0;E=C;s=Od(s|0,((s|0)<0)<<31>>31|0,121666,0)|0;D=C;t=Od(t|0,((t|0)<0)<<31>>31|0,121666,0)|0;G=C;u=Od(u|0,((u|0)<0)<<31>>31|0,121666,0)|0;F=C;v=Od(v|0,((v|0)<0)<<31>>31|0,121666,0)|0;I=C;B=Od(B|0,((B|0)<0)<<31>>31|0,121666,0)|0;H=C;x=Od(x|0,((x|0)<0)<<31>>31|0,121666,0)|0;K=C;p=Od(p|0,((p|0)<0)<<31>>31|0,121666,0)|0;J=C;z=Od(z|0,((z|0)<0)<<31>>31|0,121666,0)|0;y=C;q=Od(q|0,((q|0)<0)<<31>>31|0,121666,0)|0;L=C;o=Dd(q|0,L|0,16777216,0)|0;o=Ed(o|0,C|0,25)|0;w=C;n=Od(o|0,w|0,19,0)|0;E=Dd(n|0,C|0,r|0,E|0)|0;r=C;w=Hd(o|0,w|0,25)|0;w=Cd(q|0,L|0,w|0,C|0)|0;L=C;q=Dd(s|0,D|0,16777216,0)|0;q=Ed(q|0,C|0,25)|0;o=C;G=Dd(q|0,o|0,t|0,G|0)|0;t=C;o=Hd(q|0,o|0,25)|0;o=Cd(s|0,D|0,o|0,C|0)|0;D=C;s=Dd(u|0,F|0,16777216,0)|0;s=Ed(s|0,C|0,25)|0;q=C;I=Dd(s|0,q|0,v|0,I|0)|0;v=C;q=Hd(s|0,q|0,25)|0;q=Cd(u|0,F|0,q|0,C|0)|0;F=C;u=Dd(B|0,H|0,16777216,0)|0;u=Ed(u|0,C|0,25)|0;s=C;K=Dd(u|0,s|0,x|0,K|0)|0;x=C;s=Hd(u|0,s|0,25)|0;s=Cd(B|0,H|0,s|0,C|0)|0;H=C;B=Dd(p|0,J|0,16777216,0)|0;B=Ed(B|0,C|0,25)|0;u=C;y=Dd(B|0,u|0,z|0,y|0)|0;z=C;u=Hd(B|0,u|0,25)|0;u=Cd(p|0,J|0,u|0,C|0)|0;J=C;p=Dd(E|0,r|0,33554432,0)|0;p=Ed(p|0,C|0,26)|0;B=C;D=Dd(o|0,D|0,p|0,B|0)|0;B=Hd(p|0,B|0,26)|0;B=Cd(E|0,r|0,B|0,C|0)|0;r=Dd(G|0,t|0,33554432,0)|0;r=Ed(r|0,C|0,26)|0;E=C;F=Dd(q|0,F|0,r|0,E|0)|0;E=Hd(r|0,E|0,26)|0;E=Cd(G|0,t|0,E|0,C|0)|0;t=Dd(I|0,v|0,33554432,0)|0;t=Ed(t|0,C|0,26)|0;G=C;H=Dd(s|0,H|0,t|0,G|0)|0;G=Hd(t|0,G|0,26)|0;G=Cd(I|0,v|0,G|0,C|0)|0;v=Dd(K|0,x|0,33554432,0)|0;v=Ed(v|0,C|0,26)|0;I=C;J=Dd(u|0,J|0,v|0,I|0)|0;I=Hd(v|0,I|0,26)|0;I=Cd(K|0,x|0,I|0,C|0)|0;x=Dd(y|0,z|0,33554432,0)|0;x=Ed(x|0,C|0,26)|0;K=C;L=Dd(w|0,L|0,x|0,K|0)|0;K=Hd(x|0,K|0,26)|0;K=Cd(y|0,z|0,K|0,C|0)|0;c[Ra>>2]=B;c[Ca>>2]=D;c[V>>2]=E;c[W>>2]=F;c[X>>2]=G;c[Y>>2]=H;c[Z>>2]=I;c[_>>2]=J;c[$>>2]=K;c[aa>>2]=L;ld(Qa,Qa);D=D+(c[ba>>2]|0)|0;E=E+(c[ca>>2]|0)|0;F=F+(c[da>>2]|0)|0;G=G+(c[ea>>2]|0)|0;H=H+(c[fa>>2]|0)|0;I=I+(c[ga>>2]|0)|0;J=J+(c[ha>>2]|0)|0;K=K+(c[ia>>2]|0)|0;L=L+(c[ja>>2]|0)|0;c[Na>>2]=B+(c[Na>>2]|0);c[ba>>2]=D;c[ca>>2]=E;c[da>>2]=F;c[ea>>2]=G;c[fa>>2]=H;c[ga>>2]=I;c[ha>>2]=J;c[ia>>2]=K;c[ja>>2]=L;kd(Ra,Pa,Xa);kd(Xa,Oa,Na);if((A|0)<=0)break;e=c[Qa>>2]|0;L=c[Wa>>2]|0;f=c[ta>>2]|0;K=c[La>>2]|0;j=c[ua>>2]|0;J=c[Da>>2]|0;k=c[va>>2]|0;I=c[Ea>>2]|0;l=c[wa>>2]|0;H=c[Fa>>2]|0;m=c[xa>>2]|0;G=c[Ga>>2]|0;n=c[ya>>2]|0;F=c[Ha>>2]|0;o=c[za>>2]|0;E=c[Ia>>2]|0;p=c[Aa>>2]|0;D=c[Ja>>2]|0;q=c[Ba>>2]|0;h=c[Ka>>2]|0;r=c[Xa>>2]|0;s=c[M>>2]|0;t=c[N>>2]|0;u=c[O>>2]|0;v=c[P>>2]|0;w=c[Q>>2]|0;x=c[R>>2]|0;y=c[S>>2]|0;z=c[T>>2]|0;A=A+-1|0;B=g}ka=c[Wa>>2]|0;la=c[La>>2]|0;ma=c[Da>>2]|0;na=c[Ea>>2]|0;oa=c[Fa>>2]|0;pa=c[Ga>>2]|0;qa=c[Ha>>2]|0;ra=c[Ia>>2]|0;sa=c[Ja>>2]|0;lb=c[Ka>>2]|0;hb=c[Qa>>2]|0;db=c[ta>>2]|0;$a=c[ua>>2]|0;Pa=c[va>>2]|0;mb=c[wa>>2]|0;ib=c[xa>>2]|0;eb=c[ya>>2]|0;ab=c[za>>2]|0;Oa=c[Aa>>2]|0;Ma=c[Ba>>2]|0;nb=0-g|0;jb=(hb^ka)&nb;fb=(db^la)&nb;bb=($a^ma)&nb;Za=(Pa^na)&nb;e=(mb^oa)&nb;kb=(ib^pa)&nb;gb=(eb^qa)&nb;cb=(ab^ra)&nb;_a=(Oa^sa)&nb;Na=(Ma^lb)&nb;c[Wa>>2]=jb^ka;c[La>>2]=fb^la;c[Da>>2]=bb^ma;c[Ea>>2]=Za^na;c[Fa>>2]=e^oa;c[Ga>>2]=kb^pa;c[Ha>>2]=gb^qa;c[Ia>>2]=cb^ra;c[Ja>>2]=_a^sa;c[Ka>>2]=Na^lb;c[Qa>>2]=jb^hb;c[ta>>2]=fb^db;c[ua>>2]=bb^$a;c[va>>2]=Za^Pa;c[wa>>2]=e^mb;c[xa>>2]=kb^ib;c[ya>>2]=gb^eb;c[za>>2]=cb^ab;c[Aa>>2]=_a^Oa;c[Ba>>2]=Na^Ma;va=c[Xa>>2]|0;wa=c[M>>2]|0;xa=c[N>>2]|0;ya=c[O>>2]|0;za=c[P>>2]|0;Aa=c[Q>>2]|0;Ba=c[R>>2]|0;Ma=c[S>>2]|0;Na=c[T>>2]|0;Oa=c[U>>2]|0;Qa=c[Ra>>2]|0;_a=c[Ca>>2]|0;ab=c[V>>2]|0;cb=c[W>>2]|0;eb=c[X>>2]|0;gb=c[Y>>2]|0;ib=c[Z>>2]|0;kb=c[_>>2]|0;mb=c[$>>2]|0;e=c[aa>>2]|0;Pa=(Qa^va)&nb;Za=(_a^wa)&nb;$a=(ab^xa)&nb;bb=(cb^ya)&nb;db=(eb^za)&nb;fb=(gb^Aa)&nb;hb=(ib^Ba)&nb;jb=(kb^Ma)&nb;lb=(mb^Na)&nb;nb=(e^Oa)&nb;c[Xa>>2]=Pa^va;c[M>>2]=Za^wa;c[N>>2]=$a^xa;c[O>>2]=bb^ya;c[P>>2]=db^za;c[Q>>2]=fb^Aa;c[R>>2]=hb^Ba;c[S>>2]=jb^Ma;c[T>>2]=lb^Na;c[U>>2]=nb^Oa;c[Ra>>2]=Pa^Qa;c[Ca>>2]=Za^_a;c[V>>2]=$a^ab;c[W>>2]=bb^cb;c[X>>2]=db^eb;c[Y>>2]=fb^gb;c[Z>>2]=hb^ib;c[_>>2]=jb^kb;c[$>>2]=lb^mb;c[aa>>2]=nb^e;ld(Ta,Xa);ld(Ua,Ta);ld(Ua,Ua);kd(Ua,Xa,Ua);kd(Ta,Ta,Ua);ld(Va,Ta);kd(Ua,Ua,Va);ld(Va,Ua);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);kd(Ua,Va,Ua);ld(Va,Ua);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);kd(Va,Va,Ua);ld(Sa,Va);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);ld(Sa,Sa);kd(Va,Sa,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);ld(Va,Va);kd(Ua,Va,Ua);ld(Va,Ua);e=1;do{ld(Va,Va);e=e+1|0}while((e|0)!=50);kd(Va,Va,Ua);ld(Sa,Va);e=1;do{ld(Sa,Sa);e=e+1|0}while((e|0)!=100);kd(Va,Sa,Va);ld(Va,Va);e=1;do{ld(Va,Va);e=e+1|0}while((e|0)!=50);kd(Ua,Va,Ua);ld(Ua,Ua);ld(Ua,Ua);ld(Ua,Ua);ld(Ua,Ua);ld(Ua,Ua);kd(Xa,Ua,Ta);kd(Wa,Wa,Xa);eb=c[Wa>>2]|0;fb=c[La>>2]|0;gb=c[Da>>2]|0;hb=c[Ea>>2]|0;ib=c[Fa>>2]|0;jb=c[Ga>>2]|0;kb=c[Ha>>2]|0;lb=c[Ia>>2]|0;nb=c[Ja>>2]|0;mb=c[Ka>>2]|0;eb=(((((((((((((mb*19|0)+16777216>>25)+eb>>26)+fb>>25)+gb>>26)+hb>>25)+ib>>26)+jb>>25)+kb>>26)+lb>>25)+nb>>26)+mb>>25)*19|0)+eb|0;db=eb>>26;fb=db+fb|0;db=eb-(db<<26)|0;eb=fb>>25;gb=eb+gb|0;eb=fb-(eb<<25)|0;fb=gb>>26;hb=fb+hb|0;fb=gb-(fb<<26)|0;gb=hb>>25;ib=gb+ib|0;gb=hb-(gb<<25)|0;hb=ib>>26;jb=hb+jb|0;hb=ib-(hb<<26)|0;ib=jb>>25;kb=ib+kb|0;ib=jb-(ib<<25)|0;jb=kb>>26;lb=jb+lb|0;jb=kb-(jb<<26)|0;kb=lb>>25;nb=kb+nb|0;kb=lb-(kb<<25)|0;lb=nb>>26;mb=lb+mb|0;lb=nb-(lb<<26)|0;nb=mb&33554431;a[b>>0]=db;a[b+1>>0]=db>>>8;a[b+2>>0]=db>>>16;a[b+3>>0]=eb<<2|db>>>24;a[b+4>>0]=eb>>>6;a[b+5>>0]=eb>>>14;a[b+6>>0]=fb<<3|eb>>>22;a[b+7>>0]=fb>>>5;a[b+8>>0]=fb>>>13;a[b+9>>0]=gb<<5|fb>>>21;a[b+10>>0]=gb>>>3;a[b+11>>0]=gb>>>11;a[b+12>>0]=hb<<6|gb>>>19;a[b+13>>0]=hb>>>2;a[b+14>>0]=hb>>>10;a[b+15>>0]=hb>>>18;a[b+16>>0]=ib;a[b+17>>0]=ib>>>8;a[b+18>>0]=ib>>>16;a[b+19>>0]=jb<<1|ib>>>24;a[b+20>>0]=jb>>>7;a[b+21>>0]=jb>>>15;a[b+22>>0]=kb<<3|jb>>>23;a[b+23>>0]=kb>>>5;a[b+24>>0]=kb>>>13;a[b+25>>0]=lb<<4|kb>>>21;a[b+26>>0]=lb>>>4;a[b+27>>0]=lb>>>12;a[b+28>>0]=lb>>>20|nb<<6;a[b+29>>0]=mb>>>2;a[b+30>>0]=mb>>>10;a[b+31>>0]=nb>>>18;i=Ya;return}function nd(b,e,f,g,h,j,k,l){b=b|0;e=e|0;f=f|0;g=g|0;h=h|0;j=j|0;k=k|0;l=l|0;var m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0;D=i;B=i=i+63&-64;i=i+112|0;v=B;A=B+48|0;B=B+16|0;if((f|0)==0&(g|0)==0){i=D;return}n=B;m=n+32|0;do{a[n>>0]=a[l>>0]|0;n=n+1|0;l=l+1|0}while((n|0)<(m|0));s=h;p=s;s=s+4|0;s=d[s>>0]|d[s+1>>0]<<8|d[s+2>>0]<<16|d[s+3>>0]<<24;o=v;c[o>>2]=d[p>>0]|d[p+1>>0]<<8|d[p+2>>0]<<16|d[p+3>>0]<<24;c[o+4>>2]=s;o=v+8|0;a[o>>0]=j;s=Gd(j|0,k|0,8)|0;p=v+9|0;a[p>>0]=s;s=Gd(j|0,k|0,16)|0;q=v+10|0;a[q>>0]=s;s=Gd(j|0,k|0,24)|0;r=v+11|0;a[r>>0]=s;s=v+12|0;a[s>>0]=k;n=Gd(j|0,k|0,40)|0;t=v+13|0;a[t>>0]=n;n=Gd(j|0,k|0,48)|0;u=v+14|0;a[u>>0]=n;k=Gd(j|0,k|0,56)|0;j=v+15|0;a[j>>0]=k;if(g>>>0>0|(g|0)==0&f>>>0>63){n=e;h=f;l=g;do{ob(A,v,B,33833);m=0;do{a[b+m>>0]=a[A+m>>0]^a[n+m>>0];m=m+1|0}while((m|0)!=64);f=c[o>>2]|0;g=(f&255)+1|0;a[o>>0]=g;g=(f>>>8&255)+(g>>>8)|0;a[p>>0]=g;g=(f>>>16&255)+(g>>>8)|0;a[q>>0]=g;g=(f>>>24)+(g>>>8)|0;a[r>>0]=g;f=c[s>>2]|0;g=(f&255)+(g>>>8)|0;a[s>>0]=g;g=(f>>>8&255)+(g>>>8)|0;a[t>>0]=g;g=(f>>>16&255)+(g>>>8)|0;a[u>>0]=g;a[j>>0]=(f>>>24)+(g>>>8);h=Dd(h|0,l|0,-64,-1)|0;l=C;b=b+64|0;n=n+64|0}while(l>>>0>0|(l|0)==0&h>>>0>63);if(!((h|0)==0&(l|0)==0)){x=b;y=h;z=n;w=8}}else{x=b;y=f;z=e;w=8}if((w|0)==8?(ob(A,v,B,33833),(y|0)!=0):0){l=0;do{a[x+l>>0]=a[A+l>>0]^a[z+l>>0];l=l+1|0}while((l|0)!=(y|0))}n=A;m=n+64|0;do{a[n>>0]=0;n=n+1|0}while((n|0)<(m|0));n=B;m=n+32|0;do{a[n>>0]=0;n=n+1|0}while((n|0)<(m|0));i=D;return}function od(){var a=0;if(!(c[7979]|0))a=31964;else a=c[(oa()|0)+60>>2]|0;return a|0}function pd(a){a=a|0;var b=0,d=0;d=i;b=i=i+63&-64;i=i+16|0;c[b>>2]=c[a+60>>2];a=pa(6,b|0)|0;if(a>>>0>4294963200){if(!(c[7979]|0))b=31964;else b=c[(oa()|0)+60>>2]|0;c[b>>2]=0-a;a=-1}i=d;return a|0}function qd(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0,h=0;g=i;e=i=i+63&-64;i=i+32|0;h=e;e=e+20|0;c[h>>2]=c[a+60>>2];c[h+4>>2]=0;c[h+8>>2]=b;c[h+12>>2]=e;c[h+16>>2]=d;b=ya(140,h|0)|0;if(b>>>0<=4294963200)if((b|0)<0)f=7;else a=c[e>>2]|0;else{if(!(c[7979]|0))a=31964;else a=c[(oa()|0)+60>>2]|0;c[a>>2]=0-b;f=7}if((f|0)==7){c[e>>2]=-1;a=-1}i=g;return a|0}function rd(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0;q=i;k=i=i+63&-64;i=i+48|0;n=k+16|0;m=k;k=k+32|0;o=a+28|0;g=c[o>>2]|0;c[k>>2]=g;p=a+20|0;g=(c[p>>2]|0)-g|0;c[k+4>>2]=g;c[k+8>>2]=b;c[k+12>>2]=d;j=a+60|0;l=a+44|0;f=2;g=g+d|0;while(1){if(!(c[7979]|0)){c[n>>2]=c[j>>2];c[n+4>>2]=k;c[n+8>>2]=f;b=Aa(146,n|0)|0;if(b>>>0>4294963200){if(!(c[7979]|0))e=31964;else e=c[(oa()|0)+60>>2]|0;c[e>>2]=0-b;b=-1}}else{ua(18,a|0);c[m>>2]=c[j>>2];c[m+4>>2]=k;c[m+8>>2]=f;b=Aa(146,m|0)|0;if(b>>>0>4294963200){if(!(c[7979]|0))e=31964;else e=c[(oa()|0)+60>>2]|0;c[e>>2]=0-b;b=-1}la(0)}if((g|0)==(b|0)){b=13;break}if((b|0)<0){b=15;break}g=g-b|0;e=c[k+4>>2]|0;if(b>>>0<=e>>>0)if((f|0)==2){c[o>>2]=(c[o>>2]|0)+b;h=e;e=k;f=2}else{h=e;e=k}else{h=c[l>>2]|0;c[o>>2]=h;c[p>>2]=h;h=c[k+12>>2]|0;b=b-e|0;e=k+8|0;f=f+-1|0}c[e>>2]=(c[e>>2]|0)+b;c[e+4>>2]=h-b;k=e}if((b|0)==13){n=c[l>>2]|0;c[a+16>>2]=n+(c[a+48>>2]|0);a=n;c[o>>2]=a;c[p>>2]=a}else if((b|0)==15){c[a+16>>2]=0;c[o>>2]=0;c[p>>2]=0;c[a>>2]=c[a>>2]|32;if((f|0)==2)d=0;else d=d-(c[k+4>>2]|0)|0}i=q;return d|0}function sd(b,d,e){b=b|0;d=d|0;e=e|0;var f=0,g=0,h=0;g=i;h=i=i+63&-64;i=i+80|0;f=h;c[b+36>>2]=20;if((c[b>>2]&64|0)==0?(c[f>>2]=c[b+60>>2],c[f+4>>2]=21505,c[f+8>>2]=h+12,(wa(54,f|0)|0)!=0):0)a[b+75>>0]=-1;h=rd(b,d,e)|0;i=g;return h|0}function td(a){a=a|0;var b=0;if(!a){if(!(c[7990]|0))a=0;else a=td(c[7990]|0)|0;ma(31944);b=c[7985]|0;if(b)do{if((c[b+20>>2]|0)>>>0>(c[b+28>>2]|0)>>>0)a=xd(b)|0|a;b=c[b+56>>2]|0}while((b|0)!=0);xa(31944)}else a=xd(a)|0;return a|0}function ud(b,d){b=b|0;d=d|0;var e=0,f=0,g=0;f=d&255;a:do if(!f)b=b+(vd(b)|0)|0;else{if(b&3){e=d&255;do{g=a[b>>0]|0;if(g<<24>>24==0?1:g<<24>>24==e<<24>>24)break a;b=b+1|0}while((b&3|0)!=0)}f=_(f,16843009)|0;e=c[b>>2]|0;b:do if(!((e&-2139062144^-2139062144)&e+-16843009))do{g=e^f;if((g&-2139062144^-2139062144)&g+-16843009)break b;b=b+4|0;e=c[b>>2]|0}while(((e&-2139062144^-2139062144)&e+-16843009|0)==0);while(0);e=d&255;while(1){g=a[b>>0]|0;if(g<<24>>24==0?1:g<<24>>24==e<<24>>24)break;else b=b+1|0}}while(0);return b|0}function vd(b){b=b|0;var d=0,e=0,f=0;f=b;a:do if(!(f&3))e=4;else{d=b;b=f;while(1){if(!(a[d>>0]|0))break a;d=d+1|0;b=d;if(!(b&3)){b=d;e=4;break}}}while(0);if((e|0)==4){while(1){d=c[b>>2]|0;if(!((d&-2139062144^-2139062144)&d+-16843009))b=b+4|0;else break}if((d&255)<<24>>24)do b=b+1|0;while((a[b>>0]|0)!=0)}return b-f|0}function wd(a){a=a|0;return}function xd(a){a=a|0;var b=0,d=0,e=0,f=0,g=0,h=0;b=a+20|0;g=a+28|0;if((c[b>>2]|0)>>>0>(c[g>>2]|0)>>>0?(Fa[c[a+36>>2]&31](a,0,0)|0,(c[b>>2]|0)==0):0)b=-1;else{h=a+4|0;d=c[h>>2]|0;e=a+8|0;f=c[e>>2]|0;if(d>>>0<f>>>0)Fa[c[a+40>>2]&31](a,d-f|0,1)|0;c[a+16>>2]=0;c[g>>2]=0;c[b>>2]=0;c[e>>2]=0;c[h>>2]=0;b=0}return b|0}\nfunction Hb(a,b){a=a|0;b=b|0;var e=0,f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0;h=i;g=i=i+63&-64;i=i+640|0;e=0;do{j=b+(e<<3)|0;o=d[j+7>>0]|0;p=Hd(d[j+6>>0]|0|0,0,8)|0;f=C;n=Hd(d[j+5>>0]|0|0,0,16)|0;f=f|C;m=Hd(d[j+4>>0]|0|0,0,24)|0;f=f|C|(d[j+3>>0]|0);l=Hd(d[j+2>>0]|0|0,0,40)|0;f=f|C;k=Hd(d[j+1>>0]|0|0,0,48)|0;k=Dd(p|o|n|m|l|0,f|0,k|0,C|0)|0;f=C;j=Hd(d[j>>0]|0|0,0,56)|0;j=Dd(k|0,f|0,j|0,C|0)|0;f=g+(e<<3)|0;c[f>>2]=j;c[f+4>>2]=C;e=e+1|0}while((e|0)!=16);e=g;b=c[e>>2]|0;e=c[e+4>>2]|0;f=16;do{s=g+(f+-2<<3)|0;w=c[s>>2]|0;s=c[s+4>>2]|0;r=Gd(w|0,s|0,19)|0;j=C;q=Hd(w|0,s|0,45)|0;j=j|C;u=Gd(w|0,s|0,61)|0;v=C;t=Hd(w|0,s|0,3)|0;v=v|C;s=Gd(w|0,s|0,6)|0;j=v^C^j;v=g+(f+-7<<3)|0;w=c[v>>2]|0;v=c[v+4>>2]|0;n=g+(f+-15<<3)|0;y=b;b=c[n>>2]|0;x=e;e=c[n+4>>2]|0;n=Gd(b|0,e|0,1)|0;o=C;p=Hd(b|0,e|0,63)|0;o=o|C;k=Gd(b|0,e|0,8)|0;z=C;l=Hd(b|0,e|0,56)|0;z=z|C;m=Gd(b|0,e|0,7)|0;o=z^C^o;v=Dd(y|0,x|0,w|0,v|0)|0;j=Dd(v|0,C|0,(u|t)^s^(r|q)|0,j|0)|0;o=Dd(j|0,C|0,(k|l)^m^(n|p)|0,o|0)|0;p=g+(f<<3)|0;c[p>>2]=o;c[p+4>>2]=C;f=f+1|0}while((f|0)!=80);K=a;I=c[K>>2]|0;K=c[K+4>>2]|0;e=a+8|0;A=e;B=c[A>>2]|0;A=c[A+4>>2]|0;k=a+16|0;f=k;b=c[f>>2]|0;f=c[f+4>>2]|0;n=a+24|0;l=n;j=c[l>>2]|0;l=c[l+4>>2]|0;q=a+32|0;m=q;p=c[m>>2]|0;m=c[m+4>>2]|0;t=a+40|0;o=t;s=c[o>>2]|0;o=c[o+4>>2]|0;w=a+48|0;r=w;v=c[r>>2]|0;r=c[r+4>>2]|0;z=a+56|0;u=z;y=c[u>>2]|0;u=c[u+4>>2]|0;H=Gd(p|0,m|0,14)|0;D=C;x=Hd(p|0,m|0,50)|0;D=D|C;M=Gd(p|0,m|0,18)|0;E=C;L=Hd(p|0,m|0,46)|0;E=D^(E|C);D=Gd(p|0,m|0,41)|0;G=C;J=Hd(p|0,m|0,23)|0;G=E^(G|C);E=g;F=c[E>>2]|0;E=c[E+4>>2]|0;u=Dd(y|0,u|0,-685199838,1116352408)|0;E=Dd(u|0,C|0,F|0,E|0)|0;G=Dd(E|0,C|0,(H|x)^(M|L)^(D|J)|0,G|0)|0;G=Dd(G|0,C|0,(v^s)&p^v|0,(r^o)&m^r|0)|0;J=C;D=Gd(I|0,K|0,28)|0;L=C;M=Hd(I|0,K|0,36)|0;L=L|C;x=Gd(I|0,K|0,34)|0;H=C;E=Hd(I|0,K|0,30)|0;H=L^(H|C);L=Gd(I|0,K|0,39)|0;F=C;u=Hd(I|0,K|0,25)|0;F=Dd((b|B)&I|b&B|0,(f|A)&K|f&A|0,(D|M)^(x|E)^(L|u)|0,H^(F|C)|0)|0;H=C;l=Dd(j|0,l|0,G|0,J|0)|0;j=C;J=Dd(F|0,H|0,G|0,J|0)|0;G=C;H=Gd(l|0,j|0,14)|0;F=C;u=Hd(l|0,j|0,50)|0;F=F|C;L=Gd(l|0,j|0,18)|0;E=C;x=Hd(l|0,j|0,46)|0;E=F^(E|C);F=Gd(l|0,j|0,41)|0;M=C;D=Hd(l|0,j|0,23)|0;M=E^(M|C);E=g+8|0;y=c[E>>2]|0;E=c[E+4>>2]|0;r=Dd(v|0,r|0,602891725,1899447441)|0;E=Dd(r|0,C|0,y|0,E|0)|0;M=Dd(E|0,C|0,(H|u)^(L|x)^(F|D)|0,M|0)|0;M=Dd(M|0,C|0,(s^p)&l^s|0,(o^m)&j^o|0)|0;D=C;F=Gd(J|0,G|0,28)|0;x=C;L=Hd(J|0,G|0,36)|0;x=x|C;u=Gd(J|0,G|0,34)|0;H=C;E=Hd(J|0,G|0,30)|0;H=x^(H|C);x=Gd(J|0,G|0,39)|0;y=C;r=Hd(J|0,G|0,25)|0;y=Dd((B|I)&J|B&I|0,(A|K)&G|A&K|0,(F|L)^(u|E)^(x|r)|0,H^(y|C)|0)|0;H=C;f=Dd(b|0,f|0,M|0,D|0)|0;b=C;D=Dd(y|0,H|0,M|0,D|0)|0;M=C;H=Gd(f|0,b|0,14)|0;y=C;r=Hd(f|0,b|0,50)|0;y=y|C;x=Gd(f|0,b|0,18)|0;E=C;u=Hd(f|0,b|0,46)|0;E=y^(E|C);y=Gd(f|0,b|0,41)|0;L=C;F=Hd(f|0,b|0,23)|0;L=E^(L|C);E=g+16|0;v=c[E>>2]|0;E=c[E+4>>2]|0;o=Dd(s|0,o|0,-330482897,-1245643825)|0;E=Dd(o|0,C|0,v|0,E|0)|0;L=Dd(E|0,C|0,(H|r)^(x|u)^(y|F)|0,L|0)|0;L=Dd(L|0,C|0,(p^l)&f^p|0,(m^j)&b^m|0)|0;F=C;y=Gd(D|0,M|0,28)|0;u=C;x=Hd(D|0,M|0,36)|0;u=u|C;r=Gd(D|0,M|0,34)|0;H=C;E=Hd(D|0,M|0,30)|0;H=u^(H|C);u=Gd(D|0,M|0,39)|0;v=C;o=Hd(D|0,M|0,25)|0;v=Dd((I|J)&D|I&J|0,(K|G)&M|K&G|0,(y|x)^(r|E)^(u|o)|0,H^(v|C)|0)|0;H=C;A=Dd(B|0,A|0,L|0,F|0)|0;B=C;F=Dd(v|0,H|0,L|0,F|0)|0;L=C;H=Gd(A|0,B|0,14)|0;v=C;o=Hd(A|0,B|0,50)|0;v=v|C;u=Gd(A|0,B|0,18)|0;E=C;r=Hd(A|0,B|0,46)|0;E=v^(E|C);v=Gd(A|0,B|0,41)|0;x=C;y=Hd(A|0,B|0,23)|0;x=E^(x|C);E=g+24|0;s=c[E>>2]|0;E=c[E+4>>2]|0;m=Dd(p|0,m|0,-2121671748,-373957723)|0;E=Dd(m|0,C|0,s|0,E|0)|0;x=Dd(E|0,C|0,(H|o)^(u|r)^(v|y)|0,x|0)|0;x=Dd(x|0,C|0,(l^f)&A^l|0,(j^b)&B^j|0)|0;y=C;v=Gd(F|0,L|0,28)|0;r=C;u=Hd(F|0,L|0,36)|0;r=r|C;o=Gd(F|0,L|0,34)|0;H=C;E=Hd(F|0,L|0,30)|0;H=r^(H|C);r=Gd(F|0,L|0,39)|0;s=C;m=Hd(F|0,L|0,25)|0;s=Dd((J|D)&F|J&D|0,(G|M)&L|G&M|0,(v|u)^(o|E)^(r|m)|0,H^(s|C)|0)|0;H=C;K=Dd(I|0,K|0,x|0,y|0)|0;I=C;y=Dd(s|0,H|0,x|0,y|0)|0;x=C;H=Gd(K|0,I|0,14)|0;s=C;m=Hd(K|0,I|0,50)|0;s=s|C;r=Gd(K|0,I|0,18)|0;E=C;o=Hd(K|0,I|0,46)|0;E=s^(E|C);s=Gd(K|0,I|0,41)|0;u=C;v=Hd(K|0,I|0,23)|0;u=E^(u|C);E=g+32|0;p=c[E>>2]|0;E=c[E+4>>2]|0;j=Dd(l|0,j|0,-213338824,961987163)|0;E=Dd(j|0,C|0,p|0,E|0)|0;u=Dd(E|0,C|0,(H|m)^(r|o)^(s|v)|0,u|0)|0;u=Dd(u|0,C|0,(f^A)&K^f|0,(b^B)&I^b|0)|0;v=C;s=Gd(y|0,x|0,28)|0;o=C;r=Hd(y|0,x|0,36)|0;o=o|C;m=Gd(y|0,x|0,34)|0;H=C;E=Hd(y|0,x|0,30)|0;H=o^(H|C);o=Gd(y|0,x|0,39)|0;p=C;j=Hd(y|0,x|0,25)|0;p=Dd((D|F)&y|D&F|0,(M|L)&x|M&L|0,(s|r)^(m|E)^(o|j)|0,H^(p|C)|0)|0;H=C;G=Dd(J|0,G|0,u|0,v|0)|0;J=C;v=Dd(p|0,H|0,u|0,v|0)|0;u=C;H=Gd(G|0,J|0,14)|0;p=C;j=Hd(G|0,J|0,50)|0;p=p|C;o=Gd(G|0,J|0,18)|0;E=C;m=Hd(G|0,J|0,46)|0;E=p^(E|C);p=Gd(G|0,J|0,41)|0;r=C;s=Hd(G|0,J|0,23)|0;r=E^(r|C);E=g+40|0;l=c[E>>2]|0;E=c[E+4>>2]|0;b=Dd(f|0,b|0,-1241133031,1508970993)|0;E=Dd(b|0,C|0,l|0,E|0)|0;r=Dd(E|0,C|0,(H|j)^(o|m)^(p|s)|0,r|0)|0;r=Dd(r|0,C|0,(A^K)&G^A|0,(B^I)&J^B|0)|0;s=C;p=Gd(v|0,u|0,28)|0;m=C;o=Hd(v|0,u|0,36)|0;m=m|C;j=Gd(v|0,u|0,34)|0;H=C;E=Hd(v|0,u|0,30)|0;H=m^(H|C);m=Gd(v|0,u|0,39)|0;l=C;b=Hd(v|0,u|0,25)|0;l=Dd((F|y)&v|F&y|0,(L|x)&u|L&x|0,(p|o)^(j|E)^(m|b)|0,H^(l|C)|0)|0;H=C;M=Dd(D|0,M|0,r|0,s|0)|0;D=C;s=Dd(l|0,H|0,r|0,s|0)|0;r=C;H=Gd(M|0,D|0,14)|0;l=C;b=Hd(M|0,D|0,50)|0;l=l|C;m=Gd(M|0,D|0,18)|0;E=C;j=Hd(M|0,D|0,46)|0;E=l^(E|C);l=Gd(M|0,D|0,41)|0;o=C;p=Hd(M|0,D|0,23)|0;o=E^(o|C);E=g+48|0;f=c[E>>2]|0;E=c[E+4>>2]|0;B=Dd(A|0,B|0,-1357295717,-1841331548)|0;E=Dd(B|0,C|0,f|0,E|0)|0;o=Dd(E|0,C|0,(H|b)^(m|j)^(l|p)|0,o|0)|0;o=Dd(o|0,C|0,(K^G)&M^K|0,(I^J)&D^I|0)|0;p=C;l=Gd(s|0,r|0,28)|0;j=C;m=Hd(s|0,r|0,36)|0;j=j|C;b=Gd(s|0,r|0,34)|0;H=C;E=Hd(s|0,r|0,30)|0;H=j^(H|C);j=Gd(s|0,r|0,39)|0;f=C;B=Hd(s|0,r|0,25)|0;f=Dd((y|v)&s|y&v|0,(x|u)&r|x&u|0,(l|m)^(b|E)^(j|B)|0,H^(f|C)|0)|0;H=C;L=Dd(F|0,L|0,o|0,p|0)|0;F=C;p=Dd(f|0,H|0,o|0,p|0)|0;o=C;H=Gd(L|0,F|0,14)|0;f=C;B=Hd(L|0,F|0,50)|0;f=f|C;j=Gd(L|0,F|0,18)|0;E=C;b=Hd(L|0,F|0,46)|0;E=f^(E|C);f=Gd(L|0,F|0,41)|0;m=C;l=Hd(L|0,F|0,23)|0;m=E^(m|C);E=g+56|0;A=c[E>>2]|0;E=c[E+4>>2]|0;I=Dd(K|0,I|0,-630357736,-1424204075)|0;E=Dd(I|0,C|0,A|0,E|0)|0;m=Dd(E|0,C|0,(H|B)^(j|b)^(f|l)|0,m|0)|0;m=Dd(m|0,C|0,(G^M)&L^G|0,(J^D)&F^J|0)|0;l=C;f=Gd(p|0,o|0,28)|0;b=C;j=Hd(p|0,o|0,36)|0;b=b|C;B=Gd(p|0,o|0,34)|0;H=C;E=Hd(p|0,o|0,30)|0;H=b^(H|C);b=Gd(p|0,o|0,39)|0;A=C;I=Hd(p|0,o|0,25)|0;A=Dd((v|s)&p|v&s|0,(u|r)&o|u&r|0,(f|j)^(B|E)^(b|I)|0,H^(A|C)|0)|0;H=C;x=Dd(y|0,x|0,m|0,l|0)|0;y=C;l=Dd(A|0,H|0,m|0,l|0)|0;m=C;H=Gd(x|0,y|0,14)|0;A=C;I=Hd(x|0,y|0,50)|0;A=A|C;b=Gd(x|0,y|0,18)|0;E=C;B=Hd(x|0,y|0,46)|0;E=A^(E|C);A=Gd(x|0,y|0,41)|0;j=C;f=Hd(x|0,y|0,23)|0;j=E^(j|C);E=g+64|0;K=c[E>>2]|0;E=c[E+4>>2]|0;J=Dd(G|0,J|0,-1560083902,-670586216)|0;E=Dd(J|0,C|0,K|0,E|0)|0;j=Dd(E|0,C|0,(H|I)^(b|B)^(A|f)|0,j|0)|0;j=Dd(j|0,C|0,(M^L)&x^M|0,(D^F)&y^D|0)|0;f=C;A=Gd(l|0,m|0,28)|0;B=C;b=Hd(l|0,m|0,36)|0;B=B|C;I=Gd(l|0,m|0,34)|0;H=C;E=Hd(l|0,m|0,30)|0;H=B^(H|C);B=Gd(l|0,m|0,39)|0;K=C;J=Hd(l|0,m|0,25)|0;K=Dd((s|p)&l|s&p|0,(r|o)&m|r&o|0,(A|b)^(I|E)^(B|J)|0,H^(K|C)|0)|0;H=C;u=Dd(v|0,u|0,j|0,f|0)|0;v=C;f=Dd(K|0,H|0,j|0,f|0)|0;j=C;H=Gd(u|0,v|0,14)|0;K=C;J=Hd(u|0,v|0,50)|0;K=K|C;B=Gd(u|0,v|0,18)|0;E=C;I=Hd(u|0,v|0,46)|0;E=K^(E|C);K=Gd(u|0,v|0,41)|0;b=C;A=Hd(u|0,v|0,23)|0;b=E^(b|C);E=g+72|0;G=c[E>>2]|0;E=c[E+4>>2]|0;D=Dd(M|0,D|0,1164996542,310598401)|0;E=Dd(D|0,C|0,G|0,E|0)|0;b=Dd(E|0,C|0,(H|J)^(B|I)^(K|A)|0,b|0)|0;b=Dd(b|0,C|0,(L^x)&u^L|0,(F^y)&v^F|0)|0;A=C;K=Gd(f|0,j|0,28)|0;I=C;B=Hd(f|0,j|0,36)|0;I=I|C;J=Gd(f|0,j|0,34)|0;H=C;E=Hd(f|0,j|0,30)|0;H=I^(H|C);I=Gd(f|0,j|0,39)|0;G=C;D=Hd(f|0,j|0,25)|0;G=Dd((p|l)&f|p&l|0,(o|m)&j|o&m|0,(K|B)^(J|E)^(I|D)|0,H^(G|C)|0)|0;H=C;r=Dd(s|0,r|0,b|0,A|0)|0;s=C;A=Dd(G|0,H|0,b|0,A|0)|0;b=C;H=Gd(r|0,s|0,14)|0;G=C;D=Hd(r|0,s|0,50)|0;G=G|C;I=Gd(r|0,s|0,18)|0;E=C;J=Hd(r|0,s|0,46)|0;E=G^(E|C);G=Gd(r|0,s|0,41)|0;B=C;K=Hd(r|0,s|0,23)|0;B=E^(B|C);E=g+80|0;M=c[E>>2]|0;E=c[E+4>>2]|0;F=Dd(L|0,F|0,1323610764,607225278)|0;E=Dd(F|0,C|0,M|0,E|0)|0;B=Dd(E|0,C|0,(H|D)^(I|J)^(G|K)|0,B|0)|0;B=Dd(B|0,C|0,(x^u)&r^x|0,(y^v)&s^y|0)|0;K=C;G=Gd(A|0,b|0,28)|0;J=C;I=Hd(A|0,b|0,36)|0;J=J|C;D=Gd(A|0,b|0,34)|0;H=C;E=Hd(A|0,b|0,30)|0;H=J^(H|C);J=Gd(A|0,b|0,39)|0;M=C;F=Hd(A|0,b|0,25)|0;M=Dd((l|f)&A|l&f|0,(m|j)&b|m&j|0,(G|I)^(D|E)^(J|F)|0,H^(M|C)|0)|0;H=C;o=Dd(p|0,o|0,B|0,K|0)|0;p=C;K=Dd(M|0,H|0,B|0,K|0)|0;B=C;H=Gd(o|0,p|0,14)|0;M=C;F=Hd(o|0,p|0,50)|0;M=M|C;J=Gd(o|0,p|0,18)|0;E=C;D=Hd(o|0,p|0,46)|0;E=M^(E|C);M=Gd(o|0,p|0,41)|0;I=C;G=Hd(o|0,p|0,23)|0;I=E^(I|C);E=g+88|0;L=c[E>>2]|0;E=c[E+4>>2]|0;y=Dd(x|0,y|0,-704662302,1426881987)|0;E=Dd(y|0,C|0,L|0,E|0)|0;I=Dd(E|0,C|0,(H|F)^(J|D)^(M|G)|0,I|0)|0;I=Dd(I|0,C|0,(u^r)&o^u|0,(v^s)&p^v|0)|0;G=C;M=Gd(K|0,B|0,28)|0;D=C;J=Hd(K|0,B|0,36)|0;D=D|C;F=Gd(K|0,B|0,34)|0;H=C;E=Hd(K|0,B|0,30)|0;H=D^(H|C);D=Gd(K|0,B|0,39)|0;L=C;y=Hd(K|0,B|0,25)|0;L=Dd((f|A)&K|f&A|0,(j|b)&B|j&b|0,(M|J)^(F|E)^(D|y)|0,H^(L|C)|0)|0;H=C;m=Dd(l|0,m|0,I|0,G|0)|0;l=C;G=Dd(L|0,H|0,I|0,G|0)|0;I=C;H=Gd(m|0,l|0,14)|0;L=C;y=Hd(m|0,l|0,50)|0;L=L|C;D=Gd(m|0,l|0,18)|0;E=C;F=Hd(m|0,l|0,46)|0;E=L^(E|C);L=Gd(m|0,l|0,41)|0;J=C;M=Hd(m|0,l|0,23)|0;J=E^(J|C);E=g+96|0;x=c[E>>2]|0;E=c[E+4>>2]|0;v=Dd(u|0,v|0,-226784913,1925078388)|0;E=Dd(v|0,C|0,x|0,E|0)|0;J=Dd(E|0,C|0,(H|y)^(D|F)^(L|M)|0,J|0)|0;J=Dd(J|0,C|0,(r^o)&m^r|0,(s^p)&l^s|0)|0;M=C;L=Gd(G|0,I|0,28)|0;F=C;D=Hd(G|0,I|0,36)|0;F=F|C;y=Gd(G|0,I|0,34)|0;H=C;E=Hd(G|0,I|0,30)|0;H=F^(H|C);F=Gd(G|0,I|0,39)|0;x=C;v=Hd(G|0,I|0,25)|0;x=Dd((A|K)&G|A&K|0,(b|B)&I|b&B|0,(L|D)^(y|E)^(F|v)|0,H^(x|C)|0)|0;H=C;j=Dd(f|0,j|0,J|0,M|0)|0;f=C;M=Dd(x|0,H|0,J|0,M|0)|0;J=C;H=Gd(j|0,f|0,14)|0;x=C;v=Hd(j|0,f|0,50)|0;x=x|C;F=Gd(j|0,f|0,18)|0;E=C;y=Hd(j|0,f|0,46)|0;E=x^(E|C);x=Gd(j|0,f|0,41)|0;D=C;L=Hd(j|0,f|0,23)|0;D=E^(D|C);E=g+104|0;u=c[E>>2]|0;E=c[E+4>>2]|0;s=Dd(r|0,s|0,991336113,-2132889090)|0;E=Dd(s|0,C|0,u|0,E|0)|0;D=Dd(E|0,C|0,(H|v)^(F|y)^(x|L)|0,D|0)|0;D=Dd(D|0,C|0,(o^m)&j^o|0,(p^l)&f^p|0)|0;L=C;x=Gd(M|0,J|0,28)|0;y=C;F=Hd(M|0,J|0,36)|0;y=y|C;v=Gd(M|0,J|0,34)|0;H=C;E=Hd(M|0,J|0,30)|0;H=y^(H|C);y=Gd(M|0,J|0,39)|0;u=C;s=Hd(M|0,J|0,25)|0;u=Dd((K|G)&M|K&G|0,(B|I)&J|B&I|0,(x|F)^(v|E)^(y|s)|0,H^(u|C)|0)|0;H=C;b=Dd(A|0,b|0,D|0,L|0)|0;A=C;L=Dd(u|0,H|0,D|0,L|0)|0;D=C;H=Gd(b|0,A|0,14)|0;u=C;s=Hd(b|0,A|0,50)|0;u=u|C;y=Gd(b|0,A|0,18)|0;E=C;v=Hd(b|0,A|0,46)|0;E=u^(E|C);u=Gd(b|0,A|0,41)|0;F=C;x=Hd(b|0,A|0,23)|0;F=E^(F|C);E=g+112|0;r=c[E>>2]|0;E=c[E+4>>2]|0;p=Dd(o|0,p|0,633803317,-1680079193)|0;E=Dd(p|0,C|0,r|0,E|0)|0;F=Dd(E|0,C|0,(H|s)^(y|v)^(u|x)|0,F|0)|0;F=Dd(F|0,C|0,(m^j)&b^m|0,(l^f)&A^l|0)|0;x=C;u=Gd(L|0,D|0,28)|0;v=C;y=Hd(L|0,D|0,36)|0;v=v|C;s=Gd(L|0,D|0,34)|0;H=C;E=Hd(L|0,D|0,30)|0;H=v^(H|C);v=Gd(L|0,D|0,39)|0;r=C;p=Hd(L|0,D|0,25)|0;r=Dd((G|M)&L|G&M|0,(I|J)&D|I&J|0,(u|y)^(s|E)^(v|p)|0,H^(r|C)|0)|0;H=C;B=Dd(K|0,B|0,F|0,x|0)|0;K=C;x=Dd(r|0,H|0,F|0,x|0)|0;F=C;H=Gd(B|0,K|0,14)|0;r=C;p=Hd(B|0,K|0,50)|0;r=r|C;v=Gd(B|0,K|0,18)|0;E=C;s=Hd(B|0,K|0,46)|0;E=r^(E|C);r=Gd(B|0,K|0,41)|0;y=C;u=Hd(B|0,K|0,23)|0;y=E^(y|C);E=g+120|0;o=c[E>>2]|0;E=c[E+4>>2]|0;l=Dd(m|0,l|0,-815192428,-1046744716)|0;E=Dd(l|0,C|0,o|0,E|0)|0;y=Dd(E|0,C|0,(H|p)^(v|s)^(r|u)|0,y|0)|0;y=Dd(y|0,C|0,(j^b)&B^j|0,(f^A)&K^f|0)|0;u=C;r=Gd(x|0,F|0,28)|0;s=C;v=Hd(x|0,F|0,36)|0;s=s|C;p=Gd(x|0,F|0,34)|0;H=C;E=Hd(x|0,F|0,30)|0;H=s^(H|C);s=Gd(x|0,F|0,39)|0;o=C;l=Hd(x|0,F|0,25)|0;o=Dd((M|L)&x|M&L|0,(J|D)&F|J&D|0,(r|v)^(p|E)^(s|l)|0,H^(o|C)|0)|0;H=C;I=Dd(G|0,I|0,y|0,u|0)|0;G=C;u=Dd(o|0,H|0,y|0,u|0)|0;y=C;H=Gd(I|0,G|0,14)|0;o=C;l=Hd(I|0,G|0,50)|0;o=o|C;s=Gd(I|0,G|0,18)|0;E=C;p=Hd(I|0,G|0,46)|0;E=o^(E|C);o=Gd(I|0,G|0,41)|0;v=C;r=Hd(I|0,G|0,23)|0;v=E^(v|C);E=g+128|0;m=c[E>>2]|0;E=c[E+4>>2]|0;f=Dd(j|0,f|0,-1628353838,-459576895)|0;E=Dd(f|0,C|0,m|0,E|0)|0;v=Dd(E|0,C|0,(H|l)^(s|p)^(o|r)|0,v|0)|0;v=Dd(v|0,C|0,(b^B)&I^b|0,(A^K)&G^A|0)|0;r=C;o=Gd(u|0,y|0,28)|0;p=C;s=Hd(u|0,y|0,36)|0;p=p|C;l=Gd(u|0,y|0,34)|0;H=C;E=Hd(u|0,y|0,30)|0;H=p^(H|C);p=Gd(u|0,y|0,39)|0;m=C;f=Hd(u|0,y|0,25)|0;m=Dd((L|x)&u|L&x|0,(D|F)&y|D&F|0,(o|s)^(l|E)^(p|f)|0,H^(m|C)|0)|0;H=C;J=Dd(M|0,J|0,v|0,r|0)|0;M=C;r=Dd(m|0,H|0,v|0,r|0)|0;v=C;H=Gd(J|0,M|0,14)|0;m=C;f=Hd(J|0,M|0,50)|0;m=m|C;p=Gd(J|0,M|0,18)|0;E=C;l=Hd(J|0,M|0,46)|0;E=m^(E|C);m=Gd(J|0,M|0,41)|0;s=C;o=Hd(J|0,M|0,23)|0;s=E^(s|C);E=g+136|0;j=c[E>>2]|0;E=c[E+4>>2]|0;A=Dd(b|0,A|0,944711139,-272742522)|0;E=Dd(A|0,C|0,j|0,E|0)|0;s=Dd(E|0,C|0,(H|f)^(p|l)^(m|o)|0,s|0)|0;s=Dd(s|0,C|0,(B^I)&J^B|0,(K^G)&M^K|0)|0;o=C;m=Gd(r|0,v|0,28)|0;l=C;p=Hd(r|0,v|0,36)|0;l=l|C;f=Gd(r|0,v|0,34)|0;H=C;E=Hd(r|0,v|0,30)|0;H=l^(H|C);l=Gd(r|0,v|0,39)|0;j=C;A=Hd(r|0,v|0,25)|0;j=Dd((x|u)&r|x&u|0,(F|y)&v|F&y|0,(m|p)^(f|E)^(l|A)|0,H^(j|C)|0)|0;H=C;D=Dd(L|0,D|0,s|0,o|0)|0;L=C;o=Dd(j|0,H|0,s|0,o|0)|0;s=C;H=Gd(D|0,L|0,14)|0;j=C;A=Hd(D|0,L|0,50)|0;j=j|C;l=Gd(D|0,L|0,18)|0;E=C;f=Hd(D|0,L|0,46)|0;E=j^(E|C);j=Gd(D|0,L|0,41)|0;p=C;m=Hd(D|0,L|0,23)|0;p=E^(p|C);E=g+144|0;b=c[E>>2]|0;E=c[E+4>>2]|0;K=Dd(B|0,K|0,-1953704523,264347078)|0;E=Dd(K|0,C|0,b|0,E|0)|0;p=Dd(E|0,C|0,(H|A)^(l|f)^(j|m)|0,p|0)|0;p=Dd(p|0,C|0,(I^J)&D^I|0,(G^M)&L^G|0)|0;m=C;j=Gd(o|0,s|0,28)|0;f=C;l=Hd(o|0,s|0,36)|0;f=f|C;A=Gd(o|0,s|0,34)|0;H=C;E=Hd(o|0,s|0,30)|0;H=f^(H|C);f=Gd(o|0,s|0,39)|0;b=C;K=Hd(o|0,s|0,25)|0;b=Dd((u|r)&o|u&r|0,(y|v)&s|y&v|0,(j|l)^(A|E)^(f|K)|0,H^(b|C)|0)|0;H=C;F=Dd(x|0,F|0,p|0,m|0)|0;x=C;m=Dd(b|0,H|0,p|0,m|0)|0;p=C;H=Gd(F|0,x|0,14)|0;b=C;K=Hd(F|0,x|0,50)|0;b=b|C;f=Gd(F|0,x|0,18)|0;E=C;A=Hd(F|0,x|0,46)|0;E=b^(E|C);b=Gd(F|0,x|0,41)|0;l=C;j=Hd(F|0,x|0,23)|0;l=E^(l|C);E=g+152|0;B=c[E>>2]|0;E=c[E+4>>2]|0;G=Dd(I|0,G|0,2007800933,604807628)|0;E=Dd(G|0,C|0,B|0,E|0)|0;l=Dd(E|0,C|0,(H|K)^(f|A)^(b|j)|0,l|0)|0;l=Dd(l|0,C|0,(J^D)&F^J|0,(M^L)&x^M|0)|0;j=C;b=Gd(m|0,p|0,28)|0;A=C;f=Hd(m|0,p|0,36)|0;A=A|C;K=Gd(m|0,p|0,34)|0;H=C;E=Hd(m|0,p|0,30)|0;H=A^(H|C);A=Gd(m|0,p|0,39)|0;B=C;G=Hd(m|0,p|0,25)|0;B=Dd((r|o)&m|r&o|0,(v|s)&p|v&s|0,(b|f)^(K|E)^(A|G)|0,H^(B|C)|0)|0;H=C;y=Dd(u|0,y|0,l|0,j|0)|0;u=C;j=Dd(B|0,H|0,l|0,j|0)|0;l=C;H=Gd(y|0,u|0,14)|0;B=C;G=Hd(y|0,u|0,50)|0;B=B|C;A=Gd(y|0,u|0,18)|0;E=C;K=Hd(y|0,u|0,46)|0;E=B^(E|C);B=Gd(y|0,u|0,41)|0;f=C;b=Hd(y|0,u|0,23)|0;f=E^(f|C);E=g+160|0;I=c[E>>2]|0;E=c[E+4>>2]|0;M=Dd(J|0,M|0,1495990901,770255983)|0;E=Dd(M|0,C|0,I|0,E|0)|0;f=Dd(E|0,C|0,(H|G)^(A|K)^(B|b)|0,f|0)|0;f=Dd(f|0,C|0,(D^F)&y^D|0,(L^x)&u^L|0)|0;b=C;B=Gd(j|0,l|0,28)|0;K=C;A=Hd(j|0,l|0,36)|0;K=K|C;G=Gd(j|0,l|0,34)|0;H=C;E=Hd(j|0,l|0,30)|0;H=K^(H|C);K=Gd(j|0,l|0,39)|0;I=C;M=Hd(j|0,l|0,25)|0;I=Dd((o|m)&j|o&m|0,(s|p)&l|s&p|0,(B|A)^(G|E)^(K|M)|0,H^(I|C)|0)|0;H=C;v=Dd(r|0,v|0,f|0,b|0)|0;r=C;b=Dd(I|0,H|0,f|0,b|0)|0;f=C;H=Gd(v|0,r|0,14)|0;I=C;M=Hd(v|0,r|0,50)|0;I=I|C;K=Gd(v|0,r|0,18)|0;E=C;G=Hd(v|0,r|0,46)|0;E=I^(E|C);I=Gd(v|0,r|0,41)|0;A=C;B=Hd(v|0,r|0,23)|0;A=E^(A|C);E=g+168|0;J=c[E>>2]|0;E=c[E+4>>2]|0;L=Dd(D|0,L|0,1856431235,1249150122)|0;E=Dd(L|0,C|0,J|0,E|0)|0;A=Dd(E|0,C|0,(H|M)^(K|G)^(I|B)|0,A|0)|0;A=Dd(A|0,C|0,(F^y)&v^F|0,(x^u)&r^x|0)|0;B=C;I=Gd(b|0,f|0,28)|0;G=C;K=Hd(b|0,f|0,36)|0;G=G|C;M=Gd(b|0,f|0,34)|0;H=C;E=Hd(b|0,f|0,30)|0;H=G^(H|C);G=Gd(b|0,f|0,39)|0;J=C;L=Hd(b|0,f|0,25)|0;J=Dd((m|j)&b|m&j|0,(p|l)&f|p&l|0,(I|K)^(M|E)^(G|L)|0,H^(J|C)|0)|0;H=C;s=Dd(o|0,s|0,A|0,B|0)|0;o=C;B=Dd(J|0,H|0,A|0,B|0)|0;A=C;H=Gd(s|0,o|0,14)|0;J=C;L=Hd(s|0,o|0,50)|0;J=J|C;G=Gd(s|0,o|0,18)|0;E=C;M=Hd(s|0,o|0,46)|0;E=J^(E|C);J=Gd(s|0,o|0,41)|0;K=C;I=Hd(s|0,o|0,23)|0;K=E^(K|C);E=g+176|0;D=c[E>>2]|0;E=c[E+4>>2]|0;x=Dd(F|0,x|0,-1119749164,1555081692)|0;E=Dd(x|0,C|0,D|0,E|0)|0;K=Dd(E|0,C|0,(H|L)^(G|M)^(J|I)|0,K|0)|0;K=Dd(K|0,C|0,(y^v)&s^y|0,(u^r)&o^u|0)|0;I=C;J=Gd(B|0,A|0,28)|0;M=C;G=Hd(B|0,A|0,36)|0;M=M|C;L=Gd(B|0,A|0,34)|0;H=C;E=Hd(B|0,A|0,30)|0;H=M^(H|C);M=Gd(B|0,A|0,39)|0;D=C;x=Hd(B|0,A|0,25)|0;D=Dd((j|b)&B|j&b|0,(l|f)&A|l&f|0,(J|G)^(L|E)^(M|x)|0,H^(D|C)|0)|0;H=C;p=Dd(m|0,p|0,K|0,I|0)|0;m=C;I=Dd(D|0,H|0,K|0,I|0)|0;K=C;H=Gd(p|0,m|0,14)|0;D=C;x=Hd(p|0,m|0,50)|0;D=D|C;M=Gd(p|0,m|0,18)|0;E=C;L=Hd(p|0,m|0,46)|0;E=D^(E|C);D=Gd(p|0,m|0,41)|0;G=C;J=Hd(p|0,m|0,23)|0;G=E^(G|C);E=g+184|0;F=c[E>>2]|0;E=c[E+4>>2]|0;u=Dd(y|0,u|0,-2096016459,1996064986)|0;E=Dd(u|0,C|0,F|0,E|0)|0;G=Dd(E|0,C|0,(H|x)^(M|L)^(D|J)|0,G|0)|0;G=Dd(G|0,C|0,(v^s)&p^v|0,(r^o)&m^r|0)|0;J=C;D=Gd(I|0,K|0,28)|0;L=C;M=Hd(I|0,K|0,36)|0;L=L|C;x=Gd(I|0,K|0,34)|0;H=C;E=Hd(I|0,K|0,30)|0;H=L^(H|C);L=Gd(I|0,K|0,39)|0;F=C;u=Hd(I|0,K|0,25)|0;F=Dd((b|B)&I|b&B|0,(f|A)&K|f&A|0,(D|M)^(x|E)^(L|u)|0,H^(F|C)|0)|0;H=C;l=Dd(j|0,l|0,G|0,J|0)|0;j=C;J=Dd(F|0,H|0,G|0,J|0)|0;G=C;H=Gd(l|0,j|0,14)|0;F=C;u=Hd(l|0,j|0,50)|0;F=F|C;L=Gd(l|0,j|0,18)|0;E=C;x=Hd(l|0,j|0,46)|0;E=F^(E|C);F=Gd(l|0,j|0,41)|0;M=C;D=Hd(l|0,j|0,23)|0;M=E^(M|C);E=g+192|0;y=c[E>>2]|0;E=c[E+4>>2]|0;r=Dd(v|0,r|0,-295247957,-1740746414)|0;E=Dd(r|0,C|0,y|0,E|0)|0;M=Dd(E|0,C|0,(H|u)^(L|x)^(F|D)|0,M|0)|0;M=Dd(M|0,C|0,(s^p)&l^s|0,(o^m)&j^o|0)|0;D=C;F=Gd(J|0,G|0,28)|0;x=C;L=Hd(J|0,G|0,36)|0;x=x|C;u=Gd(J|0,G|0,34)|0;H=C;E=Hd(J|0,G|0,30)|0;H=x^(H|C);x=Gd(J|0,G|0,39)|0;y=C;r=Hd(J|0,G|0,25)|0;y=Dd((B|I)&J|B&I|0,(A|K)&G|A&K|0,(F|L)^(u|E)^(x|r)|0,H^(y|C)|0)|0;H=C;f=Dd(b|0,f|0,M|0,D|0)|0;b=C;D=Dd(y|0,H|0,M|0,D|0)|0;M=C;H=Gd(f|0,b|0,14)|0;y=C;r=Hd(f|0,b|0,50)|0;y=y|C;x=Gd(f|0,b|0,18)|0;E=C;u=Hd(f|0,b|0,46)|0;E=y^(E|C);y=Gd(f|0,b|0,41)|0;L=C;F=Hd(f|0,b|0,23)|0;L=E^(L|C);E=g+200|0;v=c[E>>2]|0;E=c[E+4>>2]|0;o=Dd(s|0,o|0,766784016,-1473132947)|0;E=Dd(o|0,C|0,v|0,E|0)|0;L=Dd(E|0,C|0,(H|r)^(x|u)^(y|F)|0,L|0)|0;L=Dd(L|0,C|0,(p^l)&f^p|0,(m^j)&b^m|0)|0;F=C;y=Gd(D|0,M|0,28)|0;u=C;x=Hd(D|0,M|0,36)|0;u=u|C;r=Gd(D|0,M|0,34)|0;H=C;E=Hd(D|0,M|0,30)|0;H=u^(H|C);u=Gd(D|0,M|0,39)|0;v=C;o=Hd(D|0,M|0,25)|0;v=Dd((I|J)&D|I&J|0,(K|G)&M|K&G|0,(y|x)^(r|E)^(u|o)|0,H^(v|C)|0)|0;H=C;A=Dd(B|0,A|0,L|0,F|0)|0;B=C;F=Dd(v|0,H|0,L|0,F|0)|0;L=C;H=Gd(A|0,B|0,14)|0;v=C;o=Hd(A|0,B|0,50)|0;v=v|C;u=Gd(A|0,B|0,18)|0;E=C;r=Hd(A|0,B|0,46)|0;E=v^(E|C);v=Gd(A|0,B|0,41)|0;x=C;y=Hd(A|0,B|0,23)|0;x=E^(x|C);E=g+208|0;s=c[E>>2]|0;E=c[E+4>>2]|0;m=Dd(p|0,m|0,-1728372417,-1341970488)|0;E=Dd(m|0,C|0,s|0,E|0)|0;x=Dd(E|0,C|0,(H|o)^(u|r)^(v|y)|0,x|0)|0;x=Dd(x|0,C|0,(l^f)&A^l|0,(j^b)&B^j|0)|0;y=C;v=Gd(F|0,L|0,28)|0;r=C;u=Hd(F|0,L|0,36)|0;r=r|C;o=Gd(F|0,L|0,34)|0;H=C;E=Hd(F|0,L|0,30)|0;H=r^(H|C);r=Gd(F|0,L|0,39)|0;s=C;m=Hd(F|0,L|0,25)|0;s=Dd((J|D)&F|J&D|0,(G|M)&L|G&M|0,(v|u)^(o|E)^(r|m)|0,H^(s|C)|0)|0;H=C;K=Dd(I|0,K|0,x|0,y|0)|0;I=C;y=Dd(s|0,H|0,x|0,y|0)|0;x=C;H=Gd(K|0,I|0,14)|0;s=C;m=Hd(K|0,I|0,50)|0;s=s|C;r=Gd(K|0,I|0,18)|0;E=C;o=Hd(K|0,I|0,46)|0;E=s^(E|C);s=Gd(K|0,I|0,41)|0;u=C;v=Hd(K|0,I|0,23)|0;u=E^(u|C);E=g+216|0;p=c[E>>2]|0;E=c[E+4>>2]|0;j=Dd(l|0,j|0,-1091629340,-1084653625)|0;E=Dd(j|0,C|0,p|0,E|0)|0;u=Dd(E|0,C|0,(H|m)^(r|o)^(s|v)|0,u|0)|0;u=Dd(u|0,C|0,(f^A)&K^f|0,(b^B)&I^b|0)|0;v=C;s=Gd(y|0,x|0,28)|0;o=C;r=Hd(y|0,x|0,36)|0;o=o|C;m=Gd(y|0,x|0,34)|0;H=C;E=Hd(y|0,x|0,30)|0;H=o^(H|C);o=Gd(y|0,x|0,39)|0;p=C;j=Hd(y|0,x|0,25)|0;p=Dd((D|F)&y|D&F|0,(M|L)&x|M&L|0,(s|r)^(m|E)^(o|j)|0,H^(p|C)|0)|0;H=C;G=Dd(J|0,G|0,u|0,v|0)|0;J=C;v=Dd(p|0,H|0,u|0,v|0)|0;u=C;H=Gd(G|0,J|0,14)|0;p=C;j=Hd(G|0,J|0,50)|0;p=p|C;o=Gd(G|0,J|0,18)|0;E=C;m=Hd(G|0,J|0,46)|0;E=p^(E|C);p=Gd(G|0,J|0,41)|0;r=C;s=Hd(G|0,J|0,23)|0;r=E^(r|C);E=g+224|0;l=c[E>>2]|0;E=c[E+4>>2]|0;b=Dd(f|0,b|0,1034457026,-958395405)|0;E=Dd(b|0,C|0,l|0,E|0)|0;r=Dd(E|0,C|0,(H|j)^(o|m)^(p|s)|0,r|0)|0;r=Dd(r|0,C|0,(A^K)&G^A|0,(B^I)&J^B|0)|0;s=C;p=Gd(v|0,u|0,28)|0;m=C;o=Hd(v|0,u|0,36)|0;m=m|C;j=Gd(v|0,u|0,34)|0;H=C;E=Hd(v|0,u|0,30)|0;H=m^(H|C);m=Gd(v|0,u|0,39)|0;l=C;b=Hd(v|0,u|0,25)|0;l=Dd((F|y)&v|F&y|0,(L|x)&u|L&x|0,(p|o)^(j|E)^(m|b)|0,H^(l|C)|0)|0;H=C;M=Dd(D|0,M|0,r|0,s|0)|0;D=C;s=Dd(l|0,H|0,r|0,s|0)|0;r=C;H=Gd(M|0,D|0,14)|0;l=C;b=Hd(M|0,D|0,50)|0;l=l|C;m=Gd(M|0,D|0,18)|0;E=C;j=Hd(M|0,D|0,46)|0;E=l^(E|C);l=Gd(M|0,D|0,41)|0;o=C;p=Hd(M|0,D|0,23)|0;o=E^(o|C);E=g+232|0;f=c[E>>2]|0;E=c[E+4>>2]|0;B=Dd(A|0,B|0,-1828018395,-710438585)|0;E=Dd(B|0,C|0,f|0,E|0)|0;o=Dd(E|0,C|0,(H|b)^(m|j)^(l|p)|0,o|0)|0;o=Dd(o|0,C|0,(K^G)&M^K|0,(I^J)&D^I|0)|0;p=C;l=Gd(s|0,r|0,28)|0;j=C;m=Hd(s|0,r|0,36)|0;j=j|C;b=Gd(s|0,r|0,34)|0;H=C;E=Hd(s|0,r|0,30)|0;H=j^(H|C);j=Gd(s|0,r|0,39)|0;f=C;B=Hd(s|0,r|0,25)|0;f=Dd((y|v)&s|y&v|0,(x|u)&r|x&u|0,(l|m)^(b|E)^(j|B)|0,H^(f|C)|0)|0;H=C;L=Dd(F|0,L|0,o|0,p|0)|0;F=C;p=Dd(f|0,H|0,o|0,p|0)|0;o=C;H=Gd(L|0,F|0,14)|0;f=C;B=Hd(L|0,F|0,50)|0;f=f|C;j=Gd(L|0,F|0,18)|0;E=C;b=Hd(L|0,F|0,46)|0;E=f^(E|C);f=Gd(L|0,F|0,41)|0;m=C;l=Hd(L|0,F|0,23)|0;m=E^(m|C);E=g+240|0;A=c[E>>2]|0;E=c[E+4>>2]|0;I=Dd(K|0,I|0,-536640913,113926993)|0;E=Dd(I|0,C|0,A|0,E|0)|0;m=Dd(E|0,C|0,(H|B)^(j|b)^(f|l)|0,m|0)|0;m=Dd(m|0,C|0,(G^M)&L^G|0,(J^D)&F^J|0)|0;l=C;f=Gd(p|0,o|0,28)|0;b=C;j=Hd(p|0,o|0,36)|0;b=b|C;B=Gd(p|0,o|0,34)|0;H=C;E=Hd(p|0,o|0,30)|0;H=b^(H|C);b=Gd(p|0,o|0,39)|0;A=C;I=Hd(p|0,o|0,25)|0;A=Dd((v|s)&p|v&s|0,(u|r)&o|u&r|0,(f|j)^(B|E)^(b|I)|0,H^(A|C)|0)|0;H=C;x=Dd(y|0,x|0,m|0,l|0)|0;y=C;l=Dd(A|0,H|0,m|0,l|0)|0;m=C;H=Gd(x|0,y|0,14)|0;A=C;I=Hd(x|0,y|0,50)|0;A=A|C;b=Gd(x|0,y|0,18)|0;E=C;B=Hd(x|0,y|0,46)|0;E=A^(E|C);A=Gd(x|0,y|0,41)|0;j=C;f=Hd(x|0,y|0,23)|0;j=E^(j|C);E=g+248|0;K=c[E>>2]|0;E=c[E+4>>2]|0;J=Dd(G|0,J|0,168717936,338241895)|0;E=Dd(J|0,C|0,K|0,E|0)|0;j=Dd(E|0,C|0,(H|I)^(b|B)^(A|f)|0,j|0)|0;j=Dd(j|0,C|0,(M^L)&x^M|0,(D^F)&y^D|0)|0;f=C;A=Gd(l|0,m|0,28)|0;B=C;b=Hd(l|0,m|0,36)|0;B=B|C;I=Gd(l|0,m|0,34)|0;H=C;E=Hd(l|0,m|0,30)|0;H=B^(H|C);B=Gd(l|0,m|0,39)|0;K=C;J=Hd(l|0,m|0,25)|0;K=Dd((s|p)&l|s&p|0,(r|o)&m|r&o|0,(A|b)^(I|E)^(B|J)|0,H^(K|C)|0)|0;H=C;u=Dd(v|0,u|0,j|0,f|0)|0;v=C;f=Dd(K|0,H|0,j|0,f|0)|0;j=C;H=Gd(u|0,v|0,14)|0;K=C;J=Hd(u|0,v|0,50)|0;K=K|C;B=Gd(u|0,v|0,18)|0;E=C;I=Hd(u|0,v|0,46)|0;E=K^(E|C);K=Gd(u|0,v|0,41)|0;b=C;A=Hd(u|0,v|0,23)|0;b=E^(b|C);E=g+256|0;G=c[E>>2]|0;E=c[E+4>>2]|0;D=Dd(M|0,D|0,1188179964,666307205)|0;E=Dd(D|0,C|0,G|0,E|0)|0;b=Dd(E|0,C|0,(H|J)^(B|I)^(K|A)|0,b|0)|0;b=Dd(b|0,C|0,(L^x)&u^L|0,(F^y)&v^F|0)|0;A=C;K=Gd(f|0,j|0,28)|0;I=C;B=Hd(f|0,j|0,36)|0;I=I|C;J=Gd(f|0,j|0,34)|0;H=C;E=Hd(f|0,j|0,30)|0;H=I^(H|C);I=Gd(f|0,j|0,39)|0;G=C;D=Hd(f|0,j|0,25)|0;G=Dd((p|l)&f|p&l|0,(o|m)&j|o&m|0,(K|B)^(J|E)^(I|D)|0,H^(G|C)|0)|0;H=C;r=Dd(s|0,r|0,b|0,A|0)|0;s=C;A=Dd(G|0,H|0,b|0,A|0)|0;b=C;H=Gd(r|0,s|0,14)|0;G=C;D=Hd(r|0,s|0,50)|0;G=G|C;I=Gd(r|0,s|0,18)|0;E=C;J=Hd(r|0,s|0,46)|0;E=G^(E|C);G=Gd(r|0,s|0,41)|0;B=C;K=Hd(r|0,s|0,23)|0;B=E^(B|C);E=g+264|0;M=c[E>>2]|0;E=c[E+4>>2]|0;F=Dd(L|0,F|0,1546045734,773529912)|0;E=Dd(F|0,C|0,M|0,E|0)|0;B=Dd(E|0,C|0,(H|D)^(I|J)^(G|K)|0,B|0)|0;B=Dd(B|0,C|0,(x^u)&r^x|0,(y^v)&s^y|0)|0;K=C;G=Gd(A|0,b|0,28)|0;J=C;I=Hd(A|0,b|0,36)|0;J=J|C;D=Gd(A|0,b|0,34)|0;H=C;E=Hd(A|0,b|0,30)|0;H=J^(H|C);J=Gd(A|0,b|0,39)|0;M=C;F=Hd(A|0,b|0,25)|0;M=Dd((l|f)&A|l&f|0,(m|j)&b|m&j|0,(G|I)^(D|E)^(J|F)|0,H^(M|C)|0)|0;H=C;o=Dd(p|0,o|0,B|0,K|0)|0;p=C;K=Dd(M|0,H|0,B|0,K|0)|0;B=C;H=Gd(o|0,p|0,14)|0;M=C;F=Hd(o|0,p|0,50)|0;M=M|C;J=Gd(o|0,p|0,18)|0;E=C;D=Hd(o|0,p|0,46)|0;E=M^(E|C);M=Gd(o|0,p|0,41)|0;I=C;G=Hd(o|0,p|0,23)|0;I=E^(I|C);E=g+272|0;L=c[E>>2]|0;E=c[E+4>>2]|0;y=Dd(x|0,y|0,1522805485,1294757372)|0;E=Dd(y|0,C|0,L|0,E|0)|0;I=Dd(E|0,C|0,(H|F)^(J|D)^(M|G)|0,I|0)|0;I=Dd(I|0,C|0,(u^r)&o^u|0,(v^s)&p^v|0)|0;G=C;M=Gd(K|0,B|0,28)|0;D=C;J=Hd(K|0,B|0,36)|0;D=D|C;F=Gd(K|0,B|0,34)|0;H=C;E=Hd(K|0,B|0,30)|0;H=D^(H|C);D=Gd(K|0,B|0,39)|0;L=C;y=Hd(K|0,B|0,25)|0;L=Dd((f|A)&K|f&A|0,(j|b)&B|j&b|0,(M|J)^(F|E)^(D|y)|0,H^(L|C)|0)|0;H=C;m=Dd(l|0,m|0,I|0,G|0)|0;l=C;G=Dd(L|0,H|0,I|0,G|0)|0;I=C;H=Gd(m|0,l|0,14)|0;L=C;y=Hd(m|0,l|0,50)|0;L=L|C;D=Gd(m|0,l|0,18)|0;E=C;F=Hd(m|0,l|0,46)|0;E=L^(E|C);L=Gd(m|0,l|0,41)|0;J=C;M=Hd(m|0,l|0,23)|0;J=E^(J|C);E=g+280|0;x=c[E>>2]|0;E=c[E+4>>2]|0;v=Dd(u|0,v|0,-1651133473,1396182291)|0;E=Dd(v|0,C|0,x|0,E|0)|0;J=Dd(E|0,C|0,(H|y)^(D|F)^(L|M)|0,J|0)|0;J=Dd(J|0,C|0,(r^o)&m^r|0,(s^p)&l^s|0)|0;M=C;L=Gd(G|0,I|0,28)|0;F=C;D=Hd(G|0,I|0,36)|0;F=F|C;y=Gd(G|0,I|0,34)|0;H=C;E=Hd(G|0,I|0,30)|0;H=F^(H|C);F=Gd(G|0,I|0,39)|0;x=C;v=Hd(G|0,I|0,25)|0;x=Dd((A|K)&G|A&K|0,(b|B)&I|b&B|0,(L|D)^(y|E)^(F|v)|0,H^(x|C)|0)|0;H=C;j=Dd(f|0,j|0,J|0,M|0)|0;f=C;M=Dd(x|0,H|0,J|0,M|0)|0;J=C;H=Gd(j|0,f|0,14)|0;x=C;v=Hd(j|0,f|0,50)|0;x=x|C;F=Gd(j|0,f|0,18)|0;E=C;y=Hd(j|0,f|0,46)|0;E=x^(E|C);x=Gd(j|0,f|0,41)|0;D=C;L=Hd(j|0,f|0,23)|0;D=E^(D|C);E=g+288|0;u=c[E>>2]|0;E=c[E+4>>2]|0;s=Dd(r|0,s|0,-1951439906,1695183700)|0;E=Dd(s|0,C|0,u|0,E|0)|0;D=Dd(E|0,C|0,(H|v)^(F|y)^(x|L)|0,D|0)|0;D=Dd(D|0,C|0,(o^m)&j^o|0,(p^l)&f^p|0)|0;L=C;x=Gd(M|0,J|0,28)|0;y=C;F=Hd(M|0,J|0,36)|0;y=y|C;v=Gd(M|0,J|0,34)|0;H=C;E=Hd(M|0,J|0,30)|0;H=y^(H|C);y=Gd(M|0,J|0,39)|0;u=C;s=Hd(M|0,J|0,25)|0;u=Dd((K|G)&M|K&G|0,(B|I)&J|B&I|0,(x|F)^(v|E)^(y|s)|0,H^(u|C)|0)|0;H=C;b=Dd(A|0,b|0,D|0,L|0)|0;A=C;L=Dd(u|0,H|0,D|0,L|0)|0;D=C;H=Gd(b|0,A|0,14)|0;u=C;s=Hd(b|0,A|0,50)|0;u=u|C;y=Gd(b|0,A|0,18)|0;E=C;v=Hd(b|0,A|0,46)|0;E=u^(E|C);u=Gd(b|0,A|0,41)|0;F=C;x=Hd(b|0,A|0,23)|0;F=E^(F|C);E=g+296|0;r=c[E>>2]|0;E=c[E+4>>2]|0;p=Dd(o|0,p|0,1014477480,1986661051)|0;E=Dd(p|0,C|0,r|0,E|0)|0;F=Dd(E|0,C|0,(H|s)^(y|v)^(u|x)|0,F|0)|0;F=Dd(F|0,C|0,(m^j)&b^m|0,(l^f)&A^l|0)|0;x=C;u=Gd(L|0,D|0,28)|0;v=C;y=Hd(L|0,D|0,36)|0;v=v|C;s=Gd(L|0,D|0,34)|0;H=C;E=Hd(L|0,D|0,30)|0;H=v^(H|C);v=Gd(L|0,D|0,39)|0;r=C;p=Hd(L|0,D|0,25)|0;r=Dd((G|M)&L|G&M|0,(I|J)&D|I&J|0,(u|y)^(s|E)^(v|p)|0,H^(r|C)|0)|0;H=C;B=Dd(K|0,B|0,F|0,x|0)|0;K=C;x=Dd(r|0,H|0,F|0,x|0)|0;F=C;H=Gd(B|0,K|0,14)|0;r=C;p=Hd(B|0,K|0,50)|0;r=r|C;v=Gd(B|0,K|0,18)|0;E=C;s=Hd(B|0,K|0,46)|0;E=r^(E|C);r=Gd(B|0,K|0,41)|0;y=C;u=Hd(B|0,K|0,23)|0;y=E^(y|C);E=g+304|0;o=c[E>>2]|0;E=c[E+4>>2]|0;l=Dd(m|0,l|0,1206759142,-2117940946)|0;E=Dd(l|0,C|0,o|0,E|0)|0;y=Dd(E|0,C|0,(H|p)^(v|s)^(r|u)|0,y|0)|0;y=Dd(y|0,C|0,(j^b)&B^j|0,(f^A)&K^f|0)|0;u=C;r=Gd(x|0,F|0,28)|0;s=C;v=Hd(x|0,F|0,36)|0;s=s|C;p=Gd(x|0,F|0,34)|0;H=C;E=Hd(x|0,F|0,30)|0;H=s^(H|C);s=Gd(x|0,F|0,39)|0;o=C;l=Hd(x|0,F|0,25)|0;o=Dd((M|L)&x|M&L|0,(J|D)&F|J&D|0,(r|v)^(p|E)^(s|l)|0,H^(o|C)|0)|0;H=C;I=Dd(G|0,I|0,y|0,u|0)|0;G=C;u=Dd(o|0,H|0,y|0,u|0)|0;y=C;H=Gd(I|0,G|0,14)|0;o=C;l=Hd(I|0,G|0,50)|0;o=o|C;s=Gd(I|0,G|0,18)|0;E=C;p=Hd(I|0,G|0,46)|0;E=o^(E|C);o=Gd(I|0,G|0,41)|0;v=C;r=Hd(I|0,G|0,23)|0;v=E^(v|C);E=g+312|0;m=c[E>>2]|0;E=c[E+4>>2]|0;f=Dd(j|0,f|0,344077627,-1838011259)|0;E=Dd(f|0,C|0,m|0,E|0)|0;v=Dd(E|0,C|0,(H|l)^(s|p)^(o|r)|0,v|0)|0;v=Dd(v|0,C|0,(b^B)&I^b|0,(A^K)&G^A|0)|0;r=C;o=Gd(u|0,y|0,28)|0;p=C;s=Hd(u|0,y|0,36)|0;p=p|C;l=Gd(u|0,y|0,34)|0;H=C;E=Hd(u|0,y|0,30)|0;H=p^(H|C);p=Gd(u|0,y|0,39)|0;m=C;f=Hd(u|0,y|0,25)|0;m=Dd((L|x)&u|L&x|0,(D|F)&y|D&F|0,(o|s)^(l|E)^(p|f)|0,H^(m|C)|0)|0;H=C;J=Dd(M|0,J|0,v|0,r|0)|0;M=C;r=Dd(m|0,H|0,v|0,r|0)|0;v=C;H=Gd(J|0,M|0,14)|0;m=C;f=Hd(J|0,M|0,50)|0;m=m|C;p=Gd(J|0,M|0,18)|0;E=C;l=Hd(J|0,M|0,46)|0;E=m^(E|C);m=Gd(J|0,M|0,41)|0;s=C;o=Hd(J|0,M|0,23)|0;s=E^(s|C);E=g+320|0;j=c[E>>2]|0;E=c[E+4>>2]|0;A=Dd(b|0,A|0,1290863460,-1564481375)|0;E=Dd(A|0,C|0,j|0,E|0)|0;s=Dd(E|0,C|0,(H|f)^(p|l)^(m|o)|0,s|0)|0;s=Dd(s|0,C|0,(B^I)&J^B|0,(K^G)&M^K|0)|0;o=C;m=Gd(r|0,v|0,28)|0;l=C;p=Hd(r|0,v|0,36)|0;l=l|C;f=Gd(r|0,v|0,34)|0;H=C;E=Hd(r|0,v|0,30)|0;H=l^(H|C);l=Gd(r|0,v|0,39)|0;j=C;A=Hd(r|0,v|0,25)|0;j=Dd((x|u)&r|x&u|0,(F|y)&v|F&y|0,(m|p)^(f|E)^(l|A)|0,H^(j|C)|0)|0;H=C;D=Dd(L|0,D|0,s|0,o|0)|0;L=C;o=Dd(j|0,H|0,s|0,o|0)|0;s=C;H=Gd(D|0,L|0,14)|0;j=C;A=Hd(D|0,L|0,50)|0;j=j|C;l=Gd(D|0,L|0,18)|0;E=C;f=Hd(D|0,L|0,46)|0;E=j^(E|C);j=Gd(D|0,L|0,41)|0;p=C;m=Hd(D|0,L|0,23)|0;p=E^(p|C);E=g+328|0;b=c[E>>2]|0;E=c[E+4>>2]|0;K=Dd(B|0,K|0,-1136513023,-1474664885)|0;E=Dd(K|0,C|0,b|0,E|0)|0;p=Dd(E|0,C|0,(H|A)^(l|f)^(j|m)|0,p|0)|0;p=Dd(p|0,C|0,(I^J)&D^I|0,(G^M)&L^G|0)|0;m=C;j=Gd(o|0,s|0,28)|0;f=C;l=Hd(o|0,s|0,36)|0;f=f|C;A=Gd(o|0,s|0,34)|0;H=C;E=Hd(o|0,s|0,30)|0;H=f^(H|C);f=Gd(o|0,s|0,39)|0;b=C;K=Hd(o|0,s|0,25)|0;b=Dd((u|r)&o|u&r|0,(y|v)&s|y&v|0,(j|l)^(A|E)^(f|K)|0,H^(b|C)|0)|0;H=C;F=Dd(x|0,F|0,p|0,m|0)|0;x=C;m=Dd(b|0,H|0,p|0,m|0)|0;p=C;H=Gd(F|0,x|0,14)|0;b=C;K=Hd(F|0,x|0,50)|0;b=b|C;f=Gd(F|0,x|0,18)|0;E=C;A=Hd(F|0,x|0,46)|0;E=b^(E|C);b=Gd(F|0,x|0,41)|0;l=C;j=Hd(F|0,x|0,23)|0;l=E^(l|C);E=g+336|0;B=c[E>>2]|0;E=c[E+4>>2]|0;G=Dd(I|0,G|0,-789014639,-1035236496)|0;E=Dd(G|0,C|0,B|0,E|0)|0;l=Dd(E|0,C|0,(H|K)^(f|A)^(b|j)|0,l|0)|0;l=Dd(l|0,C|0,(J^D)&F^J|0,(M^L)&x^M|0)|0;j=C;b=Gd(m|0,p|0,28)|0;A=C;f=Hd(m|0,p|0,36)|0;A=A|C;K=Gd(m|0,p|0,34)|0;H=C;E=Hd(m|0,p|0,30)|0;H=A^(H|C);A=Gd(m|0,p|0,39)|0;B=C;G=Hd(m|0,p|0,25)|0;B=Dd((r|o)&m|r&o|0,(v|s)&p|v&s|0,(b|f)^(K|E)^(A|G)|0,H^(B|C)|0)|0;H=C;y=Dd(u|0,y|0,l|0,j|0)|0;u=C;j=Dd(B|0,H|0,l|0,j|0)|0;l=C;H=Gd(y|0,u|0,14)|0;B=C;G=Hd(y|0,u|0,50)|0;B=B|C;A=Gd(y|0,u|0,18)|0;E=C;K=Hd(y|0,u|0,46)|0;E=B^(E|C);B=Gd(y|0,u|0,41)|0;f=C;b=Hd(y|0,u|0,23)|0;f=E^(f|C);E=g+344|0;I=c[E>>2]|0;E=c[E+4>>2]|0;M=Dd(J|0,M|0,106217008,-949202525)|0;E=Dd(M|0,C|0,I|0,E|0)|0;f=Dd(E|0,C|0,(H|G)^(A|K)^(B|b)|0,f|0)|0;f=Dd(f|0,C|0,(D^F)&y^D|0,(L^x)&u^L|0)|0;b=C;B=Gd(j|0,l|0,28)|0;K=C;A=Hd(j|0,l|0,36)|0;K=K|C;G=Gd(j|0,l|0,34)|0;H=C;E=Hd(j|0,l|0,30)|0;H=K^(H|C);K=Gd(j|0,l|0,39)|0;I=C;M=Hd(j|0,l|0,25)|0;I=Dd((o|m)&j|o&m|0,(s|p)&l|s&p|0,(B|A)^(G|E)^(K|M)|0,H^(I|C)|0)|0;H=C;v=Dd(r|0,v|0,f|0,b|0)|0;r=C;b=Dd(I|0,H|0,f|0,b|0)|0;f=C;H=Gd(v|0,r|0,14)|0;I=C;M=Hd(v|0,r|0,50)|0;I=I|C;K=Gd(v|0,r|0,18)|0;E=C;G=Hd(v|0,r|0,46)|0;E=I^(E|C);I=Gd(v|0,r|0,41)|0;A=C;B=Hd(v|0,r|0,23)|0;A=E^(A|C);E=g+352|0;J=c[E>>2]|0;E=c[E+4>>2]|0;L=Dd(D|0,L|0,-688958952,-778901479)|0;E=Dd(L|0,C|0,J|0,E|0)|0;A=Dd(E|0,C|0,(H|M)^(K|G)^(I|B)|0,A|0)|0;A=Dd(A|0,C|0,(F^y)&v^F|0,(x^u)&r^x|0)|0;B=C;I=Gd(b|0,f|0,28)|0;G=C;K=Hd(b|0,f|0,36)|0;G=G|C;M=Gd(b|0,f|0,34)|0;H=C;E=Hd(b|0,f|0,30)|0;H=G^(H|C);G=Gd(b|0,f|0,39)|0;J=C;L=Hd(b|0,f|0,25)|0;J=Dd((m|j)&b|m&j|0,(p|l)&f|p&l|0,(I|K)^(M|E)^(G|L)|0,H^(J|C)|0)|0;H=C;s=Dd(o|0,s|0,A|0,B|0)|0;o=C;B=Dd(J|0,H|0,A|0,B|0)|0;A=C;H=Gd(s|0,o|0,14)|0;J=C;L=Hd(s|0,o|0,50)|0;J=J|C;G=Gd(s|0,o|0,18)|0;E=C;M=Hd(s|0,o|0,46)|0;E=J^(E|C);J=Gd(s|0,o|0,41)|0;K=C;I=Hd(s|0,o|0,23)|0;K=E^(K|C);E=g+360|0;D=c[E>>2]|0;E=c[E+4>>2]|0;x=Dd(F|0,x|0,1432725776,-694614492)|0;E=Dd(x|0,C|0,D|0,E|0)|0;K=Dd(E|0,C|0,(H|L)^(G|M)^(J|I)|0,K|0)|0;K=Dd(K|0,C|0,(y^v)&s^y|0,(u^r)&o^u|0)|0;I=C;J=Gd(B|0,A|0,28)|0;M=C;G=Hd(B|0,A|0,36)|0;M=M|C;L=Gd(B|0,A|0,34)|0;H=C;E=Hd(B|0,A|0,30)|0;H=M^(H|C);M=Gd(B|0,A|0,39)|0;D=C;x=Hd(B|0,A|0,25)|0;D=Dd((j|b)&B|j&b|0,(l|f)&A|l&f|0,(J|G)^(L|E)^(M|x)|0,H^(D|C)|0)|0;H=C;p=Dd(m|0,p|0,K|0,I|0)|0;m=C;I=Dd(D|0,H|0,K|0,I|0)|0;K=C;H=Gd(p|0,m|0,14)|0;D=C;x=Hd(p|0,m|0,50)|0;D=D|C;M=Gd(p|0,m|0,18)|0;E=C;L=Hd(p|0,m|0,46)|0;E=D^(E|C);D=Gd(p|0,m|0,41)|0;G=C;J=Hd(p|0,m|0,23)|0;G=E^(G|C);E=g+368|0;F=c[E>>2]|0;E=c[E+4>>2]|0;u=Dd(y|0,u|0,1467031594,-200395387)|0;E=Dd(u|0,C|0,F|0,E|0)|0;G=Dd(E|0,C|0,(H|x)^(M|L)^(D|J)|0,G|0)|0;G=Dd(G|0,C|0,(v^s)&p^v|0,(r^o)&m^r|0)|0;J=C;D=Gd(I|0,K|0,28)|0;L=C;M=Hd(I|0,K|0,36)|0;L=L|C;x=Gd(I|0,K|0,34)|0;H=C;E=Hd(I|0,K|0,30)|0;H=L^(H|C);L=Gd(I|0,K|0,39)|0;F=C;u=Hd(I|0,K|0,25)|0;F=Dd((b|B)&I|b&B|0,(f|A)&K|f&A|0,(D|M)^(x|E)^(L|u)|0,H^(F|C)|0)|0;H=C;l=Dd(j|0,l|0,G|0,J|0)|0;j=C;J=Dd(F|0,H|0,G|0,J|0)|0;G=C;H=Gd(l|0,j|0,14)|0;F=C;u=Hd(l|0,j|0,50)|0;F=F|C;L=Gd(l|0,j|0,18)|0;E=C;x=Hd(l|0,j|0,46)|0;E=F^(E|C);F=Gd(l|0,j|0,41)|0;M=C;D=Hd(l|0,j|0,23)|0;M=E^(M|C);E=g+376|0;y=c[E>>2]|0;E=c[E+4>>2]|0;r=Dd(v|0,r|0,851169720,275423344)|0;E=Dd(r|0,C|0,y|0,E|0)|0;M=Dd(E|0,C|0,(H|u)^(L|x)^(F|D)|0,M|0)|0;M=Dd(M|0,C|0,(s^p)&l^s|0,(o^m)&j^o|0)|0;D=C;F=Gd(J|0,G|0,28)|0;x=C;L=Hd(J|0,G|0,36)|0;x=x|C;u=Gd(J|0,G|0,34)|0;H=C;E=Hd(J|0,G|0,30)|0;H=x^(H|C);x=Gd(J|0,G|0,39)|0;y=C;r=Hd(J|0,G|0,25)|0;y=Dd((B|I)&J|B&I|0,(A|K)&G|A&K|0,(F|L)^(u|E)^(x|r)|0,H^(y|C)|0)|0;H=C;f=Dd(b|0,f|0,M|0,D|0)|0;b=C;D=Dd(y|0,H|0,M|0,D|0)|0;M=C;H=Gd(f|0,b|0,14)|0;y=C;r=Hd(f|0,b|0,50)|0;y=y|C;x=Gd(f|0,b|0,18)|0;E=C;u=Hd(f|0,b|0,46)|0;E=y^(E|C);y=Gd(f|0,b|0,41)|0;L=C;F=Hd(f|0,b|0,23)|0;L=E^(L|C);E=g+384|0;v=c[E>>2]|0;E=c[E+4>>2]|0;o=Dd(s|0,o|0,-1194143544,430227734)|0;E=Dd(o|0,C|0,v|0,E|0)|0;L=Dd(E|0,C|0,(H|r)^(x|u)^(y|F)|0,L|0)|0;L=Dd(L|0,C|0,(p^l)&f^p|0,(m^j)&b^m|0)|0;F=C;y=Gd(D|0,M|0,28)|0;u=C;x=Hd(D|0,M|0,36)|0;u=u|C;r=Gd(D|0,M|0,34)|0;H=C;E=Hd(D|0,M|0,30)|0;H=u^(H|C);u=Gd(D|0,M|0,39)|0;v=C;o=Hd(D|0,M|0,25)|0;v=Dd((I|J)&D|I&J|0,(K|G)&M|K&G|0,(y|x)^(r|E)^(u|o)|0,H^(v|C)|0)|0;H=C;A=Dd(B|0,A|0,L|0,F|0)|0;B=C;F=Dd(v|0,H|0,L|0,F|0)|0;L=C;H=Gd(A|0,B|0,14)|0;v=C;o=Hd(A|0,B|0,50)|0;v=v|C;u=Gd(A|0,B|0,18)|0;E=C;r=Hd(A|0,B|0,46)|0;E=v^(E|C);v=Gd(A|0,B|0,41)|0;x=C;y=Hd(A|0,B|0,23)|0;x=E^(x|C);E=g+392|0;s=c[E>>2]|0;E=c[E+4>>2]|0;m=Dd(p|0,m|0,1363258195,506948616)|0;E=Dd(m|0,C|0,s|0,E|0)|0;x=Dd(E|0,C|0,(H|o)^(u|r)^(v|y)|0,x|0)|0;x=Dd(x|0,C|0,(l^f)&A^l|0,(j^b)&B^j|0)|0;y=C;v=Gd(F|0,L|0,28)|0;r=C;u=Hd(F|0,L|0,36)|0;r=r|C;o=Gd(F|0,L|0,34)|0;H=C;E=Hd(F|0,L|0,30)|0;H=r^(H|C);r=Gd(F|0,L|0,39)|0;s=C;m=Hd(F|0,L|0,25)|0;s=Dd((J|D)&F|J&D|0,(G|M)&L|G&M|0,(v|u)^(o|E)^(r|m)|0,H^(s|C)|0)|0;H=C;K=Dd(I|0,K|0,x|0,y|0)|0;I=C;y=Dd(s|0,H|0,x|0,y|0)|0;x=C;H=Gd(K|0,I|0,14)|0;s=C;m=Hd(K|0,I|0,50)|0;s=s|C;r=Gd(K|0,I|0,18)|0;E=C;o=Hd(K|0,I|0,46)|0;E=s^(E|C);s=Gd(K|0,I|0,41)|0;u=C;v=Hd(K|0,I|0,23)|0;u=E^(u|C);E=g+400|0;p=c[E>>2]|0;E=c[E+4>>2]|0;j=Dd(l|0,j|0,-544281703,659060556)|0;E=Dd(j|0,C|0,p|0,E|0)|0;u=Dd(E|0,C|0,(H|m)^(r|o)^(s|v)|0,u|0)|0;u=Dd(u|0,C|0,(f^A)&K^f|0,(b^B)&I^b|0)|0;v=C;s=Gd(y|0,x|0,28)|0;o=C;r=Hd(y|0,x|0,36)|0;o=o|C;m=Gd(y|0,x|0,34)|0;H=C;E=Hd(y|0,x|0,30)|0;H=o^(H|C);o=Gd(y|0,x|0,39)|0;p=C;j=Hd(y|0,x|0,25)|0;p=Dd((D|F)&y|D&F|0,(M|L)&x|M&L|0,(s|r)^(m|E)^(o|j)|0,H^(p|C)|0)|0;H=C;G=Dd(J|0,G|0,u|0,v|0)|0;J=C;v=Dd(p|0,H|0,u|0,v|0)|0;u=C;H=Gd(G|0,J|0,14)|0;p=C;j=Hd(G|0,J|0,50)|0;p=p|C;o=Gd(G|0,J|0,18)|0;E=C;m=Hd(G|0,J|0,46)|0;E=p^(E|C);p=Gd(G|0,J|0,41)|0;r=C;s=Hd(G|0,J|0,23)|0;r=E^(r|C);E=g+408|0;l=c[E>>2]|0;E=c[E+4>>2]|0;b=Dd(f|0,b|0,-509917016,883997877)|0;E=Dd(b|0,C|0,l|0,E|0)|0;r=Dd(E|0,C|0,(H|j)^(o|m)^(p|s)|0,r|0)|0;r=Dd(r|0,C|0,(A^K)&G^A|0,(B^I)&J^B|0)|0;s=C;p=Gd(v|0,u|0,28)|0;m=C;o=Hd(v|0,u|0,36)|0;m=m|C;j=Gd(v|0,u|0,34)|0;H=C;E=Hd(v|0,u|0,30)|0;H=m^(H|C);m=Gd(v|0,u|0,39)|0;l=C;b=Hd(v|0,u|0,25)|0;l=Dd((F|y)&v|F&y|0,(L|x)&u|L&x|0,(p|o)^(j|E)^(m|b)|0,H^(l|C)|0)|0;H=C;M=Dd(D|0,M|0,r|0,s|0)|0;D=C;s=Dd(l|0,H|0,r|0,s|0)|0;r=C;H=Gd(M|0,D|0,14)|0;l=C;b=Hd(M|0,D|0,50)|0;l=l|C;m=Gd(M|0,D|0,18)|0;E=C;j=Hd(M|0,D|0,46)|0;E=l^(E|C);l=Gd(M|0,D|0,41)|0;o=C;p=Hd(M|0,D|0,23)|0;o=E^(o|C);E=g+416|0;f=c[E>>2]|0;E=c[E+4>>2]|0;B=Dd(A|0,B|0,-976659869,958139571)|0;E=Dd(B|0,C|0,f|0,E|0)|0;o=Dd(E|0,C|0,(H|b)^(m|j)^(l|p)|0,o|0)|0;o=Dd(o|0,C|0,(K^G)&M^K|0,(I^J)&D^I|0)|0;p=C;l=Gd(s|0,r|0,28)|0;j=C;m=Hd(s|0,r|0,36)|0;j=j|C;b=Gd(s|0,r|0,34)|0;H=C;E=Hd(s|0,r|0,30)|0;H=j^(H|C);j=Gd(s|0,r|0,39)|0;f=C;B=Hd(s|0,r|0,25)|0;f=Dd((y|v)&s|y&v|0,(x|u)&r|x&u|0,(l|m)^(b|E)^(j|B)|0,H^(f|C)|0)|0;H=C;L=Dd(F|0,L|0,o|0,p|0)|0;F=C;p=Dd(f|0,H|0,o|0,p|0)|0;o=C;H=Gd(L|0,F|0,14)|0;f=C;B=Hd(L|0,F|0,50)|0;f=f|C;j=Gd(L|0,F|0,18)|0;E=C;b=Hd(L|0,F|0,46)|0;E=f^(E|C);f=Gd(L|0,F|0,41)|0;m=C;l=Hd(L|0,F|0,23)|0;m=E^(m|C);E=g+424|0;A=c[E>>2]|0;E=c[E+4>>2]|0;I=Dd(K|0,I|0,-482243893,1322822218)|0;E=Dd(I|0,C|0,A|0,E|0)|0;m=Dd(E|0,C|0,(H|B)^(j|b)^(f|l)|0,m|0)|0;m=Dd(m|0,C|0,(G^M)&L^G|0,(J^D)&F^J|0)|0;l=C;f=Gd(p|0,o|0,28)|0;b=C;j=Hd(p|0,o|0,36)|0;b=b|C;B=Gd(p|0,o|0,34)|0;H=C;E=Hd(p|0,o|0,30)|0;H=b^(H|C);b=Gd(p|0,o|0,39)|0;A=C;I=Hd(p|0,o|0,25)|0;A=Dd((v|s)&p|v&s|0,(u|r)&o|u&r|0,(f|j)^(B|E)^(b|I)|0,H^(A|C)|0)|0;H=C;x=Dd(y|0,x|0,m|0,l|0)|0;y=C;l=Dd(A|0,H|0,m|0,l|0)|0;m=C;H=Gd(x|0,y|0,14)|0;A=C;I=Hd(x|0,y|0,50)|0;A=A|C;b=Gd(x|0,y|0,18)|0;E=C;B=Hd(x|0,y|0,46)|0;E=A^(E|C);A=Gd(x|0,y|0,41)|0;j=C;f=Hd(x|0,y|0,23)|0;j=E^(j|C);E=g+432|0;K=c[E>>2]|0;E=c[E+4>>2]|0;J=Dd(G|0,J|0,2003034995,1537002063)|0;E=Dd(J|0,C|0,K|0,E|0)|0;j=Dd(E|0,C|0,(H|I)^(b|B)^(A|f)|0,j|0)|0;j=Dd(j|0,C|0,(M^L)&x^M|0,(D^F)&y^D|0)|0;f=C;A=Gd(l|0,m|0,28)|0;B=C;b=Hd(l|0,m|0,36)|0;B=B|C;I=Gd(l|0,m|0,34)|0;H=C;E=Hd(l|0,m|0,30)|0;H=B^(H|C);B=Gd(l|0,m|0,39)|0;K=C;J=Hd(l|0,m|0,25)|0;K=Dd((s|p)&l|s&p|0,(r|o)&m|r&o|0,(A|b)^(I|E)^(B|J)|0,H^(K|C)|0)|0;H=C;u=Dd(v|0,u|0,j|0,f|0)|0;v=C;f=Dd(K|0,H|0,j|0,f|0)|0;j=C;H=Gd(u|0,v|0,14)|0;K=C;J=Hd(u|0,v|0,50)|0;K=K|C;B=Gd(u|0,v|0,18)|0;E=C;I=Hd(u|0,v|0,46)|0;E=K^(E|C);K=Gd(u|0,v|0,41)|0;b=C;A=Hd(u|0,v|0,23)|0;b=E^(b|C);E=g+440|0;G=c[E>>2]|0;E=c[E+4>>2]|0;D=Dd(M|0,D|0,-692930397,1747873779)|0;E=Dd(D|0,C|0,G|0,E|0)|0;b=Dd(E|0,C|0,(H|J)^(B|I)^(K|A)|0,b|0)|0;b=Dd(b|0,C|0,(L^x)&u^L|0,(F^y)&v^F|0)|0;A=C;K=Gd(f|0,j|0,28)|0;I=C;B=Hd(f|0,j|0,36)|0;I=I|C;J=Gd(f|0,j|0,34)|0;H=C;E=Hd(f|0,j|0,30)|0;H=I^(H|C);I=Gd(f|0,j|0,39)|0;G=C;D=Hd(f|0,j|0,25)|0;G=Dd((p|l)&f|p&l|0,(o|m)&j|o&m|0,(K|B)^(J|E)^(I|D)|0,H^(G|C)|0)|0;H=C;r=Dd(s|0,r|0,b|0,A|0)|0;s=C;A=Dd(G|0,H|0,b|0,A|0)|0;b=C;H=Gd(r|0,s|0,14)|0;G=C;D=Hd(r|0,s|0,50)|0;G=G|C;I=Gd(r|0,s|0,18)|0;E=C;J=Hd(r|0,s|0,46)|0;E=G^(E|C);G=Gd(r|0,s|0,41)|0;B=C;K=Hd(r|0,s|0,23)|0;B=E^(B|C);E=g+448|0;M=c[E>>2]|0;E=c[E+4>>2]|0;F=Dd(L|0,F|0,1575990012,1955562222)|0;E=Dd(F|0,C|0,M|0,E|0)|0;B=Dd(E|0,C|0,(H|D)^(I|J)^(G|K)|0,B|0)|0;B=Dd(B|0,C|0,(x^u)&r^x|0,(y^v)&s^y|0)|0;K=C;G=Gd(A|0,b|0,28)|0;J=C;I=Hd(A|0,b|0,36)|0;J=J|C;D=Gd(A|0,b|0,34)|0;H=C;E=Hd(A|0,b|0,30)|0;H=J^(H|C);J=Gd(A|0,b|0,39)|0;M=C;F=Hd(A|0,b|0,25)|0;M=Dd((l|f)&A|l&f|0,(m|j)&b|m&j|0,(G|I)^(D|E)^(J|F)|0,H^(M|C)|0)|0;H=C;o=Dd(p|0,o|0,B|0,K|0)|0;p=C;K=Dd(M|0,H|0,B|0,K|0)|0;B=C;H=Gd(o|0,p|0,14)|0;M=C;F=Hd(o|0,p|0,50)|0;M=M|C;J=Gd(o|0,p|0,18)|0;E=C;D=Hd(o|0,p|0,46)|0;E=M^(E|C);M=Gd(o|0,p|0,41)|0;I=C;G=Hd(o|0,p|0,23)|0;I=E^(I|C);E=g+456|0;L=c[E>>2]|0;E=c[E+4>>2]|0;y=Dd(x|0,y|0,1125592928,2024104815)|0;E=Dd(y|0,C|0,L|0,E|0)|0;I=Dd(E|0,C|0,(H|F)^(J|D)^(M|G)|0,I|0)|0;I=Dd(I|0,C|0,(u^r)&o^u|0,(v^s)&p^v|0)|0;G=C;M=Gd(K|0,B|0,28)|0;D=C;J=Hd(K|0,B|0,36)|0;D=D|C;F=Gd(K|0,B|0,34)|0;H=C;E=Hd(K|0,B|0,30)|0;H=D^(H|C);D=Gd(K|0,B|0,39)|0;L=C;y=Hd(K|0,B|0,25)|0;L=Dd((f|A)&K|f&A|0,(j|b)&B|j&b|0,(M|J)^(F|E)^(D|y)|0,H^(L|C)|0)|0;H=C;m=Dd(l|0,m|0,I|0,G|0)|0;l=C;G=Dd(L|0,H|0,I|0,G|0)|0;I=C;H=Gd(m|0,l|0,14)|0;L=C;y=Hd(m|0,l|0,50)|0;L=L|C;D=Gd(m|0,l|0,18)|0;E=C;F=Hd(m|0,l|0,46)|0;E=L^(E|C);L=Gd(m|0,l|0,41)|0;J=C;M=Hd(m|0,l|0,23)|0;J=E^(J|C);E=g+464|0;x=c[E>>2]|0;E=c[E+4>>2]|0;v=Dd(u|0,v|0,-1578062990,-2067236844)|0;E=Dd(v|0,C|0,x|0,E|0)|0;J=Dd(E|0,C|0,(H|y)^(D|F)^(L|M)|0,J|0)|0;J=Dd(J|0,C|0,(r^o)&m^r|0,(s^p)&l^s|0)|0;M=C;L=Gd(G|0,I|0,28)|0;F=C;D=Hd(G|0,I|0,36)|0;F=F|C;y=Gd(G|0,I|0,34)|0;H=C;E=Hd(G|0,I|0,30)|0;H=F^(H|C);F=Gd(G|0,I|0,39)|0;x=C;v=Hd(G|0,I|0,25)|0;x=Dd((A|K)&G|A&K|0,(b|B)&I|b&B|0,(L|D)^(y|E)^(F|v)|0,H^(x|C)|0)|0;H=C;j=Dd(f|0,j|0,J|0,M|0)|0;f=C;M=Dd(x|0,H|0,J|0,M|0)|0;J=C;H=Gd(j|0,f|0,14)|0;x=C;v=Hd(j|0,f|0,50)|0;x=x|C;F=Gd(j|0,f|0,18)|0;E=C;y=Hd(j|0,f|0,46)|0;E=x^(E|C);x=Gd(j|0,f|0,41)|0;D=C;L=Hd(j|0,f|0,23)|0;D=E^(D|C);E=g+472|0;u=c[E>>2]|0;E=c[E+4>>2]|0;s=Dd(r|0,s|0,442776044,-1933114872)|0;E=Dd(s|0,C|0,u|0,E|0)|0;D=Dd(E|0,C|0,(H|v)^(F|y)^(x|L)|0,D|0)|0;D=Dd(D|0,C|0,(o^m)&j^o|0,(p^l)&f^p|0)|0;L=C;x=Gd(M|0,J|0,28)|0;y=C;F=Hd(M|0,J|0,36)|0;y=y|C;v=Gd(M|0,J|0,34)|0;H=C;E=Hd(M|0,J|0,30)|0;H=y^(H|C);y=Gd(M|0,J|0,39)|0;u=C;s=Hd(M|0,J|0,25)|0;u=Dd((K|G)&M|K&G|0,(B|I)&J|B&I|0,(x|F)^(v|E)^(y|s)|0,H^(u|C)|0)|0;H=C;b=Dd(A|0,b|0,D|0,L|0)|0;A=C;L=Dd(u|0,H|0,D|0,L|0)|0;D=C;H=Gd(b|0,A|0,14)|0;u=C;s=Hd(b|0,A|0,50)|0;u=u|C;y=Gd(b|0,A|0,18)|0;E=C;v=Hd(b|0,A|0,46)|0;E=u^(E|C);u=Gd(b|0,A|0,41)|0;F=C;x=Hd(b|0,A|0,23)|0;F=E^(F|C);E=g+480|0;r=c[E>>2]|0;E=c[E+4>>2]|0;p=Dd(o|0,p|0,593698344,-1866530822)|0;E=Dd(p|0,C|0,r|0,E|0)|0;F=Dd(E|0,C|0,(H|s)^(y|v)^(u|x)|0,F|0)|0;F=Dd(F|0,C|0,(m^j)&b^m|0,(l^f)&A^l|0)|0;x=C;u=Gd(L|0,D|0,28)|0;v=C;y=Hd(L|0,D|0,36)|0;v=v|C;s=Gd(L|0,D|0,34)|0;H=C;E=Hd(L|0,D|0,30)|0;H=v^(H|C);v=Gd(L|0,D|0,39)|0;r=C;p=Hd(L|0,D|0,25)|0;r=Dd((G|M)&L|G&M|0,(I|J)&D|I&J|0,(u|y)^(s|E)^(v|p)|0,H^(r|C)|0)|0;H=C;B=Dd(K|0,B|0,F|0,x|0)|0;K=C;x=Dd(r|0,H|0,F|0,x|0)|0;F=C;H=Gd(B|0,K|0,14)|0;r=C;p=Hd(B|0,K|0,50)|0;r=r|C;v=Gd(B|0,K|0,18)|0;E=C;s=Hd(B|0,K|0,46)|0;E=r^(E|C);r=Gd(B|0,K|0,41)|0;y=C;u=Hd(B|0,K|0,23)|0;y=E^(y|C);E=g+488|0;o=c[E>>2]|0;E=c[E+4>>2]|0;l=Dd(m|0,l|0,-561857047,-1538233109)|0;E=Dd(l|0,C|0,o|0,E|0)|0;y=Dd(E|0,C|0,(H|p)^(v|s)^(r|u)|0,y|0)|0;y=Dd(y|0,C|0,(j^b)&B^j|0,(f^A)&K^f|0)|0;u=C;r=Gd(x|0,F|0,28)|0;s=C;v=Hd(x|0,F|0,36)|0;s=s|C;p=Gd(x|0,F|0,34)|0;H=C;E=Hd(x|0,F|0,30)|0;H=s^(H|C);s=Gd(x|0,F|0,39)|0;o=C;l=Hd(x|0,F|0,25)|0;o=Dd((M|L)&x|M&L|0,(J|D)&F|J&D|0,(r|v)^(p|E)^(s|l)|0,H^(o|C)|0)|0;H=C;I=Dd(G|0,I|0,y|0,u|0)|0;G=C;u=Dd(o|0,H|0,y|0,u|0)|0;y=C;H=Gd(I|0,G|0,14)|0;o=C;l=Hd(I|0,G|0,50)|0;o=o|C;s=Gd(I|0,G|0,18)|0;E=C;p=Hd(I|0,G|0,46)|0;E=o^(E|C);o=Gd(I|0,G|0,41)|0;v=C;r=Hd(I|0,G|0,23)|0;v=E^(v|C);E=g+496|0;m=c[E>>2]|0;E=c[E+4>>2]|0;f=Dd(j|0,f|0,-1295615723,-1090935817)|0;E=Dd(f|0,C|0,m|0,E|0)|0;v=Dd(E|0,C|0,(H|l)^(s|p)^(o|r)|0,v|0)|0;v=Dd(v|0,C|0,(b^B)&I^b|0,(A^K)&G^A|0)|0;r=C;o=Gd(u|0,y|0,28)|0;p=C;s=Hd(u|0,y|0,36)|0;p=p|C;l=Gd(u|0,y|0,34)|0;H=C;E=Hd(u|0,y|0,30)|0;H=p^(H|C);p=Gd(u|0,y|0,39)|0;m=C;f=Hd(u|0,y|0,25)|0;m=Dd((L|x)&u|L&x|0,(D|F)&y|D&F|0,(o|s)^(l|E)^(p|f)|0,H^(m|C)|0)|0;H=C;J=Dd(M|0,J|0,v|0,r|0)|0;M=C;r=Dd(m|0,H|0,v|0,r|0)|0;v=C;H=Gd(J|0,M|0,14)|0;m=C;f=Hd(J|0,M|0,50)|0;m=m|C;p=Gd(J|0,M|0,18)|0;E=C;l=Hd(J|0,M|0,46)|0;E=m^(E|C);m=Gd(J|0,M|0,41)|0;s=C;o=Hd(J|0,M|0,23)|0;s=E^(s|C);E=g+504|0;j=c[E>>2]|0;E=c[E+4>>2]|0;A=Dd(b|0,A|0,-479046869,-965641998)|0;E=Dd(A|0,C|0,j|0,E|0)|0;s=Dd(E|0,C|0,(H|f)^(p|l)^(m|o)|0,s|0)|0;s=Dd(s|0,C|0,(B^I)&J^B|0,(K^G)&M^K|0)|0;o=C;m=Gd(r|0,v|0,28)|0;l=C;p=Hd(r|0,v|0,36)|0;l=l|C;f=Gd(r|0,v|0,34)|0;H=C;E=Hd(r|0,v|0,30)|0;H=l^(H|C);l=Gd(r|0,v|0,39)|0;j=C;A=Hd(r|0,v|0,25)|0;j=Dd((x|u)&r|x&u|0,(F|y)&v|F&y|0,(m|p)^(f|E)^(l|A)|0,H^(j|C)|0)|0;H=C;D=Dd(L|0,D|0,s|0,o|0)|0;L=C;o=Dd(j|0,H|0,s|0,o|0)|0;s=C;H=Gd(D|0,L|0,14)|0;j=C;A=Hd(D|0,L|0,50)|0;j=j|C;l=Gd(D|0,L|0,18)|0;E=C;f=Hd(D|0,L|0,46)|0;E=j^(E|C);j=Gd(D|0,L|0,41)|0;p=C;m=Hd(D|0,L|0,23)|0;p=E^(p|C);E=g+512|0;b=c[E>>2]|0;E=c[E+4>>2]|0;K=Dd(B|0,K|0,-366583396,-903397682)|0;E=Dd(K|0,C|0,b|0,E|0)|0;p=Dd(E|0,C|0,(H|A)^(l|f)^(j|m)|0,p|0)|0;p=Dd(p|0,C|0,(I^J)&D^I|0,(G^M)&L^G|0)|0;m=C;j=Gd(o|0,s|0,28)|0;f=C;l=Hd(o|0,s|0,36)|0;f=f|C;A=Gd(o|0,s|0,34)|0;H=C;E=Hd(o|0,s|0,30)|0;H=f^(H|C);f=Gd(o|0,s|0,39)|0;b=C;K=Hd(o|0,s|0,25)|0;b=Dd((u|r)&o|u&r|0,(y|v)&s|y&v|0,(j|l)^(A|E)^(f|K)|0,H^(b|C)|0)|0;H=C;F=Dd(x|0,F|0,p|0,m|0)|0;x=C;m=Dd(b|0,H|0,p|0,m|0)|0;p=C;H=Gd(F|0,x|0,14)|0;b=C;K=Hd(F|0,x|0,50)|0;b=b|C;f=Gd(F|0,x|0,18)|0;E=C;A=Hd(F|0,x|0,46)|0;E=b^(E|C);b=Gd(F|0,x|0,41)|0;l=C;j=Hd(F|0,x|0,23)|0;l=E^(l|C);E=g+520|0;B=c[E>>2]|0;E=c[E+4>>2]|0;G=Dd(I|0,G|0,566280711,-779700025)|0;E=Dd(G|0,C|0,B|0,E|0)|0;l=Dd(E|0,C|0,(H|K)^(f|A)^(b|j)|0,l|0)|0;l=Dd(l|0,C|0,(J^D)&F^J|0,(M^L)&x^M|0)|0;j=C;b=Gd(m|0,p|0,28)|0;A=C;f=Hd(m|0,p|0,36)|0;A=A|C;K=Gd(m|0,p|0,34)|0;H=C;E=Hd(m|0,p|0,30)|0;H=A^(H|C);A=Gd(m|0,p|0,39)|0;B=C;G=Hd(m|0,p|0,25)|0;B=Dd((r|o)&m|r&o|0,(v|s)&p|v&s|0,(b|f)^(K|E)^(A|G)|0,H^(B|C)|0)|0;H=C;y=Dd(u|0,y|0,l|0,j|0)|0;u=C;j=Dd(B|0,H|0,l|0,j|0)|0;l=C;H=Gd(y|0,u|0,14)|0;B=C;G=Hd(y|0,u|0,50)|0;B=B|C;A=Gd(y|0,u|0,18)|0;E=C;K=Hd(y|0,u|0,46)|0;E=B^(E|C);B=Gd(y|0,u|0,41)|0;f=C;b=Hd(y|0,u|0,23)|0;f=E^(f|C);E=g+528|0;I=c[E>>2]|0;E=c[E+4>>2]|0;M=Dd(J|0,M|0,-840897762,-354779690)|0;E=Dd(M|0,C|0,I|0,E|0)|0;f=Dd(E|0,C|0,(H|G)^(A|K)^(B|b)|0,f|0)|0;f=Dd(f|0,C|0,(D^F)&y^D|0,(L^x)&u^L|0)|0;b=C;B=Gd(j|0,l|0,28)|0;K=C;A=Hd(j|0,l|0,36)|0;K=K|C;G=Gd(j|0,l|0,34)|0;H=C;E=Hd(j|0,l|0,30)|0;H=K^(H|C);K=Gd(j|0,l|0,39)|0;I=C;M=Hd(j|0,l|0,25)|0;I=Dd((o|m)&j|o&m|0,(s|p)&l|s&p|0,(B|A)^(G|E)^(K|M)|0,H^(I|C)|0)|0;H=C;v=Dd(r|0,v|0,f|0,b|0)|0;r=C;b=Dd(I|0,H|0,f|0,b|0)|0;f=C;H=Gd(v|0,r|0,14)|0;I=C;M=Hd(v|0,r|0,50)|0;I=I|C;K=Gd(v|0,r|0,18)|0;E=C;G=Hd(v|0,r|0,46)|0;E=I^(E|C);I=Gd(v|0,r|0,41)|0;A=C;B=Hd(v|0,r|0,23)|0;A=E^(A|C);E=g+536|0;J=c[E>>2]|0;E=c[E+4>>2]|0;L=Dd(D|0,L|0,-294727304,-176337025)|0;E=Dd(L|0,C|0,J|0,E|0)|0;A=Dd(E|0,C|0,(H|M)^(K|G)^(I|B)|0,A|0)|0;A=Dd(A|0,C|0,(F^y)&v^F|0,(x^u)&r^x|0)|0;B=C;I=Gd(b|0,f|0,28)|0;G=C;K=Hd(b|0,f|0,36)|0;G=G|C;M=Gd(b|0,f|0,34)|0;H=C;E=Hd(b|0,f|0,30)|0;H=G^(H|C);G=Gd(b|0,f|0,39)|0;J=C;L=Hd(b|0,f|0,25)|0;J=Dd((m|j)&b|m&j|0,(p|l)&f|p&l|0,(I|K)^(M|E)^(G|L)|0,H^(J|C)|0)|0;H=C;s=Dd(o|0,s|0,A|0,B|0)|0;o=C;B=Dd(J|0,H|0,A|0,B|0)|0;A=C;H=Gd(s|0,o|0,14)|0;J=C;L=Hd(s|0,o|0,50)|0;J=J|C;G=Gd(s|0,o|0,18)|0;E=C;M=Hd(s|0,o|0,46)|0;E=J^(E|C);J=Gd(s|0,o|0,41)|0;K=C;I=Hd(s|0,o|0,23)|0;K=E^(K|C);E=g+544|0;D=c[E>>2]|0;E=c[E+4>>2]|0;x=Dd(F|0,x|0,1914138554,116418474)|0;E=Dd(x|0,C|0,D|0,E|0)|0;K=Dd(E|0,C|0,(H|L)^(G|M)^(J|I)|0,K|0)|0;K=Dd(K|0,C|0,(y^v)&s^y|0,(u^r)&o^u|0)|0;I=C;J=Gd(B|0,A|0,28)|0;M=C;G=Hd(B|0,A|0,36)|0;M=M|C;L=Gd(B|0,A|0,34)|0;H=C;E=Hd(B|0,A|0,30)|0;H=M^(H|C);M=Gd(B|0,A|0,39)|0;D=C;x=Hd(B|0,A|0,25)|0;D=Dd((j|b)&B|j&b|0,(l|f)&A|l&f|0,(J|G)^(L|E)^(M|x)|0,H^(D|C)|0)|0;H=C;p=Dd(m|0,p|0,K|0,I|0)|0;m=C;I=Dd(D|0,H|0,K|0,I|0)|0;K=C;H=Gd(p|0,m|0,14)|0;D=C;x=Hd(p|0,m|0,50)|0;D=D|C;M=Gd(p|0,m|0,18)|0;E=C;L=Hd(p|0,m|0,46)|0;E=D^(E|C);D=Gd(p|0,m|0,41)|0;G=C;J=Hd(p|0,m|0,23)|0;G=E^(G|C);E=g+552|0;F=c[E>>2]|0;E=c[E+4>>2]|0;u=Dd(y|0,u|0,-1563912026,174292421)|0;E=Dd(u|0,C|0,F|0,E|0)|0;G=Dd(E|0,C|0,(H|x)^(M|L)^(D|J)|0,G|0)|0;G=Dd(G|0,C|0,(v^s)&p^v|0,(r^o)&m^r|0)|0;J=C;D=Gd(I|0,K|0,28)|0;L=C;M=Hd(I|0,K|0,36)|0;L=L|C;x=Gd(I|0,K|0,34)|0;H=C;E=Hd(I|0,K|0,30)|0;H=L^(H|C);L=Gd(I|0,K|0,39)|0;F=C;u=Hd(I|0,K|0,25)|0;F=Dd((b|B)&I|b&B|0,(f|A)&K|f&A|0,(D|M)^(x|E)^(L|u)|0,H^(F|C)|0)|0;H=C;l=Dd(j|0,l|0,G|0,J|0)|0;j=C;J=Dd(F|0,H|0,G|0,J|0)|0;G=C;H=Gd(l|0,j|0,14)|0;F=C;u=Hd(l|0,j|0,50)|0;F=F|C;L=Gd(l|0,j|0,18)|0;E=C;x=Hd(l|0,j|0,46)|0;E=F^(E|C);F=Gd(l|0,j|0,41)|0;M=C;D=Hd(l|0,j|0,23)|0;M=E^(M|C);E=g+560|0;y=c[E>>2]|0;E=c[E+4>>2]|0;r=Dd(v|0,r|0,-1090974290,289380356)|0;E=Dd(r|0,C|0,y|0,E|0)|0;M=Dd(E|0,C|0,(H|u)^(L|x)^(F|D)|0,M|0)|0;M=Dd(M|0,C|0,(s^p)&l^s|0,(o^m)&j^o|0)|0;D=C;F=Gd(J|0,G|0,28)|0;x=C;L=Hd(J|0,G|0,36)|0;x=x|C;u=Gd(J|0,G|0,34)|0;H=C;E=Hd(J|0,G|0,30)|0;H=x^(H|C);x=Gd(J|0,G|0,39)|0;y=C;r=Hd(J|0,G|0,25)|0;y=Dd((B|I)&J|B&I|0,(A|K)&G|A&K|0,(F|L)^(u|E)^(x|r)|0,H^(y|C)|0)|0;H=C;f=Dd(b|0,f|0,M|0,D|0)|0;b=C;D=Dd(y|0,H|0,M|0,D|0)|0;M=C;H=Gd(f|0,b|0,14)|0;y=C;r=Hd(f|0,b|0,50)|0;y=y|C;x=Gd(f|0,b|0,18)|0;E=C;u=Hd(f|0,b|0,46)|0;E=y^(E|C);y=Gd(f|0,b|0,41)|0;L=C;F=Hd(f|0,b|0,23)|0;L=E^(L|C);E=g+568|0;v=c[E>>2]|0;E=c[E+4>>2]|0;o=Dd(s|0,o|0,320620315,460393269)|0;E=Dd(o|0,C|0,v|0,E|0)|0;L=Dd(E|0,C|0,(H|r)^(x|u)^(y|F)|0,L|0)|0;L=Dd(L|0,C|0,(p^l)&f^p|0,(m^j)&b^m|0)|0;F=C;y=Gd(D|0,M|0,28)|0;u=C;x=Hd(D|0,M|0,36)|0;u=u|C;r=Gd(D|0,M|0,34)|0;H=C;E=Hd(D|0,M|0,30)|0;H=u^(H|C);u=Gd(D|0,M|0,39)|0;v=C;o=Hd(D|0,M|0,25)|0;v=Dd((I|J)&D|I&J|0,(K|G)&M|K&G|0,(y|x)^(r|E)^(u|o)|0,H^(v|C)|0)|0;H=C;A=Dd(B|0,A|0,L|0,F|0)|0;B=C;F=Dd(v|0,H|0,L|0,F|0)|0;L=C;H=Gd(A|0,B|0,14)|0;v=C;o=Hd(A|0,B|0,50)|0;v=v|C;u=Gd(A|0,B|0,18)|0;E=C;r=Hd(A|0,B|0,46)|0;E=v^(E|C);v=Gd(A|0,B|0,41)|0;x=C;y=Hd(A|0,B|0,23)|0;x=E^(x|C);E=g+576|0;s=c[E>>2]|0;E=c[E+4>>2]|0;m=Dd(p|0,m|0,587496836,685471733)|0;E=Dd(m|0,C|0,s|0,E|0)|0;x=Dd(E|0,C|0,(H|o)^(u|r)^(v|y)|0,x|0)|0;x=Dd(x|0,C|0,(l^f)&A^l|0,(j^b)&B^j|0)|0;y=C;v=Gd(F|0,L|0,28)|0;r=C;u=Hd(F|0,L|0,36)|0;r=r|C;o=Gd(F|0,L|0,34)|0;H=C;E=Hd(F|0,L|0,30)|0;H=r^(H|C);r=Gd(F|0,L|0,39)|0;s=C;m=Hd(F|0,L|0,25)|0;s=Dd((J|D)&F|J&D|0,(G|M)&L|G&M|0,(v|u)^(o|E)^(r|m)|0,H^(s|C)|0)|0;H=C;K=Dd(I|0,K|0,x|0,y|0)|0;I=C;y=Dd(s|0,H|0,x|0,y|0)|0;x=C;H=Gd(K|0,I|0,14)|0;s=C;m=Hd(K|0,I|0,50)|0;s=s|C;r=Gd(K|0,I|0,18)|0;E=C;o=Hd(K|0,I|0,46)|0;E=s^(E|C);s=Gd(K|0,I|0,41)|0;u=C;v=Hd(K|0,I|0,23)|0;u=E^(u|C);E=g+584|0;p=c[E>>2]|0;E=c[E+4>>2]|0;j=Dd(l|0,j|0,1086792851,852142971)|0;E=Dd(j|0,C|0,p|0,E|0)|0;u=Dd(E|0,C|0,(H|m)^(r|o)^(s|v)|0,u|0)|0;u=Dd(u|0,C|0,(f^A)&K^f|0,(b^B)&I^b|0)|0;v=C;s=Gd(y|0,x|0,28)|0;o=C;r=Hd(y|0,x|0,36)|0;o=o|C;m=Gd(y|0,x|0,34)|0;H=C;E=Hd(y|0,x|0,30)|0;H=o^(H|C);o=Gd(y|0,x|0,39)|0;p=C;j=Hd(y|0,x|0,25)|0;p=Dd((D|F)&y|D&F|0,(M|L)&x|M&L|0,(s|r)^(m|E)^(o|j)|0,H^(p|C)|0)|0;H=C;G=Dd(J|0,G|0,u|0,v|0)|0;J=C;v=Dd(p|0,H|0,u|0,v|0)|0;u=C;H=Gd(G|0,J|0,14)|0;p=C;j=Hd(G|0,J|0,50)|0;p=p|C;o=Gd(G|0,J|0,18)|0;E=C;m=Hd(G|0,J|0,46)|0;E=p^(E|C);p=Gd(G|0,J|0,41)|0;r=C;s=Hd(G|0,J|0,23)|0;r=E^(r|C);E=g+592|0;l=c[E>>2]|0;E=c[E+4>>2]|0;b=Dd(f|0,b|0,365543100,1017036298)|0;E=Dd(b|0,C|0,l|0,E|0)|0;r=Dd(E|0,C|0,(H|j)^(o|m)^(p|s)|0,r|0)|0;r=Dd(r|0,C|0,(A^K)&G^A|0,(B^I)&J^B|0)|0;s=C;p=Gd(v|0,u|0,28)|0;m=C;o=Hd(v|0,u|0,36)|0;m=m|C;j=Gd(v|0,u|0,34)|0;H=C;E=Hd(v|0,u|0,30)|0;H=m^(H|C);m=Gd(v|0,u|0,39)|0;l=C;b=Hd(v|0,u|0,25)|0;l=Dd((F|y)&v|F&y|0,(L|x)&u|L&x|0,(p|o)^(j|E)^(m|b)|0,H^(l|C)|0)|0;H=C;M=Dd(D|0,M|0,r|0,s|0)|0;D=C;s=Dd(l|0,H|0,r|0,s|0)|0;r=C;H=Gd(M|0,D|0,14)|0;l=C;b=Hd(M|0,D|0,50)|0;l=l|C;m=Gd(M|0,D|0,18)|0;E=C;j=Hd(M|0,D|0,46)|0;E=l^(E|C);l=Gd(M|0,D|0,41)|0;o=C;p=Hd(M|0,D|0,23)|0;o=E^(o|C);E=g+600|0;f=c[E>>2]|0;E=c[E+4>>2]|0;B=Dd(A|0,B|0,-1676669620,1126000580)|0;E=Dd(B|0,C|0,f|0,E|0)|0;o=Dd(E|0,C|0,(H|b)^(m|j)^(l|p)|0,o|0)|0;o=Dd(o|0,C|0,(K^G)&M^K|0,(I^J)&D^I|0)|0;p=C;l=Gd(s|0,r|0,28)|0;j=C;m=Hd(s|0,r|0,36)|0;j=j|C;b=Gd(s|0,r|0,34)|0;H=C;E=Hd(s|0,r|0,30)|0;H=j^(H|C);j=Gd(s|0,r|0,39)|0;f=C;B=Hd(s|0,r|0,25)|0;f=Dd((y|v)&s|y&v|0,(x|u)&r|x&u|0,(l|m)^(b|E)^(j|B)|0,H^(f|C)|0)|0;H=C;L=Dd(F|0,L|0,o|0,p|0)|0;F=C;p=Dd(f|0,H|0,o|0,p|0)|0;o=C;H=Gd(L|0,F|0,14)|0;f=C;B=Hd(L|0,F|0,50)|0;f=f|C;j=Gd(L|0,F|0,18)|0;E=C;b=Hd(L|0,F|0,46)|0;E=f^(E|C);f=Gd(L|0,F|0,41)|0;m=C;l=Hd(L|0,F|0,23)|0;m=E^(m|C);E=g+608|0;A=c[E>>2]|0;E=c[E+4>>2]|0;I=Dd(K|0,I|0,-885112138,1288033470)|0;E=Dd(I|0,C|0,A|0,E|0)|0;m=Dd(E|0,C|0,(H|B)^(j|b)^(f|l)|0,m|0)|0;m=Dd(m|0,C|0,(G^M)&L^G|0,(J^D)&F^J|0)|0;l=C;f=Gd(p|0,o|0,28)|0;b=C;j=Hd(p|0,o|0,36)|0;b=b|C;B=Gd(p|0,o|0,34)|0;H=C;E=Hd(p|0,o|0,30)|0;H=b^(H|C);b=Gd(p|0,o|0,39)|0;A=C;I=Hd(p|0,o|0,25)|0;A=Dd((v|s)&p|v&s|0,(u|r)&o|u&r|0,(f|j)^(B|E)^(b|I)|0,H^(A|C)|0)|0;H=C;x=Dd(y|0,x|0,m|0,l|0)|0;y=C;l=Dd(A|0,H|0,m|0,l|0)|0;m=C;H=Gd(x|0,y|0,14)|0;A=C;I=Hd(x|0,y|0,50)|0;A=A|C;b=Gd(x|0,y|0,18)|0;E=C;B=Hd(x|0,y|0,46)|0;E=A^(E|C);A=Gd(x|0,y|0,41)|0;j=C;f=Hd(x|0,y|0,23)|0;j=E^(j|C);E=g+616|0;K=c[E>>2]|0;E=c[E+4>>2]|0;J=Dd(G|0,J|0,-60457430,1501505948)|0;E=Dd(J|0,C|0,K|0,E|0)|0;j=Dd(E|0,C|0,(H|I)^(b|B)^(A|f)|0,j|0)|0;j=Dd(j|0,C|0,(M^L)&x^M|0,(D^F)&y^D|0)|0;f=C;A=Gd(l|0,m|0,28)|0;B=C;b=Hd(l|0,m|0,36)|0;B=B|C;I=Gd(l|0,m|0,34)|0;H=C;E=Hd(l|0,m|0,30)|0;H=B^(H|C);B=Gd(l|0,m|0,39)|0;K=C;J=Hd(l|0,m|0,25)|0;K=Dd((s|p)&l|s&p|0,(r|o)&m|r&o|0,(A|b)^(I|E)^(B|J)|0,H^(K|C)|0)|0;H=C;u=Dd(v|0,u|0,j|0,f|0)|0;v=C;f=Dd(K|0,H|0,j|0,f|0)|0;j=C;H=Gd(u|0,v|0,14)|0;K=C;J=Hd(u|0,v|0,50)|0;K=K|C;B=Gd(u|0,v|0,18)|0;E=C;I=Hd(u|0,v|0,46)|0;E=K^(E|C);K=Gd(u|0,v|0,41)|0;b=C;A=Hd(u|0,v|0,23)|0;b=E^(b|C);E=g+624|0;G=c[E>>2]|0;E=c[E+4>>2]|0;D=Dd(M|0,D|0,987167468,1607167915)|0;E=Dd(D|0,C|0,G|0,E|0)|0;b=Dd(E|0,C|0,(H|J)^(B|I)^(K|A)|0,b|0)|0;b=Dd(b|0,C|0,(L^x)&u^L|0,(F^y)&v^F|0)|0;A=C;K=Gd(f|0,j|0,28)|0;I=C;B=Hd(f|0,j|0,36)|0;I=I|C;J=Gd(f|0,j|0,34)|0;H=C;E=Hd(f|0,j|0,30)|0;H=I^(H|C);I=Gd(f|0,j|0,39)|0;G=C;D=Hd(f|0,j|0,25)|0;G=Dd((p|l)&f|p&l|0,(o|m)&j|o&m|0,(K|B)^(J|E)^(I|D)|0,H^(G|C)|0)|0;H=C;r=Dd(s|0,r|0,b|0,A|0)|0;s=C;A=Dd(G|0,H|0,b|0,A|0)|0;b=C;H=Gd(r|0,s|0,14)|0;G=C;D=Hd(r|0,s|0,50)|0;G=G|C;I=Gd(r|0,s|0,18)|0;E=C;J=Hd(r|0,s|0,46)|0;E=G^(E|C);G=Gd(r|0,s|0,41)|0;B=C;K=Hd(r|0,s|0,23)|0;B=E^(B|C);g=g+632|0;E=c[g>>2]|0;g=c[g+4>>2]|0;F=Dd(L|0,F|0,1246189591,1816402316)|0;g=Dd(F|0,C|0,E|0,g|0)|0;g=Dd(g|0,C|0,(H|D)^(I|J)^(G|K)|0,B|0)|0;g=Dd(g|0,C|0,(x^u)&r^x|0,(y^v)&s^y|0)|0;B=C;K=Gd(A|0,b|0,28)|0;G=C;J=Hd(A|0,b|0,36)|0;G=G|C;I=Gd(A|0,b|0,34)|0;D=C;H=Hd(A|0,b|0,30)|0;D=G^(D|C);G=Gd(A|0,b|0,39)|0;E=C;F=Hd(A|0,b|0,25)|0;E=Dd((l|f)&A|l&f|0,(m|j)&b|m&j|0,(K|J)^(I|H)^(G|F)|0,D^(E|C)|0)|0;D=C;o=Dd(p|0,o|0,g|0,B|0)|0;p=C;B=Dd(E|0,D|0,g|0,B|0)|0;g=a;B=Dd(c[g>>2]|0,c[g+4>>2]|0,B|0,C|0)|0;g=a;c[g>>2]=B;c[g+4>>2]=C;g=e;g=Dd(c[g>>2]|0,c[g+4>>2]|0,A|0,b|0)|0;a=e;c[a>>2]=g;c[a+4>>2]=C;a=k;j=Dd(c[a>>2]|0,c[a+4>>2]|0,f|0,j|0)|0;c[k>>2]=j;c[k+4>>2]=C;k=n;m=Dd(c[k>>2]|0,c[k+4>>2]|0,l|0,m|0)|0;c[n>>2]=m;c[n+4>>2]=C;n=q;p=Dd(c[n>>2]|0,c[n+4>>2]|0,o|0,p|0)|0;c[q>>2]=p;c[q+4>>2]=C;q=t;s=Dd(c[q>>2]|0,c[q+4>>2]|0,r|0,s|0)|0;c[t>>2]=s;c[t+4>>2]=C;t=w;v=Dd(c[t>>2]|0,c[t+4>>2]|0,u|0,v|0)|0;c[w>>2]=v;c[w+4>>2]=C;w=z;y=Dd(c[w>>2]|0,c[w+4>>2]|0,x|0,y|0)|0;c[z>>2]=y;c[z+4>>2]=C;i=h;return}function Ib(){return 144}function Jb(){return 16}function Kb(){return 32}function Lb(a,b,c,d,e){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;var f=0,g=0;f=i;g=i=i+63&-64;i=i+144|0;Ub(g,e);Tb(g,b,c,d);Rb(g,a);i=f;return 0}function Mb(a,b,c,d,e){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;return Qb(a,b,c,d,e)|0}function Nb(a,b){a=a|0;b=b|0;Ub(a,b);return 0}function Ob(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;Tb(a,b,c,d);return 0}function Pb(a,b){a=a|0;b=b|0;Rb(a,b);return 0}function Qb(b,c,d,e,f){b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;var g=0,h=0,j=0;h=i;g=i=i+63&-64;i=i+160|0;j=g;g=g+144|0;Ub(j,f);Tb(j,c,d,e);Rb(j,g);i=h;return ((((a[g+1>>0]^a[b+1>>0]|a[g>>0]^a[b>>0]|a[g+2>>0]^a[b+2>>0]|a[g+3>>0]^a[b+3>>0]|a[g+4>>0]^a[b+4>>0]|a[g+5>>0]^a[b+5>>0]|a[g+6>>0]^a[b+6>>0]|a[g+7>>0]^a[b+7>>0]|a[g+8>>0]^a[b+8>>0]|a[g+9>>0]^a[b+9>>0]|a[g+10>>0]^a[b+10>>0]|a[g+11>>0]^a[b+11>>0]|a[g+12>>0]^a[b+12>>0]|a[g+13>>0]^a[b+13>>0]|a[g+14>>0]^a[b+14>>0]|a[g+15>>0]^a[b+15>>0])&255)+511|0)>>>8&1)+-1|0}function Rb(b,d){b=b|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0;h=b+56|0;g=c[h>>2]|0;h=c[h+4>>2]|0;if(!((g|0)==0&(h|0)==0)){e=b+64|0;a[e+g>>0]=1;f=Dd(g|0,h|0,1,0)|0;i=C;if(i>>>0<0|(i|0)==0&f>>>0<16){i=Cd(14,0,g|0,h|0)|0;Fd(b+(f+64)|0,0,i+1|0)|0}a[b+80>>0]=1;Sb(b,e,16,0)}i=c[b+24>>2]|0;p=(c[b+28>>2]|0)+(i>>>26)|0;e=p&67108863;n=(p>>>26)+(c[b+32>>2]|0)|0;m=n&67108863;f=(n>>>26)+(c[b+36>>2]|0)|0;h=((f>>>26)*5|0)+(c[b+20>>2]|0)|0;g=h&67108863;i=(h>>>26)+(i&67108863)|0;r=((g+5|0)>>>26)+i|0;q=r>>>26;o=(q+e|0)>>>26;k=(f|-67108864)+((o+m|0)>>>26)|0;l=(k>>>31)+-1|0;j=k>>31;i=r&67108863&l|j&i;e=q+p&67108863&l|j&e;m=o+n&67108863&l|j&m;g=Dd(h+5&67108863&l|j&g|i<<26|0,0,c[b+40>>2]|0,0)|0;h=C;i=Dd(i>>>6|e<<20|0,0,c[b+44>>2]|0,0)|0;h=Dd(i|0,C|0,h|0,0)|0;i=C;e=Dd(e>>>12|m<<14|0,0,c[b+48>>2]|0,0)|0;i=Dd(e|0,C|0,i|0,0)|0;e=C;f=Dd(m>>>18|(l&k|j&f)<<8|0,0,c[b+52>>2]|0,0)|0;e=Dd(f|0,C|0,e|0,0)|0;a[d>>0]=g;a[d+1>>0]=g>>>8;a[d+2>>0]=g>>>16;a[d+3>>0]=g>>>24;a[d+4>>0]=h;a[d+5>>0]=h>>>8;a[d+6>>0]=h>>>16;a[d+7>>0]=h>>>24;a[d+8>>0]=i;a[d+9>>0]=i>>>8;a[d+10>>0]=i>>>16;a[d+11>>0]=i>>>24;a[d+12>>0]=e;a[d+13>>0]=e>>>8;a[d+14>>0]=e>>>16;a[d+15>>0]=e>>>24;e=b+88|0;do{a[b>>0]=0;b=b+1|0}while((b|0)<(e|0));return}function Sb(b,e,f,g){b=b|0;e=e|0;f=f|0;g=g|0;var h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0;s=(a[b+80>>0]|0)!=0?0:16777216;t=c[b+4>>2]|0;u=c[b+8>>2]|0;m=c[b+12>>2]|0;n=c[b+16>>2]|0;v=b+20|0;l=c[v>>2]|0;w=b+24|0;k=c[w>>2]|0;x=b+28|0;j=c[x>>2]|0;y=b+32|0;i=c[y>>2]|0;z=b+36|0;h=c[z>>2]|0;if(!(g>>>0>0|(g|0)==0&f>>>0>15)){q=l;r=k;s=j;t=i;u=h;c[v>>2]=q;c[w>>2]=r;c[x>>2]=s;c[y>>2]=t;c[z>>2]=u;return}o=n*5|0;p=m*5|0;q=u*5|0;r=t*5|0;b=c[b>>2]|0;while(1){J=d[e+3>>0]|0;B=(d[e+1>>0]<<8|d[e>>0]|d[e+2>>0]<<16|J<<24&50331648)+l|0;H=d[e+6>>0]|0;J=((d[e+4>>0]<<8|J|d[e+5>>0]<<16|H<<24)>>>2&67108863)+k|0;G=d[e+9>>0]|0;H=((d[e+7>>0]<<8|H|d[e+8>>0]<<16|G<<24)>>>4&67108863)+j|0;G=((d[e+10>>0]<<8|G|d[e+11>>0]<<16|d[e+12>>0]<<24)>>>6)+i|0;l=(d[e+13>>0]|s|d[e+14>>0]<<8|d[e+15>>0]<<16)+h|0;k=Od(B|0,0,b|0,0)|0;j=C;A=Od(J|0,0,o|0,0)|0;j=Dd(A|0,C|0,k|0,j|0)|0;k=C;A=Od(H|0,0,p|0,0)|0;A=Dd(j|0,k|0,A|0,C|0)|0;k=C;j=Od(G|0,0,q|0,0)|0;j=Dd(A|0,k|0,j|0,C|0)|0;k=C;A=Od(l|0,0,r|0,0)|0;A=Dd(j|0,k|0,A|0,C|0)|0;k=C;j=Od(B|0,0,t|0,0)|0;i=C;F=Od(J|0,0,b|0,0)|0;i=Dd(F|0,C|0,j|0,i|0)|0;j=C;F=Od(H|0,0,o|0,0)|0;F=Dd(i|0,j|0,F|0,C|0)|0;j=C;i=Od(G|0,0,p|0,0)|0;i=Dd(F|0,j|0,i|0,C|0)|0;j=C;F=Od(l|0,0,q|0,0)|0;F=Dd(i|0,j|0,F|0,C|0)|0;j=C;i=Od(B|0,0,u|0,0)|0;h=C;E=Od(J|0,0,t|0,0)|0;h=Dd(E|0,C|0,i|0,h|0)|0;i=C;E=Od(H|0,0,b|0,0)|0;E=Dd(h|0,i|0,E|0,C|0)|0;i=C;h=Od(G|0,0,o|0,0)|0;h=Dd(E|0,i|0,h|0,C|0)|0;i=C;E=Od(l|0,0,p|0,0)|0;E=Dd(h|0,i|0,E|0,C|0)|0;i=C;h=Od(B|0,0,m|0,0)|0;I=C;D=Od(J|0,0,u|0,0)|0;I=Dd(D|0,C|0,h|0,I|0)|0;h=C;D=Od(H|0,0,t|0,0)|0;D=Dd(I|0,h|0,D|0,C|0)|0;h=C;I=Od(G|0,0,b|0,0)|0;I=Dd(D|0,h|0,I|0,C|0)|0;h=C;D=Od(l|0,0,o|0,0)|0;D=Dd(I|0,h|0,D|0,C|0)|0;h=C;B=Od(B|0,0,n|0,0)|0;I=C;J=Od(J|0,0,m|0,0)|0;I=Dd(J|0,C|0,B|0,I|0)|0;B=C;H=Od(H|0,0,u|0,0)|0;H=Dd(I|0,B|0,H|0,C|0)|0;B=C;G=Od(G|0,0,t|0,0)|0;G=Dd(H|0,B|0,G|0,C|0)|0;B=C;l=Od(l|0,0,b|0,0)|0;l=Dd(G|0,B|0,l|0,C|0)|0;B=C;k=Gd(A|0,k|0,26)|0;k=Dd(F|0,j|0,k|0,0)|0;j=Gd(k|0,C|0,26)|0;j=Dd(E|0,i|0,j|0,0)|0;i=Gd(j|0,C|0,26)|0;j=j&67108863;i=Dd(D|0,h|0,i|0,0)|0;h=Gd(i|0,C|0,26)|0;i=i&67108863;h=Dd(l|0,B|0,h|0,0)|0;B=Gd(h|0,C|0,26)|0;h=h&67108863;B=B*5|0;l=B+A&67108863;k=((B+(A&67108863)|0)>>>26)+(k&67108863)|0;f=Dd(f|0,g|0,-16,-1)|0;g=C;if(!(g>>>0>0|(g|0)==0&f>>>0>15))break;else e=e+16|0}c[v>>2]=l;c[w>>2]=k;c[x>>2]=j;c[y>>2]=i;c[z>>2]=h;return}function Tb(b,d,e,f){b=b|0;d=d|0;e=e|0;f=f|0;var g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0;n=b+56|0;g=n;h=c[g>>2]|0;g=c[g+4>>2]|0;do if(!((h|0)==0&(g|0)==0)){l=Cd(16,0,h|0,g|0)|0;m=C;k=m>>>0>f>>>0|(m|0)==(f|0)&l>>>0>e>>>0;l=k?e:l;m=k?f:m;if(!((l|0)==0&(m|0)==0)){j=b+64|0;k=0;i=0;do{o=a[d+k>>0]|0;g=Dd(h|0,g|0,k|0,i|0)|0;a[j+g>>0]=o;k=Dd(k|0,i|0,1,0)|0;i=C;g=n;h=c[g>>2]|0;g=c[g+4>>2]|0}while(i>>>0<m>>>0|(i|0)==(m|0)&k>>>0<l>>>0)}o=Dd(h|0,g|0,l|0,m|0)|0;k=C;j=n;c[j>>2]=o;c[j+4>>2]=k;if(k>>>0<0|(k|0)==0&o>>>0<16)return;else{e=Cd(e|0,f|0,l|0,m|0)|0;f=C;Sb(b,b+64|0,16,0);o=n;c[o>>2]=0;c[o+4>>2]=0;d=d+l|0;break}}while(0);if(f>>>0>0|(f|0)==0&e>>>0>15){i=e&-16;Sb(b,d,i,f);e=Cd(e|0,f|0,i|0,f|0)|0;d=d+i|0;i=C}else i=f;if((e|0)==0&(i|0)==0)return;f=b+64|0;g=0;h=0;do{b=a[d+g>>0]|0;o=n;o=Dd(c[o>>2]|0,c[o+4>>2]|0,g|0,h|0)|0;a[f+o>>0]=b;g=Dd(g|0,h|0,1,0)|0;h=C}while(h>>>0<i>>>0|(h|0)==(i|0)&g>>>0<e>>>0);b=n;b=Dd(c[b>>2]|0,c[b+4>>2]|0,e|0,i|0)|0;o=n;c[o>>2]=b;c[o+4>>2]=C;return}function Ub(b,e){b=b|0;e=e|0;var f=0,g=0;f=e+3|0;c[b>>2]=(d[e+1>>0]|0)<<8|(d[e>>0]|0)|(d[e+2>>0]|0)<<16|(d[f>>0]|0)<<24&50331648;g=e+6|0;c[b+4>>2]=((d[e+4>>0]|0)<<8|(d[f>>0]|0)|(d[e+5>>0]|0)<<16|(d[g>>0]|0)<<24)>>>2&67108611;f=e+9|0;c[b+8>>2]=((d[e+7>>0]|0)<<8|(d[g>>0]|0)|(d[e+8>>0]|0)<<16|(d[f>>0]|0)<<24)>>>4&67092735;c[b+12>>2]=((d[e+10>>0]|0)<<8|(d[f>>0]|0)|(d[e+11>>0]|0)<<16|(d[e+12>>0]|0)<<24)>>>6&66076671;c[b+16>>2]=(d[e+14>>0]|0)<<8|(d[e+13>>0]|0)|(d[e+15>>0]|0)<<16&983040;f=b+20|0;c[f>>2]=0;c[f+4>>2]=0;c[f+8>>2]=0;c[f+12>>2]=0;c[f+16>>2]=0;c[b+40>>2]=(d[e+17>>0]|0)<<8|(d[e+16>>0]|0)|(d[e+18>>0]|0)<<16|(d[e+19>>0]|0)<<24;c[b+44>>2]=(d[e+21>>0]|0)<<8|(d[e+20>>0]|0)|(d[e+22>>0]|0)<<16|(d[e+23>>0]|0)<<24;c[b+48>>2]=(d[e+25>>0]|0)<<8|(d[e+24>>0]|0)|(d[e+26>>0]|0)<<16|(d[e+27>>0]|0)<<24;c[b+52>>2]=(d[e+29>>0]|0)<<8|(d[e+28>>0]|0)|(d[e+30>>0]|0)<<16|(d[e+31>>0]|0)<<24;e=b+56|0;c[e>>2]=0;c[e+4>>2]=0;a[b+80>>0]=0;return}function Vb(b,e,f,g,h){b=b|0;e=e|0;f=f|0;g=g|0;h=h|0;var j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0;w=i;t=i=i+63&-64;i=i+48|0;j=t+8|0;u=t+4|0;if((a[g>>0]|0)!=36){h=0;i=w;return h|0}if((a[g+1>>0]|0)!=55){h=0;i=w;return h|0}if((a[g+2>>0]|0)!=36){h=0;i=w;return h|0}o=a[g+3>>0]|0;n=o&255;a:do if(1){l=65;k=34881;do{if((a[k>>0]|0)==o<<24>>24)break a;k=k+1|0;l=l+-1|0;m=(l|0)!=0}while(m&(k&3|0)!=0);if(!m){h=0;i=w;return h|0}}else{l=65;k=34881}while(0);b:do if((a[k>>0]|0)!=o<<24>>24){m=_(n,16843009)|0;c:do if(l>>>0>3)while(1){s=c[k>>2]^m;if((s&-2139062144^-2139062144)&s+-16843009)break c;k=k+4|0;l=l+-4|0;if(l>>>0<=3){v=12;break}}else v=12;while(0);if((v|0)==12)if(!l){h=0;i=w;return h|0}while(1){if((a[k>>0]|0)==o<<24>>24)break b;l=l+-1|0;if(!l){j=0;break}else k=k+1|0}i=w;return j|0}while(0);if((k|0)==0|(l|0)==0){h=0;i=w;return h|0}r=Hd(1,0,k-34881|0)|0;s=C;k=Xb(u,g+4|0)|0;if(!k){h=0;i=w;return h|0}q=Xb(t,k)|0;if(!q){h=0;i=w;return h|0}o=q;p=o-g|0;n=(o&3|0)==0;d:do if(n){k=q;v=22}else{l=q;k=o;while(1){if(!(a[l>>0]|0))break d;l=l+1|0;k=l;if(!(k&3)){k=l;v=22;break}}}while(0);if((v|0)==22){while(1){l=c[k>>2]|0;if(!((l&-2139062144^-2139062144)&l+-16843009))k=k+4|0;else break}if((l&255)<<24>>24)do k=k+1|0;while((a[k>>0]|0)!=0)}l=k-o+1|0;while(1){k=l+-1|0;if(!l){v=32;break}m=q+k|0;if((a[m>>0]|0)==36){v=30;break}else l=k}if((v|0)==30)if(!m)v=32;else l=l+-1|0;if((v|0)==32){e:do if(n){k=q;v=35}else{k=q;l=o;while(1){if(!(a[k>>0]|0)){k=l;break e}k=k+1|0;l=k;if(!(l&3)){v=35;break}}}while(0);if((v|0)==35){while(1){l=c[k>>2]|0;if(!((l&-2139062144^-2139062144)&l+-16843009))k=k+4|0;else break}if((l&255)<<24>>24)do k=k+1|0;while((a[k>>0]|0)!=0)}l=k-o|0}k=l+p|0;p=k+45|0;if(p>>>0>102|p>>>0<l>>>0){h=0;i=w;return h|0}if(hc(b,e,f,q,l,r,s,c[u>>2]|0,c[t>>2]|0,j,32)|0){h=0;i=w;return h|0}Id(h|0,g|0,k|0)|0;s=h+k|0;r=s+1|0;a[s>>0]=36;s=r;r=h+102-r|0;k=0;f:while(1){if(k>>>0<32){p=0;q=k;k=0}else break;do{g=q;q=q+1|0;k=d[j+g>>0]<<p|k;p=p+8|0}while(q>>>0<32&p>>>0<24);if(!p)k=s;else{l=k;m=r;n=s;o=0;while(1){if(!m){v=50;break f}k=n+1|0;a[n>>0]=a[34881+(l&63)>>0]|0;o=o+6|0;if(o>>>0>=p>>>0)break;else{l=l>>>6;m=m+-1|0;n=k}}}g=(k|0)==0;r=(g?0:s-k|0)+r|0;if(g){v=50;break}else{s=k;k=q}}if((v|0)==50){k=j+32|0;do{a[j>>0]=0;j=j+1|0}while((j|0)<(k|0));h=0;i=w;return h|0}k=j+32|0;do{a[j>>0]=0;j=j+1|0}while((j|0)<(k|0));if(!((s|0)!=0&s>>>0<(h+102|0)>>>0)){h=0;i=w;return h|0}a[s>>0]=0;i=w;return h|0}function Wb(a,b,d,e,f,g,h,j,k,l){a=a|0;b=b|0;d=d|0;e=e|0;f=f|0;g=g|0;h=h|0;j=j|0;k=k|0;l=l|0;var m=0,n=0;m=i;n=i=i+63&-64;i=i+16|0;c[n+4>>2]=0;c[n>>2]=0;c[n+8>>2]=0;f=hc(n,a,b,d,e,f,g,h,j,k,l)|0;g=c[n>>2]|0;if(!g){i=m;return f|0}zd(g);i=m;return f|0}function Xb(b,d){b=b|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0;i=a[d>>0]|0;h=i&255;a:do if(1){e=65;f=34881;do{if((a[f>>0]|0)==i<<24>>24)break a;f=f+1|0;e=e+-1|0;g=(e|0)!=0}while(g&(f&3|0)!=0);if(!g){d=0;n=0;c[b>>2]=n;return d|0}}else{e=65;f=34881}while(0);b:do if((a[f>>0]|0)!=i<<24>>24){g=_(h,16843009)|0;c:do if(e>>>0>3)while(1){m=c[f>>2]^g;if((m&-2139062144^-2139062144)&m+-16843009)break c;f=f+4|0;e=e+-4|0;if(e>>>0<=3){n=9;break}}else n=9;while(0);if((n|0)==9)if(!e){d=0;n=0;c[b>>2]=n;return d|0}while(1){if((a[f>>0]|0)==i<<24>>24)break b;e=e+-1|0;if(!e){e=0;f=0;break}else f=f+1|0}c[b>>2]=f;return e|0}while(0);if((f|0)==0|(e|0)==0){d=0;n=0;c[b>>2]=n;return d|0}j=a[d+1>>0]|0;i=j&255;d:do if(1){e=65;g=34881;do{if((a[g>>0]|0)==j<<24>>24)break d;g=g+1|0;e=e+-1|0;h=(e|0)!=0}while(h&(g&3|0)!=0);if(!h){d=0;n=0;c[b>>2]=n;return d|0}}else{e=65;g=34881}while(0);e:do if((a[g>>0]|0)!=j<<24>>24){h=_(i,16843009)|0;f:do if(e>>>0>3)while(1){m=c[g>>2]^h;if((m&-2139062144^-2139062144)&m+-16843009)break f;g=g+4|0;e=e+-4|0;if(e>>>0<=3){n=22;break}}else n=22;while(0);if((n|0)==22)if(!e){d=0;n=0;c[b>>2]=n;return d|0}while(1){if((a[g>>0]|0)==j<<24>>24)break e;e=e+-1|0;if(!e){e=0;f=0;break}else g=g+1|0}c[b>>2]=f;return e|0}while(0);if((g|0)==0|(e|0)==0){d=0;n=0;c[b>>2]=n;return d|0}k=a[d+2>>0]|0;j=k&255;g:do if(1){e=65;h=34881;do{if((a[h>>0]|0)==k<<24>>24)break g;h=h+1|0;e=e+-1|0;i=(e|0)!=0}while(i&(h&3|0)!=0);if(!i){d=0;n=0;c[b>>2]=n;return d|0}}else{e=65;h=34881}while(0);h:do if((a[h>>0]|0)!=k<<24>>24){i=_(j,16843009)|0;i:do if(e>>>0>3)while(1){m=c[h>>2]^i;if((m&-2139062144^-2139062144)&m+-16843009)break i;h=h+4|0;e=e+-4|0;if(e>>>0<=3){n=36;break}}else n=36;while(0);if((n|0)==36)if(!e){d=0;n=0;c[b>>2]=n;return d|0}while(1){if((a[h>>0]|0)==k<<24>>24)break h;e=e+-1|0;if(!e){e=0;f=0;break}else h=h+1|0}c[b>>2]=f;return e|0}while(0);if((h|0)==0|(e|0)==0){d=0;n=0;c[b>>2]=n;return d|0}l=a[d+3>>0]|0;k=l&255;j:do if(1){e=65;i=34881;do{if((a[i>>0]|0)==l<<24>>24)break j;i=i+1|0;e=e+-1|0;j=(e|0)!=0}while(j&(i&3|0)!=0);if(!j){d=0;n=0;c[b>>2]=n;return d|0}}else{e=65;i=34881}while(0);k:do if((a[i>>0]|0)==l<<24>>24)m=i;else{j=_(k,16843009)|0;l:do if(e>>>0>3)while(1){m=c[i>>2]^j;if((m&-2139062144^-2139062144)&m+-16843009)break l;i=i+4|0;e=e+-4|0;if(e>>>0<=3){n=49;break}}else n=49;while(0);if((n|0)==49)if(!e){d=0;n=0;c[b>>2]=n;return d|0}while(1){if((a[i>>0]|0)==l<<24>>24){m=i;break k}e=e+-1|0;if(!e){e=0;f=0;break}else i=i+1|0}c[b>>2]=f;return e|0}while(0);if((m|0)==0|(e|0)==0){d=0;n=0;c[b>>2]=n;return d|0}l=a[d+4>>0]|0;k=l&255;m:do if(1){i=65;e=34881;do{if((a[e>>0]|0)==l<<24>>24)break m;e=e+1|0;i=i+-1|0;j=(i|0)!=0}while(j&(e&3|0)!=0);if(!j){d=0;n=0;c[b>>2]=n;return d|0}}else{i=65;e=34881}while(0);n:do if((a[e>>0]|0)!=l<<24>>24){j=_(k,16843009)|0;o:do if(i>>>0>3)while(1){k=c[e>>2]^j;if((k&-2139062144^-2139062144)&k+-16843009)break o;e=e+4|0;i=i+-4|0;if(i>>>0<=3){n=62;break}}else n=62;while(0);if((n|0)==62)if(!i){d=0;n=0;c[b>>2]=n;return d|0}while(1){if((a[e>>0]|0)==l<<24>>24)break n;i=i+-1|0;if(!i){e=0;f=0;break}else e=e+1|0}c[b>>2]=f;return e|0}while(0);if((e|0)==0|(i|0)==0){d=0;n=0;c[b>>2]=n;return d|0}d=d+5|0;n=e-34881<<24|(m-34881<<18|(h-34881<<12|(g-34881<<6|f-34881)));c[b>>2]=n;return d|0}function Yb(b,d,e,f,g,h){b=b|0;d=d|0;e=e|0;f=f|0;g=g|0;h=h|0;var j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0;A=i;w=i=i+63&-64;i=i+560|0;r=w+488|0;z=w+456|0;v=w+208|0;x=w;y=w+416|0;w=w+424|0;n=v+32|0;if(d>>>0<=64){p=n;c[p>>2]=0;c[p+4>>2]=0;c[v>>2]=c[18];c[v+4>>2]=c[19];c[v+8>>2]=c[20];c[v+12>>2]=c[21];c[v+16>>2]=c[22];c[v+20>>2]=c[23];c[v+24>>2]=c[24];c[v+28>>2]=c[25];p=r;q=p+64|0;do{a[p>>0]=54;p=p+1|0}while((p|0)<(q|0));l=(d|0)==0;if(!l){j=d;k=n;a[r>>0]=a[b>>0]^54;if((j|0)==1)d=j;else{d=j;m=8}}else k=n}else{c[v>>2]=c[18];c[v+4>>2]=c[19];c[v+8>>2]=c[20];c[v+12>>2]=c[21];c[v+16>>2]=c[22];c[v+20>>2]=c[23];c[v+24>>2]=c[24];c[v+28>>2]=c[25];p=Hd(d|0,0,3)|0;l=n;c[l>>2]=p;c[l+4>>2]=C;l=v+40|0;p=l;m=b;q=p+64|0;do{a[p>>0]=a[m>>0]|0;p=p+1|0;m=m+1|0}while((p|0)<(q|0));Eb(v,l);j=b+64|0;k=Dd(d|0,0,-64,-1)|0;b=C;if(b>>>0>0|(b|0)==0&k>>>0>63){do{Eb(v,j);j=j+64|0;k=Dd(k|0,b|0,-64,-1)|0;b=C}while(b>>>0>0|(b|0)==0&k>>>0>63);b=k}else b=k;Id(l|0,j|0,b|0)|0;Db(v,z);p=n;c[p>>2]=0;c[p+4>>2]=0;c[v>>2]=c[18];c[v+4>>2]=c[19];c[v+8>>2]=c[20];c[v+12>>2]=c[21];c[v+16>>2]=c[22];c[v+20>>2]=c[23];c[v+24>>2]=c[24];c[v+28>>2]=c[25];p=r;q=p+64|0;do{a[p>>0]=54;p=p+1|0}while((p|0)<(q|0));a[r>>0]=a[z>>0]^54;d=32;b=z;k=n;l=0;m=8}if((m|0)==8){j=1;do{u=r+j|0;a[u>>0]=a[u>>0]^a[b+j>>0];j=j+1|0}while((j|0)!=(d|0))}o=k;c[o>>2]=512;c[o+4>>2]=0;o=v+40|0;p=o;m=r;q=p+64|0;do{a[p>>0]=a[m>>0]|0;p=p+1|0;m=m+1|0}while((p|0)<(q|0));Eb(v,o);n=v+104|0;m=v+136|0;p=m;c[p>>2]=0;c[p+4>>2]=0;c[n>>2]=c[18];c[n+4>>2]=c[19];c[n+8>>2]=c[20];c[n+12>>2]=c[21];c[n+16>>2]=c[22];c[n+20>>2]=c[23];c[n+24>>2]=c[24];c[n+28>>2]=c[25];p=r;q=p+64|0;do{a[p>>0]=92;p=p+1|0}while((p|0)<(q|0));if(!l?(a[r>>0]=a[b>>0]^92,(d|0)!=1):0){j=1;do{u=r+j|0;a[u>>0]=a[u>>0]^a[b+j>>0];j=j+1|0}while((j|0)!=(d|0))}j=m;c[j>>2]=512;c[j+4>>2]=0;j=v+144|0;p=j;m=r;q=p+64|0;do{a[p>>0]=a[m>>0]|0;p=p+1|0;m=m+1|0}while((p|0)<(q|0));Eb(n,j);do if(f){b=k;t=c[b>>2]|0;b=c[b+4>>2]|0;j=Gd(t|0,b|0,3)|0;j=j&63;u=Hd(f|0,0,3)|0;u=Dd(t|0,b|0,u|0,C|0)|0;b=k;c[b>>2]=u;c[b+4>>2]=C;b=64-j|0;j=v+40+j|0;if(b>>>0>f>>>0){Id(j|0,e|0,f|0)|0;break}Id(j|0,e|0,b|0)|0;Eb(v,o);j=e+b|0;k=Cd(f|0,0,b|0,0)|0;b=C;if(b>>>0>0|(b|0)==0&k>>>0>63){do{Eb(v,j);j=j+64|0;k=Dd(k|0,b|0,-64,-1)|0;b=C}while(b>>>0>0|(b|0)==0&k>>>0>63);b=k}else b=k;Id(o|0,j|0,b|0)|0}while(0);if(!h){i=A;return}l=y+3|0;d=y+2|0;n=y+1|0;o=x+32|0;r=x+104|0;e=x+136|0;f=x+144|0;s=x+40|0;t=0;u=0;do{u=u+1|0;a[l>>0]=u;a[d>>0]=u>>>8;a[n>>0]=u>>>16;a[y>>0]=u>>>24;Id(x|0,v|0,208)|0;q=o;b=c[q>>2]|0;q=c[q+4>>2]|0;j=Gd(b|0,q|0,3)|0;j=j&63;q=Dd(b|0,q|0,32,0)|0;b=o;c[b>>2]=q;c[b+4>>2]=C;b=64-j|0;j=x+40+j|0;if(b>>>0>4){q=c[y>>2]|0;a[j>>0]=q;a[j+1>>0]=q>>8;a[j+2>>0]=q>>16;a[j+3>>0]=q>>24}else{Id(j|0,y|0,b|0)|0;Eb(x,s);j=y+b|0;k=Cd(4,0,b|0,0)|0;b=C;if(b>>>0>0|(b|0)==0&k>>>0>63){do{Eb(x,j);j=j+64|0;k=Dd(k|0,b|0,-64,-1)|0;b=C}while(b>>>0>0|(b|0)==0&k>>>0>63);b=k}else b=k;Id(s|0,j|0,b|0)|0}Db(x,z);q=e;b=c[q>>2]|0;q=c[q+4>>2]|0;j=Gd(b|0,q|0,3)|0;j=j&63;q=Dd(b|0,q|0,256,0)|0;b=e;c[b>>2]=q;c[b+4>>2]=C;b=64-j|0;j=x+144+j|0;if(b>>>0>32){p=j;m=z;q=p+32|0;do{a[p>>0]=a[m>>0]|0;p=p+1|0;m=m+1|0}while((p|0)<(q|0))}else{Id(j|0,z|0,b|0)|0;Eb(r,f);j=z+b|0;k=Cd(32,0,b|0,0)|0;b=C;if(b>>>0>0|(b|0)==0&k>>>0>63){do{Eb(r,j);j=j+64|0;k=Dd(k|0,b|0,-64,-1)|0;b=C}while(b>>>0>0|(b|0)==0&k>>>0>63);b=k}else b=k;Id(f|0,j|0,b|0)|0}Db(r,w);q=h-t|0;Id(g+t|0,w|0,(q>>>0>32?32:q)|0)|0;t=u<<5}while(t>>>0<h>>>0);i=A;return}function Zb(){return 32}function _b(){return 102}function $b(){return 32984}function ac(){return 524288}function bc(){return 16777216}function cc(){return 33554432}function dc(){return 1073741824}function ec(a,b,d,e,f,g,h,j,k,l){a=a|0;b=b|0;d=d|0;e=e|0;f=f|0;g=g|0;h=h|0;j=j|0;k=k|0;l=l|0;var m=0,n=0,o=0,p=0;o=i;n=i=i+63&-64;i=i+16|0;Fd(a|0,0,b|0)|0;m=g|d;if(m>>>0>0|(m|0)==0&(f|b)>>>0>4294967295){if(!(c[7979]|0))d=31964;else d=c[(oa()|0)+60>>2]|0;c[d>>2]=27;n=-1;i=o;return n|0}g=k>>>0<0|(k|0)==0&j>>>0<32768;m=g?32768:j;k=g?0:k;a:do if(k>>>0<0|(k|0)==0&m>>>0<l>>>5>>>0){g=Gd(m|0,k|0,6)|0;j=C;k=1;while(1){m=Hd(1,0,k|0)|0;l=C;d=k+1|0;if(l>>>0>j>>>0|(l|0)==(j|0)&m>>>0>g>>>0){d=k;g=1;break a}if(d>>>0<63)k=d;else{g=1;break}}}else{g=l>>>11;j=1;while(1){l=Hd(1,0,j|0)|0;p=C;d=j+1|0;if(p>>>0>0|(p|0)==0&l>>>0>g>>>0){d=j;break}if(d>>>0<63)j=d;else break}g=Gd(m|0,k|0,2)|0;g=Gd(g|0,C|0,d|0)|0;p=C;m=p>>>0>0|(p|0)==0&g>>>0>1073741823;g=m?1073741823:g;g=g>>>3}while(0);d=Hd(1,0,d|0)|0;c[n+4>>2]=0;c[n>>2]=0;c[n+8>>2]=0;g=hc(n,e,f,h,32,d,C,8,g,a,b)|0;d=c[n>>2]|0;if(d)zd(d);p=g;i=o;return p|0}function fc(b,e,f,g,h,j,k){b=b|0;e=e|0;f=f|0;g=g|0;h=h|0;j=j|0;k=k|0;var l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0;w=i;v=i=i+63&-64;i=i+112|0;t=v+72|0;u=v+12|0;l=b;m=l+102|0;do{a[l>>0]=0;l=l+1|0}while((l|0)<(m|0));if(g>>>0>0|(g|0)==0&f>>>0>4294967295){if(!(c[7979]|0))g=31964;else g=c[(oa()|0)+60>>2]|0;c[g>>2]=27;v=-1;i=w;return v|0}m=j>>>0<0|(j|0)==0&h>>>0<32768;n=m?32768:h;m=m?0:j;a:do if(m>>>0<0|(m|0)==0&n>>>0<k>>>5>>>0){h=Gd(n|0,m|0,6)|0;l=C;m=1;while(1){k=Hd(1,0,m|0)|0;n=C;g=m+1|0;if(n>>>0>l>>>0|(n|0)==(l|0)&k>>>0>h>>>0){g=m;h=1;break a}if(g>>>0<63)m=g;else{h=1;break}}}else{h=k>>>11;l=1;while(1){k=Hd(1,0,l|0)|0;j=C;g=l+1|0;if(j>>>0>0|(j|0)==0&k>>>0>h>>>0){g=l;break}if(g>>>0<63)l=g;else break}h=Gd(n|0,m|0,2)|0;h=Gd(h|0,C|0,g|0)|0;k=C;n=k>>>0>0|(k|0)==0&h>>>0>1073741823;h=n?1073741823:h;h=h>>>3}while(0);l=0;do{a[t+l>>0]=Ba(0)|0;l=l+1|0}while((l|0)!=32);b:do if((((((((g>>>0<=63?(k=Hd(h|0,0,3)|0,n=C,!(n>>>0>0|(n|0)==0&k>>>0>1073741823)):0)?(a[u>>0]=36,a[u+1>>0]=55,a[u+2>>0]=36,a[u+3>>0]=a[34881+g>>0]|0,a[u+4>>0]=54,k=u+5|0,o=u+9|0,a[k>>0]=46,a[k+1>>0]=46,a[k+2>>0]=46,a[k+3>>0]=46,(o|0)!=0):0)?(p=o,r=u+58|0,(r|0)!=(p|0)):0)?(q=r-p|0,a[o>>0]=a[34881+(h&63)>>0]|0,(q|0)!=1):0)?(a[u+10>>0]=a[34881+(h>>>6&63)>>0]|0,(q|0)!=2):0)?(a[u+11>>0]=a[34881+(h>>>12&63)>>0]|0,(q|0)!=3):0)?(a[u+12>>0]=a[34881+(h>>>18&63)>>0]|0,(q|0)!=4):0)?(s=u+14|0,a[u+13>>0]=a[34881+(h>>>24)>>0]|0,(s|0)!=0):0){p=s;o=r-s|0;g=0;while(1){if(g>>>0<32){n=0;k=g;g=0}else break;do{s=k;k=k+1|0;g=(d[t+s>>0]|0)<<n|g;n=n+8|0}while(k>>>0<32&n>>>0<24);if(!n)g=p;else{h=g;l=o;m=p;j=0;while(1){if(!l)break b;g=m+1|0;a[m>>0]=a[34881+(h&63)>>0]|0;j=j+6|0;if(j>>>0>=n>>>0)break;else{h=h>>>6;l=l+-1|0;m=g}}}s=(g|0)==0;o=(s?0:p-g|0)+o|0;if(s)break b;else{p=g;g=k}}if(p>>>0<(u+58|0)>>>0){a[p>>0]=0;l=v+4|0;c[l>>2]=0;c[v>>2]=0;m=v+8|0;c[m>>2]=0;g=(Vb(v,e,f,u,b)|0)==0;h=c[v>>2]|0;if(h)zd(h);c[l>>2]=0;c[v>>2]=0;c[m>>2]=0;if(!g){v=0;i=w;return v|0}if(!(c[7979]|0))g=31964;else g=c[(oa()|0)+60>>2]|0;c[g>>2]=22;v=-1;i=w;return v|0}}while(0);if(!(c[7979]|0))g=31964;else g=c[(oa()|0)+60>>2]|0;c[g>>2]=22;v=-1;i=w;return v|0}function gc(b,d,e,f){b=b|0;d=d|0;e=e|0;f=f|0;var g=0,h=0,j=0,k=0,l=0,m=0;m=i;l=i=i+63&-64;i=i+128|0;f=l+12|0;a:do if(b&3){g=102;h=b;do{if(!(a[h>>0]|0)){k=5;break a}h=h+1|0;g=g+-1|0;j=(g|0)!=0}while(j&(h&3|0)!=0);if(j)k=5;else g=0}else{g=102;h=b;k=5}while(0);b:do if((k|0)==5)if(a[h>>0]|0){c:do if(g>>>0>3)while(1){j=c[h>>2]|0;if((j&-2139062144^-2139062144)&j+-16843009)break;h=h+4|0;g=g+-4|0;if(g>>>0<=3){k=10;break c}}else k=10;while(0);if((k|0)==10)if(!g){g=0;break}while(1){if(!(a[h>>0]|0))break b;h=h+1|0;g=g+-1|0;if(!g){g=0;break}}}while(0);if((((g|0)!=0?h:0)|0)!=(b+101|0)){b=-1;i=m;return b|0}j=l+4|0;c[j>>2]=0;c[l>>2]=0;k=l+8|0;c[k>>2]=0;g=(Vb(l,d,e,b,f)|0)==0;h=c[l>>2]|0;if(h)zd(h);c[j>>2]=0;c[l>>2]=0;c[k>>2]=0;if(g){b=-1;i=m;return b|0}else{g=0;h=0}do{g=a[b+h>>0]^a[f+h>>0]|g;h=h+1|0}while((h|0)!=102);h=(((g&255)+511|0)>>>8&1)+-1|0;g=f+102|0;do{a[f>>0]=0;f=f+1|0}while((f|0)<(g|0));b=h;i=m;return b|0}function hc(b,e,f,g,h,i,j,k,l,m,n){b=b|0;e=e|0;f=f|0;g=g|0;h=h|0;i=i|0;j=j|0;k=k|0;l=l|0;m=m|0;n=n|0;var o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0;J=Od(l|0,0,k|0,0)|0;I=C;if(I>>>0>0|(I|0)==0&J>>>0>1073741823){if(!(c[7979]|0))o=31964;else o=c[(oa()|0)+60>>2]|0;c[o>>2]=27;f=-1;return f|0}if(j>>>0>0|(j|0)==0&i>>>0>4294967295){if(!(c[7979]|0))o=31964;else o=c[(oa()|0)+60>>2]|0;c[o>>2]=27;f=-1;return f|0}G=Dd(i|0,j|0,-1,-1)|0;H=C;if(j>>>0<0|(j|0)==0&i>>>0<2|((G&i|0)!=0|(H&j|0)!=0)){if(!(c[7979]|0))o=31964;else o=c[(oa()|0)+60>>2]|0;c[o>>2]=22;f=-1;return f|0}if((k|0)==0|(l|0)==0){if(!(c[7979]|0))o=31964;else o=c[(oa()|0)+60>>2]|0;c[o>>2]=22;f=-1;return f|0}if(!(k>>>0>16777215?1:(33554431/(l>>>0)|0)>>>0<k>>>0)?!(0<j>>>0|(0==(j|0)?(33554431/(k>>>0)|0)>>>0<i>>>0:0)):0){I=k<<7;J=_(I,l)|0;y=Od(I|0,0,i|0,j|0)|0;o=y+J|0;if(o>>>0<y>>>0){if(!(c[7979]|0))o=31964;else o=c[(oa()|0)+60>>2]|0;c[o>>2]=12;f=-1;return f|0}F=k<<8|64;w=o+F|0;if(w>>>0<F>>>0){if(!(c[7979]|0))o=31964;else o=c[(oa()|0)+60>>2]|0;c[o>>2]=12;f=-1;return f|0}x=b+8|0;do if((c[x>>2]|0)>>>0<w>>>0){o=c[b>>2]|0;if(o)zd(o);v=b+4|0;c[v>>2]=0;c[b>>2]=0;c[x>>2]=0;do if(w>>>0<=4294967168){if(w>>>0>=4294967168){if(!(c[7979]|0))o=31964;else o=c[(oa()|0)+60>>2]|0;c[o>>2]=12;q=12;o=0;break}t=w|8;o=yd(t+76|0)|0;if(o){s=o+-8|0;do if(o&63){r=o+63&-64;F=r+-8|0;q=s;r=(F-q|0)>>>0>15?F:r+56|0;q=r-q|0;o=o+-4|0;F=c[o>>2]|0;p=(F&-8)-q|0;if(!(F&3)){c[r>>2]=(c[s>>2]|0)+q;c[r+4>>2]=p;break}else{F=r+4|0;c[F>>2]=p|c[F>>2]&1|2;E=r+p+4|0;c[E>>2]=c[E>>2]|1;c[o>>2]=q|c[o>>2]&1|2;c[F>>2]=c[F>>2]|1;Ad(s,q);break}}else r=s;while(0);o=r+4|0;p=c[o>>2]|0;if((p&3|0)!=0?(u=p&-8,u>>>0>(t+16|0)>>>0):0){F=u-t|0;E=r+t|0;c[o>>2]=t|p&1|2;c[E+4>>2]=F|3;D=E+F+4|0;c[D>>2]=c[D>>2]|1;Ad(E,F)}q=0;o=r+8|0}else{q=12;o=0}}else{q=12;o=0}while(0);if(!(c[7979]|0))p=31964;else p=c[(oa()|0)+60>>2]|0;c[p>>2]=q;if(!q){c[b>>2]=o;c[v>>2]=o;c[x>>2]=(o|0)!=0?w:0;if(!o)o=-1;else break;return o|0}else{c[b>>2]=0;c[v>>2]=0;c[x>>2]=0;f=-1;return f|0}}else o=c[b+4>>2]|0;while(0);F=o+J|0;E=F+y|0;Yb(e,f,g,h,o,J);t=k<<5;u=E+(t<<2)|0;v=E+(k<<6<<2)|0;w=(t|0)==0;x=(i|0)==0&(j|0)==0;b=t&1073741792;y=(b|0)==0;h=I+-64|0;g=E+h|0;h=u+h|0;z=h+4|0;A=g+4|0;D=0;do{B=o+(_(I,D)|0)|0;if(!w){p=0;do{s=B+(p<<2)|0;c[E+(p<<2)>>2]=(d[s+1>>0]|0)<<8|(d[s>>0]|0)|(d[s+2>>0]|0)<<16|(d[s+3>>0]|0)<<24;p=p+1|0}while((p|0)!=(t|0))}a:do if(!x){if(y){p=0;q=0;do{ic(E,u,v,k);ic(u,E,v,k);p=Dd(p|0,q|0,2,0)|0;q=C}while(q>>>0<j>>>0|(q|0)==(j|0)&p>>>0<i>>>0)}else{r=0;s=0;do{p=Od(r|0,s|0,t|0,0)|0;p=F+(p<<2)|0;q=0;do{c[p+(q<<2)>>2]=c[E+(q<<2)>>2];q=q+1|0}while((q|0)!=(b|0));ic(E,u,v,k);p=Od(r|1|0,s|0,t|0,0)|0;p=F+(p<<2)|0;q=0;do{c[p+(q<<2)>>2]=c[u+(q<<2)>>2];q=q+1|0}while((q|0)!=(b|0));ic(u,E,v,k);r=Dd(r|0,s|0,2,0)|0;s=C}while(s>>>0<j>>>0|(s|0)==(j|0)&r>>>0<i>>>0)}if(y){p=0;q=0;while(1){ic(E,u,v,k);ic(u,E,v,k);p=Dd(p|0,q|0,2,0)|0;q=C;if(!(q>>>0<j>>>0|(q|0)==(j|0)&p>>>0<i>>>0))break a}}else{r=0;s=0}do{p=Od(c[g>>2]&G|0,c[A>>2]&H|0,t|0,0)|0;p=F+(p<<2)|0;q=0;do{K=E+(q<<2)|0;c[K>>2]=c[K>>2]^c[p+(q<<2)>>2];q=q+1|0}while((q|0)!=(b|0));ic(E,u,v,k);p=Od(c[h>>2]&G|0,c[z>>2]&H|0,t|0,0)|0;p=F+(p<<2)|0;q=0;do{K=u+(q<<2)|0;c[K>>2]=c[K>>2]^c[p+(q<<2)>>2];q=q+1|0}while((q|0)!=(b|0));ic(u,E,v,k);r=Dd(r|0,s|0,2,0)|0;s=C}while(s>>>0<j>>>0|(s|0)==(j|0)&r>>>0<i>>>0)}while(0);if(!w){p=0;do{K=B+(p<<2)|0;s=c[E+(p<<2)>>2]|0;a[K>>0]=s;a[K+1>>0]=s>>>8;a[K+2>>0]=s>>>16;a[K+3>>0]=s>>>24;p=p+1|0}while((p|0)!=(t|0))}D=D+1|0}while((D|0)!=(l|0));Yb(e,f,o,J,m,n);K=0;return K|0}if(!(c[7979]|0))o=31964;else o=c[(oa()|0)+60>>2]|0;c[o>>2]=12;K=-1;return K|0}function ic(a,b,d,e){a=a|0;b=b|0;d=d|0;e=e|0;var f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0;w=e<<1;m=a+((e<<5)+-16<<2)|0;o=c[m>>2]|0;c[d>>2]=o;q=c[m+4>>2]|0;L=d+4|0;c[L>>2]=q;t=c[m+8>>2]|0;x=d+8|0;c[x>>2]=t;u=c[m+12>>2]|0;y=d+12|0;c[y>>2]=u;s=c[m+16>>2]|0;z=d+16|0;c[z>>2]=s;r=c[m+20>>2]|0;A=d+20|0;c[A>>2]=r;p=c[m+24>>2]|0;B=d+24|0;c[B>>2]=p;n=c[m+28>>2]|0;C=d+28|0;c[C>>2]=n;l=c[m+32>>2]|0;D=d+32|0;c[D>>2]=l;j=c[m+36>>2]|0;E=d+36|0;c[E>>2]=j;h=c[m+40>>2]|0;F=d+40|0;c[F>>2]=h;f=c[m+44>>2]|0;G=d+44|0;c[G>>2]=f;g=c[m+48>>2]|0;H=d+48|0;c[H>>2]=g;i=c[m+52>>2]|0;I=d+52|0;c[I>>2]=i;k=c[m+56>>2]|0;J=d+56|0;c[J>>2]=k;m=c[m+60>>2]|0;K=d+60|0;c[K>>2]=m;if(!w)return;v=e<<4;e=0;while(1){M=e<<4;N=a+(M<<2)|0;c[d>>2]=o^c[N>>2];c[L>>2]=q^c[N+4>>2];c[x>>2]=t^c[N+8>>2];c[y>>2]=u^c[N+12>>2];c[z>>2]=s^c[N+16>>2];c[A>>2]=r^c[N+20>>2];c[B>>2]=p^c[N+24>>2];c[C>>2]=n^c[N+28>>2];c[D>>2]=l^c[N+32>>2];c[E>>2]=j^c[N+36>>2];c[F>>2]=h^c[N+40>>2];c[G>>2]=f^c[N+44>>2];c[H>>2]=g^c[N+48>>2];c[I>>2]=i^c[N+52>>2];c[J>>2]=k^c[N+56>>2];c[K>>2]=m^c[N+60>>2];jc(d);u=e<<3;t=b+(u<<2)|0;c[t>>2]=c[d>>2];c[t+4>>2]=c[L>>2];c[t+8>>2]=c[x>>2];c[t+12>>2]=c[y>>2];c[t+16>>2]=c[z>>2];c[t+20>>2]=c[A>>2];c[t+24>>2]=c[B>>2];c[t+28>>2]=c[C>>2];c[t+32>>2]=c[D>>2];c[t+36>>2]=c[E>>2];c[t+40>>2]=c[F>>2];c[t+44>>2]=c[G>>2];c[t+48>>2]=c[H>>2];c[t+52>>2]=c[I>>2];c[t+56>>2]=c[J>>2];c[t+60>>2]=c[K>>2];t=a+((M|16)<<2)|0;c[d>>2]=c[d>>2]^c[t>>2];c[L>>2]=c[L>>2]^c[t+4>>2];c[x>>2]=c[x>>2]^c[t+8>>2];c[y>>2]=c[y>>2]^c[t+12>>2];c[z>>2]=c[z>>2]^c[t+16>>2];c[A>>2]=c[A>>2]^c[t+20>>2];c[B>>2]=c[B>>2]^c[t+24>>2];c[C>>2]=c[C>>2]^c[t+28>>2];c[D>>2]=c[D>>2]^c[t+32>>2];c[E>>2]=c[E>>2]^c[t+36>>2];c[F>>2]=c[F>>2]^c[t+40>>2];c[G>>2]=c[G>>2]^c[t+44>>2];c[H>>2]=c[H>>2]^c[t+48>>2];c[I>>2]=c[I>>2]^c[t+52>>2];c[J>>2]=c[J>>2]^c[t+56>>2];c[K>>2]=c[K>>2]^c[t+60>>2];jc(d);u=b+(u+v<<2)|0;c[u>>2]=c[d>>2];c[u+4>>2]=c[L>>2];c[u+8>>2]=c[x>>2];c[u+12>>2]=c[y>>2];c[u+16>>2]=c[z>>2];c[u+20>>2]=c[A>>2];c[u+24>>2]=c[B>>2];c[u+28>>2]=c[C>>2];c[u+32>>2]=c[D>>2];c[u+36>>2]=c[E>>2];c[u+40>>2]=c[F>>2];c[u+44>>2]=c[G>>2];c[u+48>>2]=c[H>>2];c[u+52>>2]=c[I>>2];c[u+56>>2]=c[J>>2];c[u+60>>2]=c[K>>2];e=e+2|0;if(e>>>0>=w>>>0)break;f=c[G>>2]|0;g=c[H>>2]|0;i=c[I>>2]|0;k=c[J>>2]|0;m=c[K>>2]|0;o=c[d>>2]|0;q=c[L>>2]|0;t=c[x>>2]|0;u=c[y>>2]|0;s=c[z>>2]|0;r=c[A>>2]|0;p=c[B>>2]|0;n=c[C>>2]|0;l=c[D>>2]|0;j=c[E>>2]|0;h=c[F>>2]|0}return}function jc(a){a=a|0;var b=0,d=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0;b=a+4|0;z=a+8|0;A=a+12|0;B=a+16|0;F=a+20|0;f=a+24|0;k=a+28|0;n=a+32|0;s=a+36|0;t=a+40|0;u=a+44|0;v=a+48|0;w=a+52|0;x=a+56|0;y=a+60|0;d=c[b>>2]|0;e=c[F>>2]|0;g=c[s>>2]|0;h=c[w>>2]|0;i=c[f>>2]|0;j=c[t>>2]|0;l=c[x>>2]|0;m=c[z>>2]|0;o=c[u>>2]|0;p=c[y>>2]|0;q=c[A>>2]|0;r=c[k>>2]|0;C=c[v>>2]|0;D=c[a>>2]|0;E=c[B>>2]|0;G=c[n>>2]|0;H=0;do{R=C+D|0;R=(R<<7|R>>>25)^E;O=R+D|0;O=(O<<9|O>>>23)^G;L=O+R|0;L=(L<<13|L>>>19)^C;U=L+O|0;U=(U<<18|U>>>14)^D;N=d+e|0;N=(N<<7|N>>>25)^g;K=N+e|0;K=(K<<9|K>>>23)^h;X=K+N|0;X=(X<<13|X>>>19)^d;Q=X+K|0;Q=(Q<<18|Q>>>14)^e;J=i+j|0;J=(J<<7|J>>>25)^l;W=J+j|0;W=(W<<9|W>>>23)^m;T=W+J|0;T=(T<<13|T>>>19)^i;M=T+W|0;M=(M<<18|M>>>14)^j;V=o+p|0;V=(V<<7|V>>>25)^q;S=V+p|0;S=(S<<9|S>>>23)^r;P=S+V|0;P=(P<<13|P>>>19)^o;I=P+S|0;I=(I<<18|I>>>14)^p;Y=V+U|0;d=(Y<<7|Y>>>25)^X;X=d+U|0;m=(X<<9|X>>>23)^W;W=m+d|0;q=(W<<13|W>>>19)^V;V=q+m|0;D=(V<<18|V>>>14)^U;U=R+Q|0;i=(U<<7|U>>>25)^T;T=i+Q|0;r=(T<<9|T>>>23)^S;S=r+i|0;E=(S<<13|S>>>19)^R;R=E+r|0;e=(R<<18|R>>>14)^Q;Q=N+M|0;o=(Q<<7|Q>>>25)^P;P=o+M|0;G=(P<<9|P>>>23)^O;O=G+o|0;g=(O<<13|O>>>19)^N;N=g+G|0;j=(N<<18|N>>>14)^M;M=J+I|0;C=(M<<7|M>>>25)^L;L=C+I|0;h=(L<<9|L>>>23)^K;K=h+C|0;l=(K<<13|K>>>19)^J;J=l+h|0;p=(J<<18|J>>>14)^I;H=H+2|0}while(H>>>0<8);c[a>>2]=(c[a>>2]|0)+D;c[b>>2]=(c[b>>2]|0)+d;c[z>>2]=(c[z>>2]|0)+m;c[A>>2]=(c[A>>2]|0)+q;c[B>>2]=(c[B>>2]|0)+E;c[F>>2]=(c[F>>2]|0)+e;c[f>>2]=(c[f>>2]|0)+i;c[k>>2]=(c[k>>2]|0)+r;c[n>>2]=(c[n>>2]|0)+G;c[s>>2]=(c[s>>2]|0)+g;c[t>>2]=(c[t>>2]|0)+j;c[u>>2]=(c[u>>2]|0)+o;c[v>>2]=(c[v>>2]|0)+C;c[w>>2]=(c[w>>2]|0)+h;c[x>>2]=(c[x>>2]|0)+l;c[y>>2]=(c[y>>2]|0)+p;return}function kc(){return 32}function lc(){return 32}function mc(a,b){a=a|0;b=b|0;md(a,b,33785);return 0}function nc(a,b,c){a=a|0;b=b|0;c=c|0;md(a,b,c);return 0}function oc(){return 32}function pc(){return 24}function qc(){return 16}function rc(b,c,d,e,f,g,h){b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;g=g|0;h=h|0;var j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0;r=i;q=i=i+63&-64;i=i+240|0;p=q;o=q+176|0;q=q+144|0;nb(q,g,h,32988);h=b;j=d;if(b>>>0>=d>>>0?0<f>>>0|0==(f|0)&(h-j|0)>>>0<e>>>0:0)k=5;else if(d>>>0>=b>>>0?0<f>>>0|0==(f|0)&(j-h|0)>>>0<e>>>0:0)k=5;if((k|0)==5){Jd(b|0,d|0,e|0)|0;d=b}h=o;k=h+32|0;do{a[h>>0]=0;h=h+1|0}while((h|0)<(k|0));l=f>>>0>0|(f|0)==0&e>>>0>32;m=l?32:e;n=l?0:f;h=(m|0)==0&(n|0)==0;if(!h){k=f>>>0<0|(f|0)==0&e>>>0<32;k=Dd((k?e:32)|0,(k?f:0)|0,-1,0)|0;Id(o+32|0,d|0,k+1|0)|0}k=Dd(m|0,n|0,32,0)|0;j=g+16|0;nd(o,o,k,C,j,0,0,q);Ub(p,o);if(!h){g=f>>>0<0|(f|0)==0&e>>>0<32;g=Dd((g?e:32)|0,(g?f:0)|0,-1,0)|0;Id(b|0,o+32|0,g+1|0)|0}h=o;k=h+64|0;do{a[h>>0]=0;h=h+1|0}while((h|0)<(k|0));if(!l){Tb(p,b,e,f);Rb(p,c);i=r;return 0}o=Cd(e|0,f|0,m|0,n|0)|0;nd(b+m|0,d+m|0,o,C,j,1,0,q);Tb(p,b,e,f);Rb(p,c);i=r;return 0}function sc(a,b,c,d,e,f){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;if(d>>>0>0|(d|0)==0&c>>>0>4294967279){e=-1;return e|0}rc(a+16|0,a,b,c,d,e,f)|0;e=0;return e|0}function tc(b,e,f,g,h,j,k){b=b|0;e=e|0;f=f|0;g=g|0;h=h|0;j=j|0;k=k|0;var l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0;t=i;s=i=i+63&-64;i=i+208|0;m=s;o=s+144|0;n=s+112|0;r=s+48|0;s=s+16|0;nb(s,j,k,32988);q=j+16|0;k=n;j=s;l=k+32|0;do{a[k>>0]=a[j>>0]|0;k=k+1|0;j=j+1|0}while((k|0)<(l|0));l=q;j=l;l=l+4|0;l=d[l>>0]|d[l+1>>0]<<8|d[l+2>>0]<<16|d[l+3>>0]<<24;k=m;c[k>>2]=d[j>>0]|d[j+1>>0]<<8|d[j+2>>0]<<16|d[j+3>>0]<<24;c[k+4>>2]=l;k=m+8|0;c[k>>2]=0;c[k+4>>2]=0;ob(o,m,n,33817);k=0;do{a[r+k>>0]=a[o+k>>0]|0;k=k+1|0}while((k|0)!=32);if(Qb(f,e,g,h,r)|0){k=s;l=k+32|0;do{a[k>>0]=0;k=k+1|0}while((k|0)<(l|0));s=-1;i=t;return s|0}k=e;j=b;if(e>>>0>=b>>>0?0<h>>>0|0==(h|0)&(k-j|0)>>>0<g>>>0:0)p=9;else if(b>>>0>=e>>>0?0<h>>>0|0==(h|0)&(j-k|0)>>>0<g>>>0:0)p=9;if((p|0)==9){Jd(b|0,e|0,g|0)|0;e=b}k=h>>>0>0|(h|0)==0&g>>>0>32;j=k?32:g;l=k?0:h;if((j|0)==0&(l|0)==0)nd(r,r,32,0,q,0,0,s);else{f=r+32|0;p=h>>>0<0|(h|0)==0&g>>>0<32;p=Dd((p?g:32)|0,(p?h:0)|0,-1,0)|0;p=p+1|0;Id(f|0,e|0,p|0)|0;o=Dd(j|0,l|0,32,0)|0;nd(r,r,o,C,q,0,0,s);Id(b|0,f|0,p|0)|0}if(k){r=Cd(g|0,h|0,j|0,l|0)|0;nd(b+j|0,e+j|0,r,C,q,1,0,s)}k=s;l=k+32|0;do{a[k>>0]=0;k=k+1|0}while((k|0)<(l|0));s=0;i=t;return s|0}function uc(a,b,c,d,e,f){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;if(d>>>0<0|(d|0)==0&c>>>0<16){e=-1;return e|0}d=Dd(c|0,d|0,-16,-1)|0;e=tc(a,b+16|0,b,d,C,e,f)|0;return e|0}function vc(){return 8}function wc(){return 16}function xc(b,c,e,f,g){b=b|0;c=c|0;e=e|0;f=f|0;g=g|0;var h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0;h=d[g>>0]|0;o=Hd(d[g+1>>0]|0|0,0,8)|0;n=C;j=Hd(d[g+2>>0]|0|0,0,16)|0;n=n|C;k=Hd(d[g+3>>0]|0|0,0,24)|0;n=n|C|(d[g+4>>0]|0);r=Hd(d[g+5>>0]|0|0,0,40)|0;n=n|C;i=Hd(d[g+6>>0]|0|0,0,48)|0;n=n|C;l=Hd(d[g+7>>0]|0|0,0,56)|0;l=o|h|j|k|r|i|l;n=n|C;i=d[g+8>>0]|0;r=Hd(d[g+9>>0]|0|0,0,8)|0;k=C;j=Hd(d[g+10>>0]|0|0,0,16)|0;k=k|C;h=Hd(d[g+11>>0]|0|0,0,24)|0;k=k|C|(d[g+12>>0]|0);o=Hd(d[g+13>>0]|0|0,0,40)|0;k=k|C;p=Hd(d[g+14>>0]|0|0,0,48)|0;k=k|C;m=Hd(d[g+15>>0]|0|0,0,56)|0;m=r|i|j|h|o|p|m;k=k|C;p=e&7;o=c+e+(0-p)|0;e=Hd(e|0,f|0,56)|0;g=C;h=m^2037671283;j=k^1952801890;i=l^1852142177;f=n^1819895653;m=m^1852075885;k=k^1685025377;l=l^1886610805;n=n^1936682341;if((o|0)!=(c|0)){do{x=d[c>>0]|0;y=Hd(d[c+1>>0]|0|0,0,8)|0;r=C;w=Hd(d[c+2>>0]|0|0,0,16)|0;r=r|C;t=Hd(d[c+3>>0]|0|0,0,24)|0;r=r|C|(d[c+4>>0]|0);u=Hd(d[c+5>>0]|0|0,0,40)|0;r=r|C;v=Hd(d[c+6>>0]|0|0,0,48)|0;r=r|C;s=Hd(d[c+7>>0]|0|0,0,56)|0;s=y|x|w|t|u|v|s;r=r|C;v=s^h;u=r^j;n=Dd(l|0,n|0,m|0,k|0)|0;l=C;t=Hd(m|0,k|0,13)|0;h=C;m=Gd(m|0,k|0,51)|0;m=(t|m)^n;h=(h|C)^l;f=Dd(v|0,u|0,i|0,f|0)|0;i=C;t=Hd(v|0,u|0,16)|0;j=C;u=Gd(v|0,u|0,48)|0;u=(t|u)^f;j=(j|C)^i;n=Dd(u|0,j|0,l|0,n|0)|0;l=C;t=Hd(u|0,j|0,21)|0;k=C;j=Gd(u|0,j|0,43)|0;j=(t|j)^n;k=(k|C)^l;i=Dd(f|0,i|0,m|0,h|0)|0;f=C;t=Hd(m|0,h|0,17)|0;u=C;h=Gd(m|0,h|0,47)|0;h=i^(t|h);u=f^(u|C);l=Dd(n|0,l|0,h|0,u|0)|0;n=C;t=Hd(h|0,u|0,13)|0;m=C;u=Gd(h|0,u|0,51)|0;u=(t|u)^l;m=(m|C)^n;i=Dd(j|0,k|0,f|0,i|0)|0;f=C;t=Hd(j|0,k|0,16)|0;h=C;k=Gd(j|0,k|0,48)|0;k=(t|k)^i;h=(h|C)^f;l=Dd(k|0,h|0,n|0,l|0)|0;n=C;t=Hd(k|0,h|0,21)|0;j=C;h=Gd(k|0,h|0,43)|0;h=(t|h)^l;j=(j|C)^n;f=Dd(i|0,f|0,u|0,m|0)|0;i=C;t=Hd(u|0,m|0,17)|0;k=C;m=Gd(u|0,m|0,47)|0;m=(t|m)^f;k=(k|C)^i;l=l^s;n=n^r;c=c+8|0}while((c|0)!=(o|0));c=o}switch(p|0){case 7:{e=Hd(d[c+6>>0]|0|0,0,48)|0|e;g=C|g;q=5;break}case 6:{q=5;break}case 5:{q=6;break}case 4:{q=7;break}case 3:{q=8;break}case 2:{q=9;break}case 1:{q=10;break}default:{}}if((q|0)==5){y=Hd(d[c+5>>0]|0|0,0,40)|0;g=C|g;e=y|e;q=6}if((q|0)==6){g=d[c+4>>0]|0|g;q=7}if((q|0)==7){y=Hd(d[c+3>>0]|0|0,0,24)|0;e=y|e;g=C|g;q=8}if((q|0)==8){y=Hd(d[c+2>>0]|0|0,0,16)|0;e=y|e;g=C|g;q=9}if((q|0)==9){y=Hd(d[c+1>>0]|0|0,0,8)|0;e=y|e;g=C|g;q=10}if((q|0)==10)e=d[c>>0]|0|e;y=e^h;r=g^j;s=Dd(l|0,n|0,m|0,k|0)|0;q=C;w=Hd(m|0,k|0,13)|0;t=C;x=Gd(m|0,k|0,51)|0;x=(w|x)^s;t=(t|C)^q;w=Dd(y|0,r|0,i|0,f|0)|0;v=C;u=Hd(y|0,r|0,16)|0;p=C;r=Gd(y|0,r|0,48)|0;r=(u|r)^w;p=(p|C)^v;s=Dd(r|0,p|0,q|0,s|0)|0;q=C;u=Hd(r|0,p|0,21)|0;y=C;p=Gd(r|0,p|0,43)|0;p=(u|p)^s;y=(y|C)^q;v=Dd(w|0,v|0,x|0,t|0)|0;w=C;u=Hd(x|0,t|0,17)|0;r=C;t=Gd(x|0,t|0,47)|0;t=v^(u|t);r=w^(r|C);q=Dd(s|0,q|0,t|0,r|0)|0;s=C;u=Hd(t|0,r|0,13)|0;x=C;r=Gd(t|0,r|0,51)|0;r=(u|r)^q;x=(x|C)^s;v=Dd(p|0,y|0,w|0,v|0)|0;w=C;u=Hd(p|0,y|0,16)|0;t=C;y=Gd(p|0,y|0,48)|0;y=(u|y)^v;t=(t|C)^w;q=Dd(y|0,t|0,s|0,q|0)|0;s=C;u=Hd(y|0,t|0,21)|0;p=C;t=Gd(y|0,t|0,43)|0;t=(u|t)^q;p=(p|C)^s;w=Dd(v|0,w|0,r|0,x|0)|0;v=C;u=Hd(r|0,x|0,17)|0;y=C;x=Gd(r|0,x|0,47)|0;x=(u|x)^w;y=(y|C)^v;s=Dd(q^e|0,s^g|0,x|0,y|0)|0;q=C;u=Hd(x|0,y|0,13)|0;r=C;y=Gd(x|0,y|0,51)|0;y=s^(u|y);r=q^(r|C);w=Dd(t|0,p|0,v^255|0,w|0)|0;v=C;u=Hd(t|0,p|0,16)|0;x=C;p=Gd(t|0,p|0,48)|0;p=(u|p)^w;x=(x|C)^v;s=Dd(p|0,x|0,q|0,s|0)|0;q=C;u=Hd(p|0,x|0,21)|0;t=C;x=Gd(p|0,x|0,43)|0;x=(u|x)^s;t=(t|C)^q;v=Dd(w|0,v|0,y|0,r|0)|0;w=C;u=Hd(y|0,r|0,17)|0;p=C;r=Gd(y|0,r|0,47)|0;r=(u|r)^v;p=(p|C)^w;q=Dd(s|0,q|0,r|0,p|0)|0;s=C;u=Hd(r|0,p|0,13)|0;y=C;p=Gd(r|0,p|0,51)|0;p=(u|p)^q;y=(y|C)^s;v=Dd(x|0,t|0,w|0,v|0)|0;w=C;u=Hd(x|0,t|0,16)|0;r=C;t=Gd(x|0,t|0,48)|0;t=(u|t)^v;r=(r|C)^w;q=Dd(t|0,r|0,s|0,q|0)|0;s=C;u=Hd(t|0,r|0,21)|0;x=C;r=Gd(t|0,r|0,43)|0;r=(u|r)^q;x=(x|C)^s;w=Dd(v|0,w|0,p|0,y|0)|0;v=C;u=Hd(p|0,y|0,17)|0;t=C;y=Gd(p|0,y|0,47)|0;y=(u|y)^w;t=(t|C)^v;s=Dd(q|0,s|0,y|0,t|0)|0;q=C;u=Hd(y|0,t|0,13)|0;p=C;t=Gd(y|0,t|0,51)|0;t=(u|t)^s;p=(p|C)^q;w=Dd(r|0,x|0,v|0,w|0)|0;v=C;u=Hd(r|0,x|0,16)|0;y=C;x=Gd(r|0,x|0,48)|0;x=(u|x)^w;y=(y|C)^v;s=Dd(x|0,y|0,q|0,s|0)|0;q=C;u=Hd(x|0,y|0,21)|0;r=C;y=Gd(x|0,y|0,43)|0;y=(u|y)^s;r=(r|C)^q;v=Dd(w|0,v|0,t|0,p|0)|0;w=C;u=Hd(t|0,p|0,17)|0;x=C;p=Gd(t|0,p|0,47)|0;p=(u|p)^v;x=(x|C)^w;q=Dd(s|0,q|0,p|0,x|0)|0;s=C;u=Hd(p|0,x|0,13)|0;t=C;x=Gd(p|0,x|0,51)|0;q=(u|x)^q;s=(t|C)^s;v=Dd(y|0,r|0,w|0,v|0)|0;w=C;t=Hd(y|0,r|0,16)|0;x=C;r=Gd(y|0,r|0,48)|0;r=(t|r)^v;x=(x|C)^w;t=Hd(r|0,x|0,21)|0;y=C;x=Gd(r|0,x|0,43)|0;y=y|C;w=Dd(v|0,w|0,q|0,s|0)|0;v=C;r=Hd(q|0,s|0,17)|0;u=C;s=Gd(q|0,s|0,47)|0;x=(r|s)^w^v^(t|x);y=(u|C)^v^w^y;a[b>>0]=x;a[b+1>>0]=x>>>8;a[b+2>>0]=x>>>16;a[b+3>>0]=x>>>24;a[b+4>>0]=y;w=Gd(x|0,y|0,40)|0;a[b+5>>0]=w;w=Gd(x|0,y|0,48)|0;a[b+6>>0]=w;y=Gd(x|0,y|0,56)|0;a[b+7>>0]=y;return 0}function yc(){return 64}function zc(){return 32}function Ac(){return 32}function Bc(){return 64}function Cc(b,e,f){b=b|0;e=e|0;f=f|0;var g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0;o=i;h=i=i+63&-64;i=i+496|0;k=h;j=h+448|0;l=h+408|0;m=h+368|0;h=h+208|0;g=k+64|0;n=k;p=8;q=n+64|0;do{c[n>>2]=c[p>>2];n=n+4|0;p=p+4|0}while((n|0)<(q|0));n=k+72|0;c[n>>2]=256;c[n+4>>2]=0;n=g;c[n>>2]=0;c[n+4>>2]=0;n=k+80|0;p=f;q=n+32|0;do{a[n>>0]=a[p>>0]|0;n=n+1|0;p=p+1|0}while((n|0)<(q|0));Gb(k,e);a[e>>0]=(d[e>>0]|0)&248;q=e+31|0;a[q>>0]=(d[q>>0]|0)&63|64;Rc(h,e);Ic(j,h+80|0);Jc(l,h,j);Jc(m,h+40|0,j);Lc(b,m);Lc(k,l);q=b+31|0;a[q>>0]=(d[q>>0]|0)^(d[k>>0]|0)<<7;Jd(e|0,f|0,32)|0;Jd(e+32|0,b|0,32)|0;i=o;return 0}function Dc(b,e){b=b|0;e=e|0;var f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0;q=i;n=i=i+63&-64;i=i+528|0;m=n;l=n+448|0;o=n+408|0;p=n+368|0;k=n+208|0;n=n+488|0;f=0;do{a[n+f>>0]=Ba(0)|0;f=f+1|0}while((f|0)!=32);f=m+64|0;g=m;h=8;j=g+64|0;do{c[g>>2]=c[h>>2];g=g+4|0;h=h+4|0}while((g|0)<(j|0));g=m+72|0;c[g>>2]=256;c[g+4>>2]=0;g=f;c[g>>2]=0;c[g+4>>2]=0;g=m+80|0;h=n;j=g+32|0;do{a[g>>0]=a[h>>0]|0;g=g+1|0;h=h+1|0}while((g|0)<(j|0));Gb(m,e);a[e>>0]=(d[e>>0]|0)&248;g=e+31|0;a[g>>0]=(d[g>>0]|0)&63|64;Rc(k,e);Ic(l,k+80|0);Jc(o,k,l);Jc(p,k+40|0,l);Lc(b,p);Lc(m,o);g=b+31|0;a[g>>0]=(d[g>>0]|0)^(d[m>>0]|0)<<7;g=e;h=n;j=g+32|0;do{a[g>>0]=a[h>>0]|0;g=g+1|0;h=h+1|0}while((g|0)<(j|0));Jd(e+32|0,b|0,32)|0;i=q;return 0}function Ec(a,b,d,e,f,g){a=a|0;b=b|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,j=0,k=0;h=i;j=i=i+63&-64;i=i+16|0;k=a+64|0;Jd(k|0,d|0,e|0)|0;Xc(a,j,k,e,f,g);g=j;d=(b|0)!=0;if((c[g>>2]|0)==64&(c[g+4>>2]|0)==0){if(!d){k=0;i=h;return k|0}j=Dd(e|0,f|0,64,0)|0;k=b;c[k>>2]=j;c[k+4>>2]=C;k=0;i=h;return k|0}else{if(d){k=b;c[k>>2]=0;c[k+4>>2]=0}k=Dd(e|0,f|0,64,0)|0;Fd(a|0,0,k|0)|0;k=-1;i=h;return k|0}return 0}function Fc(a,b,d,e,f,g){a=a|0;b=b|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0;e=Dd(e|0,f|0,-64,-1)|0;f=C;do if(!(f>>>0>0|(f|0)==0&e>>>0>4294967231)){h=d+64|0;if(Vc(d,h,e,f,g)|0){Fd(a|0,0,e|0)|0;break}if(b){d=b;c[d>>2]=e;c[d+4>>2]=f}Jd(a|0,h|0,e|0)|0;d=0;return d|0}while(0);if(!b){d=-1;return d|0}d=b;c[d>>2]=0;c[d+4>>2]=0;d=-1;return d|0}function Gc(a,b,c,d,e,f){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;Xc(a,b,c,d,e,f);return 0}function Hc(a,b,c,d,e){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;return Vc(a,b,c,d,e)|0}function Ic(a,b){a=a|0;b=b|0;var c=0,d=0,e=0,f=0,g=0;g=i;c=i=i+63&-64;i=i+160|0;d=c+120|0;e=c+80|0;f=c+40|0;Kc(d,b);Kc(e,d);Kc(e,e);Jc(e,b,e);Jc(d,d,e);Kc(f,d);Jc(e,e,f);Kc(f,e);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Jc(e,f,e);Kc(f,e);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Jc(f,f,e);Kc(c,f);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Kc(c,c);Jc(f,c,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Kc(f,f);Jc(e,f,e);Kc(f,e);b=1;do{Kc(f,f);b=b+1|0}while((b|0)!=50);Jc(f,f,e);Kc(c,f);b=1;do{Kc(c,c);b=b+1|0}while((b|0)!=100);Jc(f,c,f);Kc(f,f);b=1;do{Kc(f,f);b=b+1|0}while((b|0)!=50);Jc(e,f,e);Kc(e,e);Kc(e,e);Kc(e,e);Kc(e,e);Kc(e,e);Jc(a,e,d);i=g;return}function Jc(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0,xa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha=0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa=0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0,db=0,eb=0,fb=0,gb=0,hb=0,ib=0,jb=0,kb=0,lb=0,mb=0,nb=0,ob=0,pb=0,qb=0,rb=0,sb=0,tb=0,ub=0,vb=0,wb=0,xb=0,yb=0,zb=0,Ab=0,Bb=0,Cb=0,Db=0,Eb=0,Fb=0,Gb=0,Hb=0,Ib=0,Jb=0,Kb=0,Lb=0,Mb=0,Nb=0,Ob=0,Pb=0,Qb=0,Rb=0,Sb=0,Tb=0,Ub=0,Vb=0,Wb=0,Xb=0,Yb=0,Zb=0,_b=0,$b=0,ac=0,bc=0,cc=0,dc=0,ec=0,fc=0,gc=0,hc=0,ic=0,jc=0,kc=0,lc=0,mc=0,nc=0,oc=0,pc=0,qc=0,rc=0,sc=0,tc=0,uc=0,vc=0,wc=0,xc=0,yc=0,zc=0,Ac=0,Bc=0,Cc=0,Dc=0,Ec=0,Fc=0,Gc=0,Hc=0,Ic=0,Jc=0,Kc=0,Lc=0,Mc=0,Nc=0,Oc=0,Pc=0,Qc=0,Rc=0,Sc=0;l=c[b>>2]|0;s=c[b+4>>2]|0;j=c[b+8>>2]|0;Rb=c[b+12>>2]|0;e=c[b+16>>2]|0;za=c[b+20>>2]|0;ya=c[b+24>>2]|0;zb=c[b+28>>2]|0;h=c[b+32>>2]|0;ga=c[b+36>>2]|0;H=c[d>>2]|0;J=c[d+4>>2]|0;F=c[d+8>>2]|0;D=c[d+12>>2]|0;A=c[d+16>>2]|0;y=c[d+20>>2]|0;w=c[d+24>>2]|0;u=c[d+28>>2]|0;k=c[d+32>>2]|0;t=c[d+36>>2]|0;Oc=J*19|0;bc=F*19|0;rb=D*19|0;Ha=A*19|0;jc=y*19|0;Db=w*19|0;Ta=u*19|0;Sc=k*19|0;Qc=t*19|0;p=s<<1;f=Rb<<1;M=za<<1;i=zb<<1;d=ga<<1;o=((l|0)<0)<<31>>31;I=((H|0)<0)<<31>>31;Mc=Od(H|0,I|0,l|0,o|0)|0;Lc=C;K=((J|0)<0)<<31>>31;wc=Od(J|0,K|0,l|0,o|0)|0;vc=C;G=((F|0)<0)<<31>>31;ub=Od(F|0,G|0,l|0,o|0)|0;tb=C;E=((D|0)<0)<<31>>31;Ka=Od(D|0,E|0,l|0,o|0)|0;Ja=C;B=((A|0)<0)<<31>>31;mc=Od(A|0,B|0,l|0,o|0)|0;lc=C;z=((y|0)<0)<<31>>31;Gb=Od(y|0,z|0,l|0,o|0)|0;Fb=C;x=((w|0)<0)<<31>>31;Wa=Od(w|0,x|0,l|0,o|0)|0;Va=C;v=((u|0)<0)<<31>>31;ja=Od(u|0,v|0,l|0,o|0)|0;ia=C;Pc=((k|0)<0)<<31>>31;P=Od(k|0,Pc|0,l|0,o|0)|0;O=C;o=Od(t|0,((t|0)<0)<<31>>31|0,l|0,o|0)|0;l=C;t=((s|0)<0)<<31>>31;dc=Od(H|0,I|0,s|0,t|0)|0;ec=C;n=((p|0)<0)<<31>>31;yb=Od(J|0,K|0,p|0,n|0)|0;xb=C;Ma=Od(F|0,G|0,s|0,t|0)|0;La=C;oc=Od(D|0,E|0,p|0,n|0)|0;nc=C;Ib=Od(A|0,B|0,s|0,t|0)|0;Hb=C;Ya=Od(y|0,z|0,p|0,n|0)|0;Xa=C;la=Od(w|0,x|0,s|0,t|0)|0;ka=C;R=Od(u|0,v|0,p|0,n|0)|0;Q=C;t=Od(k|0,Pc|0,s|0,t|0)|0;s=C;Pc=((Qc|0)<0)<<31>>31;n=Od(Qc|0,Pc|0,p|0,n|0)|0;p=C;k=((j|0)<0)<<31>>31;wb=Od(H|0,I|0,j|0,k|0)|0;vb=C;Qa=Od(J|0,K|0,j|0,k|0)|0;Pa=C;qc=Od(F|0,G|0,j|0,k|0)|0;pc=C;Kb=Od(D|0,E|0,j|0,k|0)|0;Jb=C;_a=Od(A|0,B|0,j|0,k|0)|0;Za=C;na=Od(y|0,z|0,j|0,k|0)|0;ma=C;T=Od(w|0,x|0,j|0,k|0)|0;S=C;v=Od(u|0,v|0,j|0,k|0)|0;u=C;Rc=((Sc|0)<0)<<31>>31;yc=Od(Sc|0,Rc|0,j|0,k|0)|0;xc=C;k=Od(Qc|0,Pc|0,j|0,k|0)|0;j=C;Sb=((Rb|0)<0)<<31>>31;Oa=Od(H|0,I|0,Rb|0,Sb|0)|0;Na=C;fa=((f|0)<0)<<31>>31;uc=Od(J|0,K|0,f|0,fa|0)|0;tc=C;Mb=Od(F|0,G|0,Rb|0,Sb|0)|0;Lb=C;ab=Od(D|0,E|0,f|0,fa|0)|0;$a=C;pa=Od(A|0,B|0,Rb|0,Sb|0)|0;oa=C;V=Od(y|0,z|0,f|0,fa|0)|0;U=C;x=Od(w|0,x|0,Rb|0,Sb|0)|0;w=C;Ua=((Ta|0)<0)<<31>>31;Ac=Od(Ta|0,Ua|0,f|0,fa|0)|0;zc=C;Sb=Od(Sc|0,Rc|0,Rb|0,Sb|0)|0;Rb=C;fa=Od(Qc|0,Pc|0,f|0,fa|0)|0;f=C;N=((e|0)<0)<<31>>31;sc=Od(H|0,I|0,e|0,N|0)|0;rc=C;Qb=Od(J|0,K|0,e|0,N|0)|0;Pb=C;cb=Od(F|0,G|0,e|0,N|0)|0;bb=C;ra=Od(D|0,E|0,e|0,N|0)|0;qa=C;X=Od(A|0,B|0,e|0,N|0)|0;W=C;z=Od(y|0,z|0,e|0,N|0)|0;y=C;Eb=((Db|0)<0)<<31>>31;Cc=Od(Db|0,Eb|0,e|0,N|0)|0;Bc=C;Ub=Od(Ta|0,Ua|0,e|0,N|0)|0;Tb=C;ib=Od(Sc|0,Rc|0,e|0,N|0)|0;hb=C;N=Od(Qc|0,Pc|0,e|0,N|0)|0;e=C;Aa=((za|0)<0)<<31>>31;Ob=Od(H|0,I|0,za|0,Aa|0)|0;Nb=C;b=((M|0)<0)<<31>>31;gb=Od(J|0,K|0,M|0,b|0)|0;fb=C;ta=Od(F|0,G|0,za|0,Aa|0)|0;sa=C;Z=Od(D|0,E|0,M|0,b|0)|0;Y=C;B=Od(A|0,B|0,za|0,Aa|0)|0;A=C;kc=((jc|0)<0)<<31>>31;Ec=Od(jc|0,kc|0,M|0,b|0)|0;Dc=C;Wb=Od(Db|0,Eb|0,za|0,Aa|0)|0;Vb=C;kb=Od(Ta|0,Ua|0,M|0,b|0)|0;jb=C;Aa=Od(Sc|0,Rc|0,za|0,Aa|0)|0;za=C;b=Od(Qc|0,Pc|0,M|0,b|0)|0;M=C;g=((ya|0)<0)<<31>>31;eb=Od(H|0,I|0,ya|0,g|0)|0;db=C;xa=Od(J|0,K|0,ya|0,g|0)|0;wa=C;$=Od(F|0,G|0,ya|0,g|0)|0;_=C;E=Od(D|0,E|0,ya|0,g|0)|0;D=C;Ia=((Ha|0)<0)<<31>>31;Gc=Od(Ha|0,Ia|0,ya|0,g|0)|0;Fc=C;Yb=Od(jc|0,kc|0,ya|0,g|0)|0;Xb=C;mb=Od(Db|0,Eb|0,ya|0,g|0)|0;lb=C;Ca=Od(Ta|0,Ua|0,ya|0,g|0)|0;Ba=C;m=Od(Sc|0,Rc|0,ya|0,g|0)|0;r=C;g=Od(Qc|0,Pc|0,ya|0,g|0)|0;ya=C;Ab=((zb|0)<0)<<31>>31;va=Od(H|0,I|0,zb|0,Ab|0)|0;ua=C;ea=((i|0)<0)<<31>>31;da=Od(J|0,K|0,i|0,ea|0)|0;ca=C;G=Od(F|0,G|0,zb|0,Ab|0)|0;F=C;sb=((rb|0)<0)<<31>>31;Ic=Od(rb|0,sb|0,i|0,ea|0)|0;Hc=C;_b=Od(Ha|0,Ia|0,zb|0,Ab|0)|0;Zb=C;ob=Od(jc|0,kc|0,i|0,ea|0)|0;nb=C;Ea=Od(Db|0,Eb|0,zb|0,Ab|0)|0;Da=C;gc=Od(Ta|0,Ua|0,i|0,ea|0)|0;fc=C;Ab=Od(Sc|0,Rc|0,zb|0,Ab|0)|0;zb=C;ea=Od(Qc|0,Pc|0,i|0,ea|0)|0;i=C;L=((h|0)<0)<<31>>31;ba=Od(H|0,I|0,h|0,L|0)|0;aa=C;K=Od(J|0,K|0,h|0,L|0)|0;J=C;cc=((bc|0)<0)<<31>>31;Kc=Od(bc|0,cc|0,h|0,L|0)|0;Jc=C;ac=Od(rb|0,sb|0,h|0,L|0)|0;$b=C;qb=Od(Ha|0,Ia|0,h|0,L|0)|0;pb=C;Ga=Od(jc|0,kc|0,h|0,L|0)|0;Fa=C;ic=Od(Db|0,Eb|0,h|0,L|0)|0;hc=C;Cb=Od(Ta|0,Ua|0,h|0,L|0)|0;Bb=C;Sa=Od(Sc|0,Rc|0,h|0,L|0)|0;Ra=C;L=Od(Qc|0,Pc|0,h|0,L|0)|0;h=C;ha=((ga|0)<0)<<31>>31;I=Od(H|0,I|0,ga|0,ha|0)|0;H=C;q=((d|0)<0)<<31>>31;Oc=Od(Oc|0,((Oc|0)<0)<<31>>31|0,d|0,q|0)|0;Nc=C;cc=Od(bc|0,cc|0,ga|0,ha|0)|0;bc=C;sb=Od(rb|0,sb|0,d|0,q|0)|0;rb=C;Ia=Od(Ha|0,Ia|0,ga|0,ha|0)|0;Ha=C;kc=Od(jc|0,kc|0,d|0,q|0)|0;jc=C;Eb=Od(Db|0,Eb|0,ga|0,ha|0)|0;Db=C;Ua=Od(Ta|0,Ua|0,d|0,q|0)|0;Ta=C;ha=Od(Sc|0,Rc|0,ga|0,ha|0)|0;ga=C;q=Od(Qc|0,Pc|0,d|0,q|0)|0;d=C;Lc=Dd(Oc|0,Nc|0,Mc|0,Lc|0)|0;Jc=Dd(Lc|0,C|0,Kc|0,Jc|0)|0;Hc=Dd(Jc|0,C|0,Ic|0,Hc|0)|0;Fc=Dd(Hc|0,C|0,Gc|0,Fc|0)|0;Dc=Dd(Fc|0,C|0,Ec|0,Dc|0)|0;Bc=Dd(Dc|0,C|0,Cc|0,Bc|0)|0;zc=Dd(Bc|0,C|0,Ac|0,zc|0)|0;xc=Dd(zc|0,C|0,yc|0,xc|0)|0;p=Dd(xc|0,C|0,n|0,p|0)|0;n=C;ec=Dd(wc|0,vc|0,dc|0,ec|0)|0;dc=C;rc=Dd(uc|0,tc|0,sc|0,rc|0)|0;pc=Dd(rc|0,C|0,qc|0,pc|0)|0;nc=Dd(pc|0,C|0,oc|0,nc|0)|0;lc=Dd(nc|0,C|0,mc|0,lc|0)|0;jc=Dd(lc|0,C|0,kc|0,jc|0)|0;hc=Dd(jc|0,C|0,ic|0,hc|0)|0;fc=Dd(hc|0,C|0,gc|0,fc|0)|0;r=Dd(fc|0,C|0,m|0,r|0)|0;M=Dd(r|0,C|0,b|0,M|0)|0;b=C;r=Dd(p|0,n|0,33554432,0)|0;r=Ed(r|0,C|0,26)|0;m=C;bc=Dd(ec|0,dc|0,cc|0,bc|0)|0;$b=Dd(bc|0,C|0,ac|0,$b|0)|0;Zb=Dd($b|0,C|0,_b|0,Zb|0)|0;Xb=Dd(Zb|0,C|0,Yb|0,Xb|0)|0;Vb=Dd(Xb|0,C|0,Wb|0,Vb|0)|0;Tb=Dd(Vb|0,C|0,Ub|0,Tb|0)|0;Rb=Dd(Tb|0,C|0,Sb|0,Rb|0)|0;j=Dd(Rb|0,C|0,k|0,j|0)|0;j=Dd(j|0,C|0,r|0,m|0)|0;k=C;m=Hd(r|0,m|0,26)|0;m=Cd(p|0,n|0,m|0,C|0)|0;n=C;p=Dd(M|0,b|0,33554432,0)|0;p=Ed(p|0,C|0,26)|0;r=C;Nb=Dd(Qb|0,Pb|0,Ob|0,Nb|0)|0;Lb=Dd(Nb|0,C|0,Mb|0,Lb|0)|0;Jb=Dd(Lb|0,C|0,Kb|0,Jb|0)|0;Hb=Dd(Jb|0,C|0,Ib|0,Hb|0)|0;Fb=Dd(Hb|0,C|0,Gb|0,Fb|0)|0;Db=Dd(Fb|0,C|0,Eb|0,Db|0)|0;Bb=Dd(Db|0,C|0,Cb|0,Bb|0)|0;zb=Dd(Bb|0,C|0,Ab|0,zb|0)|0;ya=Dd(zb|0,C|0,g|0,ya|0)|0;ya=Dd(ya|0,C|0,p|0,r|0)|0;g=C;r=Hd(p|0,r|0,26)|0;r=Cd(M|0,b|0,r|0,C|0)|0;b=C;M=Dd(j|0,k|0,16777216,0)|0;M=Ed(M|0,C|0,25)|0;p=C;vb=Dd(yb|0,xb|0,wb|0,vb|0)|0;tb=Dd(vb|0,C|0,ub|0,tb|0)|0;rb=Dd(tb|0,C|0,sb|0,rb|0)|0;pb=Dd(rb|0,C|0,qb|0,pb|0)|0;nb=Dd(pb|0,C|0,ob|0,nb|0)|0;lb=Dd(nb|0,C|0,mb|0,lb|0)|0;jb=Dd(lb|0,C|0,kb|0,jb|0)|0;hb=Dd(jb|0,C|0,ib|0,hb|0)|0;f=Dd(hb|0,C|0,fa|0,f|0)|0;f=Dd(f|0,C|0,M|0,p|0)|0;fa=C;p=Hd(M|0,p|0,25)|0;p=Cd(j|0,k|0,p|0,C|0)|0;k=C;j=Dd(ya|0,g|0,16777216,0)|0;j=Ed(j|0,C|0,25)|0;M=C;db=Dd(gb|0,fb|0,eb|0,db|0)|0;bb=Dd(db|0,C|0,cb|0,bb|0)|0;$a=Dd(bb|0,C|0,ab|0,$a|0)|0;Za=Dd($a|0,C|0,_a|0,Za|0)|0;Xa=Dd(Za|0,C|0,Ya|0,Xa|0)|0;Va=Dd(Xa|0,C|0,Wa|0,Va|0)|0;Ta=Dd(Va|0,C|0,Ua|0,Ta|0)|0;Ra=Dd(Ta|0,C|0,Sa|0,Ra|0)|0;i=Dd(Ra|0,C|0,ea|0,i|0)|0;i=Dd(i|0,C|0,j|0,M|0)|0;ea=C;M=Hd(j|0,M|0,25)|0;M=Cd(ya|0,g|0,M|0,C|0)|0;g=C;ya=Dd(f|0,fa|0,33554432,0)|0;ya=Ed(ya|0,C|0,26)|0;j=C;Na=Dd(Qa|0,Pa|0,Oa|0,Na|0)|0;La=Dd(Na|0,C|0,Ma|0,La|0)|0;Ja=Dd(La|0,C|0,Ka|0,Ja|0)|0;Ha=Dd(Ja|0,C|0,Ia|0,Ha|0)|0;Fa=Dd(Ha|0,C|0,Ga|0,Fa|0)|0;Da=Dd(Fa|0,C|0,Ea|0,Da|0)|0;Ba=Dd(Da|0,C|0,Ca|0,Ba|0)|0;za=Dd(Ba|0,C|0,Aa|0,za|0)|0;e=Dd(za|0,C|0,N|0,e|0)|0;e=Dd(e|0,C|0,ya|0,j|0)|0;N=C;j=Hd(ya|0,j|0,26)|0;j=Cd(f|0,fa|0,j|0,C|0)|0;fa=Dd(i|0,ea|0,33554432,0)|0;fa=Ed(fa|0,C|0,26)|0;f=C;ua=Dd(xa|0,wa|0,va|0,ua|0)|0;sa=Dd(ua|0,C|0,ta|0,sa|0)|0;qa=Dd(sa|0,C|0,ra|0,qa|0)|0;oa=Dd(qa|0,C|0,pa|0,oa|0)|0;ma=Dd(oa|0,C|0,na|0,ma|0)|0;ka=Dd(ma|0,C|0,la|0,ka|0)|0;ia=Dd(ka|0,C|0,ja|0,ia|0)|0;ga=Dd(ia|0,C|0,ha|0,ga|0)|0;h=Dd(ga|0,C|0,L|0,h|0)|0;h=Dd(h|0,C|0,fa|0,f|0)|0;L=C;f=Hd(fa|0,f|0,26)|0;f=Cd(i|0,ea|0,f|0,C|0)|0;ea=Dd(e|0,N|0,16777216,0)|0;ea=Ed(ea|0,C|0,25)|0;i=C;b=Dd(ea|0,i|0,r|0,b|0)|0;r=C;i=Hd(ea|0,i|0,25)|0;i=Cd(e|0,N|0,i|0,C|0)|0;N=Dd(h|0,L|0,16777216,0)|0;N=Ed(N|0,C|0,25)|0;e=C;aa=Dd(da|0,ca|0,ba|0,aa|0)|0;_=Dd(aa|0,C|0,$|0,_|0)|0;Y=Dd(_|0,C|0,Z|0,Y|0)|0;W=Dd(Y|0,C|0,X|0,W|0)|0;U=Dd(W|0,C|0,V|0,U|0)|0;S=Dd(U|0,C|0,T|0,S|0)|0;Q=Dd(S|0,C|0,R|0,Q|0)|0;O=Dd(Q|0,C|0,P|0,O|0)|0;d=Dd(O|0,C|0,q|0,d|0)|0;d=Dd(d|0,C|0,N|0,e|0)|0;q=C;e=Hd(N|0,e|0,25)|0;e=Cd(h|0,L|0,e|0,C|0)|0;L=Dd(b|0,r|0,33554432,0)|0;L=Ed(L|0,C|0,26)|0;h=C;g=Dd(M|0,g|0,L|0,h|0)|0;h=Hd(L|0,h|0,26)|0;h=Cd(b|0,r|0,h|0,C|0)|0;r=Dd(d|0,q|0,33554432,0)|0;r=Ed(r|0,C|0,26)|0;b=C;H=Dd(K|0,J|0,I|0,H|0)|0;F=Dd(H|0,C|0,G|0,F|0)|0;D=Dd(F|0,C|0,E|0,D|0)|0;A=Dd(D|0,C|0,B|0,A|0)|0;y=Dd(A|0,C|0,z|0,y|0)|0;w=Dd(y|0,C|0,x|0,w|0)|0;u=Dd(w|0,C|0,v|0,u|0)|0;s=Dd(u|0,C|0,t|0,s|0)|0;l=Dd(s|0,C|0,o|0,l|0)|0;l=Dd(l|0,C|0,r|0,b|0)|0;o=C;b=Hd(r|0,b|0,26)|0;b=Cd(d|0,q|0,b|0,C|0)|0;q=Dd(l|0,o|0,16777216,0)|0;q=Ed(q|0,C|0,25)|0;d=C;r=Od(q|0,d|0,19,0)|0;n=Dd(r|0,C|0,m|0,n|0)|0;m=C;d=Hd(q|0,d|0,25)|0;d=Cd(l|0,o|0,d|0,C|0)|0;o=Dd(n|0,m|0,33554432,0)|0;o=Ed(o|0,C|0,26)|0;l=C;k=Dd(p|0,k|0,o|0,l|0)|0;l=Hd(o|0,l|0,26)|0;l=Cd(n|0,m|0,l|0,C|0)|0;c[a>>2]=l;c[a+4>>2]=k;c[a+8>>2]=j;c[a+12>>2]=i;c[a+16>>2]=h;c[a+20>>2]=g;c[a+24>>2]=f;c[a+28>>2]=e;c[a+32>>2]=b;c[a+36>>2]=d;return}function Kc(a,b){a=a|0;b=b|0;var d=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0,xa=0,ya=0,za=0,Aa=0,Ba=0,Ca=0,Da=0,Ea=0,Fa=0,Ga=0,Ha=0,Ia=0,Ja=0,Ka=0,La=0,Ma=0,Na=0,Oa=0,Pa=0,Qa=0,Ra=0,Sa=0,Ta=0,Ua=0,Va=0,Wa=0,Xa=0,Ya=0,Za=0,_a=0,$a=0,ab=0,bb=0,cb=0,db=0,eb=0,fb=0,gb=0;bb=c[b>>2]|0;ua=c[b+4>>2]|0;j=c[b+8>>2]|0;la=c[b+12>>2]|0;e=c[b+16>>2]|0;db=c[b+20>>2]|0;Y=c[b+24>>2]|0;La=c[b+28>>2]|0;h=c[b+32>>2]|0;b=c[b+36>>2]|0;l=bb<<1;p=ua<<1;Xa=j<<1;f=la<<1;na=e<<1;B=db<<1;m=Y<<1;i=La<<1;Ka=db*38|0;ra=Y*19|0;va=La*38|0;da=h*19|0;gb=b*38|0;cb=((bb|0)<0)<<31>>31;cb=Od(bb|0,cb|0,bb|0,cb|0)|0;bb=C;o=((l|0)<0)<<31>>31;ta=((ua|0)<0)<<31>>31;Ia=Od(l|0,o|0,ua|0,ta|0)|0;Ha=C;k=((j|0)<0)<<31>>31;Wa=Od(j|0,k|0,l|0,o|0)|0;Va=C;ma=((la|0)<0)<<31>>31;Ua=Od(la|0,ma|0,l|0,o|0)|0;Ta=C;D=((e|0)<0)<<31>>31;Oa=Od(e|0,D|0,l|0,o|0)|0;Na=C;eb=((db|0)<0)<<31>>31;ya=Od(db|0,eb|0,l|0,o|0)|0;xa=C;g=((Y|0)<0)<<31>>31;ga=Od(Y|0,g|0,l|0,o|0)|0;fa=C;Ma=((La|0)<0)<<31>>31;R=Od(La|0,Ma|0,l|0,o|0)|0;Q=C;A=((h|0)<0)<<31>>31;F=Od(h|0,A|0,l|0,o|0)|0;E=C;q=((b|0)<0)<<31>>31;o=Od(b|0,q|0,l|0,o|0)|0;l=C;n=((p|0)<0)<<31>>31;ta=Od(p|0,n|0,ua|0,ta|0)|0;ua=C;ba=Od(p|0,n|0,j|0,k|0)|0;ca=C;P=((f|0)<0)<<31>>31;Sa=Od(f|0,P|0,p|0,n|0)|0;Ra=C;Ca=Od(e|0,D|0,p|0,n|0)|0;Ba=C;d=((B|0)<0)<<31>>31;ia=Od(B|0,d|0,p|0,n|0)|0;ha=C;T=Od(Y|0,g|0,p|0,n|0)|0;S=C;O=((i|0)<0)<<31>>31;H=Od(i|0,O|0,p|0,n|0)|0;G=C;t=Od(h|0,A|0,p|0,n|0)|0;s=C;fb=((gb|0)<0)<<31>>31;n=Od(gb|0,fb|0,p|0,n|0)|0;p=C;Qa=Od(j|0,k|0,j|0,k|0)|0;Pa=C;Ya=((Xa|0)<0)<<31>>31;Aa=Od(Xa|0,Ya|0,la|0,ma|0)|0;za=C;ka=Od(e|0,D|0,Xa|0,Ya|0)|0;ja=C;X=Od(db|0,eb|0,Xa|0,Ya|0)|0;W=C;N=Od(Y|0,g|0,Xa|0,Ya|0)|0;M=C;v=Od(La|0,Ma|0,Xa|0,Ya|0)|0;u=C;ea=((da|0)<0)<<31>>31;Ya=Od(da|0,ea|0,Xa|0,Ya|0)|0;Xa=C;k=Od(gb|0,fb|0,j|0,k|0)|0;j=C;ma=Od(f|0,P|0,la|0,ma|0)|0;la=C;V=Od(f|0,P|0,e|0,D|0)|0;U=C;J=Od(B|0,d|0,f|0,P|0)|0;I=C;z=Od(Y|0,g|0,f|0,P|0)|0;y=C;wa=((va|0)<0)<<31>>31;_a=Od(va|0,wa|0,f|0,P|0)|0;Za=C;Ea=Od(da|0,ea|0,f|0,P|0)|0;Da=C;P=Od(gb|0,fb|0,f|0,P|0)|0;f=C;L=Od(e|0,D|0,e|0,D|0)|0;K=C;oa=((na|0)<0)<<31>>31;x=Od(na|0,oa|0,db|0,eb|0)|0;w=C;sa=((ra|0)<0)<<31>>31;ab=Od(ra|0,sa|0,na|0,oa|0)|0;$a=C;Ga=Od(va|0,wa|0,e|0,D|0)|0;Fa=C;oa=Od(da|0,ea|0,na|0,oa|0)|0;na=C;D=Od(gb|0,fb|0,e|0,D|0)|0;e=C;eb=Od(Ka|0,((Ka|0)<0)<<31>>31|0,db|0,eb|0)|0;db=C;Ka=Od(ra|0,sa|0,B|0,d|0)|0;Ja=C;qa=Od(va|0,wa|0,B|0,d|0)|0;pa=C;_=Od(da|0,ea|0,B|0,d|0)|0;Z=C;d=Od(gb|0,fb|0,B|0,d|0)|0;B=C;sa=Od(ra|0,sa|0,Y|0,g|0)|0;ra=C;aa=Od(va|0,wa|0,Y|0,g|0)|0;$=C;m=Od(da|0,ea|0,m|0,((m|0)<0)<<31>>31|0)|0;r=C;g=Od(gb|0,fb|0,Y|0,g|0)|0;Y=C;Ma=Od(va|0,wa|0,La|0,Ma|0)|0;La=C;wa=Od(da|0,ea|0,i|0,O|0)|0;va=C;O=Od(gb|0,fb|0,i|0,O|0)|0;i=C;ea=Od(da|0,ea|0,h|0,A|0)|0;da=C;A=Od(gb|0,fb|0,h|0,A|0)|0;h=C;q=Od(gb|0,fb|0,b|0,q|0)|0;b=C;bb=Dd(eb|0,db|0,cb|0,bb|0)|0;$a=Dd(bb|0,C|0,ab|0,$a|0)|0;Za=Dd($a|0,C|0,_a|0,Za|0)|0;Xa=Dd(Za|0,C|0,Ya|0,Xa|0)|0;p=Dd(Xa|0,C|0,n|0,p|0)|0;n=C;ua=Dd(Wa|0,Va|0,ta|0,ua|0)|0;ta=C;ca=Dd(Ua|0,Ta|0,ba|0,ca|0)|0;ba=C;Pa=Dd(Sa|0,Ra|0,Qa|0,Pa|0)|0;Na=Dd(Pa|0,C|0,Oa|0,Na|0)|0;La=Dd(Na|0,C|0,Ma|0,La|0)|0;r=Dd(La|0,C|0,m|0,r|0)|0;B=Dd(r|0,C|0,d|0,B|0)|0;d=C;r=Dd(p|0,n|0,33554432,0)|0;r=Ed(r|0,C|0,26)|0;m=C;Ha=Dd(Ka|0,Ja|0,Ia|0,Ha|0)|0;Fa=Dd(Ha|0,C|0,Ga|0,Fa|0)|0;Da=Dd(Fa|0,C|0,Ea|0,Da|0)|0;j=Dd(Da|0,C|0,k|0,j|0)|0;j=Dd(j|0,C|0,r|0,m|0)|0;k=C;m=Hd(r|0,m|0,26)|0;m=Cd(p|0,n|0,m|0,C|0)|0;n=C;p=Dd(B|0,d|0,33554432,0)|0;p=Ed(p|0,C|0,26)|0;r=C;za=Dd(Ca|0,Ba|0,Aa|0,za|0)|0;xa=Dd(za|0,C|0,ya|0,xa|0)|0;va=Dd(xa|0,C|0,wa|0,va|0)|0;Y=Dd(va|0,C|0,g|0,Y|0)|0;Y=Dd(Y|0,C|0,p|0,r|0)|0;g=C;r=Hd(p|0,r|0,26)|0;r=Cd(B|0,d|0,r|0,C|0)|0;d=C;B=Dd(j|0,k|0,16777216,0)|0;B=Ed(B|0,C|0,25)|0;p=C;ra=Dd(ua|0,ta|0,sa|0,ra|0)|0;pa=Dd(ra|0,C|0,qa|0,pa|0)|0;na=Dd(pa|0,C|0,oa|0,na|0)|0;f=Dd(na|0,C|0,P|0,f|0)|0;f=Dd(f|0,C|0,B|0,p|0)|0;P=C;p=Hd(B|0,p|0,25)|0;p=Cd(j|0,k|0,p|0,C|0)|0;k=C;j=Dd(Y|0,g|0,16777216,0)|0;j=Ed(j|0,C|0,25)|0;B=C;ja=Dd(ma|0,la|0,ka|0,ja|0)|0;ha=Dd(ja|0,C|0,ia|0,ha|0)|0;fa=Dd(ha|0,C|0,ga|0,fa|0)|0;da=Dd(fa|0,C|0,ea|0,da|0)|0;i=Dd(da|0,C|0,O|0,i|0)|0;i=Dd(i|0,C|0,j|0,B|0)|0;O=C;B=Hd(j|0,B|0,25)|0;B=Cd(Y|0,g|0,B|0,C|0)|0;g=C;Y=Dd(f|0,P|0,33554432,0)|0;Y=Ed(Y|0,C|0,26)|0;j=C;$=Dd(ca|0,ba|0,aa|0,$|0)|0;Z=Dd($|0,C|0,_|0,Z|0)|0;e=Dd(Z|0,C|0,D|0,e|0)|0;e=Dd(e|0,C|0,Y|0,j|0)|0;D=C;j=Hd(Y|0,j|0,26)|0;j=Cd(f|0,P|0,j|0,C|0)|0;P=Dd(i|0,O|0,33554432,0)|0;P=Ed(P|0,C|0,26)|0;f=C;U=Dd(X|0,W|0,V|0,U|0)|0;S=Dd(U|0,C|0,T|0,S|0)|0;Q=Dd(S|0,C|0,R|0,Q|0)|0;h=Dd(Q|0,C|0,A|0,h|0)|0;h=Dd(h|0,C|0,P|0,f|0)|0;A=C;f=Hd(P|0,f|0,26)|0;f=Cd(i|0,O|0,f|0,C|0)|0;O=Dd(e|0,D|0,16777216,0)|0;O=Ed(O|0,C|0,25)|0;i=C;d=Dd(O|0,i|0,r|0,d|0)|0;r=C;i=Hd(O|0,i|0,25)|0;i=Cd(e|0,D|0,i|0,C|0)|0;D=Dd(h|0,A|0,16777216,0)|0;D=Ed(D|0,C|0,25)|0;e=C;K=Dd(N|0,M|0,L|0,K|0)|0;I=Dd(K|0,C|0,J|0,I|0)|0;G=Dd(I|0,C|0,H|0,G|0)|0;E=Dd(G|0,C|0,F|0,E|0)|0;b=Dd(E|0,C|0,q|0,b|0)|0;b=Dd(b|0,C|0,D|0,e|0)|0;q=C;e=Hd(D|0,e|0,25)|0;e=Cd(h|0,A|0,e|0,C|0)|0;A=Dd(d|0,r|0,33554432,0)|0;A=Ed(A|0,C|0,26)|0;h=C;g=Dd(B|0,g|0,A|0,h|0)|0;h=Hd(A|0,h|0,26)|0;h=Cd(d|0,r|0,h|0,C|0)|0;r=Dd(b|0,q|0,33554432,0)|0;r=Ed(r|0,C|0,26)|0;d=C;w=Dd(z|0,y|0,x|0,w|0)|0;u=Dd(w|0,C|0,v|0,u|0)|0;s=Dd(u|0,C|0,t|0,s|0)|0;l=Dd(s|0,C|0,o|0,l|0)|0;l=Dd(l|0,C|0,r|0,d|0)|0;o=C;d=Hd(r|0,d|0,26)|0;d=Cd(b|0,q|0,d|0,C|0)|0;q=Dd(l|0,o|0,16777216,0)|0;q=Ed(q|0,C|0,25)|0;b=C;r=Od(q|0,b|0,19,0)|0;n=Dd(r|0,C|0,m|0,n|0)|0;m=C;b=Hd(q|0,b|0,25)|0;b=Cd(l|0,o|0,b|0,C|0)|0;o=Dd(n|0,m|0,33554432,0)|0;o=Ed(o|0,C|0,26)|0;l=C;k=Dd(p|0,k|0,o|0,l|0)|0;l=Hd(o|0,l|0,26)|0;l=Cd(n|0,m|0,l|0,C|0)|0;c[a>>2]=l;c[a+4>>2]=k;c[a+8>>2]=j;c[a+12>>2]=i;c[a+16>>2]=h;c[a+20>>2]=g;c[a+24>>2]=f;c[a+28>>2]=e;c[a+32>>2]=d;c[a+36>>2]=b;return}function Lc(b,d){b=b|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0;m=c[d>>2]|0;l=c[d+4>>2]|0;k=c[d+8>>2]|0;j=c[d+12>>2]|0;i=c[d+16>>2]|0;h=c[d+20>>2]|0;g=c[d+24>>2]|0;f=c[d+28>>2]|0;o=c[d+32>>2]|0;e=c[d+36>>2]|0;m=(((((((((((((e*19|0)+16777216>>25)+m>>26)+l>>25)+k>>26)+j>>25)+i>>26)+h>>25)+g>>26)+f>>25)+o>>26)+e>>25)*19|0)+m|0;n=m>>26;l=n+l|0;n=m-(n<<26)|0;m=l>>25;k=m+k|0;m=l-(m<<25)|0;l=k>>26;j=l+j|0;l=k-(l<<26)|0;k=j>>25;i=k+i|0;k=j-(k<<25)|0;j=i>>26;h=j+h|0;j=i-(j<<26)|0;i=h>>25;g=i+g|0;i=h-(i<<25)|0;h=g>>26;f=h+f|0;h=g-(h<<26)|0;g=f>>25;d=g+o|0;g=f-(g<<25)|0;f=d>>26;e=f+e|0;f=d-(f<<26)|0;d=e&33554431;a[b>>0]=n;a[b+1>>0]=n>>>8;a[b+2>>0]=n>>>16;a[b+3>>0]=m<<2|n>>>24;a[b+4>>0]=m>>>6;a[b+5>>0]=m>>>14;a[b+6>>0]=l<<3|m>>>22;a[b+7>>0]=l>>>5;a[b+8>>0]=l>>>13;a[b+9>>0]=k<<5|l>>>21;a[b+10>>0]=k>>>3;a[b+11>>0]=k>>>11;a[b+12>>0]=j<<6|k>>>19;a[b+13>>0]=j>>>2;a[b+14>>0]=j>>>10;a[b+15>>0]=j>>>18;a[b+16>>0]=i;a[b+17>>0]=i>>>8;a[b+18>>0]=i>>>16;a[b+19>>0]=h<<1|i>>>24;a[b+20>>0]=h>>>7;a[b+21>>0]=h>>>15;a[b+22>>0]=g<<3|h>>>23;a[b+23>>0]=g>>>5;a[b+24>>0]=g>>>13;a[b+25>>0]=f<<4|g>>>21;a[b+26>>0]=f>>>4;a[b+27>>0]=f>>>12;a[b+28>>0]=f>>>20|d<<6;a[b+29>>0]=e>>>2;a[b+30>>0]=e>>>10;a[b+31>>0]=d>>>18;return}function Mc(a,b,d){a=a|0;b=b|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0;V=b+40|0;j=b+44|0;m=b+48|0;p=b+52|0;s=b+56|0;v=b+60|0;y=b+64|0;B=b+68|0;E=b+72|0;C=b+76|0;S=b+4|0;P=b+8|0;e=b+12|0;l=b+16|0;n=b+20|0;u=b+24|0;w=b+28|0;D=b+32|0;O=b+36|0;ga=(c[S>>2]|0)+(c[j>>2]|0)|0;fa=(c[P>>2]|0)+(c[m>>2]|0)|0;ea=(c[e>>2]|0)+(c[p>>2]|0)|0;da=(c[l>>2]|0)+(c[s>>2]|0)|0;ca=(c[n>>2]|0)+(c[v>>2]|0)|0;ba=(c[u>>2]|0)+(c[y>>2]|0)|0;aa=(c[w>>2]|0)+(c[B>>2]|0)|0;$=(c[D>>2]|0)+(c[E>>2]|0)|0;Y=(c[O>>2]|0)+(c[C>>2]|0)|0;c[a>>2]=(c[b>>2]|0)+(c[V>>2]|0);ha=a+4|0;c[ha>>2]=ga;ga=a+8|0;c[ga>>2]=fa;fa=a+12|0;c[fa>>2]=ea;ea=a+16|0;c[ea>>2]=da;da=a+20|0;c[da>>2]=ca;ca=a+24|0;c[ca>>2]=ba;ba=a+28|0;c[ba>>2]=aa;aa=a+32|0;c[aa>>2]=$;$=a+36|0;c[$>>2]=Y;Y=a+40|0;S=(c[j>>2]|0)-(c[S>>2]|0)|0;P=(c[m>>2]|0)-(c[P>>2]|0)|0;e=(c[p>>2]|0)-(c[e>>2]|0)|0;l=(c[s>>2]|0)-(c[l>>2]|0)|0;n=(c[v>>2]|0)-(c[n>>2]|0)|0;u=(c[y>>2]|0)-(c[u>>2]|0)|0;w=(c[B>>2]|0)-(c[w>>2]|0)|0;D=(c[E>>2]|0)-(c[D>>2]|0)|0;O=(c[C>>2]|0)-(c[O>>2]|0)|0;c[Y>>2]=(c[V>>2]|0)-(c[b>>2]|0);V=a+44|0;c[V>>2]=S;S=a+48|0;c[S>>2]=P;P=a+52|0;c[P>>2]=e;e=a+56|0;c[e>>2]=l;l=a+60|0;c[l>>2]=n;n=a+64|0;c[n>>2]=u;u=a+68|0;c[u>>2]=w;w=a+72|0;c[w>>2]=D;D=a+76|0;c[D>>2]=O;O=a+80|0;Jc(O,a,d);Jc(Y,Y,d+40|0);C=a+120|0;Jc(C,d+120|0,b+120|0);Jc(a,b+80|0,d+80|0);E=c[a>>2]<<1;B=c[ha>>2]<<1;y=c[ga>>2]<<1;v=c[fa>>2]<<1;s=c[ea>>2]<<1;p=c[da>>2]<<1;m=c[ca>>2]<<1;j=c[ba>>2]<<1;g=c[aa>>2]<<1;b=c[$>>2]<<1;Z=c[O>>2]|0;N=a+84|0;W=c[N>>2]|0;M=a+88|0;T=c[M>>2]|0;L=a+92|0;Q=c[L>>2]|0;K=a+96|0;f=c[K>>2]|0;J=a+100|0;h=c[J>>2]|0;I=a+104|0;o=c[I>>2]|0;H=a+108|0;q=c[H>>2]|0;G=a+112|0;x=c[G>>2]|0;F=a+116|0;z=c[F>>2]|0;_=c[Y>>2]|0;X=c[V>>2]|0;U=c[S>>2]|0;R=c[P>>2]|0;d=c[e>>2]|0;i=c[l>>2]|0;k=c[n>>2]|0;r=c[u>>2]|0;t=c[w>>2]|0;A=c[D>>2]|0;c[a>>2]=Z-_;c[ha>>2]=W-X;c[ga>>2]=T-U;c[fa>>2]=Q-R;c[ea>>2]=f-d;c[da>>2]=h-i;c[ca>>2]=o-k;c[ba>>2]=q-r;c[aa>>2]=x-t;c[$>>2]=z-A;c[Y>>2]=_+Z;c[V>>2]=X+W;c[S>>2]=U+T;c[P>>2]=R+Q;c[e>>2]=d+f;c[l>>2]=i+h;c[n>>2]=k+o;c[u>>2]=r+q;c[w>>2]=t+x;c[D>>2]=A+z;D=c[C>>2]|0;z=a+124|0;A=c[z>>2]|0;w=a+128|0;x=c[w>>2]|0;t=a+132|0;u=c[t>>2]|0;q=a+136|0;r=c[q>>2]|0;n=a+140|0;o=c[n>>2]|0;k=a+144|0;l=c[k>>2]|0;h=a+148|0;i=c[h>>2]|0;e=a+152|0;f=c[e>>2]|0;a=a+156|0;d=c[a>>2]|0;c[O>>2]=D+E;c[N>>2]=A+B;c[M>>2]=x+y;c[L>>2]=u+v;c[K>>2]=r+s;c[J>>2]=o+p;c[I>>2]=l+m;c[H>>2]=i+j;c[G>>2]=f+g;c[F>>2]=d+b;c[C>>2]=E-D;c[z>>2]=B-A;c[w>>2]=y-x;c[t>>2]=v-u;c[q>>2]=s-r;c[n>>2]=p-o;c[k>>2]=m-l;c[h>>2]=j-i;c[e>>2]=g-f;c[a>>2]=b-d;return}\nfunction Ha(a){a=a|0;var b=0;b=i;i=i+a|0;i=i+15&-16;return b|0}function Ia(){return i|0}function Ja(a){a=a|0;i=a}function Ka(a,b){a=a|0;b=b|0;i=a;j=b}function La(a,b){a=a|0;b=b|0;if(!n){n=a;o=b}}function Ma(b){b=b|0;a[k>>0]=a[b>>0];a[k+1>>0]=a[b+1>>0];a[k+2>>0]=a[b+2>>0];a[k+3>>0]=a[b+3>>0]}function Na(b){b=b|0;a[k>>0]=a[b>>0];a[k+1>>0]=a[b+1>>0];a[k+2>>0]=a[b+2>>0];a[k+3>>0]=a[b+3>>0];a[k+4>>0]=a[b+4>>0];a[k+5>>0]=a[b+5>>0];a[k+6>>0]=a[b+6>>0];a[k+7>>0]=a[b+7>>0]}function Oa(a){a=a|0;C=a}function Pa(){return C|0}function Qa(){return 32}function Ra(){return 32}function Sa(a,b,c,d,e){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;Ua(a,b,c,d,e);return 0}function Ta(b,c,d,e,f){b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;var g=0,h=0;h=i;i=i+32|0;g=h;Ua(g,c,d,e,f);d=Yc(b,g)|0;e=(g|0)==(b|0);c=0;f=0;do{c=a[b+f>>0]^a[g+f>>0]|c;f=f+1|0}while((f|0)!=32);i=h;return (e?-1:d)|(((c&255)+511|0)>>>8&1)+-1|0}function Ua(b,d,e,f,g){b=b|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0;s=i;i=i+608|0;r=s+480|0;o=s+416|0;n=s;j=n+64|0;c[j>>2]=0;c[j+4>>2]=0;c[j+8>>2]=0;c[j+12>>2]=0;h=n;k=8;l=h+64|0;do{c[h>>2]=c[k>>2];h=h+4|0;k=k+4|0}while((h|0)<(l|0));h=r;l=h+128|0;do{a[h>>0]=54;h=h+1|0}while((h|0)<(l|0));a[r>>0]=a[g>>0]^54;h=1;do{q=r+h|0;a[q>>0]=a[q>>0]^a[g+h>>0];h=h+1|0}while((h|0)!=32);h=n+72|0;c[h>>2]=1024;c[h+4>>2]=0;c[j>>2]=0;c[j+4>>2]=0;j=n+80|0;h=j;k=r;l=h+128|0;do{a[h>>0]=a[k>>0]|0;h=h+1|0;k=k+1|0}while((h|0)<(l|0));Hb(n,j);j=a[g>>0]|0;q=n+208|0;m=n+272|0;c[m>>2]=0;c[m+4>>2]=0;c[m+8>>2]=0;c[m+12>>2]=0;h=q;k=8;l=h+64|0;do{c[h>>2]=c[k>>2];h=h+4|0;k=k+4|0}while((h|0)<(l|0));h=r;l=h+128|0;do{a[h>>0]=92;h=h+1|0}while((h|0)<(l|0));a[r>>0]=j^92;h=1;do{p=r+h|0;a[p>>0]=a[p>>0]^a[g+h>>0];h=h+1|0}while((h|0)!=32);j=n+280|0;p=j;c[p>>2]=1024;c[p+4>>2]=0;p=m;c[p>>2]=0;c[p+4>>2]=0;p=n+288|0;h=p;k=r;l=h+128|0;do{a[h>>0]=a[k>>0]|0;h=h+1|0;k=k+1|0}while((h|0)<(l|0));Hb(q,p);Fb(n,d,e,f);Gb(n,o);f=j;d=c[f>>2]|0;f=c[f+4>>2]|0;k=Gd(d|0,f|0,3)|0;k=k&127;h=Dd(d|0,f|0,512,0)|0;c[j>>2]=h;c[j+4>>2]=C;j=m;h=c[j>>2]|0;j=c[j+4>>2]|0;if(f>>>0>4294967295|(f|0)==-1&d>>>0>4294966783){h=Dd(h|0,j|0,1,0)|0;j=C;d=m;c[d>>2]=h;c[d+4>>2]=j}g=m;c[g>>2]=h;c[g+4>>2]=j;j=Cd(128,0,k|0,0)|0;g=C;h=n+288+k|0;if(g>>>0>0|(g|0)==0&j>>>0>64){k=o;l=h+64|0;do{a[h>>0]=a[k>>0]|0;h=h+1|0;k=k+1|0}while((h|0)<(l|0));Gb(q,r);h=b;k=r;l=h+32|0;do{a[h>>0]=a[k>>0]|0;h=h+1|0;k=k+1|0}while((h|0)<(l|0));i=s;return}Id(h|0,o|0,j|0)|0;Hb(q,p);h=o+j|0;j=Cd(64,0,j|0,g|0)|0;g=C;if(g>>>0>0|(g|0)==0&j>>>0>127)do{Hb(q,h);h=h+128|0;j=Dd(j|0,g|0,-128,-1)|0;g=C}while(g>>>0>0|(g|0)==0&j>>>0>127);Id(p|0,h|0,j|0)|0;Gb(q,r);h=b;k=r;l=h+32|0;do{a[h>>0]=a[k>>0]|0;h=h+1|0;k=k+1|0}while((h|0)<(l|0));i=s;return}function Va(){return 32}function Wa(){return 32}function Xa(){return 32}function Ya(){return 32}function Za(){return 24}function _a(){return 16}function $a(b,d,e){b=b|0;d=d|0;e=e|0;var f=0,g=0,h=0,j=0,k=0,l=0,m=0;k=i;i=i+272|0;h=k;g=k+208|0;f=h+64|0;j=h;l=8;m=j+64|0;do{c[j>>2]=c[l>>2];j=j+4|0;l=l+4|0}while((j|0)<(m|0));j=h+72|0;c[j>>2]=256;c[j+4>>2]=0;j=f;c[j>>2]=0;c[j+4>>2]=0;j=h+80|0;l=e;m=j+32|0;do{a[j>>0]=a[l>>0]|0;j=j+1|0;l=l+1|0}while((j|0)<(m|0));Gb(h,g);j=d;l=g;m=j+32|0;do{a[j>>0]=a[l>>0]|0;j=j+1|0;l=l+1|0}while((j|0)<(m|0));md(b,d,33785);i=k;return 0}function ab(b,c){b=b|0;c=c|0;var d=0;d=0;do{a[c+d>>0]=Ba(0)|0;d=d+1|0}while((d|0)!=32);md(b,c,33785);return 0}function bb(a,b,c){a=a|0;b=b|0;c=c|0;var d=0,e=0;d=i;i=i+32|0;e=d;md(e,c,b);nb(a,32576,e,32592);i=d;return 0}function cb(a,b,c,d,e,f,g){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;g=g|0;rc(a,b,c,d,e,f,g)|0;return 0}function db(a,b,c,d,e,f,g,h){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;g=g|0;h=h|0;var j=0,k=0,l=0;j=i;i=i+64|0;l=j+32|0;k=j;md(l,h,g);nb(k,32576,l,32592);rc(a,b,c,d,e,f,k)|0;i=j;return 0}function eb(a,b,c,d,e,f){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;if(d>>>0>0|(d|0)==0&c>>>0>4294967279){e=-1;return e|0}rc(a+16|0,a,b,c,d,e,f)|0;e=0;return e|0}function fb(a,b,c,d,e,f,g){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,j=0,k=0;k=i;i=i+64|0;j=k+32|0;h=k;if(d>>>0>0|(d|0)==0&c>>>0>4294967279){g=-1;i=k;return g|0}md(j,g,f);nb(h,32576,j,32592);rc(a+16|0,a,b,c,d,e,h)|0;g=0;i=k;return g|0}function gb(a,b,c,d,e,f,g){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;g=g|0;return tc(a,b,c,d,e,f,g)|0}function hb(a,b,c,d,e,f,g,h){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;g=g|0;h=h|0;var j=0,k=0,l=0;j=i;i=i+64|0;l=j+32|0;k=j;md(l,h,g);nb(k,32576,l,32592);h=tc(a,b,c,d,e,f,k)|0;i=j;return h|0}function ib(a,b,c,d,e,f){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;if(d>>>0<0|(d|0)==0&c>>>0<16){e=-1;return e|0}d=Dd(c|0,d|0,-16,-1)|0;e=tc(a,b+16|0,b,d,C,e,f)|0;return e|0}function jb(a,b,c,d,e,f,g){a=a|0;b=b|0;c=c|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,j=0,k=0;k=i;i=i+64|0;j=k+32|0;h=k;if(d>>>0<0|(d|0)==0&c>>>0<16){g=-1;i=k;return g|0}c=Dd(c|0,d|0,-16,-1)|0;d=C;md(j,g,f);nb(h,32576,j,32592);g=tc(a,b+16|0,b,c,d,e,h)|0;i=k;return g|0}function kb(b,d,e,f,g){b=b|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0;A=i;v=i=i+63&-64;i=i+480|0;y=v;w=v+448|0;x=v+424|0;j=v+392|0;v=v+360|0;h=0;do{a[v+h>>0]=Ba(0)|0;h=h+1|0}while((h|0)!=32);md(j,v,33785);h=b;o=j;p=h+32|0;do{a[h>>0]=a[o>>0]|0;h=h+1|0;o=o+1|0}while((h|0)<(p|0));Fd(y|0,0,357)|0;q=y;c[q>>2]=-222443248;c[q+4>>2]=1779033703;q=y+8|0;c[q>>2]=-2067093701;c[q+4>>2]=-1150833019;q=y+16|0;c[q>>2]=-23791573;c[q+4>>2]=1013904242;q=y+24|0;c[q>>2]=1595750129;c[q+4>>2]=-1521486534;q=y+32|0;c[q>>2]=-1377402159;c[q+4>>2]=1359893119;q=y+40|0;c[q>>2]=725511199;c[q+4>>2]=-1694144372;q=y+48|0;c[q>>2]=-79577749;c[q+4>>2]=528734635;q=y+56|0;c[q>>2]=327033209;c[q+4>>2]=1541459225;q=y+352|0;r=y+96|0;s=y+64|0;t=y+72|0;u=y+224|0;h=0;m=0;n=32;while(1){l=256-h|0;h=y+96+h|0;if(!(m>>>0>0|(m|0)==0&n>>>0>l>>>0)){z=5;break}Id(h|0,j|0,l|0)|0;c[q>>2]=(c[q>>2]|0)+l;p=s;h=c[p>>2]|0;p=c[p+4>>2]|0;k=Dd(h|0,p|0,128,0)|0;o=s;c[o>>2]=k;c[o+4>>2]=C;o=t;o=Dd((p>>>0>4294967295|(p|0)==-1&h>>>0>4294967167)&1|0,0,c[o>>2]|0,c[o+4>>2]|0)|0;h=t;c[h>>2]=o;c[h+4>>2]=C;Ab(y,r);h=r;o=u;p=h+128|0;do{c[h>>2]=c[o>>2];h=h+4|0;o=o+4|0}while((h|0)<(p|0));h=(c[q>>2]|0)+-128|0;c[q>>2]=h;k=Cd(n|0,m|0,l|0,0)|0;if((n|0)==(l|0)&(m|0)==0){n=g;l=0;m=32;break}else{j=j+l|0;m=C;n=k}}if((z|0)==5){Id(h|0,j|0,n|0)|0;h=Dd(c[q>>2]|0,0,n|0,m|0)|0;c[q>>2]=h;n=g;l=0;m=32}while(1){k=256-h|0;h=y+96+h|0;if(!(l>>>0>0|(l|0)==0&m>>>0>k>>>0)){z=8;break}Id(h|0,n|0,k|0)|0;c[q>>2]=(c[q>>2]|0)+k;p=s;h=c[p>>2]|0;p=c[p+4>>2]|0;j=Dd(h|0,p|0,128,0)|0;o=s;c[o>>2]=j;c[o+4>>2]=C;o=t;o=Dd((p>>>0>4294967295|(p|0)==-1&h>>>0>4294967167)&1|0,0,c[o>>2]|0,c[o+4>>2]|0)|0;h=t;c[h>>2]=o;c[h+4>>2]=C;Ab(y,r);h=r;o=u;p=h+128|0;do{c[h>>2]=c[o>>2];h=h+4|0;o=o+4|0}while((h|0)<(p|0));h=(c[q>>2]|0)+-128|0;c[q>>2]=h;j=Cd(m|0,l|0,k|0,0)|0;if((m|0)==(k|0)&(l|0)==0)break;else{n=n+k|0;l=C;m=j}}if((z|0)==8){Id(h|0,n|0,m|0)|0;z=Dd(c[q>>2]|0,0,m|0,l|0)|0;c[q>>2]=z}zb(y,x,24)|0;if(f>>>0>0|(f|0)==0&e>>>0>4294967279){z=-1;i=A;return z|0}md(y,v,g);nb(w,32576,y,32592);rc(b+48|0,b+32|0,d,e,f,x,w)|0;z=0;i=A;return z|0}function lb(a,b,d,e,f,g){a=a|0;b=b|0;d=d|0;e=e|0;f=f|0;g=g|0;var h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0;y=i;v=i=i+63&-64;i=i+416|0;w=v;u=v+384|0;v=v+360|0;if(e>>>0<0|(e|0)==0&d>>>0<48){x=-1;i=y;return x|0}Fd(w|0,0,357)|0;p=w;c[p>>2]=-222443248;c[p+4>>2]=1779033703;p=w+8|0;c[p>>2]=-2067093701;c[p+4>>2]=-1150833019;p=w+16|0;c[p>>2]=-23791573;c[p+4>>2]=1013904242;p=w+24|0;c[p>>2]=1595750129;c[p+4>>2]=-1521486534;p=w+32|0;c[p>>2]=-1377402159;c[p+4>>2]=1359893119;p=w+40|0;c[p>>2]=725511199;c[p+4>>2]=-1694144372;p=w+48|0;c[p>>2]=-79577749;c[p+4>>2]=528734635;p=w+56|0;c[p>>2]=327033209;c[p+4>>2]=1541459225;p=w+352|0;q=w+96|0;r=w+64|0;s=w+72|0;t=w+224|0;k=b;h=0;m=0;n=32;while(1){l=256-h|0;h=w+96+h|0;if(!(m>>>0>0|(m|0)==0&n>>>0>l>>>0)){x=4;break}Id(h|0,k|0,l|0)|0;c[p>>2]=(c[p>>2]|0)+l;o=r;h=c[o>>2]|0;o=c[o+4>>2]|0;z=Dd(h|0,o|0,128,0)|0;j=r;c[j>>2]=z;c[j+4>>2]=C;j=s;j=Dd((o>>>0>4294967295|(o|0)==-1&h>>>0>4294967167)&1|0,0,c[j>>2]|0,c[j+4>>2]|0)|0;h=s;c[h>>2]=j;c[h+4>>2]=C;Ab(w,q);h=q;j=t;o=h+128|0;do{c[h>>2]=c[j>>2];h=h+4|0;j=j+4|0}while((h|0)<(o|0));h=(c[p>>2]|0)+-128|0;c[p>>2]=h;j=Cd(n|0,m|0,l|0,0)|0;if((n|0)==(l|0)&(m|0)==0){l=0;m=32;break}else{k=k+l|0;m=C;n=j}}if((x|0)==4){Id(h|0,k|0,n|0)|0;h=Dd(c[p>>2]|0,0,n|0,m|0)|0;c[p>>2]=h;l=0;m=32}while(1){k=256-h|0;h=w+96+h|0;if(!(l>>>0>0|(l|0)==0&m>>>0>k>>>0)){x=7;break}Id(h|0,f|0,k|0)|0;c[p>>2]=(c[p>>2]|0)+k;o=r;h=c[o>>2]|0;o=c[o+4>>2]|0;z=Dd(h|0,o|0,128,0)|0;j=r;c[j>>2]=z;c[j+4>>2]=C;j=s;j=Dd((o>>>0>4294967295|(o|0)==-1&h>>>0>4294967167)&1|0,0,c[j>>2]|0,c[j+4>>2]|0)|0;h=s;c[h>>2]=j;c[h+4>>2]=C;Ab(w,q);h=q;j=t;o=h+128|0;do{c[h>>2]=c[j>>2];h=h+4|0;j=j+4|0}while((h|0)<(o|0));h=(c[p>>2]|0)+-128|0;c[p>>2]=h;j=Cd(m|0,l|0,k|0,0)|0;if((m|0)==(k|0)&(l|0)==0)break;else{f=f+k|0;l=C;m=j}}if((x|0)==7){Id(h|0,f|0,m|0)|0;z=Dd(c[p>>2]|0,0,m|0,l|0)|0;c[p>>2]=z}zb(w,v,24)|0;if((d&-16|0)==32&(e|0)==0){z=-1;i=y;return z|0}x=Dd(d|0,e|0,-48,-1)|0;z=C;md(w,g,b);nb(u,32576,w,32592);z=tc(a,b+48|0,b+32|0,x,z,v,u)|0;i=y;return z|0}function mb(){return 48}function nb(b,c,e,f){b=b|0;c=c|0;e=e|0;f=f|0;var g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0;k=20;l=(d[f+1>>0]|0)<<8|(d[f>>0]|0)|(d[f+2>>0]|0)<<16|(d[f+3>>0]|0)<<24;m=(d[e+1>>0]|0)<<8|(d[e>>0]|0)|(d[e+2>>0]|0)<<16|(d[e+3>>0]|0)<<24;n=(d[f+9>>0]|0)<<8|(d[f+8>>0]|0)|(d[f+10>>0]|0)<<16|(d[f+11>>0]|0)<<24;o=(d[e+17>>0]|0)<<8|(d[e+16>>0]|0)|(d[e+18>>0]|0)<<16|(d[e+19>>0]|0)<<24;p=(d[e+21>>0]|0)<<8|(d[e+20>>0]|0)|(d[e+22>>0]|0)<<16|(d[e+23>>0]|0)<<24;q=(d[e+25>>0]|0)<<8|(d[e+24>>0]|0)|(d[e+26>>0]|0)<<16|(d[e+27>>0]|0)<<24;r=(d[e+29>>0]|0)<<8|(d[e+28>>0]|0)|(d[e+30>>0]|0)<<16|(d[e+31>>0]|0)<<24;s=(d[f+13>>0]|0)<<8|(d[f+12>>0]|0)|(d[f+14>>0]|0)<<16|(d[f+15>>0]|0)<<24;t=(d[e+5>>0]|0)<<8|(d[e+4>>0]|0)|(d[e+6>>0]|0)<<16|(d[e+7>>0]|0)<<24;u=(d[e+9>>0]|0)<<8|(d[e+8>>0]|0)|(d[e+10>>0]|0)<<16|(d[e+11>>0]|0)<<24;j=(d[e+13>>0]|0)<<8|(d[e+12>>0]|0)|(d[e+14>>0]|0)<<16|(d[e+15>>0]|0)<<24;f=(d[f+5>>0]|0)<<8|(d[f+4>>0]|0)|(d[f+6>>0]|0)<<16|(d[f+7>>0]|0)<<24;g=(d[c+1>>0]|0)<<8|(d[c>>0]|0)|(d[c+2>>0]|0)<<16|(d[c+3>>0]|0)<<24;h=(d[c+5>>0]|0)<<8|(d[c+4>>0]|0)|(d[c+6>>0]|0)<<16|(d[c+7>>0]|0)<<24;i=(d[c+9>>0]|0)<<8|(d[c+8>>0]|0)|(d[c+10>>0]|0)<<16|(d[c+11>>0]|0)<<24;e=(d[c+13>>0]|0)<<8|(d[c+12>>0]|0)|(d[c+14>>0]|0)<<16|(d[c+15>>0]|0)<<24;while(1){D=p+l|0;D=(D>>>25|D<<7)^j;A=D+l|0;A=(A>>>23|A<<9)^i;x=A+D|0;x=(x>>>19|x<<13)^p;G=x+A|0;G=(G>>>14|G<<18)^l;z=f+m|0;z=e^(z>>>25|z<<7);w=z+f|0;w=q^(w>>>23|w<<9);J=w+z|0;J=(J>>>19|J<<13)^m;C=J+w|0;C=(C>>>14|C<<18)^f;v=n+g|0;v=r^(v>>>25|v<<7);I=v+n|0;I=(I>>>23|I<<9)^t;F=I+v|0;F=(F>>>19|F<<13)^g;y=F+I|0;y=(y>>>14|y<<18)^n;H=s+o|0;H=(H>>>25|H<<7)^u;E=H+s|0;E=(E>>>23|E<<9)^h;B=E+H|0;B=(B>>>19|B<<13)^o;c=B+E|0;c=(c>>>14|c<<18)^s;K=G+H|0;m=(K>>>25|K<<7)^J;J=m+G|0;t=(J>>>23|J<<9)^I;I=t+m|0;u=(I>>>19|I<<13)^H;H=u+t|0;l=(H>>>14|H<<18)^G;G=C+D|0;g=(G>>>25|G<<7)^F;F=g+C|0;h=(F>>>23|F<<9)^E;E=h+g|0;j=(E>>>19|E<<13)^D;D=j+h|0;f=(D>>>14|D<<18)^C;C=y+z|0;o=(C>>>25|C<<7)^B;B=o+y|0;i=(B>>>23|B<<9)^A;A=i+o|0;e=(A>>>19|A<<13)^z;z=e+i|0;n=(z>>>14|z<<18)^y;y=c+v|0;p=(y>>>25|y<<7)^x;x=p+c|0;q=(x>>>23|x<<9)^w;w=q+p|0;r=(w>>>19|w<<13)^v;v=r+q|0;s=(v>>>14|v<<18)^c;if((k|0)<=2)break;else k=k+-2|0}a[b>>0]=l;a[b+1>>0]=l>>>8;a[b+2>>0]=l>>>16;a[b+3>>0]=l>>>24;a[b+4>>0]=f;a[b+5>>0]=f>>>8;a[b+6>>0]=f>>>16;a[b+7>>0]=f>>>24;a[b+8>>0]=n;a[b+9>>0]=n>>>8;a[b+10>>0]=n>>>16;a[b+11>>0]=n>>>24;a[b+12>>0]=s;a[b+13>>0]=s>>>8;a[b+14>>0]=s>>>16;a[b+15>>0]=s>>>24;a[b+16>>0]=g;a[b+17>>0]=g>>>8;a[b+18>>0]=g>>>16;a[b+19>>0]=g>>>24;a[b+20>>0]=h;a[b+21>>0]=h>>>8;a[b+22>>0]=h>>>16;a[b+23>>0]=h>>>24;a[b+24>>0]=i;a[b+25>>0]=i>>>8;a[b+26>>0]=i>>>16;a[b+27>>0]=i>>>24;a[b+28>>0]=e;a[b+29>>0]=e>>>8;a[b+30>>0]=e>>>16;a[b+31>>0]=e>>>24;return}function ob(b,c,e,f){b=b|0;c=c|0;e=e|0;f=f|0;var g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0;F=(d[f+1>>0]|0)<<8|(d[f>>0]|0)|(d[f+2>>0]|0)<<16|(d[f+3>>0]|0)<<24;G=(d[e+1>>0]|0)<<8|(d[e>>0]|0)|(d[e+2>>0]|0)<<16|(d[e+3>>0]|0)<<24;H=(d[e+5>>0]|0)<<8|(d[e+4>>0]|0)|(d[e+6>>0]|0)<<16|(d[e+7>>0]|0)<<24;I=(d[e+9>>0]|0)<<8|(d[e+8>>0]|0)|(d[e+10>>0]|0)<<16|(d[e+11>>0]|0)<<24;J=(d[e+13>>0]|0)<<8|(d[e+12>>0]|0)|(d[e+14>>0]|0)<<16|(d[e+15>>0]|0)<<24;B=(d[f+5>>0]|0)<<8|(d[f+4>>0]|0)|(d[f+6>>0]|0)<<16|(d[f+7>>0]|0)<<24;C=(d[c+1>>0]|0)<<8|(d[c>>0]|0)|(d[c+2>>0]|0)<<16|(d[c+3>>0]|0)<<24;D=(d[c+5>>0]|0)<<8|(d[c+4>>0]|0)|(d[c+6>>0]|0)<<16|(d[c+7>>0]|0)<<24;E=(d[c+9>>0]|0)<<8|(d[c+8>>0]|0)|(d[c+10>>0]|0)<<16|(d[c+11>>0]|0)<<24;w=(d[c+13>>0]|0)<<8|(d[c+12>>0]|0)|(d[c+14>>0]|0)<<16|(d[c+15>>0]|0)<<24;x=(d[f+9>>0]|0)<<8|(d[f+8>>0]|0)|(d[f+10>>0]|0)<<16|(d[f+11>>0]|0)<<24;y=(d[e+17>>0]|0)<<8|(d[e+16>>0]|0)|(d[e+18>>0]|0)<<16|(d[e+19>>0]|0)<<24;z=(d[e+21>>0]|0)<<8|(d[e+20>>0]|0)|(d[e+22>>0]|0)<<16|(d[e+23>>0]|0)<<24;A=(d[e+25>>0]|0)<<8|(d[e+24>>0]|0)|(d[e+26>>0]|0)<<16|(d[e+27>>0]|0)<<24;v=(d[e+29>>0]|0)<<8|(d[e+28>>0]|0)|(d[e+30>>0]|0)<<16|(d[e+31>>0]|0)<<24;c=(d[f+13>>0]|0)<<8|(d[f+12>>0]|0)|(d[f+14>>0]|0)<<16|(d[f+15>>0]|0)<<24;e=20;f=F;g=G;h=x;i=y;j=z;k=A;l=v;m=c;n=H;o=I;p=J;q=B;r=C;s=D;t=E;u=w;while(1){T=f+j|0;T=(T>>>25|T<<7)^p;Q=T+f|0;Q=(Q>>>23|Q<<9)^t;N=Q+T|0;N=(N>>>19|N<<13)^j;W=N+Q|0;W=(W>>>14|W<<18)^f;P=g+q|0;P=(P>>>25|P<<7)^u;M=P+q|0;M=(M>>>23|M<<9)^k;Z=M+P|0;Z=(Z>>>19|Z<<13)^g;S=Z+M|0;S=(S>>>14|S<<18)^q;L=r+h|0;L=(L>>>25|L<<7)^l;Y=L+h|0;Y=(Y>>>23|Y<<9)^n;V=Y+L|0;V=(V>>>19|V<<13)^r;O=V+Y|0;O=(O>>>14|O<<18)^h;X=i+m|0;X=o^(X>>>25|X<<7);U=X+m|0;U=(U>>>23|U<<9)^s;R=U+X|0;R=(R>>>19|R<<13)^i;K=R+U|0;K=(K>>>14|K<<18)^m;_=W+X|0;g=(_>>>25|_<<7)^Z;Z=g+W|0;n=(Z>>>23|Z<<9)^Y;Y=n+g|0;o=(Y>>>19|Y<<13)^X;X=o+n|0;f=(X>>>14|X<<18)^W;W=S+T|0;r=(W>>>25|W<<7)^V;V=r+S|0;s=(V>>>23|V<<9)^U;U=s+r|0;p=(U>>>19|U<<13)^T;T=p+s|0;q=(T>>>14|T<<18)^S;S=O+P|0;i=(S>>>25|S<<7)^R;R=i+O|0;t=(R>>>23|R<<9)^Q;Q=t+i|0;u=(Q>>>19|Q<<13)^P;P=u+t|0;h=(P>>>14|P<<18)^O;O=K+L|0;j=(O>>>25|O<<7)^N;N=j+K|0;k=(N>>>23|N<<9)^M;M=k+j|0;l=(M>>>19|M<<13)^L;L=l+k|0;m=(L>>>14|L<<18)^K;if((e|0)<=2)break;else e=e+-2|0}L=f+F|0;M=g+G|0;N=n+H|0;O=o+I|0;P=p+J|0;Q=q+B|0;R=r+C|0;S=s+D|0;T=t+E|0;U=u+w|0;V=h+x|0;W=i+y|0;X=j+z|0;Y=k+A|0;Z=l+v|0;_=m+c|0;a[b>>0]=L;a[b+1>>0]=L>>>8;a[b+2>>0]=L>>>16;a[b+3>>0]=L>>>24;a[b+4>>0]=M;a[b+5>>0]=M>>>8;a[b+6>>0]=M>>>16;a[b+7>>0]=M>>>24;a[b+8>>0]=N;a[b+9>>0]=N>>>8;a[b+10>>0]=N>>>16;a[b+11>>0]=N>>>24;a[b+12>>0]=O;a[b+13>>0]=O>>>8;a[b+14>>0]=O>>>16;a[b+15>>0]=O>>>24;a[b+16>>0]=P;a[b+17>>0]=P>>>8;a[b+18>>0]=P>>>16;a[b+19>>0]=P>>>24;a[b+20>>0]=Q;a[b+21>>0]=Q>>>8;a[b+22>>0]=Q>>>16;a[b+23>>0]=Q>>>24;a[b+24>>0]=R;a[b+25>>0]=R>>>8;a[b+26>>0]=R>>>16;a[b+27>>0]=R>>>24;a[b+28>>0]=S;a[b+29>>0]=S>>>8;a[b+30>>0]=S>>>16;a[b+31>>0]=S>>>24;a[b+32>>0]=T;a[b+33>>0]=T>>>8;a[b+34>>0]=T>>>16;a[b+35>>0]=T>>>24;a[b+36>>0]=U;a[b+37>>0]=U>>>8;a[b+38>>0]=U>>>16;a[b+39>>0]=U>>>24;a[b+40>>0]=V;a[b+41>>0]=V>>>8;a[b+42>>0]=V>>>16;a[b+43>>0]=V>>>24;a[b+44>>0]=W;a[b+45>>0]=W>>>8;a[b+46>>0]=W>>>16;a[b+47>>0]=W>>>24;a[b+48>>0]=X;a[b+49>>0]=X>>>8;a[b+50>>0]=X>>>16;a[b+51>>0]=X>>>24;a[b+52>>0]=Y;a[b+53>>0]=Y>>>8;a[b+54>>0]=Y>>>16;a[b+55>>0]=Y>>>24;a[b+56>>0]=Z;a[b+57>>0]=Z>>>8;a[b+58>>0]=Z>>>16;a[b+59>>0]=Z>>>24;a[b+60>>0]=_;a[b+61>>0]=_>>>8;a[b+62>>0]=_>>>16;a[b+63>>0]=_>>>24;return}function pb(){return 16}function qb(){return 64}function rb(){return 32}function sb(){return 16}function tb(){return 64}function ub(){return 32}function vb(){return 384}function wb(b,e,f,g,h,j,k){b=b|0;e=e|0;f=f|0;g=g|0;h=h|0;j=j|0;k=k|0;var l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0;v=i;t=i=i+63&-64;i=i+496|0;n=t+360|0;if((e+-1|0)>>>0>63|k>>>0>64){u=-1;i=v;return u|0}if(e>>>0>=256)za(32608,32628,18,32680);if(k>>>0>=256)za(32707,32628,19,32680);m=k&255;do if(!((b|0)==0|(f|0)==0&((g|0)!=0|(h|0)!=0)|((e&255)+-1&255)>63)?(l=m<<24>>24==0,!((m&255)>64|((j|0)!=0|l)^1)):0){if(l){Fd(t|0,0,357)|0;m=t;c[m>>2]=e&255^-222443256;c[m+4>>2]=1779033703;m=t+8|0;c[m>>2]=-2067093701;c[m+4>>2]=-1150833019;m=t+16|0;c[m>>2]=-23791573;c[m+4>>2]=1013904242;m=t+24|0;c[m>>2]=1595750129;c[m+4>>2]=-1521486534;m=t+32|0;c[m>>2]=-1377402159;c[m+4>>2]=1359893119;m=t+40|0;c[m>>2]=725511199;c[m+4>>2]=-1694144372;m=t+48|0;c[m>>2]=-79577749;c[m+4>>2]=528734635;m=t+56|0;c[m>>2]=327033209;c[m+4>>2]=1541459225;m=0}else{if((j|0)==0|(m+-1&255)>63){l=-1;break}l=k&255;Fd(t|0,0,357)|0;s=Hd(l|0,0,8)|0;o=t;c[o>>2]=(s|e&255)^-222443256;c[o+4>>2]=C^1779033703;o=t+8|0;c[o>>2]=-2067093701;c[o+4>>2]=-1150833019;o=t+16|0;c[o>>2]=-23791573;c[o+4>>2]=1013904242;o=t+24|0;c[o>>2]=1595750129;c[o+4>>2]=-1521486534;o=t+32|0;c[o>>2]=-1377402159;c[o+4>>2]=1359893119;o=t+40|0;c[o>>2]=725511199;c[o+4>>2]=-1694144372;o=t+48|0;c[o>>2]=-79577749;c[o+4>>2]=528734635;o=t+56|0;c[o>>2]=327033209;c[o+4>>2]=1541459225;Fd(n+l|0,0,(m<<24>>24<0?0:128-l|0)|0)|0;Id(n|0,j|0,l|0)|0;l=t+352|0;o=t+96|0;m=o+128|0;do{a[o>>0]=a[n>>0]|0;o=o+1|0;n=n+1|0}while((o|0)<(m|0));c[l>>2]=128;m=128}k=t+352|0;if(!((g|0)==0&(h|0)==0)){q=t+96|0;j=t+64|0;r=t+72|0;s=t+224|0;p=f;while(1){f=256-m|0;l=t+96+m|0;if(!(h>>>0>0|(h|0)==0&g>>>0>f>>>0)){u=16;break}Id(l|0,p|0,f|0)|0;c[k>>2]=(c[k>>2]|0)+f;m=j;o=c[m>>2]|0;m=c[m+4>>2]|0;l=Dd(o|0,m|0,128,0)|0;n=j;c[n>>2]=l;c[n+4>>2]=C;n=r;n=Dd((m>>>0>4294967295|(m|0)==-1&o>>>0>4294967167)&1|0,0,c[n>>2]|0,c[n+4>>2]|0)|0;o=r;c[o>>2]=n;c[o+4>>2]=C;Ab(t,q);o=q;n=s;m=o+128|0;do{c[o>>2]=c[n>>2];o=o+4|0;n=n+4|0}while((o|0)<(m|0));m=(c[k>>2]|0)+-128|0;c[k>>2]=m;l=Cd(g|0,h|0,f|0,0)|0;if((g|0)==(f|0)&(h|0)==0)break;else{p=p+f|0;h=C;g=l}}if((u|0)==16){Id(l|0,p|0,g|0)|0;m=Dd(c[k>>2]|0,0,g|0,h|0)|0;c[k>>2]=m}l=e&255;if(m>>>0>128){s=j;e=c[s>>2]|0;s=c[s+4>>2]|0;m=Dd(e|0,s|0,128,0)|0;n=j;c[n>>2]=m;c[n+4>>2]=C;n=t+72|0;m=n;m=Dd((s>>>0>4294967295|(s|0)==-1&e>>>0>4294967167)&1|0,0,c[m>>2]|0,c[m+4>>2]|0)|0;e=n;c[e>>2]=m;c[e+4>>2]=C;e=t+96|0;Ab(t,e);m=(c[k>>2]|0)+-128|0;c[k>>2]=m;Jd(e|0,t+224|0,m|0)|0;m=c[k>>2]|0}else u=19}else{j=t+64|0;l=e&255;u=19}if((u|0)==19)n=t+72|0;u=j;u=Dd(c[u>>2]|0,c[u+4>>2]|0,m|0,0)|0;s=C;r=j;c[r>>2]=u;c[r+4>>2]=s;r=n;e=r;r=r+4|0;r=Dd((s>>>0<0|(s|0)==0&u>>>0<m>>>0)&1|0,0,d[e>>0]|d[e+1>>0]<<8|d[e+2>>0]<<16|d[e+3>>0]<<24|0,d[r>>0]|d[r+1>>0]<<8|d[r+2>>0]<<16|d[r+3>>0]<<24|0)|0;e=C;u=n;s=u;a[s>>0]=r;a[s+1>>0]=r>>8;a[s+2>>0]=r>>16;a[s+3>>0]=r>>24;u=u+4|0;a[u>>0]=e;a[u+1>>0]=e>>8;a[u+2>>0]=e>>16;a[u+3>>0]=e>>24;if(a[t+356>>0]|0){u=t+88|0;c[u>>2]=-1;c[u+4>>2]=-1}u=t+80|0;c[u>>2]=-1;c[u+4>>2]=-1;Fd(t+96+m|0,0,256-m|0)|0;Ab(t,t+96|0);Id(b|0,t|0,l|0)|0;l=0}else l=-1;while(0);u=l;i=v;return u|0}function xb(b,c,d,e){b=b|0;c=c|0;d=d|0;e=e|0;var f=0,g=0,h=0,j=0,k=0,l=0;j=i;f=i=i+63&-64;i=i+128|0;if(d>>>0>64|(e+-1|0)>>>0>63){b=-1;i=j;return b|0}if(e>>>0>=256)za(32608,32628,53,32727);if(d>>>0>=256)za(32707,32628,54,32727);h=e&255;if((c|0)==0|(d|0)==0){if((h+-1&255)>63){b=-1;i=j;return b|0}Fd(b|0,0,357)|0;c=e&255^-222443256;e=b;d=e;a[d>>0]=c;a[d+1>>0]=c>>8;a[d+2>>0]=c>>16;a[d+3>>0]=c>>24;e=e+4|0;a[e>>0]=103;a[e+1>>0]=230;a[e+2>>0]=9;a[e+3>>0]=106;e=b+8|0;d=e;a[d>>0]=-2067093701;a[d+1>>0]=-2067093701>>8;a[d+2>>0]=-2067093701>>16;a[d+3>>0]=-2067093701>>24;e=e+4|0;a[e>>0]=-1150833019;a[e+1>>0]=-1150833019>>8;a[e+2>>0]=-1150833019>>16;a[e+3>>0]=-1150833019>>24;e=b+16|0;d=e;a[d>>0]=-23791573;a[d+1>>0]=-23791573>>8;a[d+2>>0]=-23791573>>16;a[d+3>>0]=-23791573>>24;e=e+4|0;a[e>>0]=114;a[e+1>>0]=243;a[e+2>>0]=110;a[e+3>>0]=60;e=b+24|0;d=e;a[d>>0]=241;a[d+1>>0]=54;a[d+2>>0]=29;a[d+3>>0]=95;e=e+4|0;a[e>>0]=-1521486534;a[e+1>>0]=-1521486534>>8;a[e+2>>0]=-1521486534>>16;a[e+3>>0]=-1521486534>>24;e=b+32|0;d=e;a[d>>0]=-1377402159;a[d+1>>0]=-1377402159>>8;a[d+2>>0]=-1377402159>>16;a[d+3>>0]=-1377402159>>24;e=e+4|0;a[e>>0]=127;a[e+1>>0]=82;a[e+2>>0]=14;a[e+3>>0]=81;e=b+40|0;d=e;a[d>>0]=31;a[d+1>>0]=108;a[d+2>>0]=62;a[d+3>>0]=43;e=e+4|0;a[e>>0]=-1694144372;a[e+1>>0]=-1694144372>>8;a[e+2>>0]=-1694144372>>16;a[e+3>>0]=-1694144372>>24;e=b+48|0;d=e;a[d>>0]=-79577749;a[d+1>>0]=-79577749>>8;a[d+2>>0]=-79577749>>16;a[d+3>>0]=-79577749>>24;e=e+4|0;a[e>>0]=171;a[e+1>>0]=217;a[e+2>>0]=131;a[e+3>>0]=31;b=b+56|0;e=b;a[e>>0]=121;a[e+1>>0]=33;a[e+2>>0]=126;a[e+3>>0]=19;b=b+4|0;a[b>>0]=25;a[b+1>>0]=205;a[b+2>>0]=224;a[b+3>>0]=91;b=0;i=j;return b|0}else{g=d&255;if((h+-1&255)>63|(g+-1&255)>63){b=-1;i=j;return b|0}h=d&255;Fd(b|0,0,357)|0;l=Hd(h|0,0,8)|0;l=(l|e&255)^-222443256;d=C^1779033703;e=b;k=e;a[k>>0]=l;a[k+1>>0]=l>>8;a[k+2>>0]=l>>16;a[k+3>>0]=l>>24;e=e+4|0;a[e>>0]=d;a[e+1>>0]=d>>8;a[e+2>>0]=d>>16;a[e+3>>0]=d>>24;e=b+8|0;d=e;a[d>>0]=-2067093701;a[d+1>>0]=-2067093701>>8;a[d+2>>0]=-2067093701>>16;a[d+3>>0]=-2067093701>>24;e=e+4|0;a[e>>0]=-1150833019;a[e+1>>0]=-1150833019>>8;a[e+2>>0]=-1150833019>>16;a[e+3>>0]=-1150833019>>24;e=b+16|0;d=e;a[d>>0]=-23791573;a[d+1>>0]=-23791573>>8;a[d+2>>0]=-23791573>>16;a[d+3>>0]=-23791573>>24;e=e+4|0;a[e>>0]=114;a[e+1>>0]=243;a[e+2>>0]=110;a[e+3>>0]=60;e=b+24|0;d=e;a[d>>0]=241;a[d+1>>0]=54;a[d+2>>0]=29;a[d+3>>0]=95;e=e+4|0;a[e>>0]=-1521486534;a[e+1>>0]=-1521486534>>8;a[e+2>>0]=-1521486534>>16;a[e+3>>0]=-1521486534>>24;e=b+32|0;d=e;a[d>>0]=-1377402159;a[d+1>>0]=-1377402159>>8;a[d+2>>0]=-1377402159>>16;a[d+3>>0]=-1377402159>>24;e=e+4|0;a[e>>0]=127;a[e+1>>0]=82;a[e+2>>0]=14;a[e+3>>0]=81;e=b+40|0;d=e;a[d>>0]=31;a[d+1>>0]=108;a[d+2>>0]=62;a[d+3>>0]=43;e=e+4|0;a[e>>0]=-1694144372;a[e+1>>0]=-1694144372>>8;a[e+2>>0]=-1694144372>>16;a[e+3>>0]=-1694144372>>24;e=b+48|0;d=e;a[d>>0]=-79577749;a[d+1>>0]=-79577749>>8;a[d+2>>0]=-79577749>>16;a[d+3>>0]=-79577749>>24;e=e+4|0;a[e>>0]=171;a[e+1>>0]=217;a[e+2>>0]=131;a[e+3>>0]=31;e=b+56|0;d=e;a[d>>0]=121;a[d+1>>0]=33;a[d+2>>0]=126;a[d+3>>0]=19;e=e+4|0;a[e>>0]=25;a[e+1>>0]=205;a[e+2>>0]=224;a[e+3>>0]=91;Fd(f+h|0,0,(g<<24>>24<0?0:128-h|0)|0)|0;Id(f|0,c|0,h|0)|0;c=b+352|0;h=b+96|0;g=h+128|0;do{a[h>>0]=a[f>>0]|0;h=h+1|0;f=f+1|0}while((h|0)<(g|0));a[c>>0]=128;a[c+1>>0]=0;a[c+2>>0]=0;a[c+3>>0]=0;l=0;i=j;return l|0}return 0}function yb(b,c,e,f){b=b|0;c=c|0;e=e|0;f=f|0;var g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0;if((e|0)==0&(f|0)==0)return 0;k=b+352|0;l=b+96|0;m=b+64|0;n=b+72|0;o=b+224|0;g=d[k>>0]|d[k+1>>0]<<8|d[k+2>>0]<<16|d[k+3>>0]<<24;j=e;while(1){i=256-g|0;e=b+96+g|0;if(!(f>>>0>0|(f|0)==0&j>>>0>i>>>0))break;Id(e|0,c|0,i|0)|0;h=(d[k>>0]|d[k+1>>0]<<8|d[k+2>>0]<<16|d[k+3>>0]<<24)+i|0;a[k>>0]=h;a[k+1>>0]=h>>8;a[k+2>>0]=h>>16;a[k+3>>0]=h>>24;h=m;e=h;e=d[e>>0]|d[e+1>>0]<<8|d[e+2>>0]<<16|d[e+3>>0]<<24;h=h+4|0;h=d[h>>0]|d[h+1>>0]<<8|d[h+2>>0]<<16|d[h+3>>0]<<24;s=Dd(e|0,h|0,128,0)|0;g=C;q=m;r=q;a[r>>0]=s;a[r+1>>0]=s>>8;a[r+2>>0]=s>>16;a[r+3>>0]=s>>24;q=q+4|0;a[q>>0]=g;a[q+1>>0]=g>>8;a[q+2>>0]=g>>16;a[q+3>>0]=g>>24;q=n;g=q;q=q+4|0;q=Dd((h>>>0>4294967295|(h|0)==-1&e>>>0>4294967167)&1|0,0,d[g>>0]|d[g+1>>0]<<8|d[g+2>>0]<<16|d[g+3>>0]<<24|0,d[q>>0]|d[q+1>>0]<<8|d[q+2>>0]<<16|d[q+3>>0]<<24|0)|0;g=C;e=n;h=e;a[h>>0]=q;a[h+1>>0]=q>>8;a[h+2>>0]=q>>16;a[h+3>>0]=q>>24;e=e+4|0;a[e>>0]=g;a[e+1>>0]=g>>8;a[e+2>>0]=g>>16;a[e+3>>0]=g>>24;Ab(b,l);e=l;g=o;h=e+128|0;do{a[e>>0]=a[g>>0]|0;e=e+1|0;g=g+1|0}while((e|0)<(h|0));g=(d[k>>0]|d[k+1>>0]<<8|d[k+2>>0]<<16|d[k+3>>0]<<24)+-128|0;a[k>>0]=g;a[k+1>>0]=g>>8;a[k+2>>0]=g>>16;a[k+3>>0]=g>>24;e=Cd(j|0,f|0,i|0,0)|0;if((j|0)==(i|0)&(f|0)==0){p=6;break}else{c=c+i|0;f=C;j=e}}if((p|0)==6)return 0;Id(e|0,c|0,j|0)|0;s=Dd(d[k>>0]|d[k+1>>0]<<8|d[k+2>>0]<<16|d[k+3>>0]<<24|0,0,j|0,f|0)|0;a[k>>0]=s;a[k+1>>0]=s>>8;a[k+2>>0]=s>>16;a[k+3>>0]=s>>24;return 0}function zb(b,c,e){b=b|0;c=c|0;e=e|0;var f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0;if(e>>>0>=256)za(32608,32628,106,32759);f=e&255;if(!(f<<24>>24)){b=-1;return b|0}if((f&255)>64){b=-1;return b|0}g=b+352|0;f=d[g>>0]|d[g+1>>0]<<8|d[g+2>>0]<<16|d[g+3>>0]<<24;i=b+64|0;if(f>>>0>128){k=i;j=k;j=d[j>>0]|d[j+1>>0]<<8|d[j+2>>0]<<16|d[j+3>>0]<<24;k=k+4|0;k=d[k>>0]|d[k+1>>0]<<8|d[k+2>>0]<<16|d[k+3>>0]<<24;m=Dd(j|0,k|0,128,0)|0;l=C;h=i;f=h;a[f>>0]=m;a[f+1>>0]=m>>8;a[f+2>>0]=m>>16;a[f+3>>0]=m>>24;h=h+4|0;a[h>>0]=l;a[h+1>>0]=l>>8;a[h+2>>0]=l>>16;a[h+3>>0]=l>>24;h=b+72|0;l=h;f=l;l=l+4|0;l=Dd((k>>>0>4294967295|(k|0)==-1&j>>>0>4294967167)&1|0,0,d[f>>0]|d[f+1>>0]<<8|d[f+2>>0]<<16|d[f+3>>0]<<24|0,d[l>>0]|d[l+1>>0]<<8|d[l+2>>0]<<16|d[l+3>>0]<<24|0)|0;f=C;j=h;k=j;a[k>>0]=l;a[k+1>>0]=l>>8;a[k+2>>0]=l>>16;a[k+3>>0]=l>>24;j=j+4|0;a[j>>0]=f;a[j+1>>0]=f>>8;a[j+2>>0]=f>>16;a[j+3>>0]=f>>24;j=b+96|0;Ab(b,j);f=(d[g>>0]|d[g+1>>0]<<8|d[g+2>>0]<<16|d[g+3>>0]<<24)+-128|0;a[g>>0]=f;a[g+1>>0]=f>>8;a[g+2>>0]=f>>16;a[g+3>>0]=f>>24;Jd(j|0,b+224|0,f|0)|0;f=d[g>>0]|d[g+1>>0]<<8|d[g+2>>0]<<16|d[g+3>>0]<<24}else h=b+72|0;m=i;k=m;m=m+4|0;m=Dd(d[k>>0]|d[k+1>>0]<<8|d[k+2>>0]<<16|d[k+3>>0]<<24|0,d[m>>0]|d[m+1>>0]<<8|d[m+2>>0]<<16|d[m+3>>0]<<24|0,f|0,0)|0;k=C;j=i;l=j;a[l>>0]=m;a[l+1>>0]=m>>8;a[l+2>>0]=m>>16;a[l+3>>0]=m>>24;j=j+4|0;a[j>>0]=k;a[j+1>>0]=k>>8;a[j+2>>0]=k>>16;a[j+3>>0]=k>>24;j=h;l=j;j=j+4|0;j=Dd((k>>>0<0|(k|0)==0&m>>>0<f>>>0)&1|0,0,d[l>>0]|d[l+1>>0]<<8|d[l+2>>0]<<16|d[l+3>>0]<<24|0,d[j>>0]|d[j+1>>0]<<8|d[j+2>>0]<<16|d[j+3>>0]<<24|0)|0;l=C;m=h;k=m;a[k>>0]=j;a[k+1>>0]=j>>8;a[k+2>>0]=j>>16;a[k+3>>0]=j>>24;m=m+4|0;a[m>>0]=l;a[m+1>>0]=l>>8;a[m+2>>0]=l>>16;a[m+3>>0]=l>>24;if(a[b+356>>0]|0){m=b+88|0;l=m;a[l>>0]=-1;a[l+1>>0]=-1>>8;a[l+2>>0]=-1>>16;a[l+3>>0]=-1>>24;m=m+4|0;a[m>>0]=-1;a[m+1>>0]=-1>>8;a[m+2>>0]=-1>>16;a[m+3>>0]=-1>>24}m=b+80|0;l=m;a[l>>0]=-1;a[l+1>>0]=-1>>8;a[l+2>>0]=-1>>16;a[l+3>>0]=-1>>24;m=m+4|0;a[m>>0]=-1;a[m+1>>0]=-1>>8;a[m+2>>0]=-1>>16;a[m+3>>0]=-1>>24;Fd(b+96+f|0,0,256-f|0)|0;Ab(b,b+96|0);Id(c|0,b|0,e&255|0)|0;m=0;return m|0}function Ab(b,c){b=b|0;c=c|0;var e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,D=0,E=0,F=0,G=0,H=0,I=0,J=0,K=0,L=0,M=0,N=0,O=0,P=0,Q=0,R=0,S=0,T=0,U=0,V=0,W=0,X=0,Y=0,Z=0,_=0,$=0,aa=0,ba=0,ca=0,da=0,ea=0,fa=0,ga=0,ha=0,ia=0,ja=0,ka=0,la=0,ma=0,na=0,oa=0,pa=0,qa=0,ra=0,sa=0,ta=0,ua=0,va=0,wa=0;P=c;R=P;R=d[R>>0]|d[R+1>>0]<<8|d[R+2>>0]<<16|d[R+3>>0]<<24;P=P+4|0;P=d[P>>0]|d[P+1>>0]<<8|d[P+2>>0]<<16|d[P+3>>0]<<24;U=c+8|0;W=U;W=d[W>>0]|d[W+1>>0]<<8|d[W+2>>0]<<16|d[W+3>>0]<<24;U=U+4|0;U=d[U>>0]|d[U+1>>0]<<8|d[U+2>>0]<<16|d[U+3>>0]<<24;x=c+16|0;t=x;t=d[t>>0]|d[t+1>>0]<<8|d[t+2>>0]<<16|d[t+3>>0]<<24;x=x+4|0;x=d[x>>0]|d[x+1>>0]<<8|d[x+2>>0]<<16|d[x+3>>0]<<24;l=c+24|0;h=l;h=d[h>>0]|d[h+1>>0]<<8|d[h+2>>0]<<16|d[h+3>>0]<<24;l=l+4|0;l=d[l>>0]|d[l+1>>0]<<8|d[l+2>>0]<<16|d[l+3>>0]<<24;$=c+32|0;p=$;p=d[p>>0]|d[p+1>>0]<<8|d[p+2>>0]<<16|d[p+3>>0]<<24;$=$+4|0;$=d[$>>0]|d[$+1>>0]<<8|d[$+2>>0]<<16|d[$+3>>0]<<24;F=c+40|0;H=F;H=d[H>>0]|d[H+1>>0]<<8|d[H+2>>0]<<16|d[H+3>>0]<<24;F=F+4|0;F=d[F>>0]|d[F+1>>0]<<8|d[F+2>>0]<<16|d[F+3>>0]<<24;u=c+48|0;s=u;s=d[s>>0]|d[s+1>>0]<<8|d[s+2>>0]<<16|d[s+3>>0]<<24;u=u+4|0;u=d[u>>0]|d[u+1>>0]<<8|d[u+2>>0]<<16|d[u+3>>0]<<24;r=c+56|0;n=r;n=d[n>>0]|d[n+1>>0]<<8|d[n+2>>0]<<16|d[n+3>>0]<<24;r=r+4|0;r=d[r>>0]|d[r+1>>0]<<8|d[r+2>>0]<<16|d[r+3>>0]<<24;i=c+64|0;g=i;g=d[g>>0]|d[g+1>>0]<<8|d[g+2>>0]<<16|d[g+3>>0]<<24;i=i+4|0;i=d[i>>0]|d[i+1>>0]<<8|d[i+2>>0]<<16|d[i+3>>0]<<24;Y=c+72|0;j=Y;j=d[j>>0]|d[j+1>>0]<<8|d[j+2>>0]<<16|d[j+3>>0]<<24;Y=Y+4|0;Y=d[Y>>0]|d[Y+1>>0]<<8|d[Y+2>>0]<<16|d[Y+3>>0]<<24;o=c+80|0;m=o;m=d[m>>0]|d[m+1>>0]<<8|d[m+2>>0]<<16|d[m+3>>0]<<24;o=o+4|0;o=d[o>>0]|d[o+1>>0]<<8|d[o+2>>0]<<16|d[o+3>>0]<<24;K=c+88|0;M=K;M=d[M>>0]|d[M+1>>0]<<8|d[M+2>>0]<<16|d[M+3>>0]<<24;K=K+4|0;K=d[K>>0]|d[K+1>>0]<<8|d[K+2>>0]<<16|d[K+3>>0]<<24;f=c+96|0;e=f;e=d[e>>0]|d[e+1>>0]<<8|d[e+2>>0]<<16|d[e+3>>0]<<24;f=f+4|0;f=d[f>>0]|d[f+1>>0]<<8|d[f+2>>0]<<16|d[f+3>>0]<<24;S=c+104|0;B=S;B=d[B>>0]|d[B+1>>0]<<8|d[B+2>>0]<<16|d[B+3>>0]<<24;S=S+4|0;S=d[S>>0]|d[S+1>>0]<<8|d[S+2>>0]<<16|d[S+3>>0]<<24;sa=c+112|0;ra=sa;ra=d[ra>>0]|d[ra+1>>0]<<8|d[ra+2>>0]<<16|d[ra+3>>0]<<24;sa=sa+4|0;sa=d[sa>>0]|d[sa+1>>0]<<8|d[sa+2>>0]<<16|d[sa+3>>0]<<24;A=c+120|0;y=A;y=d[y>>0]|d[y+1>>0]<<8|d[y+2>>0]<<16|d[y+3>>0]<<24;A=A+4|0;A=d[A>>0]|d[A+1>>0]<<8|d[A+2>>0]<<16|d[A+3>>0]<<24;ca=b;v=ca;ca=ca+4|0;N=b+8|0;oa=N;na=oa;na=d[na>>0]|d[na+1>>0]<<8|d[na+2>>0]<<16|d[na+3>>0]<<24;oa=oa+4|0;oa=d[oa>>0]|d[oa+1>>0]<<8|d[oa+2>>0]<<16|d[oa+3>>0]<<24;I=b+16|0;ka=I;ja=ka;ja=d[ja>>0]|d[ja+1>>0]<<8|d[ja+2>>0]<<16|d[ja+3>>0]<<24;ka=ka+4|0;ka=d[ka>>0]|d[ka+1>>0]<<8|d[ka+2>>0]<<16|d[ka+3>>0]<<24;D=b+24|0;ga=D;fa=ga;fa=d[fa>>0]|d[fa+1>>0]<<8|d[fa+2>>0]<<16|d[fa+3>>0]<<24;ga=ga+4|0;ga=d[ga>>0]|d[ga+1>>0]<<8|d[ga+2>>0]<<16|d[ga+3>>0]<<24;w=b+32|0;ma=w;la=ma;la=d[la>>0]|d[la+1>>0]<<8|d[la+2>>0]<<16|d[la+3>>0]<<24;ma=ma+4|0;ma=d[ma>>0]|d[ma+1>>0]<<8|d[ma+2>>0]<<16|d[ma+3>>0]<<24;q=b+40|0;ia=q;ha=ia;ha=d[ha>>0]|d[ha+1>>0]<<8|d[ha+2>>0]<<16|d[ha+3>>0]<<24;ia=ia+4|0;ia=d[ia>>0]|d[ia+1>>0]<<8|d[ia+2>>0]<<16|d[ia+3>>0]<<24;k=b+48|0;ua=k;ta=ua;ta=d[ta>>0]|d[ta+1>>0]<<8|d[ta+2>>0]<<16|d[ta+3>>0]<<24;ua=ua+4|0;ua=d[ua>>0]|d[ua+1>>0]<<8|d[ua+2>>0]<<16|d[ua+3>>0]<<24;c=b+56|0;qa=c;pa=qa;pa=d[pa>>0]|d[pa+1>>0]<<8|d[pa+2>>0]<<16|d[pa+3>>0]<<24;qa=qa+4|0;qa=d[qa>>0]|d[qa+1>>0]<<8|d[qa+2>>0]<<16|d[qa+3>>0]<<24;ba=b+64|0;aa=ba;ba=ba+4|0;aa=(d[aa>>0]|d[aa+1>>0]<<8|d[aa+2>>0]<<16|d[aa+3>>0]<<24)^-1377402159;ba=(d[ba>>0]|d[ba+1>>0]<<8|d[ba+2>>0]<<16|d[ba+3>>0]<<24)^1359893119;_=b+72|0;Z=_;_=_+4|0;Z=(d[Z>>0]|d[Z+1>>0]<<8|d[Z+2>>0]<<16|d[Z+3>>0]<<24)^725511199;_=(d[_>>0]|d[_+1>>0]<<8|d[_+2>>0]<<16|d[_+3>>0]<<24)^-1694144372;X=b+80|0;V=X;X=X+4|0;V=(d[V>>0]|d[V+1>>0]<<8|d[V+2>>0]<<16|d[V+3>>0]<<24)^-79577749;X=(d[X>>0]|d[X+1>>0]<<8|d[X+2>>0]<<16|d[X+3>>0]<<24)^528734635;ea=b+88|0;da=ea;ea=ea+4|0;da=(d[da>>0]|d[da+1>>0]<<8|d[da+2>>0]<<16|d[da+3>>0]<<24)^327033209;ea=(d[ea>>0]|d[ea+1>>0]<<8|d[ea+2>>0]<<16|d[ea+3>>0]<<24)^1541459225;ca=Dd(la|0,ma|0,d[v>>0]|d[v+1>>0]<<8|d[v+2>>0]<<16|d[v+3>>0]<<24|0,d[ca>>0]|d[ca+1>>0]<<8|d[ca+2>>0]<<16|d[ca+3>>0]<<24|0)|0;ca=Dd(ca|0,C|0,R|0,P|0)|0;v=C;aa=aa^ca;ba=ba^v;Q=Dd(ba|0,aa|0,-205731576,1779033703)|0;T=C;la=Q^la;ma=T^ma;O=Gd(la|0,ma|0,24)|0;L=C;ma=Hd(la|0,ma|0,40)|0;O=ma|O;L=C|L;v=Dd(W|0,U|0,ca|0,v|0)|0;v=Dd(v|0,C|0,O|0,L|0)|0;ca=C;ba=v^ba;aa=ca^aa;ma=Gd(ba|0,aa|0,16)|0;la=C;aa=Hd(ba|0,aa|0,48)|0;ma=aa|ma;la=C|la;T=Dd(ma|0,la|0,Q|0,T|0)|0;Q=C;O=T^O;L=Q^L;aa=Gd(O|0,L|0,63)|0;ba=C;L=Hd(O|0,L|0,1)|0;aa=L|aa;ba=C|ba;oa=Dd(ha|0,ia|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,t|0,x|0)|0;na=C;Z=Z^oa;_=_^na;L=Dd(_|0,Z|0,-2067093701,-1150833019)|0;O=C;ha=L^ha;ia=O^ia;J=Gd(ha|0,ia|0,24)|0;G=C;ia=Hd(ha|0,ia|0,40)|0;J=ia|J;G=C|G;na=Dd(h|0,l|0,oa|0,na|0)|0;na=Dd(na|0,C|0,J|0,G|0)|0;oa=C;_=na^_;Z=oa^Z;ia=Gd(_|0,Z|0,16)|0;ha=C;Z=Hd(_|0,Z|0,48)|0;ia=Z|ia;ha=C|ha;O=Dd(ia|0,ha|0,L|0,O|0)|0;L=C;J=O^J;G=L^G;Z=Gd(J|0,G|0,63)|0;_=C;G=Hd(J|0,G|0,1)|0;Z=G|Z;_=C|_;ka=Dd(ta|0,ua|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,p|0,$|0)|0;ja=C;V=V^ka;X=X^ja;G=Dd(X|0,V|0,-23791573,1013904242)|0;J=C;ta=G^ta;ua=J^ua;E=Gd(ta|0,ua|0,24)|0;z=C;ua=Hd(ta|0,ua|0,40)|0;E=ua|E;z=C|z;ja=Dd(H|0,F|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,E|0,z|0)|0;ka=C;X=ja^X;V=ka^V;ua=Gd(X|0,V|0,16)|0;ta=C;V=Hd(X|0,V|0,48)|0;ua=V|ua;ta=C|ta;J=Dd(ua|0,ta|0,G|0,J|0)|0;G=C;E=J^E;z=G^z;V=Gd(E|0,z|0,63)|0;X=C;z=Hd(E|0,z|0,1)|0;V=z|V;X=C|X;ga=Dd(pa|0,qa|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,s|0,u|0)|0;fa=C;da=da^ga;ea=ea^fa;z=Dd(ea|0,da|0,1595750129,-1521486534)|0;E=C;pa=z^pa;qa=E^qa;wa=Gd(pa|0,qa|0,24)|0;va=C;qa=Hd(pa|0,qa|0,40)|0;wa=qa|wa;va=C|va;fa=Dd(n|0,r|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ea=fa^ea;da=ga^da;qa=Gd(ea|0,da|0,16)|0;pa=C;da=Hd(ea|0,da|0,48)|0;qa=da|qa;pa=C|pa;E=Dd(qa|0,pa|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;da=Gd(wa|0,va|0,63)|0;ea=C;va=Hd(wa|0,va|0,1)|0;da=va|da;ea=C|ea;ca=Dd(Z|0,_|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,g|0,i|0)|0;v=C;qa=qa^ca;pa=pa^v;G=Dd(pa|0,qa|0,J|0,G|0)|0;J=C;Z=G^Z;_=J^_;va=Gd(Z|0,_|0,24)|0;wa=C;_=Hd(Z|0,_|0,40)|0;va=_|va;wa=C|wa;v=Dd(j|0,Y|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;pa=v^pa;qa=ca^qa;_=Gd(pa|0,qa|0,16)|0;Z=C;qa=Hd(pa|0,qa|0,48)|0;_=qa|_;Z=C|Z;J=Dd(_|0,Z|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;qa=Gd(va|0,wa|0,63)|0;pa=C;wa=Hd(va|0,wa|0,1)|0;qa=wa|qa;pa=C|pa;oa=Dd(V|0,X|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,m|0,o|0)|0;na=C;ma=ma^oa;la=la^na;z=Dd(la|0,ma|0,E|0,z|0)|0;E=C;V=z^V;X=E^X;wa=Gd(V|0,X|0,24)|0;va=C;X=Hd(V|0,X|0,40)|0;wa=X|wa;va=C|va;na=Dd(M|0,K|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;la=na^la;ma=oa^ma;X=Gd(la|0,ma|0,16)|0;V=C;ma=Hd(la|0,ma|0,48)|0;X=ma|X;V=C|V;E=Dd(X|0,V|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ma=Gd(wa|0,va|0,63)|0;la=C;va=Hd(wa|0,va|0,1)|0;ma=va|ma;la=C|la;ka=Dd(da|0,ea|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,e|0,f|0)|0;ja=C;ia=ia^ka;ha=ha^ja;Q=Dd(ha|0,ia|0,T|0,Q|0)|0;T=C;da=Q^da;ea=T^ea;va=Gd(da|0,ea|0,24)|0;wa=C;ea=Hd(da|0,ea|0,40)|0;va=ea|va;wa=C|wa;ja=Dd(B|0,S|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;ha=ja^ha;ia=ka^ia;ea=Gd(ha|0,ia|0,16)|0;da=C;ia=Hd(ha|0,ia|0,48)|0;ea=ia|ea;da=C|da;T=Dd(ea|0,da|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;ia=Gd(va|0,wa|0,63)|0;ha=C;wa=Hd(va|0,wa|0,1)|0;ia=wa|ia;ha=C|ha;ga=Dd(aa|0,ba|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,ra|0,sa|0)|0;fa=C;ua=ua^ga;ta=ta^fa;L=Dd(ta|0,ua|0,O|0,L|0)|0;O=C;aa=L^aa;ba=O^ba;wa=Gd(aa|0,ba|0,24)|0;va=C;ba=Hd(aa|0,ba|0,40)|0;wa=ba|wa;va=C|va;fa=Dd(y|0,A|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ta=fa^ta;ua=ga^ua;ba=Gd(ta|0,ua|0,16)|0;aa=C;ua=Hd(ta|0,ua|0,48)|0;ba=ua|ba;aa=C|aa;O=Dd(ba|0,aa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ua=Gd(wa|0,va|0,63)|0;ta=C;va=Hd(wa|0,va|0,1)|0;ua=va|ua;ta=C|ta;ca=Dd(ra|0,sa|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,ua|0,ta|0)|0;v=C;X=ca^X;V=v^V;Q=Dd(V|0,X|0,T|0,Q|0)|0;T=C;ua=Q^ua;ta=T^ta;va=Gd(ua|0,ta|0,24)|0;wa=C;ta=Hd(ua|0,ta|0,40)|0;va=ta|va;wa=C|wa;v=Dd(m|0,o|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;V=v^V;X=ca^X;ta=Gd(V|0,X|0,16)|0;ua=C;X=Hd(V|0,X|0,48)|0;ta=X|ta;ua=C|ua;T=Dd(ta|0,ua|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;X=Gd(va|0,wa|0,63)|0;V=C;wa=Hd(va|0,wa|0,1)|0;X=wa|X;V=C|V;oa=Dd(qa|0,pa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,p|0,$|0)|0;na=C;ea=ea^oa;da=da^na;L=Dd(da|0,ea|0,O|0,L|0)|0;O=C;qa=L^qa;pa=O^pa;wa=Gd(qa|0,pa|0,24)|0;va=C;pa=Hd(qa|0,pa|0,40)|0;wa=pa|wa;va=C|va;na=Dd(g|0,i|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;da=na^da;ea=oa^ea;pa=Gd(da|0,ea|0,16)|0;qa=C;ea=Hd(da|0,ea|0,48)|0;pa=ea|pa;qa=C|qa;O=Dd(pa|0,qa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ea=Gd(wa|0,va|0,63)|0;da=C;va=Hd(wa|0,va|0,1)|0;ea=va|ea;da=C|da;ka=Dd(ma|0,la|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,j|0,Y|0)|0;ja=C;ba=ba^ka;aa=aa^ja;G=Dd(aa|0,ba|0,J|0,G|0)|0;J=C;ma=G^ma;la=J^la;va=Gd(ma|0,la|0,24)|0;wa=C;la=Hd(ma|0,la|0,40)|0;va=la|va;wa=C|wa;ja=Dd(y|0,A|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;aa=ja^aa;ba=ka^ba;la=Gd(aa|0,ba|0,16)|0;ma=C;ba=Hd(aa|0,ba|0,48)|0;la=ba|la;ma=C|ma;J=Dd(la|0,ma|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ba=Gd(va|0,wa|0,63)|0;aa=C;wa=Hd(va|0,wa|0,1)|0;ba=wa|ba;aa=C|aa;ga=Dd(ia|0,ha|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,B|0,S|0)|0;fa=C;_=_^ga;Z=Z^fa;z=Dd(Z|0,_|0,E|0,z|0)|0;E=C;ia=z^ia;ha=E^ha;wa=Gd(ia|0,ha|0,24)|0;va=C;ha=Hd(ia|0,ha|0,40)|0;wa=ha|wa;va=C|va;fa=Dd(s|0,u|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;Z=fa^Z;_=ga^_;ha=Gd(Z|0,_|0,16)|0;ia=C;_=Hd(Z|0,_|0,48)|0;ha=_|ha;ia=C|ia;E=Dd(ha|0,ia|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;_=Gd(wa|0,va|0,63)|0;Z=C;va=Hd(wa|0,va|0,1)|0;_=va|_;Z=C|Z;ca=Dd(ea|0,da|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,W|0,U|0)|0;v=C;ha=ha^ca;ia=ia^v;G=Dd(ia|0,ha|0,J|0,G|0)|0;J=C;ea=G^ea;da=J^da;va=Gd(ea|0,da|0,24)|0;wa=C;da=Hd(ea|0,da|0,40)|0;va=da|va;wa=C|wa;v=Dd(e|0,f|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ia=v^ia;ha=ca^ha;da=Gd(ia|0,ha|0,16)|0;ea=C;ha=Hd(ia|0,ha|0,48)|0;da=ha|da;ea=C|ea;J=Dd(da|0,ea|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ha=Gd(va|0,wa|0,63)|0;ia=C;wa=Hd(va|0,wa|0,1)|0;ha=wa|ha;ia=C|ia;oa=Dd(ba|0,aa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,R|0,P|0)|0;na=C;ta=ta^oa;ua=ua^na;z=Dd(ua|0,ta|0,E|0,z|0)|0;E=C;ba=z^ba;aa=E^aa;wa=Gd(ba|0,aa|0,24)|0;va=C;aa=Hd(ba|0,aa|0,40)|0;wa=aa|wa;va=C|va;na=Dd(t|0,x|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;ua=na^ua;ta=oa^ta;aa=Gd(ua|0,ta|0,16)|0;ba=C;ta=Hd(ua|0,ta|0,48)|0;aa=ta|aa;ba=C|ba;E=Dd(aa|0,ba|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ta=Gd(wa|0,va|0,63)|0;ua=C;va=Hd(wa|0,va|0,1)|0;ta=va|ta;ua=C|ua;ka=Dd(_|0,Z|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,M|0,K|0)|0;ja=C;pa=pa^ka;qa=qa^ja;Q=Dd(qa|0,pa|0,T|0,Q|0)|0;T=C;_=Q^_;Z=T^Z;va=Gd(_|0,Z|0,24)|0;wa=C;Z=Hd(_|0,Z|0,40)|0;va=Z|va;wa=C|wa;ja=Dd(n|0,r|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;qa=ja^qa;pa=ka^pa;Z=Gd(qa|0,pa|0,16)|0;_=C;pa=Hd(qa|0,pa|0,48)|0;Z=pa|Z;_=C|_;T=Dd(Z|0,_|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;pa=Gd(va|0,wa|0,63)|0;qa=C;wa=Hd(va|0,wa|0,1)|0;pa=wa|pa;qa=C|qa;ga=Dd(X|0,V|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,H|0,F|0)|0;fa=C;la=la^ga;ma=ma^fa;L=Dd(ma|0,la|0,O|0,L|0)|0;O=C;X=L^X;V=O^V;wa=Gd(X|0,V|0,24)|0;va=C;V=Hd(X|0,V|0,40)|0;wa=V|wa;va=C|va;fa=Dd(h|0,l|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ma=fa^ma;la=ga^la;V=Gd(ma|0,la|0,16)|0;X=C;la=Hd(ma|0,la|0,48)|0;V=la|V;X=C|X;O=Dd(V|0,X|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;la=Gd(wa|0,va|0,63)|0;ma=C;va=Hd(wa|0,va|0,1)|0;la=va|la;ma=C|ma;ca=Dd(M|0,K|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,la|0,ma|0)|0;v=C;aa=ca^aa;ba=v^ba;Q=Dd(ba|0,aa|0,T|0,Q|0)|0;T=C;la=Q^la;ma=T^ma;va=Gd(la|0,ma|0,24)|0;wa=C;ma=Hd(la|0,ma|0,40)|0;va=ma|va;wa=C|wa;v=Dd(g|0,i|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ba=v^ba;aa=ca^aa;ma=Gd(ba|0,aa|0,16)|0;la=C;aa=Hd(ba|0,aa|0,48)|0;ma=aa|ma;la=C|la;T=Dd(ma|0,la|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;aa=Gd(va|0,wa|0,63)|0;ba=C;wa=Hd(va|0,wa|0,1)|0;aa=wa|aa;ba=C|ba;oa=Dd(ha|0,ia|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,e|0,f|0)|0;na=C;Z=Z^oa;_=_^na;L=Dd(_|0,Z|0,O|0,L|0)|0;O=C;ha=L^ha;ia=O^ia;wa=Gd(ha|0,ia|0,24)|0;va=C;ia=Hd(ha|0,ia|0,40)|0;wa=ia|wa;va=C|va;na=Dd(R|0,P|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;_=na^_;Z=oa^Z;ia=Gd(_|0,Z|0,16)|0;ha=C;Z=Hd(_|0,Z|0,48)|0;ia=Z|ia;ha=C|ha;O=Dd(ia|0,ha|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;Z=Gd(wa|0,va|0,63)|0;_=C;va=Hd(wa|0,va|0,1)|0;Z=va|Z;_=C|_;ka=Dd(ta|0,ua|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,H|0,F|0)|0;ja=C;V=V^ka;X=X^ja;G=Dd(X|0,V|0,J|0,G|0)|0;J=C;ta=G^ta;ua=J^ua;va=Gd(ta|0,ua|0,24)|0;wa=C;ua=Hd(ta|0,ua|0,40)|0;va=ua|va;wa=C|wa;ja=Dd(t|0,x|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;X=ja^X;V=ka^V;ua=Gd(X|0,V|0,16)|0;ta=C;V=Hd(X|0,V|0,48)|0;ua=V|ua;ta=C|ta;J=Dd(ua|0,ta|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;V=Gd(va|0,wa|0,63)|0;X=C;wa=Hd(va|0,wa|0,1)|0;V=wa|V;X=C|X;ga=Dd(pa|0,qa|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,y|0,A|0)|0;fa=C;da=da^ga;ea=ea^fa;z=Dd(ea|0,da|0,E|0,z|0)|0;E=C;pa=z^pa;qa=E^qa;wa=Gd(pa|0,qa|0,24)|0;va=C;qa=Hd(pa|0,qa|0,40)|0;wa=qa|wa;va=C|va;fa=Dd(B|0,S|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ea=fa^ea;da=ga^da;qa=Gd(ea|0,da|0,16)|0;pa=C;da=Hd(ea|0,da|0,48)|0;qa=da|qa;pa=C|pa;E=Dd(qa|0,pa|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;da=Gd(wa|0,va|0,63)|0;ea=C;va=Hd(wa|0,va|0,1)|0;da=va|da;ea=C|ea;ca=Dd(Z|0,_|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,m|0,o|0)|0;v=C;qa=qa^ca;pa=pa^v;G=Dd(pa|0,qa|0,J|0,G|0)|0;J=C;Z=G^Z;_=J^_;va=Gd(Z|0,_|0,24)|0;wa=C;_=Hd(Z|0,_|0,40)|0;va=_|va;wa=C|wa;v=Dd(ra|0,sa|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;pa=v^pa;qa=ca^qa;_=Gd(pa|0,qa|0,16)|0;Z=C;qa=Hd(pa|0,qa|0,48)|0;_=qa|_;Z=C|Z;J=Dd(_|0,Z|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;qa=Gd(va|0,wa|0,63)|0;pa=C;wa=Hd(va|0,wa|0,1)|0;qa=wa|qa;pa=C|pa;oa=Dd(V|0,X|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,h|0,l|0)|0;na=C;ma=ma^oa;la=la^na;z=Dd(la|0,ma|0,E|0,z|0)|0;E=C;V=z^V;X=E^X;wa=Gd(V|0,X|0,24)|0;va=C;X=Hd(V|0,X|0,40)|0;wa=X|wa;va=C|va;na=Dd(s|0,u|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;la=na^la;ma=oa^ma;X=Gd(la|0,ma|0,16)|0;V=C;ma=Hd(la|0,ma|0,48)|0;X=ma|X;V=C|V;E=Dd(X|0,V|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ma=Gd(wa|0,va|0,63)|0;la=C;va=Hd(wa|0,va|0,1)|0;ma=va|ma;la=C|la;ka=Dd(da|0,ea|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,n|0,r|0)|0;ja=C;ia=ia^ka;ha=ha^ja;Q=Dd(ha|0,ia|0,T|0,Q|0)|0;T=C;da=Q^da;ea=T^ea;va=Gd(da|0,ea|0,24)|0;wa=C;ea=Hd(da|0,ea|0,40)|0;va=ea|va;wa=C|wa;ja=Dd(W|0,U|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;ha=ja^ha;ia=ka^ia;ea=Gd(ha|0,ia|0,16)|0;da=C;ia=Hd(ha|0,ia|0,48)|0;ea=ia|ea;da=C|da;T=Dd(ea|0,da|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;ia=Gd(va|0,wa|0,63)|0;ha=C;wa=Hd(va|0,wa|0,1)|0;ia=wa|ia;ha=C|ha;ga=Dd(aa|0,ba|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,j|0,Y|0)|0;fa=C;ua=ua^ga;ta=ta^fa;L=Dd(ta|0,ua|0,O|0,L|0)|0;O=C;aa=L^aa;ba=O^ba;wa=Gd(aa|0,ba|0,24)|0;va=C;ba=Hd(aa|0,ba|0,40)|0;wa=ba|wa;va=C|va;fa=Dd(p|0,$|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ta=fa^ta;ua=ga^ua;ba=Gd(ta|0,ua|0,16)|0;aa=C;ua=Hd(ta|0,ua|0,48)|0;ba=ua|ba;aa=C|aa;O=Dd(ba|0,aa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ua=Gd(wa|0,va|0,63)|0;ta=C;va=Hd(wa|0,va|0,1)|0;ua=va|ua;ta=C|ta;ca=Dd(n|0,r|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,ua|0,ta|0)|0;v=C;X=ca^X;V=v^V;Q=Dd(V|0,X|0,T|0,Q|0)|0;T=C;ua=Q^ua;ta=T^ta;va=Gd(ua|0,ta|0,24)|0;wa=C;ta=Hd(ua|0,ta|0,40)|0;va=ta|va;wa=C|wa;v=Dd(j|0,Y|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;V=v^V;X=ca^X;ta=Gd(V|0,X|0,16)|0;ua=C;X=Hd(V|0,X|0,48)|0;ta=X|ta;ua=C|ua;T=Dd(ta|0,ua|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;X=Gd(va|0,wa|0,63)|0;V=C;wa=Hd(va|0,wa|0,1)|0;X=wa|X;V=C|V;oa=Dd(qa|0,pa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,h|0,l|0)|0;na=C;ea=ea^oa;da=da^na;L=Dd(da|0,ea|0,O|0,L|0)|0;O=C;qa=L^qa;pa=O^pa;wa=Gd(qa|0,pa|0,24)|0;va=C;pa=Hd(qa|0,pa|0,40)|0;wa=pa|wa;va=C|va;na=Dd(W|0,U|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;da=na^da;ea=oa^ea;pa=Gd(da|0,ea|0,16)|0;qa=C;ea=Hd(da|0,ea|0,48)|0;pa=ea|pa;qa=C|qa;O=Dd(pa|0,qa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ea=Gd(wa|0,va|0,63)|0;da=C;va=Hd(wa|0,va|0,1)|0;ea=va|ea;da=C|da;ka=Dd(ma|0,la|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,B|0,S|0)|0;ja=C;ba=ba^ka;aa=aa^ja;G=Dd(aa|0,ba|0,J|0,G|0)|0;J=C;ma=G^ma;la=J^la;va=Gd(ma|0,la|0,24)|0;wa=C;la=Hd(ma|0,la|0,40)|0;va=la|va;wa=C|wa;ja=Dd(e|0,f|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;aa=ja^aa;ba=ka^ba;la=Gd(aa|0,ba|0,16)|0;ma=C;ba=Hd(aa|0,ba|0,48)|0;la=ba|la;ma=C|ma;J=Dd(la|0,ma|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ba=Gd(va|0,wa|0,63)|0;aa=C;wa=Hd(va|0,wa|0,1)|0;ba=wa|ba;aa=C|aa;ga=Dd(ia|0,ha|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,M|0,K|0)|0;fa=C;_=_^ga;Z=Z^fa;z=Dd(Z|0,_|0,E|0,z|0)|0;E=C;ia=z^ia;ha=E^ha;wa=Gd(ia|0,ha|0,24)|0;va=C;ha=Hd(ia|0,ha|0,40)|0;wa=ha|wa;va=C|va;fa=Dd(ra|0,sa|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;Z=fa^Z;_=ga^_;ha=Gd(Z|0,_|0,16)|0;ia=C;_=Hd(Z|0,_|0,48)|0;ha=_|ha;ia=C|ia;E=Dd(ha|0,ia|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;_=Gd(wa|0,va|0,63)|0;Z=C;va=Hd(wa|0,va|0,1)|0;_=va|_;Z=C|Z;ca=Dd(ea|0,da|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,t|0,x|0)|0;v=C;ha=ha^ca;ia=ia^v;G=Dd(ia|0,ha|0,J|0,G|0)|0;J=C;ea=G^ea;da=J^da;va=Gd(ea|0,da|0,24)|0;wa=C;da=Hd(ea|0,da|0,40)|0;va=da|va;wa=C|wa;v=Dd(s|0,u|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ia=v^ia;ha=ca^ha;da=Gd(ia|0,ha|0,16)|0;ea=C;ha=Hd(ia|0,ha|0,48)|0;da=ha|da;ea=C|ea;J=Dd(da|0,ea|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ha=Gd(va|0,wa|0,63)|0;ia=C;wa=Hd(va|0,wa|0,1)|0;ha=wa|ha;ia=C|ia;oa=Dd(ba|0,aa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,H|0,F|0)|0;na=C;ta=ta^oa;ua=ua^na;z=Dd(ua|0,ta|0,E|0,z|0)|0;E=C;ba=z^ba;aa=E^aa;wa=Gd(ba|0,aa|0,24)|0;va=C;aa=Hd(ba|0,aa|0,40)|0;wa=aa|wa;va=C|va;na=Dd(m|0,o|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;ua=na^ua;ta=oa^ta;aa=Gd(ua|0,ta|0,16)|0;ba=C;ta=Hd(ua|0,ta|0,48)|0;aa=ta|aa;ba=C|ba;E=Dd(aa|0,ba|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ta=Gd(wa|0,va|0,63)|0;ua=C;va=Hd(wa|0,va|0,1)|0;ta=va|ta;ua=C|ua;ka=Dd(_|0,Z|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,p|0,$|0)|0;ja=C;pa=pa^ka;qa=qa^ja;Q=Dd(qa|0,pa|0,T|0,Q|0)|0;T=C;_=Q^_;Z=T^Z;va=Gd(_|0,Z|0,24)|0;wa=C;Z=Hd(_|0,Z|0,40)|0;va=Z|va;wa=C|wa;ja=Dd(R|0,P|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;qa=ja^qa;pa=ka^pa;Z=Gd(qa|0,pa|0,16)|0;_=C;pa=Hd(qa|0,pa|0,48)|0;Z=pa|Z;_=C|_;T=Dd(Z|0,_|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;pa=Gd(va|0,wa|0,63)|0;qa=C;wa=Hd(va|0,wa|0,1)|0;pa=wa|pa;qa=C|qa;ga=Dd(X|0,V|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,y|0,A|0)|0;fa=C;la=la^ga;ma=ma^fa;L=Dd(ma|0,la|0,O|0,L|0)|0;O=C;X=L^X;V=O^V;wa=Gd(X|0,V|0,24)|0;va=C;V=Hd(X|0,V|0,40)|0;wa=V|wa;va=C|va;fa=Dd(g|0,i|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ma=fa^ma;la=ga^la;V=Gd(ma|0,la|0,16)|0;X=C;la=Hd(ma|0,la|0,48)|0;V=la|V;X=C|X;O=Dd(V|0,X|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;la=Gd(wa|0,va|0,63)|0;ma=C;va=Hd(wa|0,va|0,1)|0;la=va|la;ma=C|ma;ca=Dd(j|0,Y|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,la|0,ma|0)|0;v=C;aa=ca^aa;ba=v^ba;Q=Dd(ba|0,aa|0,T|0,Q|0)|0;T=C;la=Q^la;ma=T^ma;va=Gd(la|0,ma|0,24)|0;wa=C;ma=Hd(la|0,ma|0,40)|0;va=ma|va;wa=C|wa;v=Dd(R|0,P|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ba=v^ba;aa=ca^aa;ma=Gd(ba|0,aa|0,16)|0;la=C;aa=Hd(ba|0,aa|0,48)|0;ma=aa|ma;la=C|la;T=Dd(ma|0,la|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;aa=Gd(va|0,wa|0,63)|0;ba=C;wa=Hd(va|0,wa|0,1)|0;aa=wa|aa;ba=C|ba;oa=Dd(ha|0,ia|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,H|0,F|0)|0;na=C;Z=Z^oa;_=_^na;L=Dd(_|0,Z|0,O|0,L|0)|0;O=C;ha=L^ha;ia=O^ia;wa=Gd(ha|0,ia|0,24)|0;va=C;ia=Hd(ha|0,ia|0,40)|0;wa=ia|wa;va=C|va;na=Dd(n|0,r|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;_=na^_;Z=oa^Z;ia=Gd(_|0,Z|0,16)|0;ha=C;Z=Hd(_|0,Z|0,48)|0;ia=Z|ia;ha=C|ha;O=Dd(ia|0,ha|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;Z=Gd(wa|0,va|0,63)|0;_=C;va=Hd(wa|0,va|0,1)|0;Z=va|Z;_=C|_;ka=Dd(ta|0,ua|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,t|0,x|0)|0;ja=C;V=V^ka;X=X^ja;G=Dd(X|0,V|0,J|0,G|0)|0;J=C;ta=G^ta;ua=J^ua;va=Gd(ta|0,ua|0,24)|0;wa=C;ua=Hd(ta|0,ua|0,40)|0;va=ua|va;wa=C|wa;ja=Dd(p|0,$|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;X=ja^X;V=ka^V;ua=Gd(X|0,V|0,16)|0;ta=C;V=Hd(X|0,V|0,48)|0;ua=V|ua;ta=C|ta;J=Dd(ua|0,ta|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;V=Gd(va|0,wa|0,63)|0;X=C;wa=Hd(va|0,wa|0,1)|0;V=wa|V;X=C|X;ga=Dd(pa|0,qa|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,m|0,o|0)|0;fa=C;da=da^ga;ea=ea^fa;z=Dd(ea|0,da|0,E|0,z|0)|0;E=C;pa=z^pa;qa=E^qa;wa=Gd(pa|0,qa|0,24)|0;va=C;qa=Hd(pa|0,qa|0,40)|0;wa=qa|wa;va=C|va;fa=Dd(y|0,A|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ea=fa^ea;da=ga^da;qa=Gd(ea|0,da|0,16)|0;pa=C;da=Hd(ea|0,da|0,48)|0;qa=da|qa;pa=C|pa;E=Dd(qa|0,pa|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;da=Gd(wa|0,va|0,63)|0;ea=C;va=Hd(wa|0,va|0,1)|0;da=va|da;ea=C|ea;ca=Dd(Z|0,_|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,ra|0,sa|0)|0;v=C;qa=qa^ca;pa=pa^v;G=Dd(pa|0,qa|0,J|0,G|0)|0;J=C;Z=G^Z;_=J^_;va=Gd(Z|0,_|0,24)|0;wa=C;_=Hd(Z|0,_|0,40)|0;va=_|va;wa=C|wa;v=Dd(W|0,U|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;pa=v^pa;qa=ca^qa;_=Gd(pa|0,qa|0,16)|0;Z=C;qa=Hd(pa|0,qa|0,48)|0;_=qa|_;Z=C|Z;J=Dd(_|0,Z|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;qa=Gd(va|0,wa|0,63)|0;pa=C;wa=Hd(va|0,wa|0,1)|0;qa=wa|qa;pa=C|pa;oa=Dd(V|0,X|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,M|0,K|0)|0;na=C;ma=ma^oa;la=la^na;z=Dd(la|0,ma|0,E|0,z|0)|0;E=C;V=z^V;X=E^X;wa=Gd(V|0,X|0,24)|0;va=C;X=Hd(V|0,X|0,40)|0;wa=X|wa;va=C|va;na=Dd(e|0,f|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;la=na^la;ma=oa^ma;X=Gd(la|0,ma|0,16)|0;V=C;ma=Hd(la|0,ma|0,48)|0;X=ma|X;V=C|V;E=Dd(X|0,V|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ma=Gd(wa|0,va|0,63)|0;la=C;va=Hd(wa|0,va|0,1)|0;ma=va|ma;la=C|la;ka=Dd(da|0,ea|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,s|0,u|0)|0;ja=C;ia=ia^ka;ha=ha^ja;Q=Dd(ha|0,ia|0,T|0,Q|0)|0;T=C;da=Q^da;ea=T^ea;va=Gd(da|0,ea|0,24)|0;wa=C;ea=Hd(da|0,ea|0,40)|0;va=ea|va;wa=C|wa;ja=Dd(g|0,i|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;ha=ja^ha;ia=ka^ia;ea=Gd(ha|0,ia|0,16)|0;da=C;ia=Hd(ha|0,ia|0,48)|0;ea=ia|ea;da=C|da;T=Dd(ea|0,da|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;ia=Gd(va|0,wa|0,63)|0;ha=C;wa=Hd(va|0,wa|0,1)|0;ia=wa|ia;ha=C|ha;ga=Dd(aa|0,ba|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,h|0,l|0)|0;fa=C;ua=ua^ga;ta=ta^fa;L=Dd(ta|0,ua|0,O|0,L|0)|0;O=C;aa=L^aa;ba=O^ba;wa=Gd(aa|0,ba|0,24)|0;va=C;ba=Hd(aa|0,ba|0,40)|0;wa=ba|wa;va=C|va;fa=Dd(B|0,S|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ta=fa^ta;ua=ga^ua;ba=Gd(ta|0,ua|0,16)|0;aa=C;ua=Hd(ta|0,ua|0,48)|0;ba=ua|ba;aa=C|aa;O=Dd(ba|0,aa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ua=Gd(wa|0,va|0,63)|0;ta=C;va=Hd(wa|0,va|0,1)|0;ua=va|ua;ta=C|ta;ca=Dd(t|0,x|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,ua|0,ta|0)|0;v=C;X=ca^X;V=v^V;Q=Dd(V|0,X|0,T|0,Q|0)|0;T=C;ua=Q^ua;ta=T^ta;va=Gd(ua|0,ta|0,24)|0;wa=C;ta=Hd(ua|0,ta|0,40)|0;va=ta|va;wa=C|wa;v=Dd(e|0,f|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;V=v^V;X=ca^X;ta=Gd(V|0,X|0,16)|0;ua=C;X=Hd(V|0,X|0,48)|0;ta=X|ta;ua=C|ua;T=Dd(ta|0,ua|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;X=Gd(va|0,wa|0,63)|0;V=C;wa=Hd(va|0,wa|0,1)|0;X=wa|X;V=C|V;oa=Dd(qa|0,pa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,s|0,u|0)|0;na=C;ea=ea^oa;da=da^na;L=Dd(da|0,ea|0,O|0,L|0)|0;O=C;qa=L^qa;pa=O^pa;wa=Gd(qa|0,pa|0,24)|0;va=C;pa=Hd(qa|0,pa|0,40)|0;wa=pa|wa;va=C|va;na=Dd(m|0,o|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;da=na^da;ea=oa^ea;pa=Gd(da|0,ea|0,16)|0;qa=C;ea=Hd(da|0,ea|0,48)|0;pa=ea|pa;qa=C|qa;O=Dd(pa|0,qa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ea=Gd(wa|0,va|0,63)|0;da=C;va=Hd(wa|0,va|0,1)|0;ea=va|ea;da=C|da;ka=Dd(ma|0,la|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,R|0,P|0)|0;ja=C;ba=ba^ka;aa=aa^ja;G=Dd(aa|0,ba|0,J|0,G|0)|0;J=C;ma=G^ma;la=J^la;va=Gd(ma|0,la|0,24)|0;wa=C;la=Hd(ma|0,la|0,40)|0;va=la|va;wa=C|wa;ja=Dd(M|0,K|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;aa=ja^aa;ba=ka^ba;la=Gd(aa|0,ba|0,16)|0;ma=C;ba=Hd(aa|0,ba|0,48)|0;la=ba|la;ma=C|ma;J=Dd(la|0,ma|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ba=Gd(va|0,wa|0,63)|0;aa=C;wa=Hd(va|0,wa|0,1)|0;ba=wa|ba;aa=C|aa;ga=Dd(ia|0,ha|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,g|0,i|0)|0;fa=C;_=_^ga;Z=Z^fa;z=Dd(Z|0,_|0,E|0,z|0)|0;E=C;ia=z^ia;ha=E^ha;wa=Gd(ia|0,ha|0,24)|0;va=C;ha=Hd(ia|0,ha|0,40)|0;wa=ha|wa;va=C|va;fa=Dd(h|0,l|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;Z=fa^Z;_=ga^_;ha=Gd(Z|0,_|0,16)|0;ia=C;_=Hd(Z|0,_|0,48)|0;ha=_|ha;ia=C|ia;E=Dd(ha|0,ia|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;_=Gd(wa|0,va|0,63)|0;Z=C;va=Hd(wa|0,va|0,1)|0;_=va|_;Z=C|Z;ca=Dd(ea|0,da|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,p|0,$|0)|0;v=C;ha=ha^ca;ia=ia^v;G=Dd(ia|0,ha|0,J|0,G|0)|0;J=C;ea=G^ea;da=J^da;va=Gd(ea|0,da|0,24)|0;wa=C;da=Hd(ea|0,da|0,40)|0;va=da|va;wa=C|wa;v=Dd(B|0,S|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ia=v^ia;ha=ca^ha;da=Gd(ia|0,ha|0,16)|0;ea=C;ha=Hd(ia|0,ha|0,48)|0;da=ha|da;ea=C|ea;J=Dd(da|0,ea|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ha=Gd(va|0,wa|0,63)|0;ia=C;wa=Hd(va|0,wa|0,1)|0;ha=wa|ha;ia=C|ia;oa=Dd(ba|0,aa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,n|0,r|0)|0;na=C;ta=ta^oa;ua=ua^na;z=Dd(ua|0,ta|0,E|0,z|0)|0;E=C;ba=z^ba;aa=E^aa;wa=Gd(ba|0,aa|0,24)|0;va=C;aa=Hd(ba|0,aa|0,40)|0;wa=aa|wa;va=C|va;na=Dd(H|0,F|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;ua=na^ua;ta=oa^ta;aa=Gd(ua|0,ta|0,16)|0;ba=C;ta=Hd(ua|0,ta|0,48)|0;aa=ta|aa;ba=C|ba;E=Dd(aa|0,ba|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ta=Gd(wa|0,va|0,63)|0;ua=C;va=Hd(wa|0,va|0,1)|0;ta=va|ta;ua=C|ua;ka=Dd(_|0,Z|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,y|0,A|0)|0;ja=C;pa=pa^ka;qa=qa^ja;Q=Dd(qa|0,pa|0,T|0,Q|0)|0;T=C;_=Q^_;Z=T^Z;va=Gd(_|0,Z|0,24)|0;wa=C;Z=Hd(_|0,Z|0,40)|0;va=Z|va;wa=C|wa;ja=Dd(ra|0,sa|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;qa=ja^qa;pa=ka^pa;Z=Gd(qa|0,pa|0,16)|0;_=C;pa=Hd(qa|0,pa|0,48)|0;Z=pa|Z;_=C|_;T=Dd(Z|0,_|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;pa=Gd(va|0,wa|0,63)|0;qa=C;wa=Hd(va|0,wa|0,1)|0;pa=wa|pa;qa=C|qa;ga=Dd(X|0,V|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,W|0,U|0)|0;fa=C;la=la^ga;ma=ma^fa;L=Dd(ma|0,la|0,O|0,L|0)|0;O=C;X=L^X;V=O^V;wa=Gd(X|0,V|0,24)|0;va=C;V=Hd(X|0,V|0,40)|0;wa=V|wa;va=C|va;fa=Dd(j|0,Y|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ma=fa^ma;la=ga^la;V=Gd(ma|0,la|0,16)|0;X=C;la=Hd(ma|0,la|0,48)|0;V=la|V;X=C|X;O=Dd(V|0,X|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;la=Gd(wa|0,va|0,63)|0;ma=C;va=Hd(wa|0,va|0,1)|0;la=va|la;ma=C|ma;ca=Dd(e|0,f|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,la|0,ma|0)|0;v=C;aa=ca^aa;ba=v^ba;Q=Dd(ba|0,aa|0,T|0,Q|0)|0;T=C;la=Q^la;ma=T^ma;va=Gd(la|0,ma|0,24)|0;wa=C;ma=Hd(la|0,ma|0,40)|0;va=ma|va;wa=C|wa;v=Dd(H|0,F|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ba=v^ba;aa=ca^aa;ma=Gd(ba|0,aa|0,16)|0;la=C;aa=Hd(ba|0,aa|0,48)|0;ma=aa|ma;la=C|la;T=Dd(ma|0,la|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;aa=Gd(va|0,wa|0,63)|0;ba=C;wa=Hd(va|0,wa|0,1)|0;aa=wa|aa;ba=C|ba;oa=Dd(ha|0,ia|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,W|0,U|0)|0;na=C;Z=Z^oa;_=_^na;L=Dd(_|0,Z|0,O|0,L|0)|0;O=C;ha=L^ha;ia=O^ia;wa=Gd(ha|0,ia|0,24)|0;va=C;ia=Hd(ha|0,ia|0,40)|0;wa=ia|wa;va=C|va;na=Dd(y|0,A|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;_=na^_;Z=oa^Z;ia=Gd(_|0,Z|0,16)|0;ha=C;Z=Hd(_|0,Z|0,48)|0;ia=Z|ia;ha=C|ha;O=Dd(ia|0,ha|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;Z=Gd(wa|0,va|0,63)|0;_=C;va=Hd(wa|0,va|0,1)|0;Z=va|Z;_=C|_;ka=Dd(ta|0,ua|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,ra|0,sa|0)|0;ja=C;V=V^ka;X=X^ja;G=Dd(X|0,V|0,J|0,G|0)|0;J=C;ta=G^ta;ua=J^ua;va=Gd(ta|0,ua|0,24)|0;wa=C;ua=Hd(ta|0,ua|0,40)|0;va=ua|va;wa=C|wa;ja=Dd(B|0,S|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;X=ja^X;V=ka^V;ua=Gd(X|0,V|0,16)|0;ta=C;V=Hd(X|0,V|0,48)|0;ua=V|ua;ta=C|ta;J=Dd(ua|0,ta|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;V=Gd(va|0,wa|0,63)|0;X=C;wa=Hd(va|0,wa|0,1)|0;V=wa|V;X=C|X;ga=Dd(pa|0,qa|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,p|0,$|0)|0;fa=C;da=da^ga;ea=ea^fa;z=Dd(ea|0,da|0,E|0,z|0)|0;E=C;pa=z^pa;qa=E^qa;wa=Gd(pa|0,qa|0,24)|0;va=C;qa=Hd(pa|0,qa|0,40)|0;wa=qa|wa;va=C|va;fa=Dd(m|0,o|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ea=fa^ea;da=ga^da;qa=Gd(ea|0,da|0,16)|0;pa=C;da=Hd(ea|0,da|0,48)|0;qa=da|qa;pa=C|pa;E=Dd(qa|0,pa|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;da=Gd(wa|0,va|0,63)|0;ea=C;va=Hd(wa|0,va|0,1)|0;da=va|da;ea=C|ea;ca=Dd(Z|0,_|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,R|0,P|0)|0;v=C;qa=qa^ca;pa=pa^v;G=Dd(pa|0,qa|0,J|0,G|0)|0;J=C;Z=G^Z;_=J^_;va=Gd(Z|0,_|0,24)|0;wa=C;_=Hd(Z|0,_|0,40)|0;va=_|va;wa=C|wa;v=Dd(n|0,r|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;pa=v^pa;qa=ca^qa;_=Gd(pa|0,qa|0,16)|0;Z=C;qa=Hd(pa|0,qa|0,48)|0;_=qa|_;Z=C|Z;J=Dd(_|0,Z|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;qa=Gd(va|0,wa|0,63)|0;pa=C;wa=Hd(va|0,wa|0,1)|0;qa=wa|qa;pa=C|pa;oa=Dd(V|0,X|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,s|0,u|0)|0;na=C;ma=ma^oa;la=la^na;z=Dd(la|0,ma|0,E|0,z|0)|0;E=C;V=z^V;X=E^X;wa=Gd(V|0,X|0,24)|0;va=C;X=Hd(V|0,X|0,40)|0;wa=X|wa;va=C|va;na=Dd(h|0,l|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;la=na^la;ma=oa^ma;X=Gd(la|0,ma|0,16)|0;V=C;ma=Hd(la|0,ma|0,48)|0;X=ma|X;V=C|V;E=Dd(X|0,V|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ma=Gd(wa|0,va|0,63)|0;la=C;va=Hd(wa|0,va|0,1)|0;ma=va|ma;la=C|la;ka=Dd(da|0,ea|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,j|0,Y|0)|0;ja=C;ia=ia^ka;ha=ha^ja;Q=Dd(ha|0,ia|0,T|0,Q|0)|0;T=C;da=Q^da;ea=T^ea;va=Gd(da|0,ea|0,24)|0;wa=C;ea=Hd(da|0,ea|0,40)|0;va=ea|va;wa=C|wa;ja=Dd(t|0,x|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;ha=ja^ha;ia=ka^ia;ea=Gd(ha|0,ia|0,16)|0;da=C;ia=Hd(ha|0,ia|0,48)|0;ea=ia|ea;da=C|da;T=Dd(ea|0,da|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;ia=Gd(va|0,wa|0,63)|0;ha=C;wa=Hd(va|0,wa|0,1)|0;ia=wa|ia;ha=C|ha;ga=Dd(aa|0,ba|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,g|0,i|0)|0;fa=C;ua=ua^ga;ta=ta^fa;L=Dd(ta|0,ua|0,O|0,L|0)|0;O=C;aa=L^aa;ba=O^ba;wa=Gd(aa|0,ba|0,24)|0;va=C;ba=Hd(aa|0,ba|0,40)|0;wa=ba|wa;va=C|va;fa=Dd(M|0,K|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ta=fa^ta;ua=ga^ua;ba=Gd(ta|0,ua|0,16)|0;aa=C;ua=Hd(ta|0,ua|0,48)|0;ba=ua|ba;aa=C|aa;O=Dd(ba|0,aa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ua=Gd(wa|0,va|0,63)|0;ta=C;va=Hd(wa|0,va|0,1)|0;ua=va|ua;ta=C|ta;ca=Dd(B|0,S|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,ua|0,ta|0)|0;v=C;X=ca^X;V=v^V;Q=Dd(V|0,X|0,T|0,Q|0)|0;T=C;ua=Q^ua;ta=T^ta;va=Gd(ua|0,ta|0,24)|0;wa=C;ta=Hd(ua|0,ta|0,40)|0;va=ta|va;wa=C|wa;v=Dd(M|0,K|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;V=v^V;X=ca^X;ta=Gd(V|0,X|0,16)|0;ua=C;X=Hd(V|0,X|0,48)|0;ta=X|ta;ua=C|ua;T=Dd(ta|0,ua|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;X=Gd(va|0,wa|0,63)|0;V=C;wa=Hd(va|0,wa|0,1)|0;X=wa|X;V=C|V;oa=Dd(qa|0,pa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,n|0,r|0)|0;na=C;ea=ea^oa;da=da^na;L=Dd(da|0,ea|0,O|0,L|0)|0;O=C;qa=L^qa;pa=O^pa;wa=Gd(qa|0,pa|0,24)|0;va=C;pa=Hd(qa|0,pa|0,40)|0;wa=pa|wa;va=C|va;na=Dd(ra|0,sa|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;da=na^da;ea=oa^ea;pa=Gd(da|0,ea|0,16)|0;qa=C;ea=Hd(da|0,ea|0,48)|0;pa=ea|pa;qa=C|qa;O=Dd(pa|0,qa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ea=Gd(wa|0,va|0,63)|0;da=C;va=Hd(wa|0,va|0,1)|0;ea=va|ea;da=C|da;ka=Dd(ma|0,la|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,e|0,f|0)|0;ja=C;ba=ba^ka;aa=aa^ja;G=Dd(aa|0,ba|0,J|0,G|0)|0;J=C;ma=G^ma;la=J^la;va=Gd(ma|0,la|0,24)|0;wa=C;la=Hd(ma|0,la|0,40)|0;va=la|va;wa=C|wa;ja=Dd(W|0,U|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;aa=ja^aa;ba=ka^ba;la=Gd(aa|0,ba|0,16)|0;ma=C;ba=Hd(aa|0,ba|0,48)|0;la=ba|la;ma=C|ma;J=Dd(la|0,ma|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ba=Gd(va|0,wa|0,63)|0;aa=C;wa=Hd(va|0,wa|0,1)|0;ba=wa|ba;aa=C|aa;ga=Dd(ia|0,ha|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,h|0,l|0)|0;fa=C;_=_^ga;Z=Z^fa;z=Dd(Z|0,_|0,E|0,z|0)|0;E=C;ia=z^ia;ha=E^ha;wa=Gd(ia|0,ha|0,24)|0;va=C;ha=Hd(ia|0,ha|0,40)|0;wa=ha|wa;va=C|va;fa=Dd(j|0,Y|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;Z=fa^Z;_=ga^_;ha=Gd(Z|0,_|0,16)|0;ia=C;_=Hd(Z|0,_|0,48)|0;ha=_|ha;ia=C|ia;E=Dd(ha|0,ia|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;_=Gd(wa|0,va|0,63)|0;Z=C;va=Hd(wa|0,va|0,1)|0;_=va|_;Z=C|Z;ca=Dd(ea|0,da|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,H|0,F|0)|0;v=C;ha=ha^ca;ia=ia^v;G=Dd(ia|0,ha|0,J|0,G|0)|0;J=C;ea=G^ea;da=J^da;va=Gd(ea|0,da|0,24)|0;wa=C;da=Hd(ea|0,da|0,40)|0;va=da|va;wa=C|wa;v=Dd(R|0,P|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ia=v^ia;ha=ca^ha;da=Gd(ia|0,ha|0,16)|0;ea=C;ha=Hd(ia|0,ha|0,48)|0;da=ha|da;ea=C|ea;J=Dd(da|0,ea|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ha=Gd(va|0,wa|0,63)|0;ia=C;wa=Hd(va|0,wa|0,1)|0;ha=wa|ha;ia=C|ia;oa=Dd(ba|0,aa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,y|0,A|0)|0;na=C;ta=ta^oa;ua=ua^na;z=Dd(ua|0,ta|0,E|0,z|0)|0;E=C;ba=z^ba;aa=E^aa;wa=Gd(ba|0,aa|0,24)|0;va=C;aa=Hd(ba|0,aa|0,40)|0;wa=aa|wa;va=C|va;na=Dd(p|0,$|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;ua=na^ua;ta=oa^ta;aa=Gd(ua|0,ta|0,16)|0;ba=C;ta=Hd(ua|0,ta|0,48)|0;aa=ta|aa;ba=C|ba;E=Dd(aa|0,ba|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ta=Gd(wa|0,va|0,63)|0;ua=C;va=Hd(wa|0,va|0,1)|0;ta=va|ta;ua=C|ua;ka=Dd(_|0,Z|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,g|0,i|0)|0;ja=C;pa=pa^ka;qa=qa^ja;Q=Dd(qa|0,pa|0,T|0,Q|0)|0;T=C;_=Q^_;Z=T^Z;va=Gd(_|0,Z|0,24)|0;wa=C;Z=Hd(_|0,Z|0,40)|0;va=Z|va;wa=C|wa;ja=Dd(s|0,u|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;qa=ja^qa;pa=ka^pa;Z=Gd(qa|0,pa|0,16)|0;_=C;pa=Hd(qa|0,pa|0,48)|0;Z=pa|Z;_=C|_;T=Dd(Z|0,_|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;pa=Gd(va|0,wa|0,63)|0;qa=C;wa=Hd(va|0,wa|0,1)|0;pa=wa|pa;qa=C|qa;ga=Dd(X|0,V|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,t|0,x|0)|0;fa=C;la=la^ga;ma=ma^fa;L=Dd(ma|0,la|0,O|0,L|0)|0;O=C;X=L^X;V=O^V;wa=Gd(X|0,V|0,24)|0;va=C;V=Hd(X|0,V|0,40)|0;wa=V|wa;va=C|va;fa=Dd(m|0,o|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ma=fa^ma;la=ga^la;V=Gd(ma|0,la|0,16)|0;X=C;la=Hd(ma|0,la|0,48)|0;V=la|V;X=C|X;O=Dd(V|0,X|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;la=Gd(wa|0,va|0,63)|0;ma=C;va=Hd(wa|0,va|0,1)|0;la=va|la;ma=C|ma;ca=Dd(s|0,u|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,la|0,ma|0)|0;v=C;aa=ca^aa;ba=v^ba;Q=Dd(ba|0,aa|0,T|0,Q|0)|0;T=C;la=Q^la;ma=T^ma;va=Gd(la|0,ma|0,24)|0;wa=C;ma=Hd(la|0,ma|0,40)|0;va=ma|va;wa=C|wa;v=Dd(y|0,A|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ba=v^ba;aa=ca^aa;ma=Gd(ba|0,aa|0,16)|0;la=C;aa=Hd(ba|0,aa|0,48)|0;ma=aa|ma;la=C|la;T=Dd(ma|0,la|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;aa=Gd(va|0,wa|0,63)|0;ba=C;wa=Hd(va|0,wa|0,1)|0;aa=wa|aa;ba=C|ba;oa=Dd(ha|0,ia|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,ra|0,sa|0)|0;na=C;Z=Z^oa;_=_^na;L=Dd(_|0,Z|0,O|0,L|0)|0;O=C;ha=L^ha;ia=O^ia;wa=Gd(ha|0,ia|0,24)|0;va=C;ia=Hd(ha|0,ia|0,40)|0;wa=ia|wa;va=C|va;na=Dd(j|0,Y|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;_=na^_;Z=oa^Z;ia=Gd(_|0,Z|0,16)|0;ha=C;Z=Hd(_|0,Z|0,48)|0;ia=Z|ia;ha=C|ha;O=Dd(ia|0,ha|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;Z=Gd(wa|0,va|0,63)|0;_=C;va=Hd(wa|0,va|0,1)|0;Z=va|Z;_=C|_;ka=Dd(ta|0,ua|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,M|0,K|0)|0;ja=C;V=V^ka;X=X^ja;G=Dd(X|0,V|0,J|0,G|0)|0;J=C;ta=G^ta;ua=J^ua;va=Gd(ta|0,ua|0,24)|0;wa=C;ua=Hd(ta|0,ua|0,40)|0;va=ua|va;wa=C|wa;ja=Dd(h|0,l|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;X=ja^X;V=ka^V;ua=Gd(X|0,V|0,16)|0;ta=C;V=Hd(X|0,V|0,48)|0;ua=V|ua;ta=C|ta;J=Dd(ua|0,ta|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;V=Gd(va|0,wa|0,63)|0;X=C;wa=Hd(va|0,wa|0,1)|0;V=wa|V;X=C|X;ga=Dd(pa|0,qa|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,R|0,P|0)|0;fa=C;da=da^ga;ea=ea^fa;z=Dd(ea|0,da|0,E|0,z|0)|0;E=C;pa=z^pa;qa=E^qa;wa=Gd(pa|0,qa|0,24)|0;va=C;qa=Hd(pa|0,qa|0,40)|0;wa=qa|wa;va=C|va;fa=Dd(g|0,i|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ea=fa^ea;da=ga^da;qa=Gd(ea|0,da|0,16)|0;pa=C;da=Hd(ea|0,da|0,48)|0;qa=da|qa;pa=C|pa;E=Dd(qa|0,pa|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;da=Gd(wa|0,va|0,63)|0;ea=C;va=Hd(wa|0,va|0,1)|0;da=va|da;ea=C|ea;ca=Dd(Z|0,_|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,e|0,f|0)|0;v=C;qa=qa^ca;pa=pa^v;G=Dd(pa|0,qa|0,J|0,G|0)|0;J=C;Z=G^Z;_=J^_;va=Gd(Z|0,_|0,24)|0;wa=C;_=Hd(Z|0,_|0,40)|0;va=_|va;wa=C|wa;v=Dd(t|0,x|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;pa=v^pa;qa=ca^qa;_=Gd(pa|0,qa|0,16)|0;Z=C;qa=Hd(pa|0,qa|0,48)|0;_=qa|_;Z=C|Z;J=Dd(_|0,Z|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;qa=Gd(va|0,wa|0,63)|0;pa=C;wa=Hd(va|0,wa|0,1)|0;qa=wa|qa;pa=C|pa;oa=Dd(V|0,X|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,B|0,S|0)|0;na=C;ma=ma^oa;la=la^na;z=Dd(la|0,ma|0,E|0,z|0)|0;E=C;V=z^V;X=E^X;wa=Gd(V|0,X|0,24)|0;va=C;X=Hd(V|0,X|0,40)|0;wa=X|wa;va=C|va;na=Dd(n|0,r|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;la=na^la;ma=oa^ma;X=Gd(la|0,ma|0,16)|0;V=C;ma=Hd(la|0,ma|0,48)|0;X=ma|X;V=C|V;E=Dd(X|0,V|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ma=Gd(wa|0,va|0,63)|0;la=C;va=Hd(wa|0,va|0,1)|0;ma=va|ma;la=C|la;ka=Dd(da|0,ea|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,W|0,U|0)|0;ja=C;ia=ia^ka;ha=ha^ja;Q=Dd(ha|0,ia|0,T|0,Q|0)|0;T=C;da=Q^da;ea=T^ea;va=Gd(da|0,ea|0,24)|0;wa=C;ea=Hd(da|0,ea|0,40)|0;va=ea|va;wa=C|wa;ja=Dd(p|0,$|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;ha=ja^ha;ia=ka^ia;ea=Gd(ha|0,ia|0,16)|0;da=C;ia=Hd(ha|0,ia|0,48)|0;ea=ia|ea;da=C|da;T=Dd(ea|0,da|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;ia=Gd(va|0,wa|0,63)|0;ha=C;wa=Hd(va|0,wa|0,1)|0;ia=wa|ia;ha=C|ha;ga=Dd(aa|0,ba|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,m|0,o|0)|0;fa=C;ua=ua^ga;ta=ta^fa;L=Dd(ta|0,ua|0,O|0,L|0)|0;O=C;aa=L^aa;ba=O^ba;wa=Gd(aa|0,ba|0,24)|0;va=C;ba=Hd(aa|0,ba|0,40)|0;wa=ba|wa;va=C|va;fa=Dd(H|0,F|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ta=fa^ta;ua=ga^ua;ba=Gd(ta|0,ua|0,16)|0;aa=C;ua=Hd(ta|0,ua|0,48)|0;ba=ua|ba;aa=C|aa;O=Dd(ba|0,aa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ua=Gd(wa|0,va|0,63)|0;ta=C;va=Hd(wa|0,va|0,1)|0;ua=va|ua;ta=C|ta;ca=Dd(m|0,o|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,ua|0,ta|0)|0;v=C;X=ca^X;V=v^V;Q=Dd(V|0,X|0,T|0,Q|0)|0;T=C;ua=Q^ua;ta=T^ta;va=Gd(ua|0,ta|0,24)|0;wa=C;ta=Hd(ua|0,ta|0,40)|0;va=ta|va;wa=C|wa;v=Dd(t|0,x|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;V=v^V;X=ca^X;ta=Gd(V|0,X|0,16)|0;ua=C;X=Hd(V|0,X|0,48)|0;ta=X|ta;ua=C|ua;T=Dd(ta|0,ua|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;X=Gd(va|0,wa|0,63)|0;V=C;wa=Hd(va|0,wa|0,1)|0;X=wa|X;V=C|V;oa=Dd(qa|0,pa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,g|0,i|0)|0;na=C;ea=ea^oa;da=da^na;L=Dd(da|0,ea|0,O|0,L|0)|0;O=C;qa=L^qa;pa=O^pa;wa=Gd(qa|0,pa|0,24)|0;va=C;pa=Hd(qa|0,pa|0,40)|0;wa=pa|wa;va=C|va;na=Dd(p|0,$|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;da=na^da;ea=oa^ea;pa=Gd(da|0,ea|0,16)|0;qa=C;ea=Hd(da|0,ea|0,48)|0;pa=ea|pa;qa=C|qa;O=Dd(pa|0,qa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ea=Gd(wa|0,va|0,63)|0;da=C;va=Hd(wa|0,va|0,1)|0;ea=va|ea;da=C|da;ka=Dd(ma|0,la|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,n|0,r|0)|0;ja=C;ba=ba^ka;aa=aa^ja;G=Dd(aa|0,ba|0,J|0,G|0)|0;J=C;ma=G^ma;la=J^la;va=Gd(ma|0,la|0,24)|0;wa=C;la=Hd(ma|0,la|0,40)|0;va=la|va;wa=C|wa;ja=Dd(s|0,u|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;aa=ja^aa;ba=ka^ba;la=Gd(aa|0,ba|0,16)|0;ma=C;ba=Hd(aa|0,ba|0,48)|0;la=ba|la;ma=C|ma;J=Dd(la|0,ma|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ba=Gd(va|0,wa|0,63)|0;aa=C;wa=Hd(va|0,wa|0,1)|0;ba=wa|ba;aa=C|aa;ga=Dd(ia|0,ha|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,W|0,U|0)|0;fa=C;_=_^ga;Z=Z^fa;z=Dd(Z|0,_|0,E|0,z|0)|0;E=C;ia=z^ia;ha=E^ha;wa=Gd(ia|0,ha|0,24)|0;va=C;ha=Hd(ia|0,ha|0,40)|0;wa=ha|wa;va=C|va;fa=Dd(H|0,F|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;Z=fa^Z;_=ga^_;ha=Gd(Z|0,_|0,16)|0;ia=C;_=Hd(Z|0,_|0,48)|0;ha=_|ha;ia=C|ia;E=Dd(ha|0,ia|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;_=Gd(wa|0,va|0,63)|0;Z=C;va=Hd(wa|0,va|0,1)|0;_=va|_;Z=C|Z;ca=Dd(ea|0,da|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,y|0,A|0)|0;v=C;ha=ha^ca;ia=ia^v;G=Dd(ia|0,ha|0,J|0,G|0)|0;J=C;ea=G^ea;da=J^da;va=Gd(ea|0,da|0,24)|0;wa=C;da=Hd(ea|0,da|0,40)|0;va=da|va;wa=C|wa;v=Dd(M|0,K|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ia=v^ia;ha=ca^ha;da=Gd(ia|0,ha|0,16)|0;ea=C;ha=Hd(ia|0,ha|0,48)|0;da=ha|da;ea=C|ea;J=Dd(da|0,ea|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;ha=Gd(va|0,wa|0,63)|0;ia=C;wa=Hd(va|0,wa|0,1)|0;ha=wa|ha;ia=C|ia;oa=Dd(ba|0,aa|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,j|0,Y|0)|0;na=C;ta=ta^oa;ua=ua^na;z=Dd(ua|0,ta|0,E|0,z|0)|0;E=C;ba=z^ba;aa=E^aa;wa=Gd(ba|0,aa|0,24)|0;va=C;aa=Hd(ba|0,aa|0,40)|0;wa=aa|wa;va=C|va;na=Dd(ra|0,sa|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;ua=na^ua;ta=oa^ta;aa=Gd(ua|0,ta|0,16)|0;ba=C;ta=Hd(ua|0,ta|0,48)|0;aa=ta|aa;ba=C|ba;E=Dd(aa|0,ba|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ta=Gd(wa|0,va|0,63)|0;ua=C;va=Hd(wa|0,va|0,1)|0;ta=va|ta;ua=C|ua;ka=Dd(_|0,Z|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,h|0,l|0)|0;ja=C;pa=pa^ka;qa=qa^ja;Q=Dd(qa|0,pa|0,T|0,Q|0)|0;T=C;_=Q^_;Z=T^Z;va=Gd(_|0,Z|0,24)|0;wa=C;Z=Hd(_|0,Z|0,40)|0;va=Z|va;wa=C|wa;ja=Dd(e|0,f|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;qa=ja^qa;pa=ka^pa;Z=Gd(qa|0,pa|0,16)|0;_=C;pa=Hd(qa|0,pa|0,48)|0;Z=pa|Z;_=C|_;T=Dd(Z|0,_|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;pa=Gd(va|0,wa|0,63)|0;qa=C;wa=Hd(va|0,wa|0,1)|0;pa=wa|pa;qa=C|qa;ga=Dd(X|0,V|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,B|0,S|0)|0;fa=C;la=la^ga;ma=ma^fa;L=Dd(ma|0,la|0,O|0,L|0)|0;O=C;X=L^X;V=O^V;wa=Gd(X|0,V|0,24)|0;va=C;V=Hd(X|0,V|0,40)|0;wa=V|wa;va=C|va;fa=Dd(R|0,P|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ma=fa^ma;la=ga^la;V=Gd(ma|0,la|0,16)|0;X=C;la=Hd(ma|0,la|0,48)|0;V=la|V;X=C|X;O=Dd(V|0,X|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;la=Gd(wa|0,va|0,63)|0;ma=C;va=Hd(wa|0,va|0,1)|0;la=va|la;ma=C|ma;ca=Dd(R|0,P|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,la|0,ma|0)|0;v=C;aa=ca^aa;ba=v^ba;Q=Dd(ba|0,aa|0,T|0,Q|0)|0;T=C;la=Q^la;ma=T^ma;va=Gd(la|0,ma|0,24)|0;wa=C;ma=Hd(la|0,ma|0,40)|0;va=ma|va;wa=C|wa;v=Dd(W|0,U|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;ba=v^ba;aa=ca^aa;ma=Gd(ba|0,aa|0,16)|0;la=C;aa=Hd(ba|0,aa|0,48)|0;ma=aa|ma;la=C|la;T=Dd(ma|0,la|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;aa=Gd(va|0,wa|0,63)|0;ba=C;wa=Hd(va|0,wa|0,1)|0;aa=wa|aa;ba=C|ba;oa=Dd(ha|0,ia|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,t|0,x|0)|0;na=C;Z=Z^oa;_=_^na;L=Dd(_|0,Z|0,O|0,L|0)|0;O=C;ha=L^ha;ia=O^ia;wa=Gd(ha|0,ia|0,24)|0;va=C;ia=Hd(ha|0,ia|0,40)|0;wa=ia|wa;va=C|va;na=Dd(h|0,l|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;_=na^_;Z=oa^Z;ia=Gd(_|0,Z|0,16)|0;ha=C;Z=Hd(_|0,Z|0,48)|0;ia=Z|ia;ha=C|ha;O=Dd(ia|0,ha|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;Z=Gd(wa|0,va|0,63)|0;_=C;va=Hd(wa|0,va|0,1)|0;Z=va|Z;_=C|_;ka=Dd(ta|0,ua|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,p|0,$|0)|0;ja=C;V=V^ka;X=X^ja;G=Dd(X|0,V|0,J|0,G|0)|0;J=C;ta=G^ta;ua=J^ua;va=Gd(ta|0,ua|0,24)|0;wa=C;ua=Hd(ta|0,ua|0,40)|0;va=ua|va;wa=C|wa;ja=Dd(H|0,F|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;X=ja^X;V=ka^V;ua=Gd(X|0,V|0,16)|0;ta=C;V=Hd(X|0,V|0,48)|0;ua=V|ua;ta=C|ta;J=Dd(ua|0,ta|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;V=Gd(va|0,wa|0,63)|0;X=C;wa=Hd(va|0,wa|0,1)|0;V=wa|V;X=C|X;ga=Dd(pa|0,qa|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,s|0,u|0)|0;fa=C;da=da^ga;ea=ea^fa;z=Dd(ea|0,da|0,E|0,z|0)|0;E=C;pa=z^pa;qa=E^qa;wa=Gd(pa|0,qa|0,24)|0;va=C;qa=Hd(pa|0,qa|0,40)|0;wa=qa|wa;va=C|va;fa=Dd(n|0,r|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ea=fa^ea;da=ga^da;qa=Gd(ea|0,da|0,16)|0;pa=C;da=Hd(ea|0,da|0,48)|0;qa=da|qa;pa=C|pa;E=Dd(qa|0,pa|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;da=Gd(wa|0,va|0,63)|0;ea=C;va=Hd(wa|0,va|0,1)|0;da=va|da;ea=C|ea;ca=Dd(Z|0,_|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,g|0,i|0)|0;v=C;qa=qa^ca;pa=pa^v;G=Dd(pa|0,qa|0,J|0,G|0)|0;J=C;Z=G^Z;_=J^_;va=Gd(Z|0,_|0,24)|0;wa=C;_=Hd(Z|0,_|0,40)|0;va=_|va;wa=C|wa;v=Dd(j|0,Y|0,ca|0,v|0)|0;v=Dd(v|0,C|0,va|0,wa|0)|0;ca=C;pa=v^pa;qa=ca^qa;_=Gd(pa|0,qa|0,16)|0;Z=C;qa=Hd(pa|0,qa|0,48)|0;_=qa|_;Z=C|Z;J=Dd(_|0,Z|0,G|0,J|0)|0;G=C;va=J^va;wa=G^wa;qa=Gd(va|0,wa|0,63)|0;pa=C;wa=Hd(va|0,wa|0,1)|0;qa=wa|qa;pa=C|pa;oa=Dd(V|0,X|0,na|0,oa|0)|0;oa=Dd(oa|0,C|0,m|0,o|0)|0;na=C;ma=ma^oa;la=la^na;z=Dd(la|0,ma|0,E|0,z|0)|0;E=C;V=z^V;X=E^X;wa=Gd(V|0,X|0,24)|0;va=C;X=Hd(V|0,X|0,40)|0;wa=X|wa;va=C|va;na=Dd(M|0,K|0,oa|0,na|0)|0;na=Dd(na|0,C|0,wa|0,va|0)|0;oa=C;la=na^la;ma=oa^ma;X=Gd(la|0,ma|0,16)|0;V=C;ma=Hd(la|0,ma|0,48)|0;X=ma|X;V=C|V;E=Dd(X|0,V|0,z|0,E|0)|0;z=C;wa=E^wa;va=z^va;ma=Gd(wa|0,va|0,63)|0;la=C;va=Hd(wa|0,va|0,1)|0;ma=va|ma;la=C|la;ka=Dd(da|0,ea|0,ja|0,ka|0)|0;ka=Dd(ka|0,C|0,e|0,f|0)|0;ja=C;ia=ia^ka;ha=ha^ja;Q=Dd(ha|0,ia|0,T|0,Q|0)|0;T=C;da=Q^da;ea=T^ea;va=Gd(da|0,ea|0,24)|0;wa=C;ea=Hd(da|0,ea|0,40)|0;va=ea|va;wa=C|wa;ja=Dd(B|0,S|0,ka|0,ja|0)|0;ja=Dd(ja|0,C|0,va|0,wa|0)|0;ka=C;ha=ja^ha;ia=ka^ia;ea=Gd(ha|0,ia|0,16)|0;da=C;ia=Hd(ha|0,ia|0,48)|0;ea=ia|ea;da=C|da;T=Dd(ea|0,da|0,Q|0,T|0)|0;Q=C;va=T^va;wa=Q^wa;ia=Gd(va|0,wa|0,63)|0;ha=C;wa=Hd(va|0,wa|0,1)|0;ia=wa|ia;ha=C|ha;ga=Dd(aa|0,ba|0,fa|0,ga|0)|0;ga=Dd(ga|0,C|0,ra|0,sa|0)|0;fa=C;ua=ua^ga;ta=ta^fa;L=Dd(ta|0,ua|0,O|0,L|0)|0;O=C;aa=L^aa;ba=O^ba;wa=Gd(aa|0,ba|0,24)|0;va=C;ba=Hd(aa|0,ba|0,40)|0;wa=ba|wa;va=C|va;fa=Dd(y|0,A|0,ga|0,fa|0)|0;fa=Dd(fa|0,C|0,wa|0,va|0)|0;ga=C;ta=fa^ta;ua=ga^ua;ba=Gd(ta|0,ua|0,16)|0;aa=C;ua=Hd(ta|0,ua|0,48)|0;ba=ua|ba;aa=C|aa;O=Dd(ba|0,aa|0,L|0,O|0)|0;L=C;wa=O^wa;va=L^va;ua=Gd(wa|0,va|0,63)|0;ta=C;va=Hd(wa|0,va|0,1)|0;ua=va|ua;ta=C|ta;ca=Dd(ra|0,sa|0,v|0,ca|0)|0;ca=Dd(ca|0,C|0,ua|0,ta|0)|0;v=C;X=ca^X;V=v^V;Q=Dd(V|0,X|0,T|0,Q|0)|0;T=C;ua=Q^ua;ta=T^ta;sa=Gd(ua|0,ta|0,24)|0;ra=C;ta=Hd(ua|0,ta|0,40)|0;sa=ta|sa;ra=C|ra;v=Dd(m|0,o|0,ca|0,v|0)|0;v=Dd(v|0,C|0,sa|0,ra|0)|0;ca=C;V=v^V;X=ca^X;o=Gd(V|0,X|0,16)|0;m=C;X=Hd(V|0,X|0,48)|0;o=X|o;m=C|m;T=Dd(o|0,m|0,Q|0,T|0)|0;Q=C;sa=T^sa;ra=Q^ra;X=Gd(sa|0,ra|0,63)|0;V=C;ra=Hd(sa|0,ra|0,1)|0;X=ra|X;V=C|V;oa=Dd(qa|0,pa|0,na|0,oa|0)|0;$=Dd(oa|0,C|0,p|0,$|0)|0;p=C;ea=ea^$;da=da^p;L=Dd(da|0,ea|0,O|0,L|0)|0;O=C;qa=L^qa;pa=O^pa;oa=Gd(qa|0,pa|0,24)|0;na=C;pa=Hd(qa|0,pa|0,40)|0;oa=pa|oa;na=C|na;p=Dd(g|0,i|0,$|0,p|0)|0;p=Dd(p|0,C|0,oa|0,na|0)|0;$=C;da=p^da;ea=$^ea;i=Gd(da|0,ea|0,16)|0;g=C;ea=Hd(da|0,ea|0,48)|0;i=ea|i;g=C|g;O=Dd(i|0,g|0,L|0,O|0)|0;L=C;oa=O^oa;na=L^na;ea=Gd(oa|0,na|0,63)|0;da=C;na=Hd(oa|0,na|0,1)|0;ea=na|ea;da=C|da;ka=Dd(ma|0,la|0,ja|0,ka|0)|0;Y=Dd(ka|0,C|0,j|0,Y|0)|0;j=C;ba=ba^Y;aa=aa^j;G=Dd(aa|0,ba|0,J|0,G|0)|0;J=C;ma=G^ma;la=J^la;ka=Gd(ma|0,la|0,24)|0;ja=C;la=Hd(ma|0,la|0,40)|0;ka=la|ka;ja=C|ja;j=Dd(y|0,A|0,Y|0,j|0)|0;j=Dd(j|0,C|0,ka|0,ja|0)|0;Y=C;aa=j^aa;ba=Y^ba;A=Gd(aa|0,ba|0,16)|0;y=C;ba=Hd(aa|0,ba|0,48)|0;A=ba|A;y=C|y;J=Dd(A|0,y|0,G|0,J|0)|0;G=C;ka=J^ka;ja=G^ja;ba=Gd(ka|0,ja|0,63)|0;aa=C;ja=Hd(ka|0,ja|0,1)|0;ba=ja|ba;aa=C|aa;ga=Dd(ia|0,ha|0,fa|0,ga|0)|0;S=Dd(ga|0,C|0,B|0,S|0)|0;B=C;_=_^S;Z=Z^B;z=Dd(Z|0,_|0,E|0,z|0)|0;E=C;ia=z^ia;ha=E^ha;ga=Gd(ia|0,ha|0,24)|0;fa=C;ha=Hd(ia|0,ha|0,40)|0;ga=ha|ga;fa=C|fa;B=Dd(s|0,u|0,S|0,B|0)|0;B=Dd(B|0,C|0,ga|0,fa|0)|0;S=C;Z=B^Z;_=S^_;u=Gd(Z|0,_|0,16)|0;s=C;_=Hd(Z|0,_|0,48)|0;u=_|u;s=C|s;E=Dd(u|0,s|0,z|0,E|0)|0;z=C;ga=E^ga;fa=z^fa;_=Gd(ga|0,fa|0,63)|0;Z=C;fa=Hd(ga|0,fa|0,1)|0;_=fa|_;Z=C|Z;ca=Dd(ea|0,da|0,v|0,ca|0)|0;U=Dd(ca|0,C|0,W|0,U|0)|0;W=C;u=u^U;s=s^W;G=Dd(s|0,u|0,J|0,G|0)|0;J=C;ea=G^ea;da=J^da;ca=Gd(ea|0,da|0,24)|0;v=C;da=Hd(ea|0,da|0,40)|0;ca=da|ca;v=C|v;W=Dd(e|0,f|0,U|0,W|0)|0;W=Dd(W|0,C|0,ca|0,v|0)|0;U=C;s=W^s;u=U^u;f=Gd(s|0,u|0,16)|0;e=C;u=Hd(s|0,u|0,48)|0;f=u|f;e=C|e;J=Dd(f|0,e|0,G|0,J|0)|0;G=C;ca=J^ca;v=G^v;u=Gd(ca|0,v|0,63)|0;s=C;v=Hd(ca|0,v|0,1)|0;s=C|s;$=Dd(ba|0,aa|0,p|0,$|0)|0;P=Dd($|0,C|0,R|0,P|0)|0;R=C;o=o^P;m=m^R;z=Dd(m|0,o|0,E|0,z|0)|0;E=C;ba=z^ba;aa=E^aa;$=Gd(ba|0,aa|0,24)|0;p=C;aa=Hd(ba|0,aa|0,40)|0;$=aa|$;p=C|p;R=Dd(t|0,x|0,P|0,R|0)|0;R=Dd(R|0,C|0,$|0,p|0)|0;P=C;m=R^m;o=P^o;x=Gd(m|0,o|0,16)|0;t=C;o=Hd(m|0,o|0,48)|0;x=o|x;t=C|t;E=Dd(x|0,t|0,z|0,E|0)|0;z=C;$=E^$;p=z^p;o=Gd($|0,p|0,63)|0;m=C;p=Hd($|0,p|0,1)|0;m=C|m;Y=Dd(_|0,Z|0,j|0,Y|0)|0;K=Dd(Y|0,C|0,M|0,K|0)|0;M=C;i=i^K;g=g^M;Q=Dd(g|0,i|0,T|0,Q|0)|0;T=C;_=Q^_;Z=T^Z;Y=Gd(_|0,Z|0,24)|0;j=C;Z=Hd(_|0,Z|0,40)|0;Y=Z|Y;j=C|j;M=Dd(n|0,r|0,K|0,M|0)|0;M=Dd(M|0,C|0,Y|0,j|0)|0;K=C;g=M^g;i=K^i;r=Gd(g|0,i|0,16)|0;n=C;i=Hd(g|0,i|0,48)|0;r=i|r;n=C|n;T=Dd(r|0,n|0,Q|0,T|0)|0;Q=C;Y=T^Y;j=Q^j;i=Gd(Y|0,j|0,63)|0;g=C;j=Hd(Y|0,j|0,1)|0;g=C|g;S=Dd(X|0,V|0,B|0,S|0)|0;F=Dd(S|0,C|0,H|0,F|0)|0;H=C;A=A^F;y=y^H;L=Dd(y|0,A|0,O|0,L|0)|0;O=C;X=L^X;V=O^V;S=Gd(X|0,V|0,24)|0;B=C;V=Hd(X|0,V|0,40)|0;S=V|S;B=C|B;H=Dd(h|0,l|0,F|0,H|0)|0;H=Dd(H|0,C|0,S|0,B|0)|0;F=C;y=H^y;A=F^A;l=Gd(y|0,A|0,16)|0;h=C;A=Hd(y|0,A|0,48)|0;l=A|l;h=C|h;O=Dd(l|0,h|0,L|0,O|0)|0;L=C;S=O^S;B=L^B;A=Gd(S|0,B|0,63)|0;y=C;B=Hd(S|0,B|0,1)|0;S=b;V=S;S=S+4|0;T=W^(d[V>>0]|d[V+1>>0]<<8|d[V+2>>0]<<16|d[V+3>>0]<<24)^T;Q=U^(d[S>>0]|d[S+1>>0]<<8|d[S+2>>0]<<16|d[S+3>>0]<<24)^Q;S=b;a[S>>0]=T;a[S+1>>0]=T>>8;a[S+2>>0]=T>>16;a[S+3>>0]=T>>24;b=b+4|0;a[b>>0]=Q;a[b+1>>0]=Q>>8;a[b+2>>0]=Q>>16;a[b+3>>0]=Q>>24;b=N;Q=b;b=b+4|0;O=R^(d[Q>>0]|d[Q+1>>0]<<8|d[Q+2>>0]<<16|d[Q+3>>0]<<24)^O;L=P^(d[b>>0]|d[b+1>>0]<<8|d[b+2>>0]<<16|d[b+3>>0]<<24)^L;b=N;N=b;a[N>>0]=O;a[N+1>>0]=O>>8;a[N+2>>0]=O>>16;a[N+3>>0]=O>>24;b=b+4|0;a[b>>0]=L;a[b+1>>0]=L>>8;a[b+2>>0]=L>>16;a[b+3>>0]=L>>24;b=I;L=b;b=b+4|0;J=M^(d[L>>0]|d[L+1>>0]<<8|d[L+2>>0]<<16|d[L+3>>0]<<24)^J;G=K^(d[b>>0]|d[b+1>>0]<<8|d[b+2>>0]<<16|d[b+3>>0]<<24)^G;b=I;I=b;a[I>>0]=J;a[I+1>>0]=J>>8;a[I+2>>0]=J>>16;a[I+3>>0]=J>>24;b=b+4|0;a[b>>0]=G;a[b+1>>0]=G>>8;a[b+2>>0]=G>>16;a[b+3>>0]=G>>24;b=D;G=b;b=b+4|0;E=H^(d[G>>0]|d[G+1>>0]<<8|d[G+2>>0]<<16|d[G+3>>0]<<24)^E;z=F^(d[b>>0]|d[b+1>>0]<<8|d[b+2>>0]<<16|d[b+3>>0]<<24)^z;b=D;D=b;a[D>>0]=E;a[D+1>>0]=E>>8;a[D+2>>0]=E>>16;a[D+3>>0]=E>>24;b=b+4|0;a[b>>0]=z;a[b+1>>0]=z>>8;a[b+2>>0]=z>>16;a[b+3>>0]=z>>24;b=w;z=b;b=b+4|0;x=(B|A)^(d[z>>0]|d[z+1>>0]<<8|d[z+2>>0]<<16|d[z+3>>0]<<24)^x;t=(C|y)^(d[b>>0]|d[b+1>>0]<<8|d[b+2>>0]<<16|d[b+3>>0]<<24)^t;b=w;w=b;a[w>>0]=x;a[w+1>>0]=x>>8;a[w+2>>0]=x>>16;a[w+3>>0]=x>>24;b=b+4|0;a[b>>0]=t;a[b+1>>0]=t>>8;a[b+2>>0]=t>>16;a[b+3>>0]=t>>24;b=q;t=b;b=b+4|0;r=(v|u)^(d[t>>0]|d[t+1>>0]<<8|d[t+2>>0]<<16|d[t+3>>0]<<24)^r;n=s^(d[b>>0]|d[b+1>>0]<<8|d[b+2>>0]<<16|d[b+3>>0]<<24)^n;b=q;q=b;a[q>>0]=r;a[q+1>>0]=r>>8;a[q+2>>0]=r>>16;a[q+3>>0]=r>>24;b=b+4|0;a[b>>0]=n;a[b+1>>0]=n>>8;a[b+2>>0]=n>>16;a[b+3>>0]=n>>24;b=k;n=b;b=b+4|0;l=(p|o)^(d[n>>0]|d[n+1>>0]<<8|d[n+2>>0]<<16|d[n+3>>0]<<24)^l;h=m^(d[b>>0]|d[b+1>>0]<<8|d[b+2>>0]<<16|d[b+3>>0]<<24)^h;b=k;k=b;a[k>>0]=l;a[k+1>>0]=l>>8;a[k+2>>0]=l>>16;a[k+3>>0]=l>>24;b=b+4|0;a[b>>0]=h;a[b+1>>0]=h>>8;a[b+2>>0]=h>>16;a[b+3>>0]=h>>24;b=c;h=b;b=b+4|0;f=(j|i)^(d[h>>0]|d[h+1>>0]<<8|d[h+2>>0]<<16|d[h+3>>0]<<24)^f;b=g^(d[b>>0]|d[b+1>>0]<<8|d[b+2>>0]<<16|d[b+3>>0]<<24)^e;e=c;a[e>>0]=f;a[e+1>>0]=f>>8;a[e+2>>0]=f>>16;a[e+3>>0]=f>>24;c=c+4|0;a[c>>0]=b;a[c+1>>0]=b>>8;a[c+2>>0]=b>>16;a[c+3>>0]=b>>24;return}function Bb(){return 64}function Cb(b,d,e,f){b=b|0;d=d|0;e=e|0;f=f|0;var g=0,h=0,j=0,k=0,l=0,m=0,n=0;n=i;m=i=i+63&-64;i=i+208|0;g=m+64|0;h=m;j=8;k=h+64|0;do{c[h>>2]=c[j>>2];h=h+4|0;j=j+4|0}while((h|0)<(k|0));h=Hd(e|0,f|0,3)|0;j=C;k=Gd(e|0,f|0,61)|0;l=m+72|0;c[l>>2]=h;c[l+4>>2]=j;l=g;c[l>>2]=k;c[l+4>>2]=C;l=m+80|0;if(f>>>0<0|(f|0)==0&e>>>0<128){Id(l|0,d|0,e|0)|0;Gb(m,b);i=n;return 0}h=l;j=d;k=h+128|0;do{a[h>>0]=a[j>>0]|0;h=h+1|0;j=j+1|0}while((h|0)<(k|0));Hb(m,l);g=d+128|0;d=Dd(e|0,f|0,-128,-1)|0;h=C;if(h>>>0>0|(h|0)==0&d>>>0>127)do{Hb(m,g);g=g+128|0;d=Dd(d|0,h|0,-128,-1)|0;h=C}while(h>>>0>0|(h|0)==0&d>>>0>127);Id(l|0,g|0,d|0)|0;Gb(m,b);i=n;return 0}function Db(b,d){b=b|0;d=d|0;var e=0,f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0;n=i;m=i=i+63&-64;i=i+16|0;l=b+32|0;e=l;f=c[e>>2]|0;e=c[e+4>>2]|0;a[m+7>>0]=f;g=Gd(f|0,e|0,8)|0;a[m+6>>0]=g;g=Gd(f|0,e|0,16)|0;a[m+5>>0]=g;g=Gd(f|0,e|0,24)|0;a[m+4>>0]=g;a[m+3>>0]=e;g=Gd(f|0,e|0,40)|0;a[m+2>>0]=g;g=Gd(f|0,e|0,48)|0;a[m+1>>0]=g;g=Gd(f|0,e|0,56)|0;a[m>>0]=g;g=Gd(f|0,e|0,3)|0;g=g&63;k=g>>>0<56?56:120;j=k-g|0;do if((k|0)!=(g|0)){h=Hd(j|0,0,3)|0;f=Dd(h|0,C|0,f|0,e|0)|0;e=C;h=l;c[h>>2]=f;c[h+4>>2]=e;h=64-g|0;g=b+40+g|0;if(j>>>0<h>>>0){Id(g|0,32792,j|0)|0;break}Id(g|0,32792,h|0)|0;k=b+40|0;Eb(b,k);e=32792+h|0;g=Cd(j|0,0,h|0,0)|0;f=C;if(f>>>0>0|(f|0)==0&g>>>0>63){do{Eb(b,e);e=e+64|0;g=Dd(g|0,f|0,-64,-1)|0;f=C}while(f>>>0>0|(f|0)==0&g>>>0>63);f=g}else f=g;Id(k|0,e|0,f|0)|0;e=l;f=c[e>>2]|0;e=c[e+4>>2]|0}while(0);k=Gd(f|0,e|0,3)|0;k=k&63;e=Dd(f|0,e|0,64,0)|0;f=l;c[f>>2]=e;c[f+4>>2]=C;f=64-k|0;e=b+40+k|0;if(f>>>0>8){k=c[m>>2]|0;m=c[m+4>>2]|0;l=e;a[l>>0]=k;a[l+1>>0]=k>>8;a[l+2>>0]=k>>16;a[l+3>>0]=k>>24;e=e+4|0;a[e>>0]=m;a[e+1>>0]=m>>8;a[e+2>>0]=m>>16;a[e+3>>0]=m>>24;e=b}else{Id(e|0,m|0,f|0)|0;h=b+40|0;Eb(b,h);e=m+f|0;g=Cd(8,0,f|0,0)|0;f=C;if(f>>>0>0|(f|0)==0&g>>>0>63){do{Eb(b,e);e=e+64|0;g=Dd(g|0,f|0,-64,-1)|0;f=C}while(f>>>0>0|(f|0)==0&g>>>0>63);f=g}else f=g;Id(h|0,e|0,f|0)|0;e=b}e=c[e>>2]|0;a[d+3>>0]=e;a[d+2>>0]=e>>>8;a[d+1>>0]=e>>>16;a[d>>0]=e>>>24;e=c[b+4>>2]|0;a[d+7>>0]=e;a[d+6>>0]=e>>>8;a[d+5>>0]=e>>>16;a[d+4>>0]=e>>>24;e=c[b+8>>2]|0;a[d+11>>0]=e;a[d+10>>0]=e>>>8;a[d+9>>0]=e>>>16;a[d+8>>0]=e>>>24;e=c[b+12>>2]|0;a[d+15>>0]=e;a[d+14>>0]=e>>>8;a[d+13>>0]=e>>>16;a[d+12>>0]=e>>>24;e=c[b+16>>2]|0;a[d+19>>0]=e;a[d+18>>0]=e>>>8;a[d+17>>0]=e>>>16;a[d+16>>0]=e>>>24;e=c[b+20>>2]|0;a[d+23>>0]=e;a[d+22>>0]=e>>>8;a[d+21>>0]=e>>>16;a[d+20>>0]=e>>>24;e=c[b+24>>2]|0;a[d+27>>0]=e;a[d+26>>0]=e>>>8;a[d+25>>0]=e>>>16;a[d+24>>0]=e>>>24;e=c[b+28>>2]|0;a[d+31>>0]=e;a[d+30>>0]=e>>>8;a[d+29>>0]=e>>>16;a[d+28>>0]=e>>>24;e=b+104|0;do{a[b>>0]=0;b=b+1|0}while((b|0)<(e|0));i=n;return}function Eb(a,b){a=a|0;b=b|0;var e=0,f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0;g=i;f=i=i+63&-64;i=i+256|0;e=0;do{h=b+(e<<2)|0;c[f+(e<<2)>>2]=(d[h+2>>0]|0)<<8|(d[h+3>>0]|0)|(d[h+1>>0]|0)<<16|(d[h>>0]|0)<<24;e=e+1|0}while((e|0)!=16);b=c[f>>2]|0;e=16;do{h=c[f+(e+-2<<2)>>2]|0;j=b;b=c[f+(e+-15<<2)>>2]|0;c[f+(e<<2)>>2]=j+(c[f+(e+-7<<2)>>2]|0)+((h>>>19|h<<13)^h>>>10^(h>>>17|h<<15))+((b>>>18|b<<14)^b>>>3^(b>>>7|b<<25));e=e+1|0}while((e|0)!=64);u=c[a>>2]|0;s=a+4|0;t=c[s>>2]|0;q=a+8|0;r=c[q>>2]|0;o=a+12|0;m=a+16|0;n=c[m>>2]|0;k=a+20|0;l=c[k>>2]|0;e=a+24|0;b=c[e>>2]|0;j=a+28|0;h=(c[j>>2]|0)+1116352408+(c[f>>2]|0)+((n>>>6|n<<26)^(n>>>11|n<<21)^(n>>>25|n<<7))+((b^l)&n^b)|0;p=(c[o>>2]|0)+h|0;h=((r|t)&u|r&t)+((u>>>2|u<<30)^(u>>>13|u<<19)^(u>>>22|u<<10))+h|0;b=b+1899447441+(c[f+4>>2]|0)+((p>>>6|p<<26)^(p>>>11|p<<21)^(p>>>25|p<<7))+((l^n)&p^l)|0;r=r+b|0;b=((t|u)&h|t&u)+((h>>>2|h<<30)^(h>>>13|h<<19)^(h>>>22|h<<10))+b|0;l=l+-1245643825+(c[f+8>>2]|0)+((r>>>6|r<<26)^(r>>>11|r<<21)^(r>>>25|r<<7))+((n^p)&r^n)|0;t=t+l|0;l=((u|h)&b|u&h)+((b>>>2|b<<30)^(b>>>13|b<<19)^(b>>>22|b<<10))+l|0;n=n+-373957723+(c[f+12>>2]|0)+((t>>>6|t<<26)^(t>>>11|t<<21)^(t>>>25|t<<7))+((p^r)&t^p)|0;u=u+n|0;n=((h|b)&l|h&b)+((l>>>2|l<<30)^(l>>>13|l<<19)^(l>>>22|l<<10))+n|0;p=p+961987163+(c[f+16>>2]|0)+((u>>>6|u<<26)^(u>>>11|u<<21)^(u>>>25|u<<7))+((r^t)&u^r)|0;h=h+p|0;p=((b|l)&n|b&l)+((n>>>2|n<<30)^(n>>>13|n<<19)^(n>>>22|n<<10))+p|0;r=r+1508970993+(c[f+20>>2]|0)+((h>>>6|h<<26)^(h>>>11|h<<21)^(h>>>25|h<<7))+((t^u)&h^t)|0;b=b+r|0;r=((l|n)&p|l&n)+((p>>>2|p<<30)^(p>>>13|p<<19)^(p>>>22|p<<10))+r|0;t=t+-1841331548+(c[f+24>>2]|0)+((b>>>6|b<<26)^(b>>>11|b<<21)^(b>>>25|b<<7))+((u^h)&b^u)|0;l=l+t|0;t=((n|p)&r|n&p)+((r>>>2|r<<30)^(r>>>13|r<<19)^(r>>>22|r<<10))+t|0;u=u+-1424204075+(c[f+28>>2]|0)+((l>>>6|l<<26)^(l>>>11|l<<21)^(l>>>25|l<<7))+((h^b)&l^h)|0;n=n+u|0;u=((p|r)&t|p&r)+((t>>>2|t<<30)^(t>>>13|t<<19)^(t>>>22|t<<10))+u|0;h=h+-670586216+(c[f+32>>2]|0)+((n>>>6|n<<26)^(n>>>11|n<<21)^(n>>>25|n<<7))+((b^l)&n^b)|0;p=p+h|0;h=((r|t)&u|r&t)+((u>>>2|u<<30)^(u>>>13|u<<19)^(u>>>22|u<<10))+h|0;b=b+310598401+(c[f+36>>2]|0)+((p>>>6|p<<26)^(p>>>11|p<<21)^(p>>>25|p<<7))+((l^n)&p^l)|0;r=r+b|0;b=((t|u)&h|t&u)+((h>>>2|h<<30)^(h>>>13|h<<19)^(h>>>22|h<<10))+b|0;l=l+607225278+(c[f+40>>2]|0)+((r>>>6|r<<26)^(r>>>11|r<<21)^(r>>>25|r<<7))+((n^p)&r^n)|0;t=t+l|0;l=((u|h)&b|u&h)+((b>>>2|b<<30)^(b>>>13|b<<19)^(b>>>22|b<<10))+l|0;n=n+1426881987+(c[f+44>>2]|0)+((t>>>6|t<<26)^(t>>>11|t<<21)^(t>>>25|t<<7))+((p^r)&t^p)|0;u=u+n|0;n=((h|b)&l|h&b)+((l>>>2|l<<30)^(l>>>13|l<<19)^(l>>>22|l<<10))+n|0;p=p+1925078388+(c[f+48>>2]|0)+((u>>>6|u<<26)^(u>>>11|u<<21)^(u>>>25|u<<7))+((r^t)&u^r)|0;h=h+p|0;p=((b|l)&n|b&l)+((n>>>2|n<<30)^(n>>>13|n<<19)^(n>>>22|n<<10))+p|0;r=r+-2132889090+(c[f+52>>2]|0)+((h>>>6|h<<26)^(h>>>11|h<<21)^(h>>>25|h<<7))+((t^u)&h^t)|0;b=b+r|0;r=((l|n)&p|l&n)+((p>>>2|p<<30)^(p>>>13|p<<19)^(p>>>22|p<<10))+r|0;t=t+-1680079193+(c[f+56>>2]|0)+((b>>>6|b<<26)^(b>>>11|b<<21)^(b>>>25|b<<7))+((u^h)&b^u)|0;l=l+t|0;t=((n|p)&r|n&p)+((r>>>2|r<<30)^(r>>>13|r<<19)^(r>>>22|r<<10))+t|0;u=u+-1046744716+(c[f+60>>2]|0)+((l>>>6|l<<26)^(l>>>11|l<<21)^(l>>>25|l<<7))+((h^b)&l^h)|0;n=n+u|0;u=((p|r)&t|p&r)+((t>>>2|t<<30)^(t>>>13|t<<19)^(t>>>22|t<<10))+u|0;h=h+-459576895+(c[f+64>>2]|0)+((n>>>6|n<<26)^(n>>>11|n<<21)^(n>>>25|n<<7))+((b^l)&n^b)|0;p=p+h|0;h=((r|t)&u|r&t)+((u>>>2|u<<30)^(u>>>13|u<<19)^(u>>>22|u<<10))+h|0;b=b+-272742522+(c[f+68>>2]|0)+((p>>>6|p<<26)^(p>>>11|p<<21)^(p>>>25|p<<7))+((l^n)&p^l)|0;r=r+b|0;b=((t|u)&h|t&u)+((h>>>2|h<<30)^(h>>>13|h<<19)^(h>>>22|h<<10))+b|0;l=l+264347078+(c[f+72>>2]|0)+((r>>>6|r<<26)^(r>>>11|r<<21)^(r>>>25|r<<7))+((n^p)&r^n)|0;t=t+l|0;l=((u|h)&b|u&h)+((b>>>2|b<<30)^(b>>>13|b<<19)^(b>>>22|b<<10))+l|0;n=n+604807628+(c[f+76>>2]|0)+((t>>>6|t<<26)^(t>>>11|t<<21)^(t>>>25|t<<7))+((p^r)&t^p)|0;u=u+n|0;n=((h|b)&l|h&b)+((l>>>2|l<<30)^(l>>>13|l<<19)^(l>>>22|l<<10))+n|0;p=p+770255983+(c[f+80>>2]|0)+((u>>>6|u<<26)^(u>>>11|u<<21)^(u>>>25|u<<7))+((r^t)&u^r)|0;h=h+p|0;p=((b|l)&n|b&l)+((n>>>2|n<<30)^(n>>>13|n<<19)^(n>>>22|n<<10))+p|0;r=r+1249150122+(c[f+84>>2]|0)+((h>>>6|h<<26)^(h>>>11|h<<21)^(h>>>25|h<<7))+((t^u)&h^t)|0;b=b+r|0;r=((l|n)&p|l&n)+((p>>>2|p<<30)^(p>>>13|p<<19)^(p>>>22|p<<10))+r|0;t=t+1555081692+(c[f+88>>2]|0)+((b>>>6|b<<26)^(b>>>11|b<<21)^(b>>>25|b<<7))+((u^h)&b^u)|0;l=l+t|0;t=((n|p)&r|n&p)+((r>>>2|r<<30)^(r>>>13|r<<19)^(r>>>22|r<<10))+t|0;u=u+1996064986+(c[f+92>>2]|0)+((l>>>6|l<<26)^(l>>>11|l<<21)^(l>>>25|l<<7))+((h^b)&l^h)|0;n=n+u|0;u=((p|r)&t|p&r)+((t>>>2|t<<30)^(t>>>13|t<<19)^(t>>>22|t<<10))+u|0;h=h+-1740746414+(c[f+96>>2]|0)+((n>>>6|n<<26)^(n>>>11|n<<21)^(n>>>25|n<<7))+((b^l)&n^b)|0;p=p+h|0;h=((r|t)&u|r&t)+((u>>>2|u<<30)^(u>>>13|u<<19)^(u>>>22|u<<10))+h|0;b=b+-1473132947+(c[f+100>>2]|0)+((p>>>6|p<<26)^(p>>>11|p<<21)^(p>>>25|p<<7))+((l^n)&p^l)|0;r=r+b|0;b=((t|u)&h|t&u)+((h>>>2|h<<30)^(h>>>13|h<<19)^(h>>>22|h<<10))+b|0;l=l+-1341970488+(c[f+104>>2]|0)+((r>>>6|r<<26)^(r>>>11|r<<21)^(r>>>25|r<<7))+((n^p)&r^n)|0;t=t+l|0;l=((u|h)&b|u&h)+((b>>>2|b<<30)^(b>>>13|b<<19)^(b>>>22|b<<10))+l|0;n=n+-1084653625+(c[f+108>>2]|0)+((t>>>6|t<<26)^(t>>>11|t<<21)^(t>>>25|t<<7))+((p^r)&t^p)|0;u=u+n|0;n=((h|b)&l|h&b)+((l>>>2|l<<30)^(l>>>13|l<<19)^(l>>>22|l<<10))+n|0;p=p+-958395405+(c[f+112>>2]|0)+((u>>>6|u<<26)^(u>>>11|u<<21)^(u>>>25|u<<7))+((r^t)&u^r)|0;h=h+p|0;p=((b|l)&n|b&l)+((n>>>2|n<<30)^(n>>>13|n<<19)^(n>>>22|n<<10))+p|0;r=r+-710438585+(c[f+116>>2]|0)+((h>>>6|h<<26)^(h>>>11|h<<21)^(h>>>25|h<<7))+((t^u)&h^t)|0;b=b+r|0;r=((l|n)&p|l&n)+((p>>>2|p<<30)^(p>>>13|p<<19)^(p>>>22|p<<10))+r|0;t=t+113926993+(c[f+120>>2]|0)+((b>>>6|b<<26)^(b>>>11|b<<21)^(b>>>25|b<<7))+((u^h)&b^u)|0;l=l+t|0;t=((n|p)&r|n&p)+((r>>>2|r<<30)^(r>>>13|r<<19)^(r>>>22|r<<10))+t|0;u=u+338241895+(c[f+124>>2]|0)+((l>>>6|l<<26)^(l>>>11|l<<21)^(l>>>25|l<<7))+((h^b)&l^h)|0;n=n+u|0;u=((p|r)&t|p&r)+((t>>>2|t<<30)^(t>>>13|t<<19)^(t>>>22|t<<10))+u|0;h=h+666307205+(c[f+128>>2]|0)+((n>>>6|n<<26)^(n>>>11|n<<21)^(n>>>25|n<<7))+((b^l)&n^b)|0;p=p+h|0;h=((r|t)&u|r&t)+((u>>>2|u<<30)^(u>>>13|u<<19)^(u>>>22|u<<10))+h|0;b=b+773529912+(c[f+132>>2]|0)+((p>>>6|p<<26)^(p>>>11|p<<21)^(p>>>25|p<<7))+((l^n)&p^l)|0;r=r+b|0;b=((t|u)&h|t&u)+((h>>>2|h<<30)^(h>>>13|h<<19)^(h>>>22|h<<10))+b|0;l=l+1294757372+(c[f+136>>2]|0)+((r>>>6|r<<26)^(r>>>11|r<<21)^(r>>>25|r<<7))+((n^p)&r^n)|0;t=t+l|0;l=((u|h)&b|u&h)+((b>>>2|b<<30)^(b>>>13|b<<19)^(b>>>22|b<<10))+l|0;n=n+1396182291+(c[f+140>>2]|0)+((t>>>6|t<<26)^(t>>>11|t<<21)^(t>>>25|t<<7))+((p^r)&t^p)|0;u=u+n|0;n=((h|b)&l|h&b)+((l>>>2|l<<30)^(l>>>13|l<<19)^(l>>>22|l<<10))+n|0;p=p+1695183700+(c[f+144>>2]|0)+((u>>>6|u<<26)^(u>>>11|u<<21)^(u>>>25|u<<7))+((r^t)&u^r)|0;h=h+p|0;p=((b|l)&n|b&l)+((n>>>2|n<<30)^(n>>>13|n<<19)^(n>>>22|n<<10))+p|0;r=r+1986661051+(c[f+148>>2]|0)+((h>>>6|h<<26)^(h>>>11|h<<21)^(h>>>25|h<<7))+((t^u)&h^t)|0;b=b+r|0;r=((l|n)&p|l&n)+((p>>>2|p<<30)^(p>>>13|p<<19)^(p>>>22|p<<10))+r|0;t=t+-2117940946+(c[f+152>>2]|0)+((b>>>6|b<<26)^(b>>>11|b<<21)^(b>>>25|b<<7))+((u^h)&b^u)|0;l=l+t|0;t=((n|p)&r|n&p)+((r>>>2|r<<30)^(r>>>13|r<<19)^(r>>>22|r<<10))+t|0;u=u+-1838011259+(c[f+156>>2]|0)+((l>>>6|l<<26)^(l>>>11|l<<21)^(l>>>25|l<<7))+((h^b)&l^h)|0;n=n+u|0;u=((p|r)&t|p&r)+((t>>>2|t<<30)^(t>>>13|t<<19)^(t>>>22|t<<10))+u|0;h=h+-1564481375+(c[f+160>>2]|0)+((n>>>6|n<<26)^(n>>>11|n<<21)^(n>>>25|n<<7))+((b^l)&n^b)|0;p=p+h|0;h=((r|t)&u|r&t)+((u>>>2|u<<30)^(u>>>13|u<<19)^(u>>>22|u<<10))+h|0;b=b+-1474664885+(c[f+164>>2]|0)+((p>>>6|p<<26)^(p>>>11|p<<21)^(p>>>25|p<<7))+((l^n)&p^l)|0;r=r+b|0;b=((t|u)&h|t&u)+((h>>>2|h<<30)^(h>>>13|h<<19)^(h>>>22|h<<10))+b|0;l=l+-1035236496+(c[f+168>>2]|0)+((r>>>6|r<<26)^(r>>>11|r<<21)^(r>>>25|r<<7))+((n^p)&r^n)|0;t=t+l|0;l=((u|h)&b|u&h)+((b>>>2|b<<30)^(b>>>13|b<<19)^(b>>>22|b<<10))+l|0;n=n+-949202525+(c[f+172>>2]|0)+((t>>>6|t<<26)^(t>>>11|t<<21)^(t>>>25|t<<7))+((p^r)&t^p)|0;u=u+n|0;n=((h|b)&l|h&b)+((l>>>2|l<<30)^(l>>>13|l<<19)^(l>>>22|l<<10))+n|0;p=p+-778901479+(c[f+176>>2]|0)+((u>>>6|u<<26)^(u>>>11|u<<21)^(u>>>25|u<<7))+((r^t)&u^r)|0;h=h+p|0;p=((b|l)&n|b&l)+((n>>>2|n<<30)^(n>>>13|n<<19)^(n>>>22|n<<10))+p|0;r=r+-694614492+(c[f+180>>2]|0)+((h>>>6|h<<26)^(h>>>11|h<<21)^(h>>>25|h<<7))+((t^u)&h^t)|0;b=b+r|0;r=((l|n)&p|l&n)+((p>>>2|p<<30)^(p>>>13|p<<19)^(p>>>22|p<<10))+r|0;t=t+-200395387+(c[f+184>>2]|0)+((b>>>6|b<<26)^(b>>>11|b<<21)^(b>>>25|b<<7))+((u^h)&b^u)|0;l=l+t|0;t=((n|p)&r|n&p)+((r>>>2|r<<30)^(r>>>13|r<<19)^(r>>>22|r<<10))+t|0;u=u+275423344+(c[f+188>>2]|0)+((l>>>6|l<<26)^(l>>>11|l<<21)^(l>>>25|l<<7))+((h^b)&l^h)|0;n=n+u|0;u=((p|r)&t|p&r)+((t>>>2|t<<30)^(t>>>13|t<<19)^(t>>>22|t<<10))+u|0;h=h+430227734+(c[f+192>>2]|0)+((n>>>6|n<<26)^(n>>>11|n<<21)^(n>>>25|n<<7))+((b^l)&n^b)|0;p=p+h|0;h=((r|t)&u|r&t)+((u>>>2|u<<30)^(u>>>13|u<<19)^(u>>>22|u<<10))+h|0;b=b+506948616+(c[f+196>>2]|0)+((p>>>6|p<<26)^(p>>>11|p<<21)^(p>>>25|p<<7))+((l^n)&p^l)|0;r=r+b|0;b=((t|u)&h|t&u)+((h>>>2|h<<30)^(h>>>13|h<<19)^(h>>>22|h<<10))+b|0;l=l+659060556+(c[f+200>>2]|0)+((r>>>6|r<<26)^(r>>>11|r<<21)^(r>>>25|r<<7))+((n^p)&r^n)|0;t=t+l|0;l=((u|h)&b|u&h)+((b>>>2|b<<30)^(b>>>13|b<<19)^(b>>>22|b<<10))+l|0;n=n+883997877+(c[f+204>>2]|0)+((t>>>6|t<<26)^(t>>>11|t<<21)^(t>>>25|t<<7))+((p^r)&t^p)|0;u=u+n|0;n=((h|b)&l|h&b)+((l>>>2|l<<30)^(l>>>13|l<<19)^(l>>>22|l<<10))+n|0;p=p+958139571+(c[f+208>>2]|0)+((u>>>6|u<<26)^(u>>>11|u<<21)^(u>>>25|u<<7))+((r^t)&u^r)|0;h=h+p|0;p=((b|l)&n|b&l)+((n>>>2|n<<30)^(n>>>13|n<<19)^(n>>>22|n<<10))+p|0;r=r+1322822218+(c[f+212>>2]|0)+((h>>>6|h<<26)^(h>>>11|h<<21)^(h>>>25|h<<7))+((t^u)&h^t)|0;b=b+r|0;r=((l|n)&p|l&n)+((p>>>2|p<<30)^(p>>>13|p<<19)^(p>>>22|p<<10))+r|0;t=t+1537002063+(c[f+216>>2]|0)+((b>>>6|b<<26)^(b>>>11|b<<21)^(b>>>25|b<<7))+((u^h)&b^u)|0;l=l+t|0;t=((n|p)&r|n&p)+((r>>>2|r<<30)^(r>>>13|r<<19)^(r>>>22|r<<10))+t|0;u=u+1747873779+(c[f+220>>2]|0)+((l>>>6|l<<26)^(l>>>11|l<<21)^(l>>>25|l<<7))+((h^b)&l^h)|0;n=n+u|0;u=((p|r)&t|p&r)+((t>>>2|t<<30)^(t>>>13|t<<19)^(t>>>22|t<<10))+u|0;h=h+1955562222+(c[f+224>>2]|0)+((n>>>6|n<<26)^(n>>>11|n<<21)^(n>>>25|n<<7))+((b^l)&n^b)|0;p=p+h|0;h=((r|t)&u|r&t)+((u>>>2|u<<30)^(u>>>13|u<<19)^(u>>>22|u<<10))+h|0;b=b+2024104815+(c[f+228>>2]|0)+((p>>>6|p<<26)^(p>>>11|p<<21)^(p>>>25|p<<7))+((l^n)&p^l)|0;r=r+b|0;b=((t|u)&h|t&u)+((h>>>2|h<<30)^(h>>>13|h<<19)^(h>>>22|h<<10))+b|0;l=l+-2067236844+(c[f+232>>2]|0)+((r>>>6|r<<26)^(r>>>11|r<<21)^(r>>>25|r<<7))+((n^p)&r^n)|0;t=t+l|0;l=((u|h)&b|u&h)+((b>>>2|b<<30)^(b>>>13|b<<19)^(b>>>22|b<<10))+l|0;n=n+-1933114872+(c[f+236>>2]|0)+((t>>>6|t<<26)^(t>>>11|t<<21)^(t>>>25|t<<7))+((p^r)&t^p)|0;u=u+n|0;n=((h|b)&l|h&b)+((l>>>2|l<<30)^(l>>>13|l<<19)^(l>>>22|l<<10))+n|0;p=p+-1866530822+(c[f+240>>2]|0)+((u>>>6|u<<26)^(u>>>11|u<<21)^(u>>>25|u<<7))+((r^t)&u^r)|0;h=h+p|0;p=((b|l)&n|b&l)+((n>>>2|n<<30)^(n>>>13|n<<19)^(n>>>22|n<<10))+p|0;r=r+-1538233109+(c[f+244>>2]|0)+((h>>>6|h<<26)^(h>>>11|h<<21)^(h>>>25|h<<7))+((t^u)&h^t)|0;b=b+r|0;r=((l|n)&p|l&n)+((p>>>2|p<<30)^(p>>>13|p<<19)^(p>>>22|p<<10))+r|0;t=t+-1090935817+(c[f+248>>2]|0)+((b>>>6|b<<26)^(b>>>11|b<<21)^(b>>>25|b<<7))+((u^h)&b^u)|0;l=l+t|0;t=((n|p)&r|n&p)+((r>>>2|r<<30)^(r>>>13|r<<19)^(r>>>22|r<<10))+t|0;f=u+-965641998+(c[f+252>>2]|0)+((l>>>6|l<<26)^(l>>>11|l<<21)^(l>>>25|l<<7))+((h^b)&l^h)|0;c[a>>2]=(c[a>>2]|0)+(((p|r)&t|p&r)+((t>>>2|t<<30)^(t>>>13|t<<19)^(t>>>22|t<<10))+f);c[s>>2]=(c[s>>2]|0)+t;c[q>>2]=(c[q>>2]|0)+r;c[o>>2]=(c[o>>2]|0)+p;c[m>>2]=(c[m>>2]|0)+(n+f);c[k>>2]=(c[k>>2]|0)+l;c[e>>2]=(c[e>>2]|0)+b;c[j>>2]=(c[j>>2]|0)+h;i=g;return}function Fb(a,b,d,e){a=a|0;b=b|0;d=d|0;e=e|0;var f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0;j=a+72|0;m=j;o=c[m>>2]|0;m=c[m+4>>2]|0;k=Gd(o|0,m|0,3)|0;k=k&127;l=Hd(d|0,e|0,3)|0;n=C;h=Gd(d|0,e|0,61)|0;i=C;m=Dd(o|0,m|0,l|0,n|0)|0;o=C;c[j>>2]=m;c[j+4>>2]=o;j=a+64|0;g=j;f=c[g>>2]|0;g=c[g+4>>2]|0;if(o>>>0<n>>>0|(o|0)==(n|0)&m>>>0<l>>>0){f=Dd(f|0,g|0,1,0)|0;g=C;o=j;c[o>>2]=f;c[o+4>>2]=g}h=Dd(f|0,g|0,h|0,i|0)|0;g=j;c[g>>2]=h;c[g+4>>2]=C;g=Cd(128,0,k|0,0)|0;h=C;f=a+80+k|0;if(h>>>0>e>>>0|(h|0)==(e|0)&g>>>0>d>>>0){Id(f|0,b|0,d|0)|0;return}Id(f|0,b|0,g|0)|0;i=a+80|0;Hb(a,i);f=b+g|0;g=Cd(d|0,e|0,g|0,h|0)|0;h=C;if(h>>>0>0|(h|0)==0&g>>>0>127)do{Hb(a,f);f=f+128|0;g=Dd(g|0,h|0,-128,-1)|0;h=C}while(h>>>0>0|(h|0)==0&g>>>0>127);Id(i|0,f|0,g|0)|0;return}function Gb(b,d){b=b|0;d=d|0;var e=0,f=0,g=0,h=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0;s=i;e=i=i+63&-64;i=i+16|0;r=b+64|0;f=r;g=c[f>>2]|0;f=c[f+4>>2]|0;a[e+7>>0]=g;q=Gd(g|0,f|0,8)|0;a[e+6>>0]=q;q=Gd(g|0,f|0,16)|0;a[e+5>>0]=q;q=Gd(g|0,f|0,24)|0;a[e+4>>0]=q;a[e+3>>0]=f;q=Gd(g|0,f|0,40)|0;a[e+2>>0]=q;q=Gd(g|0,f|0,48)|0;a[e+1>>0]=q;q=Gd(g|0,f|0,56)|0;a[e>>0]=q;q=b+72|0;j=q;h=c[j>>2]|0;j=c[j+4>>2]|0;a[e+15>>0]=h;n=Gd(h|0,j|0,8)|0;a[e+14>>0]=n;n=Gd(h|0,j|0,16)|0;a[e+13>>0]=n;n=Gd(h|0,j|0,24)|0;a[e+12>>0]=n;a[e+11>>0]=j;n=Gd(h|0,j|0,40)|0;a[e+10>>0]=n;n=Gd(h|0,j|0,48)|0;a[e+9>>0]=n;n=Gd(h|0,j|0,56)|0;a[e+8>>0]=n;n=Gd(h|0,j|0,3)|0;n=n&127;o=0<0|0==0&n>>>0<112;o=Cd((o?112:240)|0,(o?0:0)|0,n|0,0)|0;p=C;m=Hd(o|0,p|0,3)|0;t=C;k=Gd(o|0,p|0,61)|0;l=C;j=Dd(m|0,t|0,h|0,j|0)|0;h=C;u=q;c[u>>2]=j;c[u+4>>2]=h;if(h>>>0<t>>>0|(h|0)==(t|0)&j>>>0<m>>>0){g=Dd(g|0,f|0,1,0)|0;f=C;u=r;c[u>>2]=g;c[u+4>>2]=f}g=Dd(g|0,f|0,k|0,l|0)|0;f=C;l=r;c[l>>2]=g;c[l+4>>2]=f;l=Cd(128,0,n|0,0)|0;m=C;k=b+80+n|0;if(p>>>0<m>>>0|(p|0)==(m|0)&o>>>0<l>>>0)Id(k|0,32856,o|0)|0;else{Id(k|0,32856,l|0)|0;j=b+80|0;Hb(b,j);f=32856+l|0;g=Cd(o|0,p|0,l|0,m|0)|0;h=C;if(h>>>0>0|(h|0)==0&g>>>0>127)do{Hb(b,f);f=f+128|0;g=Dd(g|0,h|0,-128,-1)|0;h=C}while(h>>>0>0|(h|0)==0&g>>>0>127);Id(j|0,f|0,g|0)|0;h=q;f=r;j=c[h>>2]|0;h=c[h+4>>2]|0;g=c[f>>2]|0;f=c[f+4>>2]|0}k=Gd(j|0,h|0,3)|0;k=k&127;t=Dd(j|0,h|0,128,0)|0;u=q;c[u>>2]=t;c[u+4>>2]=C;if(h>>>0>4294967295|(h|0)==-1&j>>>0>4294967167){g=Dd(g|0,f|0,1,0)|0;f=C;u=r;c[u>>2]=g;c[u+4>>2]=f}h=r;c[h>>2]=g;c[h+4>>2]=f;g=Cd(128,0,k|0,0)|0;h=C;f=b+80+k|0;if(h>>>0>0|(h|0)==0&g>>>0>16){g=f;f=g+16|0;do{a[g>>0]=a[e>>0]|0;g=g+1|0;e=e+1|0}while((g|0)<(f|0))}else{Id(f|0,e|0,g|0)|0;j=b+80|0;Hb(b,j);e=e+g|0;f=Cd(16,0,g|0,h|0)|0;g=C;if(g>>>0>0|(g|0)==0&f>>>0>127)do{Hb(b,e);e=e+128|0;f=Dd(f|0,g|0,-128,-1)|0;g=C}while(g>>>0>0|(g|0)==0&f>>>0>127);Id(j|0,e|0,f|0)|0}e=0;do{u=d+(e<<3)|0;t=b+(e<<3)|0;r=c[t>>2]|0;t=c[t+4>>2]|0;a[u+7>>0]=r;q=Gd(r|0,t|0,8)|0;a[u+6>>0]=q;q=Gd(r|0,t|0,16)|0;a[u+5>>0]=q;q=Gd(r|0,t|0,24)|0;a[u+4>>0]=q;a[u+3>>0]=t;q=Gd(r|0,t|0,40)|0;a[u+2>>0]=q;q=Gd(r|0,t|0,48)|0;a[u+1>>0]=q;t=Gd(r|0,t|0,56)|0;a[u>>0]=t;e=e+1|0}while((e|0)!=8);Fd(b|0,0,208)|0;i=s;return}\nfunction yd(a){a=a|0;var b=0,d=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0,s=0,t=0,u=0,v=0,w=0,x=0,y=0,z=0,A=0,B=0,C=0,D=0,E=0,F=0,G=0;do if(a>>>0<245){o=a>>>0<11?16:a+11&-8;a=o>>>3;j=c[8020]|0;b=j>>>a;if(b&3){b=(b&1^1)+a|0;d=32120+(b<<1<<2)|0;e=d+8|0;f=c[e>>2]|0;g=f+8|0;h=c[g>>2]|0;do if((d|0)!=(h|0)){if(h>>>0<(c[8024]|0)>>>0)ra();a=h+12|0;if((c[a>>2]|0)==(f|0)){c[a>>2]=d;c[e>>2]=h;break}else ra()}else c[8020]=j&~(1<<b);while(0);G=b<<3;c[f+4>>2]=G|3;G=f+G+4|0;c[G>>2]=c[G>>2]|1;G=g;return G|0}h=c[8022]|0;if(o>>>0>h>>>0){if(b){d=2<<a;d=b<<a&(d|0-d);d=(d&0-d)+-1|0;i=d>>>12&16;d=d>>>i;f=d>>>5&8;d=d>>>f;g=d>>>2&4;d=d>>>g;e=d>>>1&2;d=d>>>e;b=d>>>1&1;b=(f|i|g|e|b)+(d>>>b)|0;d=32120+(b<<1<<2)|0;e=d+8|0;g=c[e>>2]|0;i=g+8|0;f=c[i>>2]|0;do if((d|0)!=(f|0)){if(f>>>0<(c[8024]|0)>>>0)ra();a=f+12|0;if((c[a>>2]|0)==(g|0)){c[a>>2]=d;c[e>>2]=f;k=c[8022]|0;break}else ra()}else{c[8020]=j&~(1<<b);k=h}while(0);h=(b<<3)-o|0;c[g+4>>2]=o|3;e=g+o|0;c[e+4>>2]=h|1;c[e+h>>2]=h;if(k){f=c[8025]|0;b=k>>>3;d=32120+(b<<1<<2)|0;a=c[8020]|0;b=1<<b;if(a&b){a=d+8|0;b=c[a>>2]|0;if(b>>>0<(c[8024]|0)>>>0)ra();else{l=a;m=b}}else{c[8020]=a|b;l=d+8|0;m=d}c[l>>2]=f;c[m+12>>2]=f;c[f+8>>2]=m;c[f+12>>2]=d}c[8022]=h;c[8025]=e;G=i;return G|0}a=c[8021]|0;if(a){i=(a&0-a)+-1|0;F=i>>>12&16;i=i>>>F;E=i>>>5&8;i=i>>>E;G=i>>>2&4;i=i>>>G;b=i>>>1&2;i=i>>>b;j=i>>>1&1;j=c[32384+((E|F|G|b|j)+(i>>>j)<<2)>>2]|0;i=(c[j+4>>2]&-8)-o|0;b=j;while(1){a=c[b+16>>2]|0;if(!a){a=c[b+20>>2]|0;if(!a)break}b=(c[a+4>>2]&-8)-o|0;G=b>>>0<i>>>0;i=G?b:i;b=a;j=G?a:j}f=c[8024]|0;if(j>>>0<f>>>0)ra();h=j+o|0;if(j>>>0>=h>>>0)ra();g=c[j+24>>2]|0;d=c[j+12>>2]|0;do if((d|0)==(j|0)){b=j+20|0;a=c[b>>2]|0;if(!a){b=j+16|0;a=c[b>>2]|0;if(!a){n=0;break}}while(1){d=a+20|0;e=c[d>>2]|0;if(e){a=e;b=d;continue}d=a+16|0;e=c[d>>2]|0;if(!e)break;else{a=e;b=d}}if(b>>>0<f>>>0)ra();else{c[b>>2]=0;n=a;break}}else{e=c[j+8>>2]|0;if(e>>>0<f>>>0)ra();a=e+12|0;if((c[a>>2]|0)!=(j|0))ra();b=d+8|0;if((c[b>>2]|0)==(j|0)){c[a>>2]=d;c[b>>2]=e;n=d;break}else ra()}while(0);do if(g){a=c[j+28>>2]|0;b=32384+(a<<2)|0;if((j|0)==(c[b>>2]|0)){c[b>>2]=n;if(!n){c[8021]=c[8021]&~(1<<a);break}}else{if(g>>>0<(c[8024]|0)>>>0)ra();a=g+16|0;if((c[a>>2]|0)==(j|0))c[a>>2]=n;else c[g+20>>2]=n;if(!n)break}b=c[8024]|0;if(n>>>0<b>>>0)ra();c[n+24>>2]=g;a=c[j+16>>2]|0;do if(a)if(a>>>0<b>>>0)ra();else{c[n+16>>2]=a;c[a+24>>2]=n;break}while(0);a=c[j+20>>2]|0;if(a)if(a>>>0<(c[8024]|0)>>>0)ra();else{c[n+20>>2]=a;c[a+24>>2]=n;break}}while(0);if(i>>>0<16){G=i+o|0;c[j+4>>2]=G|3;G=j+G+4|0;c[G>>2]=c[G>>2]|1}else{c[j+4>>2]=o|3;c[h+4>>2]=i|1;c[h+i>>2]=i;a=c[8022]|0;if(a){e=c[8025]|0;b=a>>>3;d=32120+(b<<1<<2)|0;a=c[8020]|0;b=1<<b;if(a&b){a=d+8|0;b=c[a>>2]|0;if(b>>>0<(c[8024]|0)>>>0)ra();else{p=a;q=b}}else{c[8020]=a|b;p=d+8|0;q=d}c[p>>2]=e;c[q+12>>2]=e;c[e+8>>2]=q;c[e+12>>2]=d}c[8022]=i;c[8025]=h}G=j+8|0;return G|0}}}else if(a>>>0<=4294967231){a=a+11|0;o=a&-8;k=c[8021]|0;if(k){d=0-o|0;a=a>>>8;if(a)if(o>>>0>16777215)j=31;else{q=(a+1048320|0)>>>16&8;z=a<<q;p=(z+520192|0)>>>16&4;z=z<<p;j=(z+245760|0)>>>16&2;j=14-(p|q|j)+(z<<j>>>15)|0;j=o>>>(j+7|0)&1|j<<1}else j=0;b=c[32384+(j<<2)>>2]|0;a:do if(!b){a=0;b=0;z=86}else{f=d;a=0;h=o<<((j|0)==31?0:25-(j>>>1)|0);i=b;b=0;while(1){e=c[i+4>>2]&-8;d=e-o|0;if(d>>>0<f>>>0)if((e|0)==(o|0)){a=i;b=i;z=90;break a}else b=i;else d=f;e=c[i+20>>2]|0;i=c[i+16+(h>>>31<<2)>>2]|0;a=(e|0)==0|(e|0)==(i|0)?a:e;e=(i|0)==0;if(e){z=86;break}else{f=d;h=h<<(e&1^1)}}}while(0);if((z|0)==86){if((a|0)==0&(b|0)==0){a=2<<j;a=k&(a|0-a);if(!a)break;q=(a&0-a)+-1|0;m=q>>>12&16;q=q>>>m;l=q>>>5&8;q=q>>>l;n=q>>>2&4;q=q>>>n;p=q>>>1&2;q=q>>>p;a=q>>>1&1;a=c[32384+((l|m|n|p|a)+(q>>>a)<<2)>>2]|0}if(!a){i=d;j=b}else z=90}if((z|0)==90)while(1){z=0;q=(c[a+4>>2]&-8)-o|0;e=q>>>0<d>>>0;d=e?q:d;b=e?a:b;e=c[a+16>>2]|0;if(e){a=e;z=90;continue}a=c[a+20>>2]|0;if(!a){i=d;j=b;break}else z=90}if((j|0)!=0?i>>>0<((c[8022]|0)-o|0)>>>0:0){f=c[8024]|0;if(j>>>0<f>>>0)ra();h=j+o|0;if(j>>>0>=h>>>0)ra();g=c[j+24>>2]|0;d=c[j+12>>2]|0;do if((d|0)==(j|0)){b=j+20|0;a=c[b>>2]|0;if(!a){b=j+16|0;a=c[b>>2]|0;if(!a){s=0;break}}while(1){d=a+20|0;e=c[d>>2]|0;if(e){a=e;b=d;continue}d=a+16|0;e=c[d>>2]|0;if(!e)break;else{a=e;b=d}}if(b>>>0<f>>>0)ra();else{c[b>>2]=0;s=a;break}}else{e=c[j+8>>2]|0;if(e>>>0<f>>>0)ra();a=e+12|0;if((c[a>>2]|0)!=(j|0))ra();b=d+8|0;if((c[b>>2]|0)==(j|0)){c[a>>2]=d;c[b>>2]=e;s=d;break}else ra()}while(0);do if(g){a=c[j+28>>2]|0;b=32384+(a<<2)|0;if((j|0)==(c[b>>2]|0)){c[b>>2]=s;if(!s){c[8021]=c[8021]&~(1<<a);break}}else{if(g>>>0<(c[8024]|0)>>>0)ra();a=g+16|0;if((c[a>>2]|0)==(j|0))c[a>>2]=s;else c[g+20>>2]=s;if(!s)break}b=c[8024]|0;if(s>>>0<b>>>0)ra();c[s+24>>2]=g;a=c[j+16>>2]|0;do if(a)if(a>>>0<b>>>0)ra();else{c[s+16>>2]=a;c[a+24>>2]=s;break}while(0);a=c[j+20>>2]|0;if(a)if(a>>>0<(c[8024]|0)>>>0)ra();else{c[s+20>>2]=a;c[a+24>>2]=s;break}}while(0);do if(i>>>0>=16){c[j+4>>2]=o|3;c[h+4>>2]=i|1;c[h+i>>2]=i;a=i>>>3;if(i>>>0<256){d=32120+(a<<1<<2)|0;b=c[8020]|0;a=1<<a;if(b&a){a=d+8|0;b=c[a>>2]|0;if(b>>>0<(c[8024]|0)>>>0)ra();else{t=a;v=b}}else{c[8020]=b|a;t=d+8|0;v=d}c[t>>2]=h;c[v+12>>2]=h;c[h+8>>2]=v;c[h+12>>2]=d;break}a=i>>>8;if(a)if(i>>>0>16777215)d=31;else{F=(a+1048320|0)>>>16&8;G=a<<F;E=(G+520192|0)>>>16&4;G=G<<E;d=(G+245760|0)>>>16&2;d=14-(E|F|d)+(G<<d>>>15)|0;d=i>>>(d+7|0)&1|d<<1}else d=0;e=32384+(d<<2)|0;c[h+28>>2]=d;a=h+16|0;c[a+4>>2]=0;c[a>>2]=0;a=c[8021]|0;b=1<<d;if(!(a&b)){c[8021]=a|b;c[e>>2]=h;c[h+24>>2]=e;c[h+12>>2]=h;c[h+8>>2]=h;break}d=i<<((d|0)==31?0:25-(d>>>1)|0);e=c[e>>2]|0;while(1){if((c[e+4>>2]&-8|0)==(i|0)){z=148;break}b=e+16+(d>>>31<<2)|0;a=c[b>>2]|0;if(!a){z=145;break}else{d=d<<1;e=a}}if((z|0)==145)if(b>>>0<(c[8024]|0)>>>0)ra();else{c[b>>2]=h;c[h+24>>2]=e;c[h+12>>2]=h;c[h+8>>2]=h;break}else if((z|0)==148){a=e+8|0;b=c[a>>2]|0;G=c[8024]|0;if(b>>>0>=G>>>0&e>>>0>=G>>>0){c[b+12>>2]=h;c[a>>2]=h;c[h+8>>2]=b;c[h+12>>2]=e;c[h+24>>2]=0;break}else ra()}}else{G=i+o|0;c[j+4>>2]=G|3;G=j+G+4|0;c[G>>2]=c[G>>2]|1}while(0);G=j+8|0;return G|0}}}else o=-1;while(0);d=c[8022]|0;if(d>>>0>=o>>>0){a=d-o|0;b=c[8025]|0;if(a>>>0>15){G=b+o|0;c[8025]=G;c[8022]=a;c[G+4>>2]=a|1;c[G+a>>2]=a;c[b+4>>2]=o|3}else{c[8022]=0;c[8025]=0;c[b+4>>2]=d|3;G=b+d+4|0;c[G>>2]=c[G>>2]|1}G=b+8|0;return G|0}a=c[8023]|0;if(a>>>0>o>>>0){E=a-o|0;c[8023]=E;G=c[8026]|0;F=G+o|0;c[8026]=F;c[F+4>>2]=E|1;c[G+4>>2]=o|3;G=G+8|0;return G|0}do if(!(c[8138]|0)){a=na(30)|0;if(!(a+-1&a)){c[8140]=a;c[8139]=a;c[8141]=-1;c[8142]=-1;c[8143]=0;c[8131]=0;c[8138]=(ta(0)|0)&-16^1431655768;break}else ra()}while(0);h=o+48|0;e=c[8140]|0;i=o+47|0;d=e+i|0;e=0-e|0;j=d&e;if(j>>>0<=o>>>0){G=0;return G|0}a=c[8130]|0;if((a|0)!=0?(t=c[8128]|0,v=t+j|0,v>>>0<=t>>>0|v>>>0>a>>>0):0){G=0;return G|0}b:do if(!(c[8131]&4)){b=c[8026]|0;c:do if(b){f=32528;while(1){a=c[f>>2]|0;if(a>>>0<=b>>>0?(r=f+4|0,(a+(c[r>>2]|0)|0)>>>0>b>>>0):0)break;a=c[f+8>>2]|0;if(!a){z=173;break c}else f=a}a=d-(c[8023]|0)&e;if(a>>>0<2147483647){b=sa(a|0)|0;if((b|0)==((c[f>>2]|0)+(c[r>>2]|0)|0)){if((b|0)!=(-1|0)){h=b;g=a;z=193;break b}}else z=183}}else z=173;while(0);do if((z|0)==173?(u=sa(0)|0,(u|0)!=(-1|0)):0){a=u;b=c[8139]|0;d=b+-1|0;if(!(d&a))a=j;else a=j-a+(d+a&0-b)|0;b=c[8128]|0;d=b+a|0;if(a>>>0>o>>>0&a>>>0<2147483647){v=c[8130]|0;if((v|0)!=0?d>>>0<=b>>>0|d>>>0>v>>>0:0)break;b=sa(a|0)|0;if((b|0)==(u|0)){h=u;g=a;z=193;break b}else z=183}}while(0);d:do if((z|0)==183){d=0-a|0;do if(h>>>0>a>>>0&(a>>>0<2147483647&(b|0)!=(-1|0))?(w=c[8140]|0,w=i-a+w&0-w,w>>>0<2147483647):0)if((sa(w|0)|0)==(-1|0)){sa(d|0)|0;break d}else{a=w+a|0;break}while(0);if((b|0)!=(-1|0)){h=b;g=a;z=193;break b}}while(0);c[8131]=c[8131]|4;z=190}else z=190;while(0);if((((z|0)==190?j>>>0<2147483647:0)?(x=sa(j|0)|0,y=sa(0)|0,x>>>0<y>>>0&((x|0)!=(-1|0)&(y|0)!=(-1|0))):0)?(g=y-x|0,g>>>0>(o+40|0)>>>0):0){h=x;z=193}if((z|0)==193){a=(c[8128]|0)+g|0;c[8128]=a;if(a>>>0>(c[8129]|0)>>>0)c[8129]=a;k=c[8026]|0;do if(k){f=32528;while(1){a=c[f>>2]|0;b=f+4|0;d=c[b>>2]|0;if((h|0)==(a+d|0)){z=203;break}e=c[f+8>>2]|0;if(!e)break;else f=e}if(((z|0)==203?(c[f+12>>2]&8|0)==0:0)?k>>>0<h>>>0&k>>>0>=a>>>0:0){c[b>>2]=d+g;G=k+8|0;G=(G&7|0)==0?0:0-G&7;F=k+G|0;G=g-G+(c[8023]|0)|0;c[8026]=F;c[8023]=G;c[F+4>>2]=G|1;c[F+G+4>>2]=40;c[8027]=c[8142];break}a=c[8024]|0;if(h>>>0<a>>>0){c[8024]=h;i=h}else i=a;b=h+g|0;a=32528;while(1){if((c[a>>2]|0)==(b|0)){z=211;break}a=c[a+8>>2]|0;if(!a){b=32528;break}}if((z|0)==211)if(!(c[a+12>>2]&8)){c[a>>2]=h;m=a+4|0;c[m>>2]=(c[m>>2]|0)+g;m=h+8|0;m=h+((m&7|0)==0?0:0-m&7)|0;a=b+8|0;a=b+((a&7|0)==0?0:0-a&7)|0;l=m+o|0;j=a-m-o|0;c[m+4>>2]=o|3;do if((a|0)!=(k|0)){if((a|0)==(c[8025]|0)){G=(c[8022]|0)+j|0;c[8022]=G;c[8025]=l;c[l+4>>2]=G|1;c[l+G>>2]=G;break}b=c[a+4>>2]|0;if((b&3|0)==1){h=b&-8;f=b>>>3;e:do if(b>>>0>=256){g=c[a+24>>2]|0;e=c[a+12>>2]|0;do if((e|0)==(a|0)){e=a+16|0;d=e+4|0;b=c[d>>2]|0;if(!b){b=c[e>>2]|0;if(!b){E=0;break}else d=e}while(1){e=b+20|0;f=c[e>>2]|0;if(f){b=f;d=e;continue}e=b+16|0;f=c[e>>2]|0;if(!f)break;else{b=f;d=e}}if(d>>>0<i>>>0)ra();else{c[d>>2]=0;E=b;break}}else{f=c[a+8>>2]|0;if(f>>>0<i>>>0)ra();b=f+12|0;if((c[b>>2]|0)!=(a|0))ra();d=e+8|0;if((c[d>>2]|0)==(a|0)){c[b>>2]=e;c[d>>2]=f;E=e;break}else ra()}while(0);if(!g)break;b=c[a+28>>2]|0;d=32384+(b<<2)|0;do if((a|0)!=(c[d>>2]|0)){if(g>>>0<(c[8024]|0)>>>0)ra();b=g+16|0;if((c[b>>2]|0)==(a|0))c[b>>2]=E;else c[g+20>>2]=E;if(!E)break e}else{c[d>>2]=E;if(E)break;c[8021]=c[8021]&~(1<<b);break e}while(0);e=c[8024]|0;if(E>>>0<e>>>0)ra();c[E+24>>2]=g;b=a+16|0;d=c[b>>2]|0;do if(d)if(d>>>0<e>>>0)ra();else{c[E+16>>2]=d;c[d+24>>2]=E;break}while(0);b=c[b+4>>2]|0;if(!b)break;if(b>>>0<(c[8024]|0)>>>0)ra();else{c[E+20>>2]=b;c[b+24>>2]=E;break}}else{d=c[a+8>>2]|0;e=c[a+12>>2]|0;b=32120+(f<<1<<2)|0;do if((d|0)!=(b|0)){if(d>>>0<i>>>0)ra();if((c[d+12>>2]|0)==(a|0))break;ra()}while(0);if((e|0)==(d|0)){c[8020]=c[8020]&~(1<<f);break}do if((e|0)==(b|0))B=e+8|0;else{if(e>>>0<i>>>0)ra();b=e+8|0;if((c[b>>2]|0)==(a|0)){B=b;break}ra()}while(0);c[d+12>>2]=e;c[B>>2]=d}while(0);a=a+h|0;f=h+j|0}else f=j;a=a+4|0;c[a>>2]=c[a>>2]&-2;c[l+4>>2]=f|1;c[l+f>>2]=f;a=f>>>3;if(f>>>0<256){d=32120+(a<<1<<2)|0;b=c[8020]|0;a=1<<a;do if(!(b&a)){c[8020]=b|a;F=d+8|0;G=d}else{a=d+8|0;b=c[a>>2]|0;if(b>>>0>=(c[8024]|0)>>>0){F=a;G=b;break}ra()}while(0);c[F>>2]=l;c[G+12>>2]=l;c[l+8>>2]=G;c[l+12>>2]=d;break}a=f>>>8;do if(!a)d=0;else{if(f>>>0>16777215){d=31;break}F=(a+1048320|0)>>>16&8;G=a<<F;E=(G+520192|0)>>>16&4;G=G<<E;d=(G+245760|0)>>>16&2;d=14-(E|F|d)+(G<<d>>>15)|0;d=f>>>(d+7|0)&1|d<<1}while(0);e=32384+(d<<2)|0;c[l+28>>2]=d;a=l+16|0;c[a+4>>2]=0;c[a>>2]=0;a=c[8021]|0;b=1<<d;if(!(a&b)){c[8021]=a|b;c[e>>2]=l;c[l+24>>2]=e;c[l+12>>2]=l;c[l+8>>2]=l;break}d=f<<((d|0)==31?0:25-(d>>>1)|0);e=c[e>>2]|0;while(1){if((c[e+4>>2]&-8|0)==(f|0)){z=281;break}b=e+16+(d>>>31<<2)|0;a=c[b>>2]|0;if(!a){z=278;break}else{d=d<<1;e=a}}if((z|0)==278)if(b>>>0<(c[8024]|0)>>>0)ra();else{c[b>>2]=l;c[l+24>>2]=e;c[l+12>>2]=l;c[l+8>>2]=l;break}else if((z|0)==281){a=e+8|0;b=c[a>>2]|0;G=c[8024]|0;if(b>>>0>=G>>>0&e>>>0>=G>>>0){c[b+12>>2]=l;c[a>>2]=l;c[l+8>>2]=b;c[l+12>>2]=e;c[l+24>>2]=0;break}else ra()}}else{G=(c[8023]|0)+j|0;c[8023]=G;c[8026]=l;c[l+4>>2]=G|1}while(0);G=m+8|0;return G|0}else b=32528;while(1){a=c[b>>2]|0;if(a>>>0<=k>>>0?(A=a+(c[b+4>>2]|0)|0,A>>>0>k>>>0):0)break;b=c[b+8>>2]|0}f=A+-47|0;b=f+8|0;b=f+((b&7|0)==0?0:0-b&7)|0;f=k+16|0;b=b>>>0<f>>>0?k:b;a=b+8|0;d=h+8|0;d=(d&7|0)==0?0:0-d&7;G=h+d|0;d=g+-40-d|0;c[8026]=G;c[8023]=d;c[G+4>>2]=d|1;c[G+d+4>>2]=40;c[8027]=c[8142];d=b+4|0;c[d>>2]=27;c[a>>2]=c[8132];c[a+4>>2]=c[8133];c[a+8>>2]=c[8134];c[a+12>>2]=c[8135];c[8132]=h;c[8133]=g;c[8135]=0;c[8134]=a;a=b+24|0;do{a=a+4|0;c[a>>2]=7}while((a+4|0)>>>0<A>>>0);if((b|0)!=(k|0)){g=b-k|0;c[d>>2]=c[d>>2]&-2;c[k+4>>2]=g|1;c[b>>2]=g;a=g>>>3;if(g>>>0<256){d=32120+(a<<1<<2)|0;b=c[8020]|0;a=1<<a;if(b&a){a=d+8|0;b=c[a>>2]|0;if(b>>>0<(c[8024]|0)>>>0)ra();else{C=a;D=b}}else{c[8020]=b|a;C=d+8|0;D=d}c[C>>2]=k;c[D+12>>2]=k;c[k+8>>2]=D;c[k+12>>2]=d;break}a=g>>>8;if(a)if(g>>>0>16777215)d=31;else{F=(a+1048320|0)>>>16&8;G=a<<F;E=(G+520192|0)>>>16&4;G=G<<E;d=(G+245760|0)>>>16&2;d=14-(E|F|d)+(G<<d>>>15)|0;d=g>>>(d+7|0)&1|d<<1}else d=0;e=32384+(d<<2)|0;c[k+28>>2]=d;c[k+20>>2]=0;c[f>>2]=0;a=c[8021]|0;b=1<<d;if(!(a&b)){c[8021]=a|b;c[e>>2]=k;c[k+24>>2]=e;c[k+12>>2]=k;c[k+8>>2]=k;break}d=g<<((d|0)==31?0:25-(d>>>1)|0);e=c[e>>2]|0;while(1){if((c[e+4>>2]&-8|0)==(g|0)){z=307;break}b=e+16+(d>>>31<<2)|0;a=c[b>>2]|0;if(!a){z=304;break}else{d=d<<1;e=a}}if((z|0)==304)if(b>>>0<(c[8024]|0)>>>0)ra();else{c[b>>2]=k;c[k+24>>2]=e;c[k+12>>2]=k;c[k+8>>2]=k;break}else if((z|0)==307){a=e+8|0;b=c[a>>2]|0;G=c[8024]|0;if(b>>>0>=G>>>0&e>>>0>=G>>>0){c[b+12>>2]=k;c[a>>2]=k;c[k+8>>2]=b;c[k+12>>2]=e;c[k+24>>2]=0;break}else ra()}}}else{G=c[8024]|0;if((G|0)==0|h>>>0<G>>>0)c[8024]=h;c[8132]=h;c[8133]=g;c[8135]=0;c[8029]=c[8138];c[8028]=-1;a=0;do{G=32120+(a<<1<<2)|0;c[G+12>>2]=G;c[G+8>>2]=G;a=a+1|0}while((a|0)!=32);G=h+8|0;G=(G&7|0)==0?0:0-G&7;F=h+G|0;G=g+-40-G|0;c[8026]=F;c[8023]=G;c[F+4>>2]=G|1;c[F+G+4>>2]=40;c[8027]=c[8142]}while(0);a=c[8023]|0;if(a>>>0>o>>>0){E=a-o|0;c[8023]=E;G=c[8026]|0;F=G+o|0;c[8026]=F;c[F+4>>2]=E|1;c[G+4>>2]=o|3;G=G+8|0;return G|0}}if(!(c[7979]|0))a=31964;else a=c[(oa()|0)+60>>2]|0;c[a>>2]=12;G=0;return G|0}function zd(a){a=a|0;var b=0,d=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0;if(!a)return;d=a+-8|0;h=c[8024]|0;if(d>>>0<h>>>0)ra();a=c[a+-4>>2]|0;b=a&3;if((b|0)==1)ra();e=a&-8;m=d+e|0;do if(!(a&1)){a=c[d>>2]|0;if(!b)return;k=d+(0-a)|0;j=a+e|0;if(k>>>0<h>>>0)ra();if((k|0)==(c[8025]|0)){a=m+4|0;b=c[a>>2]|0;if((b&3|0)!=3){q=k;f=j;break}c[8022]=j;c[a>>2]=b&-2;c[k+4>>2]=j|1;c[k+j>>2]=j;return}e=a>>>3;if(a>>>0<256){b=c[k+8>>2]|0;d=c[k+12>>2]|0;a=32120+(e<<1<<2)|0;if((b|0)!=(a|0)){if(b>>>0<h>>>0)ra();if((c[b+12>>2]|0)!=(k|0))ra()}if((d|0)==(b|0)){c[8020]=c[8020]&~(1<<e);q=k;f=j;break}if((d|0)!=(a|0)){if(d>>>0<h>>>0)ra();a=d+8|0;if((c[a>>2]|0)==(k|0))g=a;else ra()}else g=d+8|0;c[b+12>>2]=d;c[g>>2]=b;q=k;f=j;break}g=c[k+24>>2]|0;d=c[k+12>>2]|0;do if((d|0)==(k|0)){d=k+16|0;b=d+4|0;a=c[b>>2]|0;if(!a){a=c[d>>2]|0;if(!a){i=0;break}else b=d}while(1){d=a+20|0;e=c[d>>2]|0;if(e){a=e;b=d;continue}d=a+16|0;e=c[d>>2]|0;if(!e)break;else{a=e;b=d}}if(b>>>0<h>>>0)ra();else{c[b>>2]=0;i=a;break}}else{e=c[k+8>>2]|0;if(e>>>0<h>>>0)ra();a=e+12|0;if((c[a>>2]|0)!=(k|0))ra();b=d+8|0;if((c[b>>2]|0)==(k|0)){c[a>>2]=d;c[b>>2]=e;i=d;break}else ra()}while(0);if(g){a=c[k+28>>2]|0;b=32384+(a<<2)|0;if((k|0)==(c[b>>2]|0)){c[b>>2]=i;if(!i){c[8021]=c[8021]&~(1<<a);q=k;f=j;break}}else{if(g>>>0<(c[8024]|0)>>>0)ra();a=g+16|0;if((c[a>>2]|0)==(k|0))c[a>>2]=i;else c[g+20>>2]=i;if(!i){q=k;f=j;break}}d=c[8024]|0;if(i>>>0<d>>>0)ra();c[i+24>>2]=g;a=k+16|0;b=c[a>>2]|0;do if(b)if(b>>>0<d>>>0)ra();else{c[i+16>>2]=b;c[b+24>>2]=i;break}while(0);a=c[a+4>>2]|0;if(a)if(a>>>0<(c[8024]|0)>>>0)ra();else{c[i+20>>2]=a;c[a+24>>2]=i;q=k;f=j;break}else{q=k;f=j}}else{q=k;f=j}}else{q=d;f=e}while(0);if(q>>>0>=m>>>0)ra();a=m+4|0;b=c[a>>2]|0;if(!(b&1))ra();if(!(b&2)){if((m|0)==(c[8026]|0)){p=(c[8023]|0)+f|0;c[8023]=p;c[8026]=q;c[q+4>>2]=p|1;if((q|0)!=(c[8025]|0))return;c[8025]=0;c[8022]=0;return}if((m|0)==(c[8025]|0)){p=(c[8022]|0)+f|0;c[8022]=p;c[8025]=q;c[q+4>>2]=p|1;c[q+p>>2]=p;return}f=(b&-8)+f|0;e=b>>>3;do if(b>>>0>=256){g=c[m+24>>2]|0;a=c[m+12>>2]|0;do if((a|0)==(m|0)){d=m+16|0;b=d+4|0;a=c[b>>2]|0;if(!a){a=c[d>>2]|0;if(!a){n=0;break}else b=d}while(1){d=a+20|0;e=c[d>>2]|0;if(e){a=e;b=d;continue}d=a+16|0;e=c[d>>2]|0;if(!e)break;else{a=e;b=d}}if(b>>>0<(c[8024]|0)>>>0)ra();else{c[b>>2]=0;n=a;break}}else{b=c[m+8>>2]|0;if(b>>>0<(c[8024]|0)>>>0)ra();d=b+12|0;if((c[d>>2]|0)!=(m|0))ra();e=a+8|0;if((c[e>>2]|0)==(m|0)){c[d>>2]=a;c[e>>2]=b;n=a;break}else ra()}while(0);if(g){a=c[m+28>>2]|0;b=32384+(a<<2)|0;if((m|0)==(c[b>>2]|0)){c[b>>2]=n;if(!n){c[8021]=c[8021]&~(1<<a);break}}else{if(g>>>0<(c[8024]|0)>>>0)ra();a=g+16|0;if((c[a>>2]|0)==(m|0))c[a>>2]=n;else c[g+20>>2]=n;if(!n)break}d=c[8024]|0;if(n>>>0<d>>>0)ra();c[n+24>>2]=g;a=m+16|0;b=c[a>>2]|0;do if(b)if(b>>>0<d>>>0)ra();else{c[n+16>>2]=b;c[b+24>>2]=n;break}while(0);a=c[a+4>>2]|0;if(a)if(a>>>0<(c[8024]|0)>>>0)ra();else{c[n+20>>2]=a;c[a+24>>2]=n;break}}}else{b=c[m+8>>2]|0;d=c[m+12>>2]|0;a=32120+(e<<1<<2)|0;if((b|0)!=(a|0)){if(b>>>0<(c[8024]|0)>>>0)ra();if((c[b+12>>2]|0)!=(m|0))ra()}if((d|0)==(b|0)){c[8020]=c[8020]&~(1<<e);break}if((d|0)!=(a|0)){if(d>>>0<(c[8024]|0)>>>0)ra();a=d+8|0;if((c[a>>2]|0)==(m|0))l=a;else ra()}else l=d+8|0;c[b+12>>2]=d;c[l>>2]=b}while(0);c[q+4>>2]=f|1;c[q+f>>2]=f;if((q|0)==(c[8025]|0)){c[8022]=f;return}}else{c[a>>2]=b&-2;c[q+4>>2]=f|1;c[q+f>>2]=f}a=f>>>3;if(f>>>0<256){d=32120+(a<<1<<2)|0;b=c[8020]|0;a=1<<a;if(b&a){a=d+8|0;b=c[a>>2]|0;if(b>>>0<(c[8024]|0)>>>0)ra();else{o=a;p=b}}else{c[8020]=b|a;o=d+8|0;p=d}c[o>>2]=q;c[p+12>>2]=q;c[q+8>>2]=p;c[q+12>>2]=d;return}a=f>>>8;if(a)if(f>>>0>16777215)d=31;else{o=(a+1048320|0)>>>16&8;p=a<<o;n=(p+520192|0)>>>16&4;p=p<<n;d=(p+245760|0)>>>16&2;d=14-(n|o|d)+(p<<d>>>15)|0;d=f>>>(d+7|0)&1|d<<1}else d=0;e=32384+(d<<2)|0;c[q+28>>2]=d;c[q+20>>2]=0;c[q+16>>2]=0;a=c[8021]|0;b=1<<d;do if(a&b){d=f<<((d|0)==31?0:25-(d>>>1)|0);e=c[e>>2]|0;while(1){if((c[e+4>>2]&-8|0)==(f|0)){a=130;break}b=e+16+(d>>>31<<2)|0;a=c[b>>2]|0;if(!a){a=127;break}else{d=d<<1;e=a}}if((a|0)==127)if(b>>>0<(c[8024]|0)>>>0)ra();else{c[b>>2]=q;c[q+24>>2]=e;c[q+12>>2]=q;c[q+8>>2]=q;break}else if((a|0)==130){a=e+8|0;b=c[a>>2]|0;p=c[8024]|0;if(b>>>0>=p>>>0&e>>>0>=p>>>0){c[b+12>>2]=q;c[a>>2]=q;c[q+8>>2]=b;c[q+12>>2]=e;c[q+24>>2]=0;break}else ra()}}else{c[8021]=a|b;c[e>>2]=q;c[q+24>>2]=e;c[q+12>>2]=q;c[q+8>>2]=q}while(0);q=(c[8028]|0)+-1|0;c[8028]=q;if(!q)a=32536;else return;while(1){a=c[a>>2]|0;if(!a)break;else a=a+8|0}c[8028]=-1;return}function Ad(a,b){a=a|0;b=b|0;var d=0,e=0,f=0,g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0,q=0,r=0;o=a+b|0;d=c[a+4>>2]|0;do if(!(d&1)){g=c[a>>2]|0;if(!(d&3))return;l=a+(0-g)|0;k=g+b|0;i=c[8024]|0;if(l>>>0<i>>>0)ra();if((l|0)==(c[8025]|0)){a=o+4|0;d=c[a>>2]|0;if((d&3|0)!=3){r=l;f=k;break}c[8022]=k;c[a>>2]=d&-2;c[l+4>>2]=k|1;c[l+k>>2]=k;return}e=g>>>3;if(g>>>0<256){a=c[l+8>>2]|0;b=c[l+12>>2]|0;d=32120+(e<<1<<2)|0;if((a|0)!=(d|0)){if(a>>>0<i>>>0)ra();if((c[a+12>>2]|0)!=(l|0))ra()}if((b|0)==(a|0)){c[8020]=c[8020]&~(1<<e);r=l;f=k;break}if((b|0)!=(d|0)){if(b>>>0<i>>>0)ra();d=b+8|0;if((c[d>>2]|0)==(l|0))h=d;else ra()}else h=b+8|0;c[a+12>>2]=b;c[h>>2]=a;r=l;f=k;break}g=c[l+24>>2]|0;b=c[l+12>>2]|0;do if((b|0)==(l|0)){b=l+16|0;a=b+4|0;d=c[a>>2]|0;if(!d){d=c[b>>2]|0;if(!d){j=0;break}else a=b}while(1){b=d+20|0;e=c[b>>2]|0;if(e){d=e;a=b;continue}b=d+16|0;e=c[b>>2]|0;if(!e)break;else{d=e;a=b}}if(a>>>0<i>>>0)ra();else{c[a>>2]=0;j=d;break}}else{e=c[l+8>>2]|0;if(e>>>0<i>>>0)ra();d=e+12|0;if((c[d>>2]|0)!=(l|0))ra();a=b+8|0;if((c[a>>2]|0)==(l|0)){c[d>>2]=b;c[a>>2]=e;j=b;break}else ra()}while(0);if(g){d=c[l+28>>2]|0;a=32384+(d<<2)|0;if((l|0)==(c[a>>2]|0)){c[a>>2]=j;if(!j){c[8021]=c[8021]&~(1<<d);r=l;f=k;break}}else{if(g>>>0<(c[8024]|0)>>>0)ra();d=g+16|0;if((c[d>>2]|0)==(l|0))c[d>>2]=j;else c[g+20>>2]=j;if(!j){r=l;f=k;break}}b=c[8024]|0;if(j>>>0<b>>>0)ra();c[j+24>>2]=g;d=l+16|0;a=c[d>>2]|0;do if(a)if(a>>>0<b>>>0)ra();else{c[j+16>>2]=a;c[a+24>>2]=j;break}while(0);d=c[d+4>>2]|0;if(d)if(d>>>0<(c[8024]|0)>>>0)ra();else{c[j+20>>2]=d;c[d+24>>2]=j;r=l;f=k;break}else{r=l;f=k}}else{r=l;f=k}}else{r=a;f=b}while(0);h=c[8024]|0;if(o>>>0<h>>>0)ra();d=o+4|0;a=c[d>>2]|0;if(!(a&2)){if((o|0)==(c[8026]|0)){q=(c[8023]|0)+f|0;c[8023]=q;c[8026]=r;c[r+4>>2]=q|1;if((r|0)!=(c[8025]|0))return;c[8025]=0;c[8022]=0;return}if((o|0)==(c[8025]|0)){q=(c[8022]|0)+f|0;c[8022]=q;c[8025]=r;c[r+4>>2]=q|1;c[r+q>>2]=q;return}f=(a&-8)+f|0;e=a>>>3;do if(a>>>0>=256){g=c[o+24>>2]|0;b=c[o+12>>2]|0;do if((b|0)==(o|0)){b=o+16|0;a=b+4|0;d=c[a>>2]|0;if(!d){d=c[b>>2]|0;if(!d){n=0;break}else a=b}while(1){b=d+20|0;e=c[b>>2]|0;if(e){d=e;a=b;continue}b=d+16|0;e=c[b>>2]|0;if(!e)break;else{d=e;a=b}}if(a>>>0<h>>>0)ra();else{c[a>>2]=0;n=d;break}}else{e=c[o+8>>2]|0;if(e>>>0<h>>>0)ra();d=e+12|0;if((c[d>>2]|0)!=(o|0))ra();a=b+8|0;if((c[a>>2]|0)==(o|0)){c[d>>2]=b;c[a>>2]=e;n=b;break}else ra()}while(0);if(g){d=c[o+28>>2]|0;a=32384+(d<<2)|0;if((o|0)==(c[a>>2]|0)){c[a>>2]=n;if(!n){c[8021]=c[8021]&~(1<<d);break}}else{if(g>>>0<(c[8024]|0)>>>0)ra();d=g+16|0;if((c[d>>2]|0)==(o|0))c[d>>2]=n;else c[g+20>>2]=n;if(!n)break}b=c[8024]|0;if(n>>>0<b>>>0)ra();c[n+24>>2]=g;d=o+16|0;a=c[d>>2]|0;do if(a)if(a>>>0<b>>>0)ra();else{c[n+16>>2]=a;c[a+24>>2]=n;break}while(0);d=c[d+4>>2]|0;if(d)if(d>>>0<(c[8024]|0)>>>0)ra();else{c[n+20>>2]=d;c[d+24>>2]=n;break}}}else{a=c[o+8>>2]|0;b=c[o+12>>2]|0;d=32120+(e<<1<<2)|0;if((a|0)!=(d|0)){if(a>>>0<h>>>0)ra();if((c[a+12>>2]|0)!=(o|0))ra()}if((b|0)==(a|0)){c[8020]=c[8020]&~(1<<e);break}if((b|0)!=(d|0)){if(b>>>0<h>>>0)ra();d=b+8|0;if((c[d>>2]|0)==(o|0))m=d;else ra()}else m=b+8|0;c[a+12>>2]=b;c[m>>2]=a}while(0);c[r+4>>2]=f|1;c[r+f>>2]=f;if((r|0)==(c[8025]|0)){c[8022]=f;return}}else{c[d>>2]=a&-2;c[r+4>>2]=f|1;c[r+f>>2]=f}d=f>>>3;if(f>>>0<256){b=32120+(d<<1<<2)|0;a=c[8020]|0;d=1<<d;if(a&d){d=b+8|0;a=c[d>>2]|0;if(a>>>0<(c[8024]|0)>>>0)ra();else{p=d;q=a}}else{c[8020]=a|d;p=b+8|0;q=b}c[p>>2]=r;c[q+12>>2]=r;c[r+8>>2]=q;c[r+12>>2]=b;return}d=f>>>8;if(d)if(f>>>0>16777215)b=31;else{p=(d+1048320|0)>>>16&8;q=d<<p;o=(q+520192|0)>>>16&4;q=q<<o;b=(q+245760|0)>>>16&2;b=14-(o|p|b)+(q<<b>>>15)|0;b=f>>>(b+7|0)&1|b<<1}else b=0;e=32384+(b<<2)|0;c[r+28>>2]=b;c[r+20>>2]=0;c[r+16>>2]=0;d=c[8021]|0;a=1<<b;if(!(d&a)){c[8021]=d|a;c[e>>2]=r;c[r+24>>2]=e;c[r+12>>2]=r;c[r+8>>2]=r;return}b=f<<((b|0)==31?0:25-(b>>>1)|0);e=c[e>>2]|0;while(1){if((c[e+4>>2]&-8|0)==(f|0)){d=127;break}a=e+16+(b>>>31<<2)|0;d=c[a>>2]|0;if(!d){d=124;break}else{b=b<<1;e=d}}if((d|0)==124){if(a>>>0<(c[8024]|0)>>>0)ra();c[a>>2]=r;c[r+24>>2]=e;c[r+12>>2]=r;c[r+8>>2]=r;return}else if((d|0)==127){d=e+8|0;a=c[d>>2]|0;q=c[8024]|0;if(!(a>>>0>=q>>>0&e>>>0>=q>>>0))ra();c[a+12>>2]=r;c[d>>2]=r;c[r+8>>2]=a;c[r+12>>2]=e;c[r+24>>2]=0;return}}function Bd(){}function Cd(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;d=b-d-(c>>>0>a>>>0|0)>>>0;return (C=d,a-c>>>0|0)|0}function Dd(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;c=a+c>>>0;return (C=b+d+(c>>>0<a>>>0|0)>>>0,c|0)|0}function Ed(a,b,c){a=a|0;b=b|0;c=c|0;if((c|0)<32){C=b>>c;return a>>>c|(b&(1<<c)-1)<<32-c}C=(b|0)<0?-1:0;return b>>c-32|0}function Fd(b,d,e){b=b|0;d=d|0;e=e|0;var f=0,g=0,h=0,i=0;f=b+e|0;if((e|0)>=20){d=d&255;h=b&3;i=d|d<<8|d<<16|d<<24;g=f&~3;if(h){h=b+4-h|0;while((b|0)<(h|0)){a[b>>0]=d;b=b+1|0}}while((b|0)<(g|0)){c[b>>2]=i;b=b+4|0}}while((b|0)<(f|0)){a[b>>0]=d;b=b+1|0}return b-e|0}function Gd(a,b,c){a=a|0;b=b|0;c=c|0;if((c|0)<32){C=b>>>c;return a>>>c|(b&(1<<c)-1)<<32-c}C=0;return b>>>c-32|0}function Hd(a,b,c){a=a|0;b=b|0;c=c|0;if((c|0)<32){C=b<<c|(a&(1<<c)-1<<32-c)>>>32-c;return a<<c}C=a<<c-32;return 0}function Id(b,d,e){b=b|0;d=d|0;e=e|0;var f=0;if((e|0)>=4096)return va(b|0,d|0,e|0)|0;f=b|0;if((b&3)==(d&3)){while(b&3){if(!e)return f|0;a[b>>0]=a[d>>0]|0;b=b+1|0;d=d+1|0;e=e-1|0}while((e|0)>=4){c[b>>2]=c[d>>2];b=b+4|0;d=d+4|0;e=e-4|0}}while((e|0)>0){a[b>>0]=a[d>>0]|0;b=b+1|0;d=d+1|0;e=e-1|0}return f|0}function Jd(b,c,d){b=b|0;c=c|0;d=d|0;var e=0;if((c|0)<(b|0)&(b|0)<(c+d|0)){e=b;c=c+d|0;b=b+d|0;while((d|0)>0){b=b-1|0;c=c-1|0;d=d-1|0;a[b>>0]=a[c>>0]|0}b=e}else Id(b,c,d)|0;return b|0}function Kd(b){b=b|0;var c=0;c=a[m+(b&255)>>0]|0;if((c|0)<8)return c|0;c=a[m+(b>>8&255)>>0]|0;if((c|0)<8)return c+8|0;c=a[m+(b>>16&255)>>0]|0;if((c|0)<8)return c+16|0;return (a[m+(b>>>24)>>0]|0)+24|0}function Ld(a,b){a=a|0;b=b|0;var c=0,d=0,e=0,f=0;f=a&65535;e=b&65535;c=_(e,f)|0;d=a>>>16;a=(c>>>16)+(_(e,d)|0)|0;e=b>>>16;b=_(e,f)|0;return (C=(a>>>16)+(_(e,d)|0)+(((a&65535)+b|0)>>>16)|0,a+b<<16|c&65535|0)|0}function Md(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;var e=0,f=0,g=0,h=0,i=0,j=0;j=b>>31|((b|0)<0?-1:0)<<1;i=((b|0)<0?-1:0)>>31|((b|0)<0?-1:0)<<1;f=d>>31|((d|0)<0?-1:0)<<1;e=((d|0)<0?-1:0)>>31|((d|0)<0?-1:0)<<1;h=Cd(j^a,i^b,j,i)|0;g=C;a=f^j;b=e^i;return Cd((Rd(h,g,Cd(f^c,e^d,f,e)|0,C,0)|0)^a,C^b,a,b)|0}function Nd(a,b,d,e){a=a|0;b=b|0;d=d|0;e=e|0;var f=0,g=0,h=0,j=0,k=0,l=0;f=i;i=i+16|0;j=f|0;h=b>>31|((b|0)<0?-1:0)<<1;g=((b|0)<0?-1:0)>>31|((b|0)<0?-1:0)<<1;l=e>>31|((e|0)<0?-1:0)<<1;k=((e|0)<0?-1:0)>>31|((e|0)<0?-1:0)<<1;a=Cd(h^a,g^b,h,g)|0;b=C;Rd(a,b,Cd(l^d,k^e,l,k)|0,C,j)|0;e=Cd(c[j>>2]^h,c[j+4>>2]^g,h,g)|0;d=C;i=f;return (C=d,e)|0}function Od(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;var e=0,f=0;e=a;f=c;c=Ld(e,f)|0;a=C;return (C=(_(b,f)|0)+(_(d,e)|0)+a|a&0,c|0|0)|0}function Pd(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;return Rd(a,b,c,d,0)|0}function Qd(a,b,d,e){a=a|0;b=b|0;d=d|0;e=e|0;var f=0,g=0;g=i;i=i+16|0;f=g|0;Rd(a,b,d,e,f)|0;i=g;return (C=c[f+4>>2]|0,c[f>>2]|0)|0}function Rd(a,b,d,e,f){a=a|0;b=b|0;d=d|0;e=e|0;f=f|0;var g=0,h=0,i=0,j=0,k=0,l=0,m=0,n=0,o=0,p=0;l=a;j=b;k=j;h=d;n=e;i=n;if(!k){g=(f|0)!=0;if(!i){if(g){c[f>>2]=(l>>>0)%(h>>>0);c[f+4>>2]=0}n=0;f=(l>>>0)/(h>>>0)>>>0;return (C=n,f)|0}else{if(!g){n=0;f=0;return (C=n,f)|0}c[f>>2]=a|0;c[f+4>>2]=b&0;n=0;f=0;return (C=n,f)|0}}g=(i|0)==0;do if(h){if(!g){g=(aa(i|0)|0)-(aa(k|0)|0)|0;if(g>>>0<=31){m=g+1|0;i=31-g|0;b=g-31>>31;h=m;a=l>>>(m>>>0)&b|k<<i;b=k>>>(m>>>0)&b;g=0;i=l<<i;break}if(!f){n=0;f=0;return (C=n,f)|0}c[f>>2]=a|0;c[f+4>>2]=j|b&0;n=0;f=0;return (C=n,f)|0}g=h-1|0;if(g&h){i=(aa(h|0)|0)+33-(aa(k|0)|0)|0;p=64-i|0;m=32-i|0;j=m>>31;o=i-32|0;b=o>>31;h=i;a=m-1>>31&k>>>(o>>>0)|(k<<m|l>>>(i>>>0))&b;b=b&k>>>(i>>>0);g=l<<p&j;i=(k<<p|l>>>(o>>>0))&j|l<<m&i-33>>31;break}if(f){c[f>>2]=g&l;c[f+4>>2]=0}if((h|0)==1){o=j|b&0;p=a|0|0;return (C=o,p)|0}else{p=Kd(h|0)|0;o=k>>>(p>>>0)|0;p=k<<32-p|l>>>(p>>>0)|0;return (C=o,p)|0}}else{if(g){if(f){c[f>>2]=(k>>>0)%(h>>>0);c[f+4>>2]=0}o=0;p=(k>>>0)/(h>>>0)>>>0;return (C=o,p)|0}if(!l){if(f){c[f>>2]=0;c[f+4>>2]=(k>>>0)%(i>>>0)}o=0;p=(k>>>0)/(i>>>0)>>>0;return (C=o,p)|0}g=i-1|0;if(!(g&i)){if(f){c[f>>2]=a|0;c[f+4>>2]=g&k|b&0}o=0;p=k>>>((Kd(i|0)|0)>>>0);return (C=o,p)|0}g=(aa(i|0)|0)-(aa(k|0)|0)|0;if(g>>>0<=30){b=g+1|0;i=31-g|0;h=b;a=k<<i|l>>>(b>>>0);b=k>>>(b>>>0);g=0;i=l<<i;break}if(!f){o=0;p=0;return (C=o,p)|0}c[f>>2]=a|0;c[f+4>>2]=j|b&0;o=0;p=0;return (C=o,p)|0}while(0);if(!h){k=i;j=0;i=0}else{m=d|0|0;l=n|e&0;k=Dd(m|0,l|0,-1,-1)|0;d=C;j=i;i=0;do{e=j;j=g>>>31|j<<1;g=i|g<<1;e=a<<1|e>>>31|0;n=a>>>31|b<<1|0;Cd(k,d,e,n)|0;p=C;o=p>>31|((p|0)<0?-1:0)<<1;i=o&1;a=Cd(e,n,o&m,(((p|0)<0?-1:0)>>31|((p|0)<0?-1:0)<<1)&l)|0;b=C;h=h-1|0}while((h|0)!=0);k=j;j=0}h=0;if(f){c[f>>2]=a;c[f+4>>2]=b}o=(g|0)>>>31|(k|h)<<1|(h<<1|g>>>31)&0|j;p=(g<<1|0>>>31)&-2|i;return (C=o,p)|0}function Sd(a){a=a|0;return Da[a&31]()|0}function Td(){return ea(0)|0}function Ud(){return ea(1)|0}function Vd(){return ea(2)|0}function Wd(){return ea(3)|0}function Xd(){return ea(4)|0}function Yd(){return ea(5)|0}function Zd(){return ea(6)|0}function _d(){return ea(7)|0}function $d(a,b){a=a|0;b=b|0;return Ea[a&31](b|0)|0}function ae(a){a=a|0;return ga(0,a|0)|0}function be(a){a=a|0;return ga(1,a|0)|0}function ce(a){a=a|0;return ga(2,a|0)|0}function de(a){a=a|0;return ga(3,a|0)|0}function ee(a){a=a|0;return ga(4,a|0)|0}function fe(a){a=a|0;return ga(5,a|0)|0}function ge(a){a=a|0;return ga(6,a|0)|0}function he(a){a=a|0;return ga(7,a|0)|0}function ie(a,b,c,d){a=a|0;b=b|0;c=c|0;d=d|0;return Fa[a&31](b|0,c|0,d|0)|0}function je(a,b,c){a=a|0;b=b|0;c=c|0;return ia(0,a|0,b|0,c|0)|0}function ke(a,b,c){a=a|0;b=b|0;c=c|0;return ia(1,a|0,b|0,c|0)|0}function le(a,b,c){a=a|0;b=b|0;c=c|0;return ia(2,a|0,b|0,c|0)|0}function me(a,b,c){a=a|0;b=b|0;c=c|0;return ia(3,a|0,b|0,c|0)|0}function ne(a,b,c){a=a|0;b=b|0;c=c|0;return ia(4,a|0,b|0,c|0)|0}function oe(a,b,c){a=a|0;b=b|0;c=c|0;return ia(5,a|0,b|0,c|0)|0}function pe(a,b,c){a=a|0;b=b|0;c=c|0;return ia(6,a|0,b|0,c|0)|0}function qe(a,b,c){a=a|0;b=b|0;c=c|0;return ia(7,a|0,b|0,c|0)|0}function re(a,b){a=a|0;b=b|0;Ga[a&31](b|0)}function se(a){a=a|0;ka(0,a|0)}function te(a){a=a|0;ka(1,a|0)}function ue(a){a=a|0;ka(2,a|0)}function ve(a){a=a|0;ka(3,a|0)}function we(a){a=a|0;ka(4,a|0)}function xe(a){a=a|0;ka(5,a|0)}function ye(a){a=a|0;ka(6,a|0)}function ze(a){a=a|0;ka(7,a|0)}function Ae(){ba(0);return 0}function Be(a){a=a|0;ba(1);return 0}function Ce(a,b,c){a=a|0;b=b|0;c=c|0;ba(2);return 0}function De(a){a=a|0;ba(3)}\n\n// EMSCRIPTEN_END_FUNCS\nvar Da=[Ae,Ae,Td,Ae,Ud,Ae,Vd,Ae,Wd,Ae,Xd,Ae,Yd,Ae,Zd,Ae,_d,Ae,Ae,Ae,Ae,Ae,Ae,Ae,Ae,Ae,Ae,Ae,Ae,Ae,Ae,Ae];var Ea=[Be,Be,ae,Be,be,Be,ce,Be,de,Be,ee,Be,fe,Be,ge,Be,he,Be,pd,Be,Be,Be,Be,Be,Be,Be,Be,Be,Be,Be,Be,Be];var Fa=[Ce,Ce,je,Ce,ke,Ce,le,Ce,me,Ce,ne,Ce,oe,Ce,pe,Ce,qe,Ce,sd,qd,rd,Ce,Ce,Ce,Ce,Ce,Ce,Ce,Ce,Ce,Ce,Ce];var Ga=[De,De,se,De,te,De,ue,De,ve,De,we,De,xe,De,ye,De,ze,De,wd,De,De,De,De,De,De,De,De,De,De,De,De,De];return{_sodium_library_version_minor:jd,_crypto_onetimeauth_bytes:Jb,_sodium_version_string:hd,_sodium_hex2bin:gd,_crypto_pwhash_scryptsalsa208sha256_memlimit_sensitive:dc,_bitshift64Lshr:Gd,_crypto_pwhash_scryptsalsa208sha256:ec,_crypto_box_noncebytes:Za,_crypto_box_beforenm:bb,_crypto_scalarmult_base:mc,_crypto_auth_bytes:Qa,_crypto_sign_open:Fc,_memcpy:Id,_crypto_box_seed_keypair:$a,_crypto_pwhash_scryptsalsa208sha256_memlimit_interactive:bc,_crypto_box_open_easy_afternm:ib,_crypto_sign_ed25519_sk_to_curve25519:Uc,_sodium_memzero:ed,_crypto_box_seal:kb,_free:zd,_crypto_shorthash:xc,_crypto_auth_keybytes:Ra,_crypto_pwhash_scryptsalsa208sha256_saltbytes:Zb,_crypto_sign_seedbytes:zc,_crypto_box_detached_afternm:cb,_crypto_auth:Sa,_randombytes_random:_c,_crypto_sign_keypair:Dc,_crypto_shorthash_keybytes:wc,_crypto_generichash_statebytes:vb,_crypto_pwhash_scryptsalsa208sha256_str_verify:gc,_crypto_generichash_init:xb,_crypto_generichash_keybytes_max:tb,_crypto_sign_ed25519_pk_to_curve25519:Tc,_crypto_box_beforenmbytes:Ya,_crypto_generichash:wb,_sodium_library_version_major:id,_randombytes_stir:$c,_randombytes_close:cd,_crypto_onetimeauth_keybytes:Kb,_crypto_onetimeauth:Lb,_crypto_shorthash_bytes:vc,_crypto_box_secretkeybytes:Xa,_crypto_onetimeauth_update:Ob,_crypto_pwhash_scryptsalsa208sha256_ll:Wb,_crypto_box_detached:db,_randombytes_buf:bd,_crypto_pwhash_scryptsalsa208sha256_str:fc,_bitshift64Ashr:Ed,_crypto_box_open_detached:hb,_crypto_scalarmult_bytes:kc,_crypto_auth_verify:Ta,_crypto_box_seal_open:lb,_crypto_secretbox_detached:rc,_crypto_secretbox_easy:sc,_crypto_pwhash_scryptsalsa208sha256_strbytes:_b,_memset:Fd,_crypto_box_open_detached_afternm:gb,_crypto_box_sealbytes:mb,_i64Subtract:Cd,_crypto_pwhash_scryptsalsa208sha256_strprefix:$b,_crypto_box_seedbytes:Va,_crypto_hash:Cb,_crypto_box_easy_afternm:eb,_crypto_box_macbytes:_a,_crypto_box_publickeybytes:Wa,_sodium_bin2hex:fd,_crypto_sign_secretkeybytes:Bc,_crypto_scalarmult_scalarbytes:lc,_crypto_onetimeauth_statebytes:Ib,_crypto_generichash_keybytes_min:sb,_malloc:yd,_memmove:Jd,_crypto_sign:Ec,_crypto_secretbox_noncebytes:pc,_randombytes_set_implementation:Zc,_crypto_box_keypair:ab,_crypto_generichash_keybytes:ub,_crypto_generichash_bytes_min:pb,_sodium_init:dd,_crypto_secretbox_macbytes:qc,_crypto_secretbox_keybytes:oc,_bitshift64Shl:Hd,_crypto_hash_bytes:Bb,_fflush:td,_crypto_generichash_bytes:rb,_crypto_generichash_bytes_max:qb,_crypto_secretbox_open_detached:tc,_crypto_sign_verify_detached:Hc,_crypto_onetimeauth_verify:Mb,_crypto_box_open_easy:jb,_crypto_pwhash_scryptsalsa208sha256_opslimit_sensitive:cc,_crypto_sign_publickeybytes:Ac,_i64Add:Dd,_crypto_sign_bytes:yc,_crypto_generichash_update:yb,_crypto_scalarmult:nc,_crypto_sign_detached:Gc,_crypto_box_easy:fb,___errno_location:od,_crypto_onetimeauth_final:Pb,_crypto_secretbox_open_easy:uc,_crypto_generichash_final:zb,_randombytes_uniform:ad,_crypto_sign_seed_keypair:Cc,_crypto_pwhash_scryptsalsa208sha256_opslimit_interactive:ac,_crypto_onetimeauth_init:Nb,runPostSets:Bd,stackAlloc:Ha,stackSave:Ia,stackRestore:Ja,establishStackSpace:Ka,setThrew:La,setTempRet0:Oa,getTempRet0:Pa,dynCall_i:Sd,dynCall_ii:$d,dynCall_iiii:ie,dynCall_vi:re}})\n\n\n// EMSCRIPTEN_END_ASM\n(Module.asmGlobalArg,Module.asmLibraryArg,buffer);var _sodium_library_version_minor=Module[\"_sodium_library_version_minor\"]=asm[\"_sodium_library_version_minor\"];var _crypto_onetimeauth_bytes=Module[\"_crypto_onetimeauth_bytes\"]=asm[\"_crypto_onetimeauth_bytes\"];var _crypto_pwhash_scryptsalsa208sha256_memlimit_sensitive=Module[\"_crypto_pwhash_scryptsalsa208sha256_memlimit_sensitive\"]=asm[\"_crypto_pwhash_scryptsalsa208sha256_memlimit_sensitive\"];var _bitshift64Lshr=Module[\"_bitshift64Lshr\"]=asm[\"_bitshift64Lshr\"];var _crypto_pwhash_scryptsalsa208sha256=Module[\"_crypto_pwhash_scryptsalsa208sha256\"]=asm[\"_crypto_pwhash_scryptsalsa208sha256\"];var _crypto_box_noncebytes=Module[\"_crypto_box_noncebytes\"]=asm[\"_crypto_box_noncebytes\"];var _crypto_box_beforenm=Module[\"_crypto_box_beforenm\"]=asm[\"_crypto_box_beforenm\"];var _crypto_scalarmult_base=Module[\"_crypto_scalarmult_base\"]=asm[\"_crypto_scalarmult_base\"];var _crypto_auth_bytes=Module[\"_crypto_auth_bytes\"]=asm[\"_crypto_auth_bytes\"];var _crypto_sign_open=Module[\"_crypto_sign_open\"]=asm[\"_crypto_sign_open\"];var _memcpy=Module[\"_memcpy\"]=asm[\"_memcpy\"];var _crypto_box_seed_keypair=Module[\"_crypto_box_seed_keypair\"]=asm[\"_crypto_box_seed_keypair\"];var _crypto_pwhash_scryptsalsa208sha256_memlimit_interactive=Module[\"_crypto_pwhash_scryptsalsa208sha256_memlimit_interactive\"]=asm[\"_crypto_pwhash_scryptsalsa208sha256_memlimit_interactive\"];var _crypto_box_open_easy_afternm=Module[\"_crypto_box_open_easy_afternm\"]=asm[\"_crypto_box_open_easy_afternm\"];var _crypto_sign_ed25519_sk_to_curve25519=Module[\"_crypto_sign_ed25519_sk_to_curve25519\"]=asm[\"_crypto_sign_ed25519_sk_to_curve25519\"];var _sodium_memzero=Module[\"_sodium_memzero\"]=asm[\"_sodium_memzero\"];var _crypto_box_seal=Module[\"_crypto_box_seal\"]=asm[\"_crypto_box_seal\"];var _free=Module[\"_free\"]=asm[\"_free\"];var runPostSets=Module[\"runPostSets\"]=asm[\"runPostSets\"];var _crypto_shorthash=Module[\"_crypto_shorthash\"]=asm[\"_crypto_shorthash\"];var _crypto_auth_keybytes=Module[\"_crypto_auth_keybytes\"]=asm[\"_crypto_auth_keybytes\"];var _crypto_pwhash_scryptsalsa208sha256_saltbytes=Module[\"_crypto_pwhash_scryptsalsa208sha256_saltbytes\"]=asm[\"_crypto_pwhash_scryptsalsa208sha256_saltbytes\"];var _crypto_sign_seedbytes=Module[\"_crypto_sign_seedbytes\"]=asm[\"_crypto_sign_seedbytes\"];var _crypto_box_detached_afternm=Module[\"_crypto_box_detached_afternm\"]=asm[\"_crypto_box_detached_afternm\"];var _crypto_auth=Module[\"_crypto_auth\"]=asm[\"_crypto_auth\"];var _randombytes_random=Module[\"_randombytes_random\"]=asm[\"_randombytes_random\"];var _crypto_sign_keypair=Module[\"_crypto_sign_keypair\"]=asm[\"_crypto_sign_keypair\"];var _crypto_generichash_keybytes_min=Module[\"_crypto_generichash_keybytes_min\"]=asm[\"_crypto_generichash_keybytes_min\"];var _crypto_generichash_statebytes=Module[\"_crypto_generichash_statebytes\"]=asm[\"_crypto_generichash_statebytes\"];var _crypto_pwhash_scryptsalsa208sha256_str_verify=Module[\"_crypto_pwhash_scryptsalsa208sha256_str_verify\"]=asm[\"_crypto_pwhash_scryptsalsa208sha256_str_verify\"];var _sodium_version_string=Module[\"_sodium_version_string\"]=asm[\"_sodium_version_string\"];var _crypto_generichash_keybytes_max=Module[\"_crypto_generichash_keybytes_max\"]=asm[\"_crypto_generichash_keybytes_max\"];var _crypto_sign_ed25519_pk_to_curve25519=Module[\"_crypto_sign_ed25519_pk_to_curve25519\"]=asm[\"_crypto_sign_ed25519_pk_to_curve25519\"];var _crypto_sign_publickeybytes=Module[\"_crypto_sign_publickeybytes\"]=asm[\"_crypto_sign_publickeybytes\"];var _crypto_box_beforenmbytes=Module[\"_crypto_box_beforenmbytes\"]=asm[\"_crypto_box_beforenmbytes\"];var _crypto_generichash=Module[\"_crypto_generichash\"]=asm[\"_crypto_generichash\"];var _sodium_library_version_major=Module[\"_sodium_library_version_major\"]=asm[\"_sodium_library_version_major\"];var _randombytes_stir=Module[\"_randombytes_stir\"]=asm[\"_randombytes_stir\"];var _crypto_shorthash_keybytes=Module[\"_crypto_shorthash_keybytes\"]=asm[\"_crypto_shorthash_keybytes\"];var _randombytes_close=Module[\"_randombytes_close\"]=asm[\"_randombytes_close\"];var _crypto_onetimeauth_keybytes=Module[\"_crypto_onetimeauth_keybytes\"]=asm[\"_crypto_onetimeauth_keybytes\"];var _crypto_onetimeauth=Module[\"_crypto_onetimeauth\"]=asm[\"_crypto_onetimeauth\"];var _crypto_shorthash_bytes=Module[\"_crypto_shorthash_bytes\"]=asm[\"_crypto_shorthash_bytes\"];var _crypto_box_secretkeybytes=Module[\"_crypto_box_secretkeybytes\"]=asm[\"_crypto_box_secretkeybytes\"];var _crypto_onetimeauth_update=Module[\"_crypto_onetimeauth_update\"]=asm[\"_crypto_onetimeauth_update\"];var _crypto_pwhash_scryptsalsa208sha256_ll=Module[\"_crypto_pwhash_scryptsalsa208sha256_ll\"]=asm[\"_crypto_pwhash_scryptsalsa208sha256_ll\"];var _crypto_box_detached=Module[\"_crypto_box_detached\"]=asm[\"_crypto_box_detached\"];var _randombytes_buf=Module[\"_randombytes_buf\"]=asm[\"_randombytes_buf\"];var _crypto_pwhash_scryptsalsa208sha256_strbytes=Module[\"_crypto_pwhash_scryptsalsa208sha256_strbytes\"]=asm[\"_crypto_pwhash_scryptsalsa208sha256_strbytes\"];var _bitshift64Ashr=Module[\"_bitshift64Ashr\"]=asm[\"_bitshift64Ashr\"];var _crypto_box_open_detached=Module[\"_crypto_box_open_detached\"]=asm[\"_crypto_box_open_detached\"];var _crypto_scalarmult_bytes=Module[\"_crypto_scalarmult_bytes\"]=asm[\"_crypto_scalarmult_bytes\"];var _crypto_auth_verify=Module[\"_crypto_auth_verify\"]=asm[\"_crypto_auth_verify\"];var _crypto_sign_detached=Module[\"_crypto_sign_detached\"]=asm[\"_crypto_sign_detached\"];var _crypto_secretbox_detached=Module[\"_crypto_secretbox_detached\"]=asm[\"_crypto_secretbox_detached\"];var _crypto_secretbox_easy=Module[\"_crypto_secretbox_easy\"]=asm[\"_crypto_secretbox_easy\"];var _crypto_pwhash_scryptsalsa208sha256_str=Module[\"_crypto_pwhash_scryptsalsa208sha256_str\"]=asm[\"_crypto_pwhash_scryptsalsa208sha256_str\"];var _memset=Module[\"_memset\"]=asm[\"_memset\"];var _crypto_box_open_detached_afternm=Module[\"_crypto_box_open_detached_afternm\"]=asm[\"_crypto_box_open_detached_afternm\"];var _crypto_box_sealbytes=Module[\"_crypto_box_sealbytes\"]=asm[\"_crypto_box_sealbytes\"];var _i64Subtract=Module[\"_i64Subtract\"]=asm[\"_i64Subtract\"];var _crypto_pwhash_scryptsalsa208sha256_strprefix=Module[\"_crypto_pwhash_scryptsalsa208sha256_strprefix\"]=asm[\"_crypto_pwhash_scryptsalsa208sha256_strprefix\"];var _crypto_box_seedbytes=Module[\"_crypto_box_seedbytes\"]=asm[\"_crypto_box_seedbytes\"];var _crypto_hash=Module[\"_crypto_hash\"]=asm[\"_crypto_hash\"];var _crypto_box_easy_afternm=Module[\"_crypto_box_easy_afternm\"]=asm[\"_crypto_box_easy_afternm\"];var _crypto_box_macbytes=Module[\"_crypto_box_macbytes\"]=asm[\"_crypto_box_macbytes\"];var _crypto_box_publickeybytes=Module[\"_crypto_box_publickeybytes\"]=asm[\"_crypto_box_publickeybytes\"];var _sodium_bin2hex=Module[\"_sodium_bin2hex\"]=asm[\"_sodium_bin2hex\"];var _crypto_sign_secretkeybytes=Module[\"_crypto_sign_secretkeybytes\"]=asm[\"_crypto_sign_secretkeybytes\"];var _crypto_scalarmult_scalarbytes=Module[\"_crypto_scalarmult_scalarbytes\"]=asm[\"_crypto_scalarmult_scalarbytes\"];var _crypto_onetimeauth_statebytes=Module[\"_crypto_onetimeauth_statebytes\"]=asm[\"_crypto_onetimeauth_statebytes\"];var _crypto_generichash_bytes_min=Module[\"_crypto_generichash_bytes_min\"]=asm[\"_crypto_generichash_bytes_min\"];var _malloc=Module[\"_malloc\"]=asm[\"_malloc\"];var _crypto_secretbox_open_easy=Module[\"_crypto_secretbox_open_easy\"]=asm[\"_crypto_secretbox_open_easy\"];var _crypto_sign=Module[\"_crypto_sign\"]=asm[\"_crypto_sign\"];var _crypto_secretbox_noncebytes=Module[\"_crypto_secretbox_noncebytes\"]=asm[\"_crypto_secretbox_noncebytes\"];var _randombytes_set_implementation=Module[\"_randombytes_set_implementation\"]=asm[\"_randombytes_set_implementation\"];var _crypto_box_keypair=Module[\"_crypto_box_keypair\"]=asm[\"_crypto_box_keypair\"];var _crypto_generichash_keybytes=Module[\"_crypto_generichash_keybytes\"]=asm[\"_crypto_generichash_keybytes\"];var _sodium_hex2bin=Module[\"_sodium_hex2bin\"]=asm[\"_sodium_hex2bin\"];var _sodium_init=Module[\"_sodium_init\"]=asm[\"_sodium_init\"];var _crypto_secretbox_macbytes=Module[\"_crypto_secretbox_macbytes\"]=asm[\"_crypto_secretbox_macbytes\"];var _crypto_secretbox_keybytes=Module[\"_crypto_secretbox_keybytes\"]=asm[\"_crypto_secretbox_keybytes\"];var _bitshift64Shl=Module[\"_bitshift64Shl\"]=asm[\"_bitshift64Shl\"];var _crypto_hash_bytes=Module[\"_crypto_hash_bytes\"]=asm[\"_crypto_hash_bytes\"];var _fflush=Module[\"_fflush\"]=asm[\"_fflush\"];var _crypto_generichash_bytes=Module[\"_crypto_generichash_bytes\"]=asm[\"_crypto_generichash_bytes\"];var _crypto_generichash_bytes_max=Module[\"_crypto_generichash_bytes_max\"]=asm[\"_crypto_generichash_bytes_max\"];var _crypto_secretbox_open_detached=Module[\"_crypto_secretbox_open_detached\"]=asm[\"_crypto_secretbox_open_detached\"];var _crypto_sign_verify_detached=Module[\"_crypto_sign_verify_detached\"]=asm[\"_crypto_sign_verify_detached\"];var _crypto_onetimeauth_verify=Module[\"_crypto_onetimeauth_verify\"]=asm[\"_crypto_onetimeauth_verify\"];var _crypto_box_open_easy=Module[\"_crypto_box_open_easy\"]=asm[\"_crypto_box_open_easy\"];var _crypto_pwhash_scryptsalsa208sha256_opslimit_sensitive=Module[\"_crypto_pwhash_scryptsalsa208sha256_opslimit_sensitive\"]=asm[\"_crypto_pwhash_scryptsalsa208sha256_opslimit_sensitive\"];var _crypto_generichash_init=Module[\"_crypto_generichash_init\"]=asm[\"_crypto_generichash_init\"];var _i64Add=Module[\"_i64Add\"]=asm[\"_i64Add\"];var _crypto_sign_bytes=Module[\"_crypto_sign_bytes\"]=asm[\"_crypto_sign_bytes\"];var _crypto_generichash_update=Module[\"_crypto_generichash_update\"]=asm[\"_crypto_generichash_update\"];var _crypto_scalarmult=Module[\"_crypto_scalarmult\"]=asm[\"_crypto_scalarmult\"];var _crypto_box_seal_open=Module[\"_crypto_box_seal_open\"]=asm[\"_crypto_box_seal_open\"];var _crypto_box_easy=Module[\"_crypto_box_easy\"]=asm[\"_crypto_box_easy\"];var ___errno_location=Module[\"___errno_location\"]=asm[\"___errno_location\"];var _crypto_onetimeauth_final=Module[\"_crypto_onetimeauth_final\"]=asm[\"_crypto_onetimeauth_final\"];var _memmove=Module[\"_memmove\"]=asm[\"_memmove\"];var _crypto_generichash_final=Module[\"_crypto_generichash_final\"]=asm[\"_crypto_generichash_final\"];var _randombytes_uniform=Module[\"_randombytes_uniform\"]=asm[\"_randombytes_uniform\"];var _crypto_sign_seed_keypair=Module[\"_crypto_sign_seed_keypair\"]=asm[\"_crypto_sign_seed_keypair\"];var _crypto_pwhash_scryptsalsa208sha256_opslimit_interactive=Module[\"_crypto_pwhash_scryptsalsa208sha256_opslimit_interactive\"]=asm[\"_crypto_pwhash_scryptsalsa208sha256_opslimit_interactive\"];var _crypto_onetimeauth_init=Module[\"_crypto_onetimeauth_init\"]=asm[\"_crypto_onetimeauth_init\"];var dynCall_i=Module[\"dynCall_i\"]=asm[\"dynCall_i\"];var dynCall_ii=Module[\"dynCall_ii\"]=asm[\"dynCall_ii\"];var dynCall_iiii=Module[\"dynCall_iiii\"]=asm[\"dynCall_iiii\"];var dynCall_vi=Module[\"dynCall_vi\"]=asm[\"dynCall_vi\"];Runtime.stackAlloc=asm[\"stackAlloc\"];Runtime.stackSave=asm[\"stackSave\"];Runtime.stackRestore=asm[\"stackRestore\"];Runtime.establishStackSpace=asm[\"establishStackSpace\"];Runtime.setTempRet0=asm[\"setTempRet0\"];Runtime.getTempRet0=asm[\"getTempRet0\"];function ExitStatus(status){this.name=\"ExitStatus\";this.message=\"Program terminated with exit(\"+status+\")\";this.status=status}ExitStatus.prototype=new Error;ExitStatus.prototype.constructor=ExitStatus;var initialStackTop;var preloadStartTime=null;var calledMain=false;dependenciesFulfilled=function runCaller(){if(!Module[\"calledRun\"])run();if(!Module[\"calledRun\"])dependenciesFulfilled=runCaller};Module[\"callMain\"]=Module.callMain=function callMain(args){assert(runDependencies==0,\"cannot call main when async dependencies remain! (listen on __ATMAIN__)\");assert(__ATPRERUN__.length==0,\"cannot call main when preRun functions remain to be called\");args=args||[];ensureInitRuntime();var argc=args.length+1;function pad(){for(var i=0;i<4-1;i++){argv.push(0)}}var argv=[allocate(intArrayFromString(Module[\"thisProgram\"]),\"i8\",ALLOC_NORMAL)];pad();for(var i=0;i<argc-1;i=i+1){argv.push(allocate(intArrayFromString(args[i]),\"i8\",ALLOC_NORMAL));pad()}argv.push(0);argv=allocate(argv,\"i32\",ALLOC_NORMAL);try{var ret=Module[\"_main\"](argc,argv,0);exit(ret,true)}catch(e){if(e instanceof ExitStatus){return}else if(e==\"SimulateInfiniteLoop\"){Module[\"noExitRuntime\"]=true;return}else{if(e&&typeof e===\"object\"&&e.stack)Module.printErr(\"exception thrown: \"+[e,e.stack]);throw e}}finally{calledMain=true}};function run(args){args=args||Module[\"arguments\"];if(preloadStartTime===null)preloadStartTime=Date.now();if(runDependencies>0){return}preRun();if(runDependencies>0)return;if(Module[\"calledRun\"])return;function doRun(){if(Module[\"calledRun\"])return;Module[\"calledRun\"]=true;if(ABORT)return;ensureInitRuntime();preMain();if(Module[\"onRuntimeInitialized\"])Module[\"onRuntimeInitialized\"]();if(Module[\"_main\"]&&shouldRunNow)Module[\"callMain\"](args);postRun()}if(Module[\"setStatus\"]){Module[\"setStatus\"](\"Running...\");setTimeout((function(){setTimeout((function(){Module[\"setStatus\"](\"\")}),1);doRun()}),1)}else{doRun()}}Module[\"run\"]=Module.run=run;function exit(status,implicit){if(implicit&&Module[\"noExitRuntime\"]){return}if(Module[\"noExitRuntime\"]){}else{ABORT=true;EXITSTATUS=status;STACKTOP=initialStackTop;exitRuntime();if(Module[\"onExit\"])Module[\"onExit\"](status)}if(ENVIRONMENT_IS_NODE){process[\"stdout\"][\"once\"](\"drain\",(function(){process[\"exit\"](status)}));console.log(\" \");setTimeout((function(){process[\"exit\"](status)}),500)}else if(ENVIRONMENT_IS_SHELL&&typeof quit===\"function\"){quit(status)}throw new ExitStatus(status)}Module[\"exit\"]=Module.exit=exit;var abortDecorators=[];function abort(what){if(what!==undefined){Module.print(what);Module.printErr(what);what=JSON.stringify(what)}else{what=\"\"}ABORT=true;EXITSTATUS=1;var extra=\"\\nIf this abort() is unexpected, build with -s ASSERTIONS=1 which can give more information.\";var output=\"abort(\"+what+\") at \"+stackTrace()+extra;if(abortDecorators){abortDecorators.forEach((function(decorator){output=decorator(output,what)}))}throw output}Module[\"abort\"]=Module.abort=abort;if(Module[\"preInit\"]){if(typeof Module[\"preInit\"]==\"function\")Module[\"preInit\"]=[Module[\"preInit\"]];while(Module[\"preInit\"].length>0){Module[\"preInit\"].pop()()}}var shouldRunNow=true;if(Module[\"noInitialRun\"]){shouldRunNow=false}run()\n\n\n\n\n    return Module;\n});\n","'use strict';\n\n/**\n * Get the count of the longest repeating streak of\n * `character` in `value`.\n *\n * @example\n *   longestStreak('` foo `` bar `', '`') // 2\n *\n * @param {string} value - Content, coerced to string.\n * @param {string} character - Single character to look\n *   for.\n * @return {number} - Number of characters at the place\n *   where `character` occurs in its longest streak in\n *   `value`.\n * @throws {Error} - when `character` is not a single\n *   character.\n */\nfunction longestStreak(value, character) {\n    var count = 0;\n    var maximum = 0;\n    var index = -1;\n    var length;\n\n    value = String(value);\n    length = value.length;\n\n    if (typeof character !== 'string' || character.length !== 1) {\n        throw new Error('Expected character');\n    }\n\n    while (++index < length) {\n        if (value.charAt(index) === character) {\n            count++;\n\n            if (count > maximum) {\n                maximum = count;\n            }\n        } else {\n            count = 0;\n        }\n    }\n\n    return maximum;\n}\n\n/*\n * Expose.\n */\n\nmodule.exports = longestStreak;\n","\nvar looper = module.exports = function (fun) {\n  return function next (a, b, c) {\n    var loop = true, returned = false, sync = false\n    do {\n      sync = true; loop = false\n      fun.call(function (x, y, z) {\n        if(sync) {\n          a = x; b = y; c = z\n          loop = true\n        }\n        else\n          next(x, y, z)\n      }, a, b, c)\n      sync = false\n    } while(loop)\n  }\n}\n","\nexports.compare = function (a, b) {\n\n  if(Buffer.isBuffer(a)) {\n    var l = Math.min(a.length, b.length)\n    for(var i = 0; i < l; i++) {\n      var cmp = a[i] - b[i]\n      if(cmp) return cmp\n    }\n    return a.length - b.length\n  }\n\n  return a < b ? -1 : a > b ? 1 : 0\n}\n\nfunction has(obj, key) {\n  return Object.hasOwnProperty.call(obj, key)\n}\n\n// to be compatible with the current abstract-leveldown tests\n// nullish or empty strings.\n// I could use !!val but I want to permit numbers and booleans,\n// if possible.\n\nfunction isDef (val) {\n  return val !== undefined && val !== ''\n}\n\nfunction has (range, name) {\n  return Object.hasOwnProperty.call(range, name)\n}\n\nfunction hasKey(range, name) {\n  return Object.hasOwnProperty.call(range, name) && name\n}\n\nvar lowerBoundKey = exports.lowerBoundKey = function (range) {\n    return (\n       hasKey(range, 'gt')\n    || hasKey(range, 'gte')\n    || hasKey(range, 'min')\n    || (range.reverse ? hasKey(range, 'end') : hasKey(range, 'start'))\n    || undefined\n    )\n}\n\nvar lowerBound = exports.lowerBound = function (range) {\n  var k = lowerBoundKey(range)\n  return k && range[k]\n  return (\n      has(range, 'gt')                      ? range.gt\n    : has(range, 'gte')                     ? range.gte\n    : has(range, 'min')                     ? range.min\n    : has(range, 'start') && !range.reverse ? range.start\n    : has(range, 'end')   && range.reverse  ? range.end\n    :                                         undefined\n  )\n}\n\nexports.lowerBoundInclusive = function (range) {\n  return has(range, 'gt') ? false : true\n}\n\nexports.upperBoundInclusive =\n  function (range) {\n    return has(range, 'lt') || !range.minEx ? false : true\n  }\n\nvar lowerBoundExclusive = exports.lowerBoundExclusive =\n  function (range) {\n    return has(range, 'gt') || range.minEx ? true : false\n  }\n\nvar upperBoundExclusive = exports.upperBoundExclusive =\n  function (range) {\n    return has(range, 'lt') ? true : false\n  }\n\nvar upperBoundKey = exports.upperBoundKey = function (range) {\n    return (\n       hasKey(range, 'lt')\n    || hasKey(range, 'lte')\n    || hasKey(range, 'max')\n    || (range.reverse ? hasKey(range, 'start') : hasKey(range, 'end'))\n    || undefined\n    )\n}\n\nvar upperBound = exports.upperBound = function (range) {\n  var k = upperBoundKey(range)\n  return k && range[k]\n}\n\nfunction id (e) { return e }\n\nexports.toLtgt = function (range, _range, map, lower, upper) {\n  _range = _range || {}\n  map = map || id\n  var defaults = arguments.length > 3\n  var lb = exports.lowerBoundKey(range)\n  var ub = exports.upperBoundKey(range)\n  if(lb) {\n    if(lb === 'gt') _range.gt = map(range.gt)\n    else            _range.gte = map(range[lb])\n  }\n  else if(defaults)\n    _range.gte = map(lower)\n\n  if(ub) {\n    if(ub === 'lt') _range.lt = map(range.lt)\n    else            _range.lte = map(range[ub])\n  }\n  else if(defaults)\n    _range.lte = map(upper)\n\n  if(range.reverse != null)\n    _range.reverse = !!range.reverse\n\n  return _range\n}\n\nexports.contains = function (range, key, compare) {\n  compare = compare || exports.compare\n\n  var lb = lowerBound(range)\n  if(isDef(lb)) {\n    var cmp = compare(key, lb)\n    if(cmp < 0 || (cmp === 0 && lowerBoundExclusive(range)))\n      return false\n  }\n\n  var ub = upperBound(range)\n  if(isDef(ub)) {\n    var cmp = compare(key, ub)\n    if(cmp > 0 || (cmp === 0) && upperBoundExclusive(range))\n      return false\n  }\n\n  return true\n}\n\nexports.filter = function (range, compare) {\n  return function (key) {\n    return exports.contains(range, key, compare)\n  }\n}\n","\nmodule.exports = {\n  $count:\n    function (a, b) {\n      if(b === undefined) return (a||0)\n      return (a||0)+1\n    },\n  $sum:\n    function (a, b) {\n      if(b === undefined) return (a||0)\n      return (a||0)+(b||0)\n    },\n  $max:\n    function (a, b) {\n      if(b === undefined) a\n      if(a === undefined) return b\n      return Math.max(a, b)\n    },\n  $min:\n    function (a, b) {\n      if(b === undefined) a\n      if(a === undefined) return b\n      return Math.min(a, b)\n    },\n  $collect:\n    function (a, b) {\n      if(!a) a = a || []\n      if(!Array.isArray(a)) a = [a]\n      if(b == undefined) return a\n      a.push(b)\n      return a\n    }\n}\n","var u = require('./util')\nvar isBasic = u.isBasic\nvar isRange = u.isRange\nvar isString = u.isString\nvar isLtgt = u.isLtgt\nvar isObject = u.isObject\nvar isArray = u.isArray\nvar has = u.has\nvar map = u.map\n\nfunction exact(q) {\n  return function (v) {\n    return q === v\n  }\n}\nfunction prefix(p) {\n  if(isString(p))\n    return function (v) {\n      return isString(v) && v.substring(0, p.length) === p\n    }\n  if(isArray(p)) {\n    if(!p.every(isBasic))\n      throw new Error('{$prefix: array} must have exact elements in the array')\n    return function (v) {\n      if(!isArray(v) || v.length < p.length) return false\n      for(var i = 0; i < p.length; i++)\n        if(v[i] !== p[i]) return false\n      return true\n    }\n  }\n}\n\nfunction lt (q) {\n  return function (v) { return v < q }\n}\nfunction gt (q) {\n  return function (v) { return v > q }\n}\nfunction lte (q) {\n  return function (v) { return v <= q }\n}\nfunction gte (q) {\n  return function (v) { return v >= q }\n}\n\nfunction combine(f, g) {\n  if(!g) return f\n  return function (v) {\n    return f(v) && g(v)\n  }\n}\n\nfunction ltgt (q) {\n  var filter = null\n  if(has(q, '$lt'))  filter = lt(q.$lt)\n  if(has(q, '$lte')) filter = combine(lte(q.$lte), filter)\n  if(has(q, '$gt'))  filter = combine(gt(q.$gt), filter)\n  if(has(q, '$gte')) filter = combine(gte(q.$gte), filter)\n  return filter\n}\n\nfunction all (q) {\n  return function (v) {\n    if(v == null) return false\n    for(var k in q) if(!q[k](v[k])) return false\n    return true\n  }\n}\n\nfunction absent (v) {\n  return v == null\n}\n\nfunction never () { return false }\n\nfunction make (q) {\n  return (\n    isBasic(q)        ? exact(q)\n  : has(q, '$prefix') ? prefix(q.$prefix)\n  : isLtgt(q)         ? ltgt(q)\n  : u.isObject(q)\n    || u.isArray(q)   ? all(map(q, make))\n  : isNullish(q)      ? absent\n  :                     never\n  )\n}\n\nmodule.exports = make\n\n","var pull = require('pull-stream')\n\nvar filter = require('./filter')\nvar map = require('./map')\nvar reduce = require('./reduce')\nvar SinkThrough = require('pull-sink-through')\n\nfunction first (q) {\n  for(var k in q) return k\n}\n\nfunction get (q) {\n  var k = first(q)\n  var s = k.substring(1)\n  if(k[0] == '$' && exports[s]) return exports[s](q[k])\n  throw new Error('unknown function:'+ k)\n}\n\nfunction last (l) {\n  return l[l.length - 1]\n}\n\nexports = module.exports = function (q, cb) {\n  q = q.filter(Boolean)\n  if(last(q).$reduce && cb) {\n    return pull.apply(null,\n      q.slice(0, q.length - 1).map(get)\n        .concat(exports.reduce(last(q).$reduce, cb))\n    )\n  }\n  else if(Array.isArray(q))\n    return pull.apply(null, q.map(get))\n  else\n  return get(q)\n}\n\nexports.filter = function (q) {\n  return pull.filter(filter(q))\n}\n\nexports.map = function (q) {\n  return pull(pull.map(map(q)),pull.filter())\n}\n\nexports.reduce = function (q, cb) {\n  if(cb)\n    return pull.reduce(reduce(q), null, cb)\n  return SinkThrough(function (cb) {\n    return pull.reduce(reduce(q), null, cb)\n  })\n}\n\n","var u = require('./util')\nvar isArray = u.isArray\nvar isString = u.isString\n\nvar extractors = {\n  $filter: function (query) {\n    var o = {}\n    for(var k in query)\n      o[k] = true\n    return o\n  },\n  $reduce: function (query) {\n    var o = {}\n    if(isArray(query.$group))\n      query.$group.forEach(function (path) {\n        o[isArray(path) ? path[0]: path] = true\n      })\n    //TODO: check what paths the other reduces touch.\n\n    return o\n  },\n  $map: function (query) {\n    var o = {}\n    for(var k in query)\n      if(isArray(query[k])) o[query[k][0]] = true\n      else if(isString(query[k])) o[query[k]] = true\n    return o\n  }\n}\n\nfunction merge (a, b) {\n  var o = {}\n  for(var k in a)\n    o[k] = true\n  for(var k in b)\n    o[k] = true\n  return o\n}\n\nfunction first(q) {\n  for(var k in q) return k\n}\n\nfunction keys (query) {\n  var keys = {}\n  for(var i = query.length - 1; i >= 0; i--) {\n    var k = first(query[i])\n    keys = merge(extractors[k](query[i][k]), keys)\n  }\n  return keys\n}\n\nmodule.exports = keys\n","var u = require('./util')\nvar map = u.map\n\nfunction id (v, k) {\n  return k ? v[k] : v\n}\n\nfunction isNull (n) {\n  return n == null\n}\n\nfunction key(q) {\n  return function (v) {\n    if(isNull(v)) return undefined\n    return v[q]\n  }\n}\n\nfunction path (q) {\n  return q.reduce(function (map1, map2) {\n    return function (v) { return map2(map1(v)) }\n  })\n}\n\nfunction notEmpty (o) {\n  for(var k in o) return o\n  return undefined\n}\n\nfunction obj (q) {\n  return function (v) {\n    if(isNull(v)) return undefined\n    return notEmpty(map(q, function (fn, k, o) {\n      return fn(v, k)\n    }))\n  }\n}\n\nfunction make(q) {\n  if(true === q) return id\n  if(isNull(q)) return isNull\n  if(u.isString(q) || u.isNumber(q)) return key(q)\n  if(u.isArray(q)) return path(q.map(make))\n  if(u.isObject(q)) return obj(map(q, make))\n  throw new Error('no match - should never mappen')\n}\n\nmodule.exports = make\n\n","var sources  = require('./sources')\nvar sinks    = require('./sinks')\nvar throughs = require('./throughs')\n\nexports = module.exports = require('./pull')\n\nfor(var k in sources)\n  exports[k] = sources[k]\n\nfor(var k in throughs)\n  exports[k] = throughs[k]\n\nfor(var k in sinks)\n  exports[k] = sinks[k]\n\n","module.exports = function pull (a) {\n  var length = arguments.length\n  if (typeof a === 'function' && a.length === 1) {\n    var args = new Array(length)\n    for(var i = 0; i < length; i++)\n      args[i] = arguments[i]\n    return function (read) {\n      args.unshift(read)\n      return pull.apply(null, args)\n    }\n  }\n\n  var read = a\n\n  if (read && typeof read.source === 'function') {\n    read = read.source\n  }\n\n  for (var i = 1; i < length; i++) {\n    var s = arguments[i]\n    if (typeof s === 'function') {\n      read = s(read)\n    } else if (s && typeof s === 'object') {\n      s.sink(read)\n      read = s.source\n    }\n  }\n\n  return read\n}\n\n\n\n\n\n","'use strict'\n\nfunction id (item) { return item }\n\nfunction prop (key) {\n  return (\n    'string' == typeof key\n    ? function (data) { return data[key] }\n    : key && 'object' === typeof key && 'function' === typeof key.exec //regexp\n    ? function (data) { var v = map.exec(data); return v && v[0] }\n    : key || id\n  )\n}\n\n\nvar drain = exports.drain = function (op, done) {\n  var read, abort\n\n  function sink (_read) {\n    read = _read\n    if(abort) return sink.abort()\n    //this function is much simpler to write if you\n    //just use recursion, but by using a while loop\n    //we do not blow the stack if the stream happens to be sync.\n    ;(function next() {\n        var loop = true, cbed = false\n        while(loop) {\n          cbed = false\n          read(null, function (end, data) {\n            cbed = true\n            if(end = end || abort) {\n              loop = false\n              if(done) done(end === true ? null : end)\n              else if(end && end !== true)\n                throw end\n            }\n            else if(op && false === op(data) || abort) {\n              loop = false\n              read(abort || true, done || function () {})\n            }\n            else if(!loop){\n              next()\n            }\n          })\n          if(!cbed) {\n            loop = false\n            return\n          }\n        }\n      })()\n  }\n\n  sink.abort = function (err, cb) {\n    if('function' == typeof err)\n      cb = err, err = true\n    abort = err || true\n    if(read) return read(abort, cb || function () {})\n  }\n\n  return sink\n}\n\nvar onEnd = exports.onEnd = function (done) {\n  return drain(null, done)\n}\n\nvar log = exports.log = function (done) {\n  return drain(function (data) {\n    console.log(data)\n  }, done)\n}\n\nvar find =\nexports.find = function (test, cb) {\n  var ended = false\n  if(!cb)\n    cb = test, test = id\n  else\n    test = prop(test) || id\n\n  return drain(function (data) {\n    if(test(data)) {\n      ended = true\n      cb(null, data)\n    return false\n    }\n  }, function (err) {\n    if(ended) return //already called back\n    cb(err === true ? null : err, null)\n  })\n}\n\nvar reduce = exports.reduce = function (reduce, acc, cb) {\n\n  return drain(function (data) {\n    acc = reduce(acc, data)\n  }, function (err) {\n    cb(err, acc)\n  })\n\n}\n\nvar collect = exports.collect =\nfunction (cb) {\n  return reduce(function (arr, item) {\n    arr.push(item)\n    return arr\n  }, [], cb)\n}\n\nvar concat = exports.concat =\nfunction (cb) {\n  return reduce(function (a, b) {\n    return a + b\n  }, '', cb)\n}\n\n\n\n\n\n","\nvar keys = exports.keys =\nfunction (object) {\n  return values(Object.keys(object))\n}\n\nfunction abortCb(cb, abort, onAbort) {\n  cb(abort)\n  onAbort && onAbort(abort === true ? null: abort)\n  return\n}\n\nvar once = exports.once =\nfunction (value, onAbort) {\n  return function (abort, cb) {\n    if(abort)\n      return abortCb(cb, abort, onAbort)\n    if(value != null) {\n      var _value = value; value = null\n      cb(null, _value)\n    } else\n      cb(true)\n  }\n}\n\nvar values = exports.values = exports.readArray =\nfunction (array, onAbort) {\n  if(!array)\n    return function (abort, cb) {\n      if(abort) return abortCb(cb, abort, onAbort)\n      return cb(true)\n    }\n  if(!Array.isArray(array))\n    array = Object.keys(array).map(function (k) {\n      return array[k]\n    })\n  var i = 0\n  return function (abort, cb) {\n    if(abort)\n      return abortCb(cb, abort, onAbort)\n    cb(i >= array.length || null, array[i++])\n  }\n}\n\n\nvar count = exports.count =\nfunction (max) {\n  var i = 0; max = max || Infinity\n  return function (end, cb) {\n    if(end) return cb && cb(end)\n    if(i > max)\n      return cb(true)\n    cb(null, i++)\n  }\n}\n\nvar infinite = exports.infinite =\nfunction (generate) {\n  generate = generate || Math.random\n  return function (end, cb) {\n    if(end) return cb && cb(end)\n    return cb(null, generate())\n  }\n}\n\n//a stream that ends immediately.\nvar empty = exports.empty = function () {\n  return function (abort, cb) {\n    cb(true)\n  }\n}\n\n//a stream that errors immediately.\nvar error = exports.error = function (err) {\n  return function (abort, cb) {\n    cb(err)\n  }\n}\n\n","'use strict';\n\nfunction id (item) { return item }\n\nfunction prop (key) {\n  return (\n    'string' == typeof key\n    ? function (data) { return data[key] }\n    : 'object' === typeof key && 'function' === typeof key.exec //regexp\n    ? function (data) { var v = map.exec(data); return v && v[0] }\n    : key\n  )\n}\n\nfunction tester (test) {\n  return (\n    'object' === typeof test && 'function' === typeof test.test //regexp\n    ? function (data) { return test.test(data) }\n    : prop (test) || id\n  )\n}\n\nvar sources = require('./sources')\nvar sinks = require('./sinks')\n\nvar map = exports.map =\n\nfunction (map) {\n  if(!map) return id\n  map = prop(map)\n  return function (read) {\n    return function (abort, cb) {\n      read(abort, function (end, data) {\n        try {\n        data = !end ? map(data) : null\n        } catch (err) {\n          return read(err, function () {\n            return cb(err)\n          })\n        }\n        cb(end, data)\n      })\n    }\n  }\n}\n\nvar asyncMap = exports.asyncMap =\nfunction async (map) {\n  if(!map) return id\n  map = prop(map)\n  var busy = false, abortCb, aborted\n  return function (read) {\n    return function next (abort, cb) {\n      if(aborted) return cb(aborted)\n      if(abort) {\n        aborted = abort\n        if(!busy) read(abort, cb)\n        else read(abort, function () {\n          //if we are still busy, wait for the mapper to complete.\n          if(busy) abortCb = cb\n          else cb(abort)\n        })\n      }\n      else\n        read(null, function (end, data) {\n          if(end) {\n            cb(end)\n            if(abortCb) cb(end, data)\n          }\n          else {\n            busy = true\n            map(data, function (err, data) {\n              busy = false\n              if(aborted) {\n                cb(aborted)\n                abortCb(aborted)\n              }\n              else if(err) next (err, cb)\n              else cb(null, data)\n            })\n          }\n        })\n    }\n  }\n}\n\n\nfunction asyncMap (map) {\n  if(!map) return id //when read is passed, pass it on.\n  return function (read) {\n    return function (end, cb) {\n      if(end) return read(end, cb) //abort\n      read(null, function (end, data) {\n        if(end) return cb(end, data)\n        map(data, cb)\n      })\n    }\n  }\n}\n\nvar filter = exports.filter =\nfunction (test) {\n  //regexp\n  test = tester(test)\n  return function (read) {\n    return function next (end, cb) {\n      var sync, loop = true\n      while(loop) {\n        loop = false\n        sync = true\n        read(end, function (end, data) {\n          if(!end && !test(data))\n            return sync ? loop = true : next(end, cb)\n          cb(end, data)\n        })\n        sync = false\n      }\n    }\n  }\n}\n\nvar filterNot = exports.filterNot =\nfunction (test) {\n  test = tester(test)\n  return filter(function (data) { return !test(data) })\n}\n\n//a pass through stream that doesn't change the value.\nvar through = exports.through =\nfunction (op, onEnd) {\n  var a = false\n\n  function once (abort) {\n    if(a || !onEnd) return\n    a = true\n    onEnd(abort === true ? null : abort)\n  }\n\n  return function (read) {\n    return function (end, cb) {\n      if(end) once(end)\n      return read(end, function (end, data) {\n        if(!end) op && op(data)\n        else once(end)\n        cb(end, data)\n      })\n    }\n  }\n}\n\n//read a number of items and then stop.\nvar take = exports.take =\nfunction (test, opts) {\n  opts = opts || {}\n  var last = opts.last || false // whether the first item for which !test(item) should still pass\n  var ended = false\n  if('number' === typeof test) {\n    last = true\n    var n = test; test = function () {\n      return --n\n    }\n  }\n\n  return function (read) {\n\n    function terminate (cb) {\n      read(true, function (err) {\n        last = false; cb(err || true)\n      })\n    }\n\n    return function (end, cb) {\n      if(ended)            last ? terminate(cb) : cb(ended)\n      else if(ended = end) read(ended, cb)\n      else\n        read(null, function (end, data) {\n          if(ended = ended || end) {\n            //last ? terminate(cb) :\n            cb(ended)\n          }\n          else if(!test(data)) {\n            ended = true\n            last ? cb(null, data) : terminate(cb)\n          }\n          else\n            cb(null, data)\n        })\n    }\n  }\n}\n\n//drop items you have already seen.\nvar unique = exports.unique = function (field, invert) {\n  field = prop(field) || id\n  var seen = {}\n  return filter(function (data) {\n    var key = field(data)\n    if(seen[key]) return !!invert //false, by default\n    else seen[key] = true\n    return !invert //true by default\n  })\n}\n\n//passes an item through when you see it for the second time.\nvar nonUnique = exports.nonUnique = function (field) {\n  return unique(field, true)\n}\n\n//convert a stream of arrays or streams into just a stream.\nvar flatten = exports.flatten = function () {\n  return function (read) {\n    var _read\n    return function (abort, cb) {\n      if (abort) { //abort the current stream, and then stream of streams.\n        _read ? _read(abort, function(err) {\n          read(err || abort, cb)\n        }) : read(abort, cb)\n      }\n      else if(_read) nextChunk()\n      else nextStream()\n\n      function nextChunk () {\n        _read(null, function (err, data) {\n          if (err === true) nextStream()\n          else if (err) {\n            read(true, function(abortErr) {\n              // TODO: what do we do with the abortErr?\n              cb(err)\n            })\n          }\n          else cb(null, data)\n        })\n      }\n      function nextStream () {\n        _read = null\n        read(null, function (end, stream) {\n          if(end)\n            return cb(end)\n          if(Array.isArray(stream) || stream && 'object' === typeof stream)\n            stream = sources.values(stream)\n          else if('function' != typeof stream)\n            stream = sources.once(stream)\n          _read = stream\n          nextChunk()\n        })\n      }\n    }\n  }\n}\n\n\n\n\n\n\n\n","var u = require('./util')\nvar map = u.map\nvar simple = require('./basic')\n\nfunction isFunction (f) { return 'function' === typeof f }\n\nfunction isSimple(query) {\n  for(var k in simple) if(u.has(query, k)) return k\n}\n\nfunction lookup(reduce, path) {\n  if(path === true) return reduce\n  return function (a, b) {\n    return reduce(a, u.get(b, path))\n  }\n}\n\nfunction multi(obj) {\n  return function (a, b) {\n    return map(obj, function (reduce, k) {\n      return reduce(a[k], b)\n    }, a = a || {})\n  }\n}\n\nfunction each(list, iter) {\n  if(u.isString(list)) return iter(list)\n  for(var i = 0; i < list.length; i++)\n    iter(list[i], (list.length - i - 1))\n}\n\n//instead of taking the query,\n//this should take a path, and a reduce function.\nfunction group (g, reduce) {\n  return function (a, b) {\n    var A = a = a || {}\n    each(g, function (k, notLast) {\n      var v = u.get(b, k)\n      A[v] = !notLast ? reduce(A[v], b) : A[v] || {}\n      A = A[v]\n    })\n    return a\n  }\n}\n\nfunction make (query) {\n  var k = isSimple(query)\n  if(k) return lookup(simple[k], query[k])\n  else if(u.isObject(query))\n    return multi(map(query, function (q, k) {\n      if(k == '$group') return undefined\n      return gmake(query[k])\n    }))\n}\n\nfunction gmake (query) {\n return query.$group ? group(query.$group, make(query)) : make(query)\n}\n\nmodule.exports = gmake\n\n\n\n","'use strict'\nfunction isString(s) { return 'string' === typeof s }\n\nfunction isNumber(n) { return !isNaN(+n) }\n\nfunction isBoolean (b) { return 'boolean' === typeof b }\n\nfunction isBasic (p) { return isString(p) || isNumber(p) || isBoolean(p) }\n\nvar isArray = Array.isArray\n\nfunction isObject (o) { return o && 'object' === typeof o }\n\nfunction has(o, k) {\n  return Object.hasOwnProperty.call(o, k)\n}\n\nfunction isExact (v) {\n  if(isBasic(v)) return true\n  if(isArray(v))\n    return v.every(isExact)\n  return isObject(v) && has(v, '$eq')\n}\n\nfunction isLtgt (v) {\n  return has(v, '$lt') || has(v, '$gt') || has(v, '$lte') || has(v, '$gte')\n}\n\nfunction isRange (v) {\n  if(!isObject(v)) return false\n  if(isString(v.$prefix)) return true\n  if(isArray(v)) return find(v, isRange)\n  return isLtgt(v)\n}\n\nfunction find (ary, test) {\n  for(var i = 0; i < ary.length; i++)\n    if(test(ary[i], i, ary)) return true\n  return false\n}\n\nfunction lower (v) {\n  if(isBasic(v)) return v\n  if(isObject(v)) {\n    if(isArray(v.$prefix)) return v.$prefix.concat(exports.HI)\n    if(isString(v.$prefix)) return v.$prefix\n    if(has(v, '$lt')) return v.$lt\n    if(has(v, '$lte')) return v.$lte\n  }\n  if(isArray(v)) return v.map(lower)\n}\n\nfunction upper (v) {\n  if(isBasic(v)) return v\n  if(isObject(v)) {\n    if(isArray(v.$prefix)) return v.$prefix.concat(exports.LO)\n    if(isString(v.$prefix)) return v.$prefix+'\\uffff'\n    if(has(v, '$gt')) return v.$gt\n    if(has(v, '$gte')) return v.$gte\n  }\n  if(isArray(v)) return v.map(upper)\n}\n\nfunction get(obj, path) {\n  if(isString(path)) return obj[path]\n  if(isArray(path)) {\n    for(var i = 0; i < path.length; i++) {\n      if(obj == null) return undefined\n      obj = obj[path[i]]\n    }\n    return obj\n  }\n  if(path === true) return obj\n  return undefined\n}\n\nfunction map(obj, iter, o) {\n  if(Array.isArray(obj)) return obj.map(iter)\n  o = o || {}\n  for(var k in obj) {\n    var v = iter(obj[k], k, obj)\n    if(v !== undefined) o[k] = v\n  }\n  return o\n}\n\nexports.isString = isString\nexports.isNumber = isNumber\nexports.isBasic = isBasic\nexports.isArray = isArray\nexports.isObject = isObject\nexports.isRange = isRange\nexports.isExact = isExact\nexports.isLtgt = isLtgt\n\nexports.has = has\nexports.get = get\nexports.map = map\n\nexports.upper = upper\nexports.lower = lower\n\nexports.HI = undefined\nexports.LO = null\n","\nfunction isObject(o) {\n  return o && 'object' === typeof o\n}\n\nvar isArray = Array.isArray\n\nfunction isUndefined (u) {\n  return 'undefined' === typeof u\n}\n\nvar find = exports.find = function find(ary, test) {\n  for(var i in ary)\n    if(test(ary[i], i, ary)) return ary[i]\n}\n\nexports = module.exports = merge\nexports.merge = exports\n\nvar clone = exports.clone = function clone (obj, mapper) {\n  function map(v, k) {\n    return isObject(v) ? clone(v, mapper) : mapper(v, k)\n  }\n  if(isArray(obj))\n    return obj.map(map)\n  else if(isObject(obj)) {\n    var o = {}\n    for(var k in obj)\n      o[k] = map(obj[k], k)\n    return o\n  }\n  else\n    return map(obj)\n}\n\nvar mergeKeys = exports.mergeKeys = function (a, b, iter) {\n  var o = {}\n  for(var k in a) {\n    if(!isUndefined(a[k]))\n      o[k] = iter(a[k], b[k], k)\n  }\n  for(var k in b) {\n    if(isUndefined(a[k]))\n      o[k] = iter(undefined, b[k], k)\n  }\n  return o\n}\n\nvar mergeArrays = exports.mergeArrays = function (a, b, iter) {\n  var o = []\n  a.forEach(function (v, i) {\n    var j = b.indexOf(v)\n    o.push(iter(v, b[j], o.length))\n  })\n  b.forEach(function (v, i) {\n    var j = a.indexOf(v)\n    if(!~j)\n      o.push(iter(undefined, b[i], o.length))\n  })\n  return o\n}\n\nfunction merge (a, b, merge) {\n\n  //merge a and b objects\n\n  merge = merge || function (x, y) {\n    return y == null ? x : y\n  }\n\n  function merger(a, b, k) {\n\n    if(isArray(a) && isArray(b))\n      return mergeArrays(a, b, merger)\n    else if(isObject(a) && isObject(b)) {\n      return mergeKeys(a, b, merger)\n    }\n    else\n      return merge(a, b, k)\n\n  }\n\n  return merger(a, b, undefined)\n\n\n}\n","'use strict';\n\n/*\n * Useful expressions.\n */\n\nvar EXPRESSION_DOT = /\\./;\nvar EXPRESSION_LAST_DOT = /\\.[^.]*$/;\n\n/*\n * Allowed alignment values.\n */\n\nvar LEFT = 'l';\nvar RIGHT = 'r';\nvar CENTER = 'c';\nvar DOT = '.';\nvar NULL = '';\n\nvar ALLIGNMENT = [LEFT, RIGHT, CENTER, DOT, NULL];\n\n/*\n * Characters.\n */\n\nvar COLON = ':';\nvar DASH = '-';\nvar PIPE = '|';\nvar SPACE = ' ';\nvar NEW_LINE = '\\n';\n\n/**\n * Get the length of `value`.\n *\n * @param {string} value\n * @return {number}\n */\nfunction lengthNoop(value) {\n    return String(value).length;\n}\n\n/**\n * Get a string consisting of `length` `character`s.\n *\n * @param {number} length\n * @param {string} [character=' ']\n * @return {string}\n */\nfunction pad(length, character) {\n    return Array(length + 1).join(character || SPACE);\n}\n\n/**\n * Get the position of the last dot in `value`.\n *\n * @param {string} value\n * @return {number}\n */\nfunction dotindex(value) {\n    var match = EXPRESSION_LAST_DOT.exec(value);\n\n    return match ? match.index + 1 : value.length;\n}\n\n/**\n * Create a table from a matrix of strings.\n *\n * @param {Array.<Array.<string>>} table\n * @param {Object?} options\n * @param {boolean?} [options.rule=true]\n * @param {string?} [options.delimiter=\" | \"]\n * @param {string?} [options.start=\"| \"]\n * @param {string?} [options.end=\" |\"]\n * @param {Array.<string>?} options.align\n * @param {function(string)?} options.stringLength\n * @return {string} Pretty table\n */\nfunction markdownTable(table, options) {\n    var settings = options || {};\n    var delimiter = settings.delimiter;\n    var start = settings.start;\n    var end = settings.end;\n    var alignment = settings.align;\n    var calculateStringLength = settings.stringLength || lengthNoop;\n    var cellCount = 0;\n    var rowIndex = -1;\n    var rowLength = table.length;\n    var sizes = [];\n    var align;\n    var rule;\n    var rows;\n    var row;\n    var cells;\n    var index;\n    var position;\n    var size;\n    var value;\n    var spacing;\n    var before;\n    var after;\n\n    alignment = alignment ? alignment.concat() : [];\n\n    if (delimiter === null || delimiter === undefined) {\n        delimiter = SPACE + PIPE + SPACE;\n    }\n\n    if (start === null || start === undefined) {\n        start = PIPE + SPACE;\n    }\n\n    if (end === null || end === undefined) {\n        end = SPACE + PIPE;\n    }\n\n    while (++rowIndex < rowLength) {\n        row = table[rowIndex];\n\n        index = -1;\n\n        if (row.length > cellCount) {\n            cellCount = row.length;\n        }\n\n        while (++index < cellCount) {\n            position = row[index] ? dotindex(row[index]) : null;\n\n            if (!sizes[index]) {\n                sizes[index] = 3;\n            }\n\n            if (position > sizes[index]) {\n                sizes[index] = position;\n            }\n        }\n    }\n\n    if (typeof alignment === 'string') {\n        alignment = pad(cellCount, alignment).split('');\n    }\n\n    /*\n     * Make sure only valid alignments are used.\n     */\n\n    index = -1;\n\n    while (++index < cellCount) {\n        align = alignment[index];\n\n        if (typeof align === 'string') {\n            align = align.charAt(0).toLowerCase();\n        }\n\n        if (ALLIGNMENT.indexOf(align) === -1) {\n            align = NULL;\n        }\n\n        alignment[index] = align;\n    }\n\n    rowIndex = -1;\n    rows = [];\n\n    while (++rowIndex < rowLength) {\n        row = table[rowIndex];\n\n        index = -1;\n        cells = [];\n\n        while (++index < cellCount) {\n            value = row[index];\n\n            if (value === null || value === undefined) {\n                value = '';\n            } else {\n                value = String(value);\n            }\n\n            if (alignment[index] !== DOT) {\n                cells[index] = value;\n            } else {\n                position = dotindex(value);\n\n                size = sizes[index] +\n                    (EXPRESSION_DOT.test(value) ? 0 : 1) -\n                    (calculateStringLength(value) - position);\n\n                cells[index] = value + pad(size - 1);\n            }\n        }\n\n        rows[rowIndex] = cells;\n    }\n\n    sizes = [];\n    rowIndex = -1;\n\n    while (++rowIndex < rowLength) {\n        cells = rows[rowIndex];\n\n        index = -1;\n\n        while (++index < cellCount) {\n            value = cells[index];\n\n            if (!sizes[index]) {\n                sizes[index] = 3;\n            }\n\n            size = calculateStringLength(value);\n\n            if (size > sizes[index]) {\n                sizes[index] = size;\n            }\n        }\n    }\n\n    rowIndex = -1;\n\n    while (++rowIndex < rowLength) {\n        cells = rows[rowIndex];\n\n        index = -1;\n\n        while (++index < cellCount) {\n            value = cells[index];\n\n            position = sizes[index] - (calculateStringLength(value) || 0);\n            spacing = pad(position);\n\n            if (alignment[index] === RIGHT || alignment[index] === DOT) {\n                value = spacing + value;\n            } else if (alignment[index] !== CENTER) {\n                value = value + spacing;\n            } else {\n                position = position / 2;\n\n                if (position % 1 === 0) {\n                    before = position;\n                    after = position;\n                } else {\n                    before = position + 0.5;\n                    after = position - 0.5;\n                }\n\n                value = pad(before) + value + pad(after);\n            }\n\n            cells[index] = value;\n        }\n\n        rows[rowIndex] = cells.join(delimiter);\n    }\n\n    if (settings.rule !== false) {\n        index = -1;\n        rule = [];\n\n        while (++index < cellCount) {\n            align = alignment[index];\n\n            /*\n             * When `align` is left, don't add colons.\n             */\n\n            value = align === RIGHT || align === NULL ? DASH : COLON;\n            value += pad(sizes[index] - 2, DASH);\n            value += align !== LEFT && align !== NULL ? COLON : DASH;\n\n            rule[index] = value;\n        }\n\n        rows.splice(1, 0, rule.join(delimiter));\n    }\n\n    return start + rows.join(end + NEW_LINE + start) + end;\n}\n\n/*\n * Expose `markdownTable`.\n */\n\nmodule.exports = markdownTable;\n","var assert = require('assert')\nvar remark = require('remark')\nvar html = require('remark-html')\n\n// - obj: object\n// - path: array, a list of keys\n// - value: any\n// will create any subobject needed\n// eg var x = {}; set(x, ['foo', 'bar'], 5); x.foo.bar == 5\nfunction set (obj, path, value) {\n  while (path.length > 1) {\n    var k = path.shift()\n    if (!obj[k])\n      obj[k] = {}\n    obj = obj[k]\n  }\n  obj[path[0]] = value\n}\n\nfunction fill (str, n) {\n  if (n > str.length)\n    return str + ' '.repeat(n - str.length)\n  return str\n}\n\nfunction methodTable (methods, nameWidth) {\n  // figure out how long the names column needs to be\n  if (!nameWidth) {\n    nameWidth = 1\n    methods.forEach(function (m) {\n      if (m.name.length > nameWidth)\n        nameWidth = m.name.length\n    })\n  }\n\n  return methods.map(function (m) {\n    return '  ' + fill(m.name, nameWidth) + ' ' + m.desc\n  }).join('').trim()\n}\n\nfunction parseMethodHeading (token, prefix) {\n  var textToken = token.children[0]\n  assert.equal(textToken.type, 'text', 'Headings should not have any markup')\n\n  var parts = textToken.value.split(': ')\n  assert.equal(parts.length, 2, 'Heading \"'+textToken.value+'\" should be of form `method: type`')\n  \n  var name = parts[0], type = parts[1]\n  assert(nameRegex.test(name), 'Function name \"'+name+'\" does nots match '+nameRegex)\n  assert(nameRegex.test(type), 'Function type \"'+type+'\" does not match '+typeRegex)\n\n  if (prefix)\n    parts[0] = prefix + '.' + parts[0]\n\n  return parts\n}\n\nvar nameRegex = /^[a-z][a-z0-9\\.\\-_]*$/i\nvar typeRegex = /^[a-z]+$/i\nmodule.exports.manifest = function (text) {\n  assert.equal(typeof text, 'string', 'Input should be a markdown string')\n\n  var manifest = {}\n  remark().parse(text).children.forEach(function (token, i) {\n    if (token.type === 'heading' && token.depth === 2) {\n      var parts = parseMethodHeading(token)\n      set(manifest, parts[0].split('.'), parts[1])\n    }\n  })\n\n  return manifest\n}\n\nmodule.exports.usage = function (text, cmd, opts) {\n  assert.equal(typeof text, 'string', 'Input should be a markdown string')\n  opts = opts || {}\n\n  var lexer = remark()\n  var tokens = lexer.parse(text).children\n  if (!cmd) {\n    // toplevel usage\n    var inSummary = true // in the api summary?\n    var toplevelParas = []\n    var methods = []\n    var currentMethod\n    tokens.forEach(function (token) {\n      if (token.type == 'paragraph' && inSummary) {\n        // a para in the api's toplevel summary\n        toplevelParas.push(lexer.stringify({ type: 'root', children: token.children }))\n      } else if (token.type == 'heading' && token.depth == 2) {\n        // a method heading\n        inSummary = false // no longer in the api summary\n        var parts = parseMethodHeading(token, opts.prefix)\n        currentMethod = parts[0]\n      }\n      else if (token.type == 'paragraph' && currentMethod) {\n        // the first para in a method\n        methods.push({ name: currentMethod, desc: lexer.stringify({ type: 'root', children: token.children })})\n        currentMethod = null\n      }\n    })\n    if (currentMethod)\n      methods.push({ name: currentMethod })\n    return toplevelParas.join('\\n') + '\\nCommands:\\n  ' + methodTable(methods, opts.nameWidth)\n  }\n\n  // method usage\n  var inMethod = false // in the method?\n  var elems = []\n  for (var i=0; i < tokens.length; i++) {\n    var token = tokens[i]\n    if (token.type == 'heading') {\n      // a heading\n      if (inMethod)\n        break // done pulling from the method's summary\n      if (token.depth == 2 && parseMethodHeading(token)[0] == cmd)\n        inMethod = true // we're in the target method's summary\n    }\n    else if (inMethod) {\n      if (token.type == 'code') {\n        // only include code examples for the CLI\n        if (token.lang == 'bash' || token.lang == 'sh' || token.lang == 'shell' || !token.lang) {\n          token.type = 'text'\n          elems.push(token)\n        }\n      } else\n        elems.push(token)\n    }\n  }\n  return lexer\n    .stringify({ type: 'root', children: elems })\n    .trim()\n    .replace(/\\\\\\[/g, '[') // dont escape '['\n}\n\nmodule.exports.html = function (text) {\n  assert.equal(typeof text, 'string', 'Input should be a markdown string')\n  return remark().use(html).process(text)\n}","var bn = require('bn.js');\nvar brorand = require('brorand');\n\nfunction MillerRabin(rand) {\n  this.rand = rand || new brorand.Rand();\n}\nmodule.exports = MillerRabin;\n\nMillerRabin.create = function create(rand) {\n  return new MillerRabin(rand);\n};\n\nMillerRabin.prototype._rand = function _rand(n) {\n  var len = n.bitLength();\n  var buf = this.rand.generate(Math.ceil(len / 8));\n\n  // Set low bits\n  buf[0] |= 3;\n\n  // Mask high bits\n  var mask = len & 0x7;\n  if (mask !== 0)\n    buf[buf.length - 1] >>= 7 - mask;\n\n  return new bn(buf);\n}\n\nMillerRabin.prototype.test = function test(n, k, cb) {\n  var len = n.bitLength();\n  var red = bn.mont(n);\n  var rone = new bn(1).toRed(red);\n\n  if (!k)\n    k = Math.max(1, (len / 48) | 0);\n\n  // Find d and s, (n - 1) = (2 ^ s) * d;\n  var n1 = n.subn(1);\n  var n2 = n1.subn(1);\n  for (var s = 0; !n1.testn(s); s++) {}\n  var d = n.shrn(s);\n\n  var rn1 = n1.toRed(red);\n\n  var prime = true;\n  for (; k > 0; k--) {\n    var a = this._rand(n2);\n    if (cb)\n      cb(a);\n\n    var x = a.toRed(red).redPow(d);\n    if (x.cmp(rone) === 0 || x.cmp(rn1) === 0)\n      continue;\n\n    for (var i = 1; i < s; i++) {\n      x = x.redSqr();\n\n      if (x.cmp(rone) === 0)\n        return false;\n      if (x.cmp(rn1) === 0)\n        break;\n    }\n\n    if (i === s)\n      return false;\n  }\n\n  return prime;\n};\n\nMillerRabin.prototype.getDivisor = function getDivisor(n, k) {\n  var len = n.bitLength();\n  var red = bn.mont(n);\n  var rone = new bn(1).toRed(red);\n\n  if (!k)\n    k = Math.max(1, (len / 48) | 0);\n\n  // Find d and s, (n - 1) = (2 ^ s) * d;\n  var n1 = n.subn(1);\n  var n2 = n1.subn(1);\n  for (var s = 0; !n1.testn(s); s++) {}\n  var d = n.shrn(s);\n\n  var rn1 = n1.toRed(red);\n\n  for (; k > 0; k--) {\n    var a = this._rand(n2);\n\n    var g = n.gcd(a);\n    if (g.cmpn(1) !== 0)\n      return g;\n\n    var x = a.toRed(red).redPow(d);\n    if (x.cmp(rone) === 0 || x.cmp(rn1) === 0)\n      continue;\n\n    for (var i = 1; i < s; i++) {\n      x = x.redSqr();\n\n      if (x.cmp(rone) === 0)\n        return x.fromRed().subn(1).gcd(n);\n      if (x.cmp(rn1) === 0)\n        break;\n    }\n\n    if (i === s) {\n      x = x.redSqr();\n      return x.fromRed().subn(1).gcd(n);\n    }\n  }\n\n  return false;\n};\n","module.exports={\n  \"application/1d-interleaved-parityfec\": {\n    \"source\": \"iana\"\n  },\n  \"application/3gpdash-qoe-report+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/3gpp-ims+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/a2l\": {\n    \"source\": \"iana\"\n  },\n  \"application/activemessage\": {\n    \"source\": \"iana\"\n  },\n  \"application/alto-costmap+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/alto-costmapfilter+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/alto-directory+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/alto-endpointcost+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/alto-endpointcostparams+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/alto-endpointprop+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/alto-endpointpropparams+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/alto-error+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/alto-networkmap+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/alto-networkmapfilter+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/aml\": {\n    \"source\": \"iana\"\n  },\n  \"application/andrew-inset\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ez\"]\n  },\n  \"application/applefile\": {\n    \"source\": \"iana\"\n  },\n  \"application/applixware\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"aw\"]\n  },\n  \"application/atf\": {\n    \"source\": \"iana\"\n  },\n  \"application/atfx\": {\n    \"source\": \"iana\"\n  },\n  \"application/atom+xml\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"atom\"]\n  },\n  \"application/atomcat+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"atomcat\"]\n  },\n  \"application/atomdeleted+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/atomicmail\": {\n    \"source\": \"iana\"\n  },\n  \"application/atomsvc+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"atomsvc\"]\n  },\n  \"application/atxml\": {\n    \"source\": \"iana\"\n  },\n  \"application/auth-policy+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/bacnet-xdd+zip\": {\n    \"source\": \"iana\"\n  },\n  \"application/batch-smtp\": {\n    \"source\": \"iana\"\n  },\n  \"application/bdoc\": {\n    \"compressible\": false,\n    \"extensions\": [\"bdoc\"]\n  },\n  \"application/beep+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/calendar+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/calendar+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/call-completion\": {\n    \"source\": \"iana\"\n  },\n  \"application/cals-1840\": {\n    \"source\": \"iana\"\n  },\n  \"application/cbor\": {\n    \"source\": \"iana\"\n  },\n  \"application/ccmp+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/ccxml+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ccxml\"]\n  },\n  \"application/cdfx+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/cdmi-capability\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cdmia\"]\n  },\n  \"application/cdmi-container\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cdmic\"]\n  },\n  \"application/cdmi-domain\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cdmid\"]\n  },\n  \"application/cdmi-object\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cdmio\"]\n  },\n  \"application/cdmi-queue\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cdmiq\"]\n  },\n  \"application/cdni\": {\n    \"source\": \"iana\"\n  },\n  \"application/cea\": {\n    \"source\": \"iana\"\n  },\n  \"application/cea-2018+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/cellml+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/cfw\": {\n    \"source\": \"iana\"\n  },\n  \"application/cms\": {\n    \"source\": \"iana\"\n  },\n  \"application/cnrp+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/coap-group+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/commonground\": {\n    \"source\": \"iana\"\n  },\n  \"application/conference-info+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/cpl+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/csrattrs\": {\n    \"source\": \"iana\"\n  },\n  \"application/csta+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/cstadata+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/csvm+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/cu-seeme\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"cu\"]\n  },\n  \"application/cybercash\": {\n    \"source\": \"iana\"\n  },\n  \"application/dart\": {\n    \"compressible\": true\n  },\n  \"application/dash+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mpd\"]\n  },\n  \"application/dashdelta\": {\n    \"source\": \"iana\"\n  },\n  \"application/davmount+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"davmount\"]\n  },\n  \"application/dca-rft\": {\n    \"source\": \"iana\"\n  },\n  \"application/dcd\": {\n    \"source\": \"iana\"\n  },\n  \"application/dec-dx\": {\n    \"source\": \"iana\"\n  },\n  \"application/dialog-info+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/dicom\": {\n    \"source\": \"iana\"\n  },\n  \"application/dii\": {\n    \"source\": \"iana\"\n  },\n  \"application/dit\": {\n    \"source\": \"iana\"\n  },\n  \"application/dns\": {\n    \"source\": \"iana\"\n  },\n  \"application/docbook+xml\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"dbk\"]\n  },\n  \"application/dskpp+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/dssc+der\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"dssc\"]\n  },\n  \"application/dssc+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xdssc\"]\n  },\n  \"application/dvcs\": {\n    \"source\": \"iana\"\n  },\n  \"application/ecmascript\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"ecma\"]\n  },\n  \"application/edi-consent\": {\n    \"source\": \"iana\"\n  },\n  \"application/edi-x12\": {\n    \"source\": \"iana\",\n    \"compressible\": false\n  },\n  \"application/edifact\": {\n    \"source\": \"iana\",\n    \"compressible\": false\n  },\n  \"application/emergencycalldata.comment+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/emergencycalldata.deviceinfo+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/emergencycalldata.providerinfo+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/emergencycalldata.serviceinfo+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/emergencycalldata.subscriberinfo+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/emma+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"emma\"]\n  },\n  \"application/emotionml+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/encaprtp\": {\n    \"source\": \"iana\"\n  },\n  \"application/epp+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/epub+zip\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"epub\"]\n  },\n  \"application/eshop\": {\n    \"source\": \"iana\"\n  },\n  \"application/exi\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"exi\"]\n  },\n  \"application/fastinfoset\": {\n    \"source\": \"iana\"\n  },\n  \"application/fastsoap\": {\n    \"source\": \"iana\"\n  },\n  \"application/fdt+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/fits\": {\n    \"source\": \"iana\"\n  },\n  \"application/font-sfnt\": {\n    \"source\": \"iana\"\n  },\n  \"application/font-tdpfr\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"pfr\"]\n  },\n  \"application/font-woff\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"woff\"]\n  },\n  \"application/font-woff2\": {\n    \"compressible\": false,\n    \"extensions\": [\"woff2\"]\n  },\n  \"application/framework-attributes+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/gml+xml\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"gml\"]\n  },\n  \"application/gpx+xml\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"gpx\"]\n  },\n  \"application/gxf\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"gxf\"]\n  },\n  \"application/gzip\": {\n    \"source\": \"iana\",\n    \"compressible\": false\n  },\n  \"application/h224\": {\n    \"source\": \"iana\"\n  },\n  \"application/held+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/http\": {\n    \"source\": \"iana\"\n  },\n  \"application/hyperstudio\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"stk\"]\n  },\n  \"application/ibe-key-request+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/ibe-pkg-reply+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/ibe-pp-data\": {\n    \"source\": \"iana\"\n  },\n  \"application/iges\": {\n    \"source\": \"iana\"\n  },\n  \"application/im-iscomposing+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/index\": {\n    \"source\": \"iana\"\n  },\n  \"application/index.cmd\": {\n    \"source\": \"iana\"\n  },\n  \"application/index.obj\": {\n    \"source\": \"iana\"\n  },\n  \"application/index.response\": {\n    \"source\": \"iana\"\n  },\n  \"application/index.vnd\": {\n    \"source\": \"iana\"\n  },\n  \"application/inkml+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ink\",\"inkml\"]\n  },\n  \"application/iotp\": {\n    \"source\": \"iana\"\n  },\n  \"application/ipfix\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ipfix\"]\n  },\n  \"application/ipp\": {\n    \"source\": \"iana\"\n  },\n  \"application/isup\": {\n    \"source\": \"iana\"\n  },\n  \"application/its+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/java-archive\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"jar\",\"war\",\"ear\"]\n  },\n  \"application/java-serialized-object\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"ser\"]\n  },\n  \"application/java-vm\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"class\"]\n  },\n  \"application/javascript\": {\n    \"source\": \"iana\",\n    \"charset\": \"UTF-8\",\n    \"compressible\": true,\n    \"extensions\": [\"js\"]\n  },\n  \"application/jose\": {\n    \"source\": \"iana\"\n  },\n  \"application/jose+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/jrd+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/json\": {\n    \"source\": \"iana\",\n    \"charset\": \"UTF-8\",\n    \"compressible\": true,\n    \"extensions\": [\"json\",\"map\"]\n  },\n  \"application/json-patch+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/json-seq\": {\n    \"source\": \"iana\"\n  },\n  \"application/json5\": {\n    \"extensions\": [\"json5\"]\n  },\n  \"application/jsonml+json\": {\n    \"source\": \"apache\",\n    \"compressible\": true,\n    \"extensions\": [\"jsonml\"]\n  },\n  \"application/jwk+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/jwk-set+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/jwt\": {\n    \"source\": \"iana\"\n  },\n  \"application/kpml-request+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/kpml-response+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/ld+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"jsonld\"]\n  },\n  \"application/link-format\": {\n    \"source\": \"iana\"\n  },\n  \"application/load-control+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/lost+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"lostxml\"]\n  },\n  \"application/lostsync+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/lxf\": {\n    \"source\": \"iana\"\n  },\n  \"application/mac-binhex40\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"hqx\"]\n  },\n  \"application/mac-compactpro\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"cpt\"]\n  },\n  \"application/macwriteii\": {\n    \"source\": \"iana\"\n  },\n  \"application/mads+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mads\"]\n  },\n  \"application/manifest+json\": {\n    \"charset\": \"UTF-8\",\n    \"compressible\": true,\n    \"extensions\": [\"webmanifest\"]\n  },\n  \"application/marc\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mrc\"]\n  },\n  \"application/marcxml+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mrcx\"]\n  },\n  \"application/mathematica\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ma\",\"nb\",\"mb\"]\n  },\n  \"application/mathml+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mathml\"]\n  },\n  \"application/mathml-content+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/mathml-presentation+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/mbms-associated-procedure-description+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/mbms-deregister+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/mbms-envelope+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/mbms-msk+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/mbms-msk-response+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/mbms-protection-description+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/mbms-reception-report+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/mbms-register+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/mbms-register-response+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/mbms-schedule+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/mbms-user-service-description+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/mbox\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mbox\"]\n  },\n  \"application/media-policy-dataset+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/media_control+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/mediaservercontrol+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mscml\"]\n  },\n  \"application/merge-patch+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/metalink+xml\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"metalink\"]\n  },\n  \"application/metalink4+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"meta4\"]\n  },\n  \"application/mets+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mets\"]\n  },\n  \"application/mf4\": {\n    \"source\": \"iana\"\n  },\n  \"application/mikey\": {\n    \"source\": \"iana\"\n  },\n  \"application/mods+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mods\"]\n  },\n  \"application/moss-keys\": {\n    \"source\": \"iana\"\n  },\n  \"application/moss-signature\": {\n    \"source\": \"iana\"\n  },\n  \"application/mosskey-data\": {\n    \"source\": \"iana\"\n  },\n  \"application/mosskey-request\": {\n    \"source\": \"iana\"\n  },\n  \"application/mp21\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"m21\",\"mp21\"]\n  },\n  \"application/mp4\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mp4s\",\"m4p\"]\n  },\n  \"application/mpeg4-generic\": {\n    \"source\": \"iana\"\n  },\n  \"application/mpeg4-iod\": {\n    \"source\": \"iana\"\n  },\n  \"application/mpeg4-iod-xmt\": {\n    \"source\": \"iana\"\n  },\n  \"application/mrb-consumer+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/mrb-publish+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/msc-ivr+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/msc-mixer+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/msword\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"doc\",\"dot\"]\n  },\n  \"application/mxf\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mxf\"]\n  },\n  \"application/nasdata\": {\n    \"source\": \"iana\"\n  },\n  \"application/news-checkgroups\": {\n    \"source\": \"iana\"\n  },\n  \"application/news-groupinfo\": {\n    \"source\": \"iana\"\n  },\n  \"application/news-transmission\": {\n    \"source\": \"iana\"\n  },\n  \"application/nlsml+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/nss\": {\n    \"source\": \"iana\"\n  },\n  \"application/ocsp-request\": {\n    \"source\": \"iana\"\n  },\n  \"application/ocsp-response\": {\n    \"source\": \"iana\"\n  },\n  \"application/octet-stream\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"bin\",\"dms\",\"lrf\",\"mar\",\"so\",\"dist\",\"distz\",\"pkg\",\"bpk\",\"dump\",\"elc\",\"deploy\",\"exe\",\"dll\",\"deb\",\"dmg\",\"iso\",\"img\",\"msi\",\"msp\",\"msm\",\"buffer\"]\n  },\n  \"application/oda\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"oda\"]\n  },\n  \"application/odx\": {\n    \"source\": \"iana\"\n  },\n  \"application/oebps-package+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"opf\"]\n  },\n  \"application/ogg\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"ogx\"]\n  },\n  \"application/omdoc+xml\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"omdoc\"]\n  },\n  \"application/onenote\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"onetoc\",\"onetoc2\",\"onetmp\",\"onepkg\"]\n  },\n  \"application/oxps\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"oxps\"]\n  },\n  \"application/p2p-overlay+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/parityfec\": {\n    \"source\": \"iana\"\n  },\n  \"application/patch-ops-error+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xer\"]\n  },\n  \"application/pdf\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"pdf\"]\n  },\n  \"application/pdx\": {\n    \"source\": \"iana\"\n  },\n  \"application/pgp-encrypted\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"pgp\"]\n  },\n  \"application/pgp-keys\": {\n    \"source\": \"iana\"\n  },\n  \"application/pgp-signature\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"asc\",\"sig\"]\n  },\n  \"application/pics-rules\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"prf\"]\n  },\n  \"application/pidf+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/pidf-diff+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/pkcs10\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"p10\"]\n  },\n  \"application/pkcs12\": {\n    \"source\": \"iana\"\n  },\n  \"application/pkcs7-mime\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"p7m\",\"p7c\"]\n  },\n  \"application/pkcs7-signature\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"p7s\"]\n  },\n  \"application/pkcs8\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"p8\"]\n  },\n  \"application/pkix-attr-cert\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ac\"]\n  },\n  \"application/pkix-cert\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cer\"]\n  },\n  \"application/pkix-crl\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"crl\"]\n  },\n  \"application/pkix-pkipath\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"pkipath\"]\n  },\n  \"application/pkixcmp\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"pki\"]\n  },\n  \"application/pls+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"pls\"]\n  },\n  \"application/poc-settings+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/postscript\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"ai\",\"eps\",\"ps\"]\n  },\n  \"application/ppsp-tracker+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/problem+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/problem+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/provenance+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/prs.alvestrand.titrax-sheet\": {\n    \"source\": \"iana\"\n  },\n  \"application/prs.cww\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cww\"]\n  },\n  \"application/prs.hpub+zip\": {\n    \"source\": \"iana\"\n  },\n  \"application/prs.nprend\": {\n    \"source\": \"iana\"\n  },\n  \"application/prs.plucker\": {\n    \"source\": \"iana\"\n  },\n  \"application/prs.rdf-xml-crypt\": {\n    \"source\": \"iana\"\n  },\n  \"application/prs.xsf+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/pskc+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"pskcxml\"]\n  },\n  \"application/qsig\": {\n    \"source\": \"iana\"\n  },\n  \"application/raptorfec\": {\n    \"source\": \"iana\"\n  },\n  \"application/rdap+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/rdf+xml\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"rdf\"]\n  },\n  \"application/reginfo+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"rif\"]\n  },\n  \"application/relax-ng-compact-syntax\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"rnc\"]\n  },\n  \"application/remote-printing\": {\n    \"source\": \"iana\"\n  },\n  \"application/reputon+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/resource-lists+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"rl\"]\n  },\n  \"application/resource-lists-diff+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"rld\"]\n  },\n  \"application/rfc+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/riscos\": {\n    \"source\": \"iana\"\n  },\n  \"application/rlmi+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/rls-services+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"rs\"]\n  },\n  \"application/rpki-ghostbusters\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"gbr\"]\n  },\n  \"application/rpki-manifest\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mft\"]\n  },\n  \"application/rpki-roa\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"roa\"]\n  },\n  \"application/rpki-updown\": {\n    \"source\": \"iana\"\n  },\n  \"application/rsd+xml\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"rsd\"]\n  },\n  \"application/rss+xml\": {\n    \"source\": \"apache\",\n    \"compressible\": true,\n    \"extensions\": [\"rss\"]\n  },\n  \"application/rtf\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"rtf\"]\n  },\n  \"application/rtploopback\": {\n    \"source\": \"iana\"\n  },\n  \"application/rtx\": {\n    \"source\": \"iana\"\n  },\n  \"application/samlassertion+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/samlmetadata+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/sbml+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"sbml\"]\n  },\n  \"application/scaip+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/scim+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/scvp-cv-request\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"scq\"]\n  },\n  \"application/scvp-cv-response\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"scs\"]\n  },\n  \"application/scvp-vp-request\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"spq\"]\n  },\n  \"application/scvp-vp-response\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"spp\"]\n  },\n  \"application/sdp\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"sdp\"]\n  },\n  \"application/sep+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/sep-exi\": {\n    \"source\": \"iana\"\n  },\n  \"application/session-info\": {\n    \"source\": \"iana\"\n  },\n  \"application/set-payment\": {\n    \"source\": \"iana\"\n  },\n  \"application/set-payment-initiation\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"setpay\"]\n  },\n  \"application/set-registration\": {\n    \"source\": \"iana\"\n  },\n  \"application/set-registration-initiation\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"setreg\"]\n  },\n  \"application/sgml\": {\n    \"source\": \"iana\"\n  },\n  \"application/sgml-open-catalog\": {\n    \"source\": \"iana\"\n  },\n  \"application/shf+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"shf\"]\n  },\n  \"application/sieve\": {\n    \"source\": \"iana\"\n  },\n  \"application/simple-filter+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/simple-message-summary\": {\n    \"source\": \"iana\"\n  },\n  \"application/simplesymbolcontainer\": {\n    \"source\": \"iana\"\n  },\n  \"application/slate\": {\n    \"source\": \"iana\"\n  },\n  \"application/smil\": {\n    \"source\": \"iana\"\n  },\n  \"application/smil+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"smi\",\"smil\"]\n  },\n  \"application/smpte336m\": {\n    \"source\": \"iana\"\n  },\n  \"application/soap+fastinfoset\": {\n    \"source\": \"iana\"\n  },\n  \"application/soap+xml\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/sparql-query\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"rq\"]\n  },\n  \"application/sparql-results+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"srx\"]\n  },\n  \"application/spirits-event+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/sql\": {\n    \"source\": \"iana\"\n  },\n  \"application/srgs\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"gram\"]\n  },\n  \"application/srgs+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"grxml\"]\n  },\n  \"application/sru+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"sru\"]\n  },\n  \"application/ssdl+xml\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"ssdl\"]\n  },\n  \"application/ssml+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ssml\"]\n  },\n  \"application/tamp-apex-update\": {\n    \"source\": \"iana\"\n  },\n  \"application/tamp-apex-update-confirm\": {\n    \"source\": \"iana\"\n  },\n  \"application/tamp-community-update\": {\n    \"source\": \"iana\"\n  },\n  \"application/tamp-community-update-confirm\": {\n    \"source\": \"iana\"\n  },\n  \"application/tamp-error\": {\n    \"source\": \"iana\"\n  },\n  \"application/tamp-sequence-adjust\": {\n    \"source\": \"iana\"\n  },\n  \"application/tamp-sequence-adjust-confirm\": {\n    \"source\": \"iana\"\n  },\n  \"application/tamp-status-query\": {\n    \"source\": \"iana\"\n  },\n  \"application/tamp-status-response\": {\n    \"source\": \"iana\"\n  },\n  \"application/tamp-update\": {\n    \"source\": \"iana\"\n  },\n  \"application/tamp-update-confirm\": {\n    \"source\": \"iana\"\n  },\n  \"application/tar\": {\n    \"compressible\": true\n  },\n  \"application/tei+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"tei\",\"teicorpus\"]\n  },\n  \"application/thraud+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"tfi\"]\n  },\n  \"application/timestamp-query\": {\n    \"source\": \"iana\"\n  },\n  \"application/timestamp-reply\": {\n    \"source\": \"iana\"\n  },\n  \"application/timestamped-data\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"tsd\"]\n  },\n  \"application/ttml+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/tve-trigger\": {\n    \"source\": \"iana\"\n  },\n  \"application/ulpfec\": {\n    \"source\": \"iana\"\n  },\n  \"application/urc-grpsheet+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/urc-ressheet+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/urc-targetdesc+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/urc-uisocketdesc+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vcard+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vcard+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vemmi\": {\n    \"source\": \"iana\"\n  },\n  \"application/vividence.scriptfile\": {\n    \"source\": \"apache\"\n  },\n  \"application/vnd.3gpp-prose+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.3gpp-prose-pc3ch+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.3gpp.access-transfer-events+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.3gpp.bsf+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.3gpp.mid-call+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.3gpp.pic-bw-large\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"plb\"]\n  },\n  \"application/vnd.3gpp.pic-bw-small\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"psb\"]\n  },\n  \"application/vnd.3gpp.pic-bw-var\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"pvb\"]\n  },\n  \"application/vnd.3gpp.sms\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.3gpp.srvcc-ext+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.3gpp.srvcc-info+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.3gpp.state-and-event-info+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.3gpp.ussd+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.3gpp2.bcmcsinfo+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.3gpp2.sms\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.3gpp2.tcap\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"tcap\"]\n  },\n  \"application/vnd.3m.post-it-notes\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"pwn\"]\n  },\n  \"application/vnd.accpac.simply.aso\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"aso\"]\n  },\n  \"application/vnd.accpac.simply.imp\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"imp\"]\n  },\n  \"application/vnd.acucobol\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"acu\"]\n  },\n  \"application/vnd.acucorp\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"atc\",\"acutc\"]\n  },\n  \"application/vnd.adobe.air-application-installer-package+zip\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"air\"]\n  },\n  \"application/vnd.adobe.flash.movie\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.adobe.formscentral.fcdt\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"fcdt\"]\n  },\n  \"application/vnd.adobe.fxp\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"fxp\",\"fxpl\"]\n  },\n  \"application/vnd.adobe.partial-upload\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.adobe.xdp+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xdp\"]\n  },\n  \"application/vnd.adobe.xfdf\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xfdf\"]\n  },\n  \"application/vnd.aether.imp\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ah-barcode\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ahead.space\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ahead\"]\n  },\n  \"application/vnd.airzip.filesecure.azf\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"azf\"]\n  },\n  \"application/vnd.airzip.filesecure.azs\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"azs\"]\n  },\n  \"application/vnd.amazon.ebook\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"azw\"]\n  },\n  \"application/vnd.americandynamics.acc\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"acc\"]\n  },\n  \"application/vnd.amiga.ami\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ami\"]\n  },\n  \"application/vnd.amundsen.maze+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.android.package-archive\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"apk\"]\n  },\n  \"application/vnd.anki\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.anser-web-certificate-issue-initiation\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cii\"]\n  },\n  \"application/vnd.anser-web-funds-transfer-initiation\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"fti\"]\n  },\n  \"application/vnd.antix.game-component\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"atx\"]\n  },\n  \"application/vnd.apache.thrift.binary\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.apache.thrift.compact\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.apache.thrift.json\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.api+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.apple.installer+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mpkg\"]\n  },\n  \"application/vnd.apple.mpegurl\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"m3u8\"]\n  },\n  \"application/vnd.apple.pkpass\": {\n    \"compressible\": false,\n    \"extensions\": [\"pkpass\"]\n  },\n  \"application/vnd.arastra.swi\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.aristanetworks.swi\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"swi\"]\n  },\n  \"application/vnd.artsquare\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.astraea-software.iota\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"iota\"]\n  },\n  \"application/vnd.audiograph\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"aep\"]\n  },\n  \"application/vnd.autopackage\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.avistar+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.balsamiq.bmml+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.balsamiq.bmpr\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.bekitzur-stech+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.biopax.rdf+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.blueice.multipass\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mpm\"]\n  },\n  \"application/vnd.bluetooth.ep.oob\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.bluetooth.le.oob\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.bmi\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"bmi\"]\n  },\n  \"application/vnd.businessobjects\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"rep\"]\n  },\n  \"application/vnd.cab-jscript\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.canon-cpdl\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.canon-lips\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.cendio.thinlinc.clientconf\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.century-systems.tcp_stream\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.chemdraw+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cdxml\"]\n  },\n  \"application/vnd.chipnuts.karaoke-mmd\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mmd\"]\n  },\n  \"application/vnd.cinderella\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cdy\"]\n  },\n  \"application/vnd.cirpack.isdn-ext\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.citationstyles.style+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.claymore\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cla\"]\n  },\n  \"application/vnd.cloanto.rp9\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"rp9\"]\n  },\n  \"application/vnd.clonk.c4group\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"c4g\",\"c4d\",\"c4f\",\"c4p\",\"c4u\"]\n  },\n  \"application/vnd.cluetrust.cartomobile-config\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"c11amc\"]\n  },\n  \"application/vnd.cluetrust.cartomobile-config-pkg\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"c11amz\"]\n  },\n  \"application/vnd.coffeescript\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.collection+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.collection.doc+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.collection.next+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.commerce-battelle\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.commonspace\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"csp\"]\n  },\n  \"application/vnd.contact.cmsg\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cdbcmsg\"]\n  },\n  \"application/vnd.cosmocaller\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cmc\"]\n  },\n  \"application/vnd.crick.clicker\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"clkx\"]\n  },\n  \"application/vnd.crick.clicker.keyboard\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"clkk\"]\n  },\n  \"application/vnd.crick.clicker.palette\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"clkp\"]\n  },\n  \"application/vnd.crick.clicker.template\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"clkt\"]\n  },\n  \"application/vnd.crick.clicker.wordbank\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"clkw\"]\n  },\n  \"application/vnd.criticaltools.wbs+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"wbs\"]\n  },\n  \"application/vnd.ctc-posml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"pml\"]\n  },\n  \"application/vnd.ctct.ws+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.cups-pdf\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.cups-postscript\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.cups-ppd\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ppd\"]\n  },\n  \"application/vnd.cups-raster\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.cups-raw\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.curl\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.curl.car\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"car\"]\n  },\n  \"application/vnd.curl.pcurl\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"pcurl\"]\n  },\n  \"application/vnd.cyan.dean.root+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.cybank\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dart\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"dart\"]\n  },\n  \"application/vnd.data-vision.rdz\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"rdz\"]\n  },\n  \"application/vnd.debian.binary-package\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dece.data\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"uvf\",\"uvvf\",\"uvd\",\"uvvd\"]\n  },\n  \"application/vnd.dece.ttml+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"uvt\",\"uvvt\"]\n  },\n  \"application/vnd.dece.unspecified\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"uvx\",\"uvvx\"]\n  },\n  \"application/vnd.dece.zip\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"uvz\",\"uvvz\"]\n  },\n  \"application/vnd.denovo.fcselayout-link\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"fe_launch\"]\n  },\n  \"application/vnd.desmume-movie\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dir-bi.plate-dl-nosuffix\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dm.delegation+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dna\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"dna\"]\n  },\n  \"application/vnd.document+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.dolby.mlp\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"mlp\"]\n  },\n  \"application/vnd.dolby.mobile.1\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dolby.mobile.2\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.doremir.scorecloud-binary-document\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dpgraph\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"dpg\"]\n  },\n  \"application/vnd.dreamfactory\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"dfac\"]\n  },\n  \"application/vnd.drive+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.ds-keypoint\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"kpxx\"]\n  },\n  \"application/vnd.dtg.local\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dtg.local.flash\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dtg.local.html\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dvb.ait\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ait\"]\n  },\n  \"application/vnd.dvb.dvbj\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dvb.esgcontainer\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dvb.ipdcdftnotifaccess\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dvb.ipdcesgaccess\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dvb.ipdcesgaccess2\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dvb.ipdcesgpdd\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dvb.ipdcroaming\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dvb.iptv.alfec-base\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dvb.iptv.alfec-enhancement\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dvb.notif-aggregate-root+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dvb.notif-container+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dvb.notif-generic+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dvb.notif-ia-msglist+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dvb.notif-ia-registration-request+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dvb.notif-ia-registration-response+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dvb.notif-init+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dvb.pfr\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dvb.service\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"svc\"]\n  },\n  \"application/vnd.dxr\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.dynageo\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"geo\"]\n  },\n  \"application/vnd.dzr\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.easykaraoke.cdgdownload\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ecdis-update\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ecowin.chart\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mag\"]\n  },\n  \"application/vnd.ecowin.filerequest\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ecowin.fileupdate\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ecowin.series\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ecowin.seriesrequest\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ecowin.seriesupdate\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.emclient.accessrequest+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.enliven\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"nml\"]\n  },\n  \"application/vnd.enphase.envoy\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.eprints.data+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.epson.esf\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"esf\"]\n  },\n  \"application/vnd.epson.msf\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"msf\"]\n  },\n  \"application/vnd.epson.quickanime\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"qam\"]\n  },\n  \"application/vnd.epson.salt\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"slt\"]\n  },\n  \"application/vnd.epson.ssf\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ssf\"]\n  },\n  \"application/vnd.ericsson.quickcall\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.eszigno3+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"es3\",\"et3\"]\n  },\n  \"application/vnd.etsi.aoc+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.asic-e+zip\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.asic-s+zip\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.cug+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.iptvcommand+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.iptvdiscovery+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.iptvprofile+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.iptvsad-bc+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.iptvsad-cod+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.iptvsad-npvr+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.iptvservice+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.iptvsync+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.iptvueprofile+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.mcid+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.mheg5\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.overload-control-policy-dataset+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.pstn+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.sci+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.simservs+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.timestamp-token\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.tsl+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.etsi.tsl.der\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.eudora.data\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ezpix-album\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ez2\"]\n  },\n  \"application/vnd.ezpix-package\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ez3\"]\n  },\n  \"application/vnd.f-secure.mobile\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.fastcopy-disk-image\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.fdf\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"fdf\"]\n  },\n  \"application/vnd.fdsn.mseed\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mseed\"]\n  },\n  \"application/vnd.fdsn.seed\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"seed\",\"dataless\"]\n  },\n  \"application/vnd.ffsns\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.filmit.zfc\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.fints\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.firemonkeys.cloudcell\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.flographit\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"gph\"]\n  },\n  \"application/vnd.fluxtime.clip\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ftc\"]\n  },\n  \"application/vnd.font-fontforge-sfd\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.framemaker\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"fm\",\"frame\",\"maker\",\"book\"]\n  },\n  \"application/vnd.frogans.fnc\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"fnc\"]\n  },\n  \"application/vnd.frogans.ltf\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ltf\"]\n  },\n  \"application/vnd.fsc.weblaunch\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"fsc\"]\n  },\n  \"application/vnd.fujitsu.oasys\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"oas\"]\n  },\n  \"application/vnd.fujitsu.oasys2\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"oa2\"]\n  },\n  \"application/vnd.fujitsu.oasys3\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"oa3\"]\n  },\n  \"application/vnd.fujitsu.oasysgp\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"fg5\"]\n  },\n  \"application/vnd.fujitsu.oasysprs\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"bh2\"]\n  },\n  \"application/vnd.fujixerox.art-ex\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.fujixerox.art4\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.fujixerox.ddd\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ddd\"]\n  },\n  \"application/vnd.fujixerox.docuworks\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xdw\"]\n  },\n  \"application/vnd.fujixerox.docuworks.binder\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xbd\"]\n  },\n  \"application/vnd.fujixerox.docuworks.container\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.fujixerox.hbpl\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.fut-misnet\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.fuzzysheet\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"fzs\"]\n  },\n  \"application/vnd.genomatix.tuxedo\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"txd\"]\n  },\n  \"application/vnd.geo+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.geocube+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.geogebra.file\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ggb\"]\n  },\n  \"application/vnd.geogebra.tool\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ggt\"]\n  },\n  \"application/vnd.geometry-explorer\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"gex\",\"gre\"]\n  },\n  \"application/vnd.geonext\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"gxt\"]\n  },\n  \"application/vnd.geoplan\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"g2w\"]\n  },\n  \"application/vnd.geospace\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"g3w\"]\n  },\n  \"application/vnd.gerber\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.globalplatform.card-content-mgt\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.globalplatform.card-content-mgt-response\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.gmx\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"gmx\"]\n  },\n  \"application/vnd.google-apps.document\": {\n    \"compressible\": false,\n    \"extensions\": [\"gdoc\"]\n  },\n  \"application/vnd.google-apps.presentation\": {\n    \"compressible\": false,\n    \"extensions\": [\"gslides\"]\n  },\n  \"application/vnd.google-apps.spreadsheet\": {\n    \"compressible\": false,\n    \"extensions\": [\"gsheet\"]\n  },\n  \"application/vnd.google-earth.kml+xml\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"kml\"]\n  },\n  \"application/vnd.google-earth.kmz\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"kmz\"]\n  },\n  \"application/vnd.gov.sk.e-form+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.gov.sk.e-form+zip\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.gov.sk.xmldatacontainer+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.grafeq\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"gqf\",\"gqs\"]\n  },\n  \"application/vnd.gridmp\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.groove-account\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"gac\"]\n  },\n  \"application/vnd.groove-help\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ghf\"]\n  },\n  \"application/vnd.groove-identity-message\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"gim\"]\n  },\n  \"application/vnd.groove-injector\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"grv\"]\n  },\n  \"application/vnd.groove-tool-message\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"gtm\"]\n  },\n  \"application/vnd.groove-tool-template\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"tpl\"]\n  },\n  \"application/vnd.groove-vcard\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"vcg\"]\n  },\n  \"application/vnd.hal+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.hal+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"hal\"]\n  },\n  \"application/vnd.handheld-entertainment+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"zmm\"]\n  },\n  \"application/vnd.hbci\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"hbci\"]\n  },\n  \"application/vnd.hcl-bireports\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.hdt\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.heroku+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.hhe.lesson-player\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"les\"]\n  },\n  \"application/vnd.hp-hpgl\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"hpgl\"]\n  },\n  \"application/vnd.hp-hpid\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"hpid\"]\n  },\n  \"application/vnd.hp-hps\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"hps\"]\n  },\n  \"application/vnd.hp-jlyt\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"jlt\"]\n  },\n  \"application/vnd.hp-pcl\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"pcl\"]\n  },\n  \"application/vnd.hp-pclxl\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"pclxl\"]\n  },\n  \"application/vnd.httphone\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.hydrostatix.sof-data\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"sfd-hdstx\"]\n  },\n  \"application/vnd.hyperdrive+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.hzn-3d-crossword\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ibm.afplinedata\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ibm.electronic-media\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ibm.minipay\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mpy\"]\n  },\n  \"application/vnd.ibm.modcap\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"afp\",\"listafp\",\"list3820\"]\n  },\n  \"application/vnd.ibm.rights-management\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"irm\"]\n  },\n  \"application/vnd.ibm.secure-container\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"sc\"]\n  },\n  \"application/vnd.iccprofile\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"icc\",\"icm\"]\n  },\n  \"application/vnd.ieee.1905\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.igloader\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"igl\"]\n  },\n  \"application/vnd.immervision-ivp\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ivp\"]\n  },\n  \"application/vnd.immervision-ivu\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ivu\"]\n  },\n  \"application/vnd.ims.imsccv1p1\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ims.imsccv1p2\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ims.imsccv1p3\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ims.lis.v2.result+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.ims.lti.v2.toolconsumerprofile+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.ims.lti.v2.toolproxy+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.ims.lti.v2.toolproxy.id+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.ims.lti.v2.toolsettings+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.ims.lti.v2.toolsettings.simple+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.informedcontrol.rms+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.informix-visionary\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.infotech.project\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.infotech.project+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.innopath.wamp.notification\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.insors.igm\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"igm\"]\n  },\n  \"application/vnd.intercon.formnet\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xpw\",\"xpx\"]\n  },\n  \"application/vnd.intergeo\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"i2g\"]\n  },\n  \"application/vnd.intertrust.digibox\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.intertrust.nncp\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.intu.qbo\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"qbo\"]\n  },\n  \"application/vnd.intu.qfx\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"qfx\"]\n  },\n  \"application/vnd.iptc.g2.catalogitem+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.iptc.g2.conceptitem+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.iptc.g2.knowledgeitem+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.iptc.g2.newsitem+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.iptc.g2.newsmessage+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.iptc.g2.packageitem+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.iptc.g2.planningitem+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ipunplugged.rcprofile\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"rcprofile\"]\n  },\n  \"application/vnd.irepository.package+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"irp\"]\n  },\n  \"application/vnd.is-xpr\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xpr\"]\n  },\n  \"application/vnd.isac.fcs\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"fcs\"]\n  },\n  \"application/vnd.jam\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"jam\"]\n  },\n  \"application/vnd.japannet-directory-service\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.japannet-jpnstore-wakeup\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.japannet-payment-wakeup\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.japannet-registration\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.japannet-registration-wakeup\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.japannet-setstore-wakeup\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.japannet-verification\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.japannet-verification-wakeup\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.jcp.javame.midlet-rms\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"rms\"]\n  },\n  \"application/vnd.jisp\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"jisp\"]\n  },\n  \"application/vnd.joost.joda-archive\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"joda\"]\n  },\n  \"application/vnd.jsk.isdn-ngn\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.kahootz\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ktz\",\"ktr\"]\n  },\n  \"application/vnd.kde.karbon\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"karbon\"]\n  },\n  \"application/vnd.kde.kchart\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"chrt\"]\n  },\n  \"application/vnd.kde.kformula\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"kfo\"]\n  },\n  \"application/vnd.kde.kivio\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"flw\"]\n  },\n  \"application/vnd.kde.kontour\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"kon\"]\n  },\n  \"application/vnd.kde.kpresenter\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"kpr\",\"kpt\"]\n  },\n  \"application/vnd.kde.kspread\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ksp\"]\n  },\n  \"application/vnd.kde.kword\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"kwd\",\"kwt\"]\n  },\n  \"application/vnd.kenameaapp\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"htke\"]\n  },\n  \"application/vnd.kidspiration\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"kia\"]\n  },\n  \"application/vnd.kinar\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"kne\",\"knp\"]\n  },\n  \"application/vnd.koan\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"skp\",\"skd\",\"skt\",\"skm\"]\n  },\n  \"application/vnd.kodak-descriptor\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"sse\"]\n  },\n  \"application/vnd.las.las+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"lasxml\"]\n  },\n  \"application/vnd.liberty-request+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.llamagraphics.life-balance.desktop\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"lbd\"]\n  },\n  \"application/vnd.llamagraphics.life-balance.exchange+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"lbe\"]\n  },\n  \"application/vnd.lotus-1-2-3\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"123\"]\n  },\n  \"application/vnd.lotus-approach\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"apr\"]\n  },\n  \"application/vnd.lotus-freelance\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"pre\"]\n  },\n  \"application/vnd.lotus-notes\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"nsf\"]\n  },\n  \"application/vnd.lotus-organizer\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"org\"]\n  },\n  \"application/vnd.lotus-screencam\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"scm\"]\n  },\n  \"application/vnd.lotus-wordpro\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"lwp\"]\n  },\n  \"application/vnd.macports.portpkg\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"portpkg\"]\n  },\n  \"application/vnd.mapbox-vector-tile\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.marlin.drm.actiontoken+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.marlin.drm.conftoken+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.marlin.drm.license+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.marlin.drm.mdcf\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.mason+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.maxmind.maxmind-db\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.mcd\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mcd\"]\n  },\n  \"application/vnd.medcalcdata\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mc1\"]\n  },\n  \"application/vnd.mediastation.cdkey\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cdkey\"]\n  },\n  \"application/vnd.meridian-slingshot\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.mfer\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mwf\"]\n  },\n  \"application/vnd.mfmp\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mfm\"]\n  },\n  \"application/vnd.micro+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.micrografx.flo\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"flo\"]\n  },\n  \"application/vnd.micrografx.igx\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"igx\"]\n  },\n  \"application/vnd.microsoft.portable-executable\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.miele+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.mif\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mif\"]\n  },\n  \"application/vnd.minisoft-hp3000-save\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.mitsubishi.misty-guard.trustweb\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.mobius.daf\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"daf\"]\n  },\n  \"application/vnd.mobius.dis\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"dis\"]\n  },\n  \"application/vnd.mobius.mbk\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mbk\"]\n  },\n  \"application/vnd.mobius.mqy\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mqy\"]\n  },\n  \"application/vnd.mobius.msl\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"msl\"]\n  },\n  \"application/vnd.mobius.plc\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"plc\"]\n  },\n  \"application/vnd.mobius.txf\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"txf\"]\n  },\n  \"application/vnd.mophun.application\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mpn\"]\n  },\n  \"application/vnd.mophun.certificate\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mpc\"]\n  },\n  \"application/vnd.motorola.flexsuite\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.motorola.flexsuite.adsi\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.motorola.flexsuite.fis\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.motorola.flexsuite.gotap\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.motorola.flexsuite.kmr\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.motorola.flexsuite.ttc\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.motorola.flexsuite.wem\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.motorola.iprm\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.mozilla.xul+xml\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"xul\"]\n  },\n  \"application/vnd.ms-3mfdocument\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ms-artgalry\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cil\"]\n  },\n  \"application/vnd.ms-asf\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ms-cab-compressed\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cab\"]\n  },\n  \"application/vnd.ms-color.iccprofile\": {\n    \"source\": \"apache\"\n  },\n  \"application/vnd.ms-excel\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"xls\",\"xlm\",\"xla\",\"xlc\",\"xlt\",\"xlw\"]\n  },\n  \"application/vnd.ms-excel.addin.macroenabled.12\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xlam\"]\n  },\n  \"application/vnd.ms-excel.sheet.binary.macroenabled.12\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xlsb\"]\n  },\n  \"application/vnd.ms-excel.sheet.macroenabled.12\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xlsm\"]\n  },\n  \"application/vnd.ms-excel.template.macroenabled.12\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xltm\"]\n  },\n  \"application/vnd.ms-fontobject\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"eot\"]\n  },\n  \"application/vnd.ms-htmlhelp\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"chm\"]\n  },\n  \"application/vnd.ms-ims\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ims\"]\n  },\n  \"application/vnd.ms-lrm\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"lrm\"]\n  },\n  \"application/vnd.ms-office.activex+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ms-officetheme\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"thmx\"]\n  },\n  \"application/vnd.ms-opentype\": {\n    \"source\": \"apache\",\n    \"compressible\": true\n  },\n  \"application/vnd.ms-package.obfuscated-opentype\": {\n    \"source\": \"apache\"\n  },\n  \"application/vnd.ms-pki.seccat\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"cat\"]\n  },\n  \"application/vnd.ms-pki.stl\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"stl\"]\n  },\n  \"application/vnd.ms-playready.initiator+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ms-powerpoint\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"ppt\",\"pps\",\"pot\"]\n  },\n  \"application/vnd.ms-powerpoint.addin.macroenabled.12\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ppam\"]\n  },\n  \"application/vnd.ms-powerpoint.presentation.macroenabled.12\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"pptm\"]\n  },\n  \"application/vnd.ms-powerpoint.slide.macroenabled.12\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"sldm\"]\n  },\n  \"application/vnd.ms-powerpoint.slideshow.macroenabled.12\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ppsm\"]\n  },\n  \"application/vnd.ms-powerpoint.template.macroenabled.12\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"potm\"]\n  },\n  \"application/vnd.ms-printdevicecapabilities+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ms-printing.printticket+xml\": {\n    \"source\": \"apache\"\n  },\n  \"application/vnd.ms-printschematicket+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ms-project\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mpp\",\"mpt\"]\n  },\n  \"application/vnd.ms-tnef\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ms-windows.devicepairing\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ms-windows.nwprinting.oob\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ms-windows.printerpairing\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ms-windows.wsd.oob\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ms-wmdrm.lic-chlg-req\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ms-wmdrm.lic-resp\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ms-wmdrm.meter-chlg-req\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ms-wmdrm.meter-resp\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ms-word.document.macroenabled.12\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"docm\"]\n  },\n  \"application/vnd.ms-word.template.macroenabled.12\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"dotm\"]\n  },\n  \"application/vnd.ms-works\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"wps\",\"wks\",\"wcm\",\"wdb\"]\n  },\n  \"application/vnd.ms-wpl\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"wpl\"]\n  },\n  \"application/vnd.ms-xpsdocument\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"xps\"]\n  },\n  \"application/vnd.msa-disk-image\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.mseq\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mseq\"]\n  },\n  \"application/vnd.msign\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.multiad.creator\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.multiad.creator.cif\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.music-niff\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.musician\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mus\"]\n  },\n  \"application/vnd.muvee.style\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"msty\"]\n  },\n  \"application/vnd.mynfc\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"taglet\"]\n  },\n  \"application/vnd.ncd.control\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ncd.reference\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.nervana\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.netfpx\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.neurolanguage.nlu\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"nlu\"]\n  },\n  \"application/vnd.nintendo.nitro.rom\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.nintendo.snes.rom\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.nitf\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ntf\",\"nitf\"]\n  },\n  \"application/vnd.noblenet-directory\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"nnd\"]\n  },\n  \"application/vnd.noblenet-sealer\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"nns\"]\n  },\n  \"application/vnd.noblenet-web\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"nnw\"]\n  },\n  \"application/vnd.nokia.catalogs\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.nokia.conml+wbxml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.nokia.conml+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.nokia.iptv.config+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.nokia.isds-radio-presets\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.nokia.landmark+wbxml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.nokia.landmark+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.nokia.landmarkcollection+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.nokia.n-gage.ac+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.nokia.n-gage.data\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ngdat\"]\n  },\n  \"application/vnd.nokia.n-gage.symbian.install\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"n-gage\"]\n  },\n  \"application/vnd.nokia.ncd\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.nokia.pcd+wbxml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.nokia.pcd+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.nokia.radio-preset\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"rpst\"]\n  },\n  \"application/vnd.nokia.radio-presets\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"rpss\"]\n  },\n  \"application/vnd.novadigm.edm\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"edm\"]\n  },\n  \"application/vnd.novadigm.edx\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"edx\"]\n  },\n  \"application/vnd.novadigm.ext\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ext\"]\n  },\n  \"application/vnd.ntt-local.content-share\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ntt-local.file-transfer\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ntt-local.ogw_remote-access\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ntt-local.sip-ta_remote\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ntt-local.sip-ta_tcp_stream\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oasis.opendocument.chart\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"odc\"]\n  },\n  \"application/vnd.oasis.opendocument.chart-template\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"otc\"]\n  },\n  \"application/vnd.oasis.opendocument.database\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"odb\"]\n  },\n  \"application/vnd.oasis.opendocument.formula\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"odf\"]\n  },\n  \"application/vnd.oasis.opendocument.formula-template\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"odft\"]\n  },\n  \"application/vnd.oasis.opendocument.graphics\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"odg\"]\n  },\n  \"application/vnd.oasis.opendocument.graphics-template\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"otg\"]\n  },\n  \"application/vnd.oasis.opendocument.image\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"odi\"]\n  },\n  \"application/vnd.oasis.opendocument.image-template\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"oti\"]\n  },\n  \"application/vnd.oasis.opendocument.presentation\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"odp\"]\n  },\n  \"application/vnd.oasis.opendocument.presentation-template\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"otp\"]\n  },\n  \"application/vnd.oasis.opendocument.spreadsheet\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"ods\"]\n  },\n  \"application/vnd.oasis.opendocument.spreadsheet-template\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ots\"]\n  },\n  \"application/vnd.oasis.opendocument.text\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"odt\"]\n  },\n  \"application/vnd.oasis.opendocument.text-master\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"odm\"]\n  },\n  \"application/vnd.oasis.opendocument.text-template\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ott\"]\n  },\n  \"application/vnd.oasis.opendocument.text-web\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"oth\"]\n  },\n  \"application/vnd.obn\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oftn.l10n+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.oipf.contentaccessdownload+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oipf.contentaccessstreaming+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oipf.cspg-hexbinary\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oipf.dae.svg+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oipf.dae.xhtml+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oipf.mippvcontrolmessage+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oipf.pae.gem\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oipf.spdiscovery+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oipf.spdlist+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oipf.ueprofile+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oipf.userprofile+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.olpc-sugar\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xo\"]\n  },\n  \"application/vnd.oma-scws-config\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma-scws-http-request\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma-scws-http-response\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.bcast.associated-procedure-parameter+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.bcast.drm-trigger+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.bcast.imd+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.bcast.ltkm\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.bcast.notification+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.bcast.provisioningtrigger\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.bcast.sgboot\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.bcast.sgdd+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.bcast.sgdu\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.bcast.simple-symbol-container\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.bcast.smartcard-trigger+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.bcast.sprov+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.bcast.stkm\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.cab-address-book+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.cab-feature-handler+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.cab-pcc+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.cab-subs-invite+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.cab-user-prefs+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.dcd\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.dcdc\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.dd2+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"dd2\"]\n  },\n  \"application/vnd.oma.drm.risd+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.group-usage-list+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.pal+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.poc.detailed-progress-report+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.poc.final-report+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.poc.groups+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.poc.invocation-descriptor+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.poc.optimized-progress-report+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.push\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.scidm.messages+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oma.xcap-directory+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.omads-email+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.omads-file+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.omads-folder+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.omaloc-supl-init\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openblox.game+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openblox.game-binary\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openeye.oeb\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openofficeorg.extension\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"oxt\"]\n  },\n  \"application/vnd.openxmlformats-officedocument.custom-properties+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.customxmlproperties+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.drawing+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.drawingml.chart+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.drawingml.chartshapes+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.drawingml.diagramcolors+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.drawingml.diagramdata+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.drawingml.diagramlayout+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.drawingml.diagramstyle+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.extended-properties+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml-template\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.commentauthors+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.comments+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.handoutmaster+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.notesmaster+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.notesslide+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.presentation\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"pptx\"]\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.presentation.main+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.presprops+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.slide\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"sldx\"]\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.slide+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.slidelayout+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.slidemaster+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.slideshow\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ppsx\"]\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.slideshow.main+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.slideupdateinfo+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.tablestyles+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.tags+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.template\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"potx\"]\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.template.main+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.presentationml.viewprops+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml-template\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.calcchain+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.chartsheet+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.comments+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.connections+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.dialogsheet+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.externallink+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotcachedefinition+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotcacherecords+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.pivottable+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.querytable+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.revisionheaders+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.revisionlog+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.sharedstrings+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"xlsx\"]\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.sheetmetadata+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.table+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.tablesinglecells+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.template\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"xltx\"]\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.template.main+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.usernames+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.volatiledependencies+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.theme+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.themeoverride+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.vmldrawing\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.wordprocessingml-template\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.wordprocessingml.comments+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.wordprocessingml.document\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"docx\"]\n  },\n  \"application/vnd.openxmlformats-officedocument.wordprocessingml.document.glossary+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.wordprocessingml.document.main+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.wordprocessingml.endnotes+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.wordprocessingml.fonttable+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.wordprocessingml.footer+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.wordprocessingml.footnotes+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.wordprocessingml.numbering+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.wordprocessingml.settings+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.wordprocessingml.styles+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.wordprocessingml.template\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"dotx\"]\n  },\n  \"application/vnd.openxmlformats-officedocument.wordprocessingml.template.main+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-officedocument.wordprocessingml.websettings+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-package.core-properties+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-package.digital-signature-xmlsignature+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.openxmlformats-package.relationships+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oracle.resource+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.orange.indata\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.osa.netdeploy\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.osgeo.mapguide.package\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mgp\"]\n  },\n  \"application/vnd.osgi.bundle\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.osgi.dp\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"dp\"]\n  },\n  \"application/vnd.osgi.subsystem\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"esa\"]\n  },\n  \"application/vnd.otps.ct-kip+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.oxli.countgraph\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.pagerduty+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.palm\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"pdb\",\"pqa\",\"oprc\"]\n  },\n  \"application/vnd.panoply\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.paos+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.paos.xml\": {\n    \"source\": \"apache\"\n  },\n  \"application/vnd.pawaafile\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"paw\"]\n  },\n  \"application/vnd.pcos\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.pg.format\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"str\"]\n  },\n  \"application/vnd.pg.osasli\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ei6\"]\n  },\n  \"application/vnd.piaccess.application-licence\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.picsel\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"efif\"]\n  },\n  \"application/vnd.pmi.widget\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"wg\"]\n  },\n  \"application/vnd.poc.group-advertisement+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.pocketlearn\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"plf\"]\n  },\n  \"application/vnd.powerbuilder6\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"pbd\"]\n  },\n  \"application/vnd.powerbuilder6-s\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.powerbuilder7\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.powerbuilder7-s\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.powerbuilder75\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.powerbuilder75-s\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.preminet\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.previewsystems.box\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"box\"]\n  },\n  \"application/vnd.proteus.magazine\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mgz\"]\n  },\n  \"application/vnd.publishare-delta-tree\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"qps\"]\n  },\n  \"application/vnd.pvi.ptid1\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ptid\"]\n  },\n  \"application/vnd.pwg-multiplexed\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.pwg-xhtml-print+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.qualcomm.brew-app-res\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.quark.quarkxpress\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"qxd\",\"qxt\",\"qwd\",\"qwt\",\"qxl\",\"qxb\"]\n  },\n  \"application/vnd.quobject-quoxdocument\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.radisys.moml+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.radisys.msml+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.radisys.msml-audit+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.radisys.msml-audit-conf+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.radisys.msml-audit-conn+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.radisys.msml-audit-dialog+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.radisys.msml-audit-stream+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.radisys.msml-conf+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.radisys.msml-dialog+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.radisys.msml-dialog-base+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.radisys.msml-dialog-fax-detect+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.radisys.msml-dialog-fax-sendrecv+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.radisys.msml-dialog-group+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.radisys.msml-dialog-speech+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.radisys.msml-dialog-transform+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.rainstor.data\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.rapid\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.realvnc.bed\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"bed\"]\n  },\n  \"application/vnd.recordare.musicxml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mxl\"]\n  },\n  \"application/vnd.recordare.musicxml+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"musicxml\"]\n  },\n  \"application/vnd.renlearn.rlprint\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.rig.cryptonote\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cryptonote\"]\n  },\n  \"application/vnd.rim.cod\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"cod\"]\n  },\n  \"application/vnd.rn-realmedia\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"rm\"]\n  },\n  \"application/vnd.rn-realmedia-vbr\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"rmvb\"]\n  },\n  \"application/vnd.route66.link66+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"link66\"]\n  },\n  \"application/vnd.rs-274x\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ruckus.download\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.s3sms\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.sailingtracker.track\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"st\"]\n  },\n  \"application/vnd.sbm.cid\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.sbm.mid2\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.scribus\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.sealed.3df\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.sealed.csf\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.sealed.doc\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.sealed.eml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.sealed.mht\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.sealed.net\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.sealed.ppt\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.sealed.tiff\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.sealed.xls\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.sealedmedia.softseal.html\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.sealedmedia.softseal.pdf\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.seemail\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"see\"]\n  },\n  \"application/vnd.sema\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"sema\"]\n  },\n  \"application/vnd.semd\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"semd\"]\n  },\n  \"application/vnd.semf\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"semf\"]\n  },\n  \"application/vnd.shana.informed.formdata\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ifm\"]\n  },\n  \"application/vnd.shana.informed.formtemplate\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"itp\"]\n  },\n  \"application/vnd.shana.informed.interchange\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"iif\"]\n  },\n  \"application/vnd.shana.informed.package\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ipk\"]\n  },\n  \"application/vnd.simtech-mindmapper\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"twd\",\"twds\"]\n  },\n  \"application/vnd.siren+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.smaf\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mmf\"]\n  },\n  \"application/vnd.smart.notebook\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.smart.teacher\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"teacher\"]\n  },\n  \"application/vnd.software602.filler.form+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.software602.filler.form-xml-zip\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.solent.sdkm+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"sdkm\",\"sdkd\"]\n  },\n  \"application/vnd.spotfire.dxp\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"dxp\"]\n  },\n  \"application/vnd.spotfire.sfs\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"sfs\"]\n  },\n  \"application/vnd.sss-cod\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.sss-dtf\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.sss-ntf\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.stardivision.calc\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sdc\"]\n  },\n  \"application/vnd.stardivision.draw\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sda\"]\n  },\n  \"application/vnd.stardivision.impress\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sdd\"]\n  },\n  \"application/vnd.stardivision.math\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"smf\"]\n  },\n  \"application/vnd.stardivision.writer\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sdw\",\"vor\"]\n  },\n  \"application/vnd.stardivision.writer-global\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sgl\"]\n  },\n  \"application/vnd.stepmania.package\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"smzip\"]\n  },\n  \"application/vnd.stepmania.stepchart\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"sm\"]\n  },\n  \"application/vnd.street-stream\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.sun.wadl+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.sun.xml.calc\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sxc\"]\n  },\n  \"application/vnd.sun.xml.calc.template\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"stc\"]\n  },\n  \"application/vnd.sun.xml.draw\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sxd\"]\n  },\n  \"application/vnd.sun.xml.draw.template\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"std\"]\n  },\n  \"application/vnd.sun.xml.impress\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sxi\"]\n  },\n  \"application/vnd.sun.xml.impress.template\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sti\"]\n  },\n  \"application/vnd.sun.xml.math\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sxm\"]\n  },\n  \"application/vnd.sun.xml.writer\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sxw\"]\n  },\n  \"application/vnd.sun.xml.writer.global\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sxg\"]\n  },\n  \"application/vnd.sun.xml.writer.template\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"stw\"]\n  },\n  \"application/vnd.sus-calendar\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"sus\",\"susp\"]\n  },\n  \"application/vnd.svd\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"svd\"]\n  },\n  \"application/vnd.swiftview-ics\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.symbian.install\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sis\",\"sisx\"]\n  },\n  \"application/vnd.syncml+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xsm\"]\n  },\n  \"application/vnd.syncml.dm+wbxml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"bdm\"]\n  },\n  \"application/vnd.syncml.dm+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xdm\"]\n  },\n  \"application/vnd.syncml.dm.notification\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.syncml.dmddf+wbxml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.syncml.dmddf+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.syncml.dmtnds+wbxml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.syncml.dmtnds+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.syncml.ds.notification\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.tao.intent-module-archive\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"tao\"]\n  },\n  \"application/vnd.tcpdump.pcap\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"pcap\",\"cap\",\"dmp\"]\n  },\n  \"application/vnd.tmd.mediaflex.api+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.tml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.tmobile-livetv\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"tmo\"]\n  },\n  \"application/vnd.trid.tpt\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"tpt\"]\n  },\n  \"application/vnd.triscape.mxs\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mxs\"]\n  },\n  \"application/vnd.trueapp\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"tra\"]\n  },\n  \"application/vnd.truedoc\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ubisoft.webplayer\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.ufdl\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ufd\",\"ufdl\"]\n  },\n  \"application/vnd.uiq.theme\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"utz\"]\n  },\n  \"application/vnd.umajin\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"umj\"]\n  },\n  \"application/vnd.unity\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"unityweb\"]\n  },\n  \"application/vnd.uoml+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"uoml\"]\n  },\n  \"application/vnd.uplanet.alert\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.uplanet.alert-wbxml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.uplanet.bearer-choice\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.uplanet.bearer-choice-wbxml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.uplanet.cacheop\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.uplanet.cacheop-wbxml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.uplanet.channel\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.uplanet.channel-wbxml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.uplanet.list\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.uplanet.list-wbxml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.uplanet.listcmd\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.uplanet.listcmd-wbxml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.uplanet.signal\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.uri-map\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.valve.source.material\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.vcx\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"vcx\"]\n  },\n  \"application/vnd.vd-study\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.vectorworks\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.verimatrix.vcas\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.vidsoft.vidconference\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.visio\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"vsd\",\"vst\",\"vss\",\"vsw\"]\n  },\n  \"application/vnd.visionary\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"vis\"]\n  },\n  \"application/vnd.vividence.scriptfile\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.vsf\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"vsf\"]\n  },\n  \"application/vnd.wap.sic\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.wap.slc\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.wap.wbxml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"wbxml\"]\n  },\n  \"application/vnd.wap.wmlc\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"wmlc\"]\n  },\n  \"application/vnd.wap.wmlscriptc\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"wmlsc\"]\n  },\n  \"application/vnd.webturbo\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"wtb\"]\n  },\n  \"application/vnd.wfa.p2p\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.wfa.wsc\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.windows.devicepairing\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.wmc\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.wmf.bootstrap\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.wolfram.mathematica\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.wolfram.mathematica.package\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.wolfram.player\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"nbp\"]\n  },\n  \"application/vnd.wordperfect\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"wpd\"]\n  },\n  \"application/vnd.wqd\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"wqd\"]\n  },\n  \"application/vnd.wrq-hp3000-labelled\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.wt.stf\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"stf\"]\n  },\n  \"application/vnd.wv.csp+wbxml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.wv.csp+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.wv.ssp+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.xacml+json\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/vnd.xara\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xar\"]\n  },\n  \"application/vnd.xfdl\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xfdl\"]\n  },\n  \"application/vnd.xfdl.webform\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.xmi+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.xmpie.cpkg\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.xmpie.dpkg\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.xmpie.plan\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.xmpie.ppkg\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.xmpie.xlim\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.yamaha.hv-dic\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"hvd\"]\n  },\n  \"application/vnd.yamaha.hv-script\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"hvs\"]\n  },\n  \"application/vnd.yamaha.hv-voice\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"hvp\"]\n  },\n  \"application/vnd.yamaha.openscoreformat\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"osf\"]\n  },\n  \"application/vnd.yamaha.openscoreformat.osfpvg+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"osfpvg\"]\n  },\n  \"application/vnd.yamaha.remote-setup\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.yamaha.smaf-audio\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"saf\"]\n  },\n  \"application/vnd.yamaha.smaf-phrase\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"spf\"]\n  },\n  \"application/vnd.yamaha.through-ngn\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.yamaha.tunnel-udpencap\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.yaoweme\": {\n    \"source\": \"iana\"\n  },\n  \"application/vnd.yellowriver-custom-menu\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cmp\"]\n  },\n  \"application/vnd.zul\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"zir\",\"zirz\"]\n  },\n  \"application/vnd.zzazz.deck+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"zaz\"]\n  },\n  \"application/voicexml+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"vxml\"]\n  },\n  \"application/vq-rtcpxr\": {\n    \"source\": \"iana\"\n  },\n  \"application/watcherinfo+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/whoispp-query\": {\n    \"source\": \"iana\"\n  },\n  \"application/whoispp-response\": {\n    \"source\": \"iana\"\n  },\n  \"application/widget\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"wgt\"]\n  },\n  \"application/winhlp\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"hlp\"]\n  },\n  \"application/wita\": {\n    \"source\": \"iana\"\n  },\n  \"application/wordperfect5.1\": {\n    \"source\": \"iana\"\n  },\n  \"application/wsdl+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"wsdl\"]\n  },\n  \"application/wspolicy+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"wspolicy\"]\n  },\n  \"application/x-7z-compressed\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"7z\"]\n  },\n  \"application/x-abiword\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"abw\"]\n  },\n  \"application/x-ace-compressed\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"ace\"]\n  },\n  \"application/x-amf\": {\n    \"source\": \"apache\"\n  },\n  \"application/x-apple-diskimage\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"dmg\"]\n  },\n  \"application/x-authorware-bin\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"aab\",\"x32\",\"u32\",\"vox\"]\n  },\n  \"application/x-authorware-map\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"aam\"]\n  },\n  \"application/x-authorware-seg\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"aas\"]\n  },\n  \"application/x-bcpio\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"bcpio\"]\n  },\n  \"application/x-bdoc\": {\n    \"compressible\": false,\n    \"extensions\": [\"bdoc\"]\n  },\n  \"application/x-bittorrent\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"torrent\"]\n  },\n  \"application/x-blorb\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"blb\",\"blorb\"]\n  },\n  \"application/x-bzip\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"bz\"]\n  },\n  \"application/x-bzip2\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"bz2\",\"boz\"]\n  },\n  \"application/x-cbr\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"cbr\",\"cba\",\"cbt\",\"cbz\",\"cb7\"]\n  },\n  \"application/x-cdlink\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"vcd\"]\n  },\n  \"application/x-cfs-compressed\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"cfs\"]\n  },\n  \"application/x-chat\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"chat\"]\n  },\n  \"application/x-chess-pgn\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"pgn\"]\n  },\n  \"application/x-chrome-extension\": {\n    \"extensions\": [\"crx\"]\n  },\n  \"application/x-cocoa\": {\n    \"source\": \"nginx\",\n    \"extensions\": [\"cco\"]\n  },\n  \"application/x-compress\": {\n    \"source\": \"apache\"\n  },\n  \"application/x-conference\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"nsc\"]\n  },\n  \"application/x-cpio\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"cpio\"]\n  },\n  \"application/x-csh\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"csh\"]\n  },\n  \"application/x-deb\": {\n    \"compressible\": false\n  },\n  \"application/x-debian-package\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"deb\",\"udeb\"]\n  },\n  \"application/x-dgc-compressed\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"dgc\"]\n  },\n  \"application/x-director\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"dir\",\"dcr\",\"dxr\",\"cst\",\"cct\",\"cxt\",\"w3d\",\"fgd\",\"swa\"]\n  },\n  \"application/x-doom\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"wad\"]\n  },\n  \"application/x-dtbncx+xml\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"ncx\"]\n  },\n  \"application/x-dtbook+xml\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"dtb\"]\n  },\n  \"application/x-dtbresource+xml\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"res\"]\n  },\n  \"application/x-dvi\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"dvi\"]\n  },\n  \"application/x-envoy\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"evy\"]\n  },\n  \"application/x-eva\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"eva\"]\n  },\n  \"application/x-font-bdf\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"bdf\"]\n  },\n  \"application/x-font-dos\": {\n    \"source\": \"apache\"\n  },\n  \"application/x-font-framemaker\": {\n    \"source\": \"apache\"\n  },\n  \"application/x-font-ghostscript\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"gsf\"]\n  },\n  \"application/x-font-libgrx\": {\n    \"source\": \"apache\"\n  },\n  \"application/x-font-linux-psf\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"psf\"]\n  },\n  \"application/x-font-otf\": {\n    \"source\": \"apache\",\n    \"compressible\": true,\n    \"extensions\": [\"otf\"]\n  },\n  \"application/x-font-pcf\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"pcf\"]\n  },\n  \"application/x-font-snf\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"snf\"]\n  },\n  \"application/x-font-speedo\": {\n    \"source\": \"apache\"\n  },\n  \"application/x-font-sunos-news\": {\n    \"source\": \"apache\"\n  },\n  \"application/x-font-ttf\": {\n    \"source\": \"apache\",\n    \"compressible\": true,\n    \"extensions\": [\"ttf\",\"ttc\"]\n  },\n  \"application/x-font-type1\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"pfa\",\"pfb\",\"pfm\",\"afm\"]\n  },\n  \"application/x-font-vfont\": {\n    \"source\": \"apache\"\n  },\n  \"application/x-freearc\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"arc\"]\n  },\n  \"application/x-futuresplash\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"spl\"]\n  },\n  \"application/x-gca-compressed\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"gca\"]\n  },\n  \"application/x-glulx\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"ulx\"]\n  },\n  \"application/x-gnumeric\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"gnumeric\"]\n  },\n  \"application/x-gramps-xml\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"gramps\"]\n  },\n  \"application/x-gtar\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"gtar\"]\n  },\n  \"application/x-gzip\": {\n    \"source\": \"apache\"\n  },\n  \"application/x-hdf\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"hdf\"]\n  },\n  \"application/x-httpd-php\": {\n    \"compressible\": true,\n    \"extensions\": [\"php\"]\n  },\n  \"application/x-install-instructions\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"install\"]\n  },\n  \"application/x-iso9660-image\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"iso\"]\n  },\n  \"application/x-java-archive-diff\": {\n    \"source\": \"nginx\",\n    \"extensions\": [\"jardiff\"]\n  },\n  \"application/x-java-jnlp-file\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"jnlp\"]\n  },\n  \"application/x-javascript\": {\n    \"compressible\": true\n  },\n  \"application/x-latex\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"latex\"]\n  },\n  \"application/x-lua-bytecode\": {\n    \"extensions\": [\"luac\"]\n  },\n  \"application/x-lzh-compressed\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"lzh\",\"lha\"]\n  },\n  \"application/x-makeself\": {\n    \"source\": \"nginx\",\n    \"extensions\": [\"run\"]\n  },\n  \"application/x-mie\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"mie\"]\n  },\n  \"application/x-mobipocket-ebook\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"prc\",\"mobi\"]\n  },\n  \"application/x-mpegurl\": {\n    \"compressible\": false\n  },\n  \"application/x-ms-application\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"application\"]\n  },\n  \"application/x-ms-shortcut\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"lnk\"]\n  },\n  \"application/x-ms-wmd\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"wmd\"]\n  },\n  \"application/x-ms-wmz\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"wmz\"]\n  },\n  \"application/x-ms-xbap\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"xbap\"]\n  },\n  \"application/x-msaccess\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"mdb\"]\n  },\n  \"application/x-msbinder\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"obd\"]\n  },\n  \"application/x-mscardfile\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"crd\"]\n  },\n  \"application/x-msclip\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"clp\"]\n  },\n  \"application/x-msdos-program\": {\n    \"extensions\": [\"exe\"]\n  },\n  \"application/x-msdownload\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"exe\",\"dll\",\"com\",\"bat\",\"msi\"]\n  },\n  \"application/x-msmediaview\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"mvb\",\"m13\",\"m14\"]\n  },\n  \"application/x-msmetafile\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"wmf\",\"wmz\",\"emf\",\"emz\"]\n  },\n  \"application/x-msmoney\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"mny\"]\n  },\n  \"application/x-mspublisher\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"pub\"]\n  },\n  \"application/x-msschedule\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"scd\"]\n  },\n  \"application/x-msterminal\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"trm\"]\n  },\n  \"application/x-mswrite\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"wri\"]\n  },\n  \"application/x-netcdf\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"nc\",\"cdf\"]\n  },\n  \"application/x-ns-proxy-autoconfig\": {\n    \"compressible\": true,\n    \"extensions\": [\"pac\"]\n  },\n  \"application/x-nzb\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"nzb\"]\n  },\n  \"application/x-perl\": {\n    \"source\": \"nginx\",\n    \"extensions\": [\"pl\",\"pm\"]\n  },\n  \"application/x-pilot\": {\n    \"source\": \"nginx\",\n    \"extensions\": [\"prc\",\"pdb\"]\n  },\n  \"application/x-pkcs12\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"p12\",\"pfx\"]\n  },\n  \"application/x-pkcs7-certificates\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"p7b\",\"spc\"]\n  },\n  \"application/x-pkcs7-certreqresp\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"p7r\"]\n  },\n  \"application/x-rar-compressed\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"rar\"]\n  },\n  \"application/x-redhat-package-manager\": {\n    \"source\": \"nginx\",\n    \"extensions\": [\"rpm\"]\n  },\n  \"application/x-research-info-systems\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"ris\"]\n  },\n  \"application/x-sea\": {\n    \"source\": \"nginx\",\n    \"extensions\": [\"sea\"]\n  },\n  \"application/x-sh\": {\n    \"source\": \"apache\",\n    \"compressible\": true,\n    \"extensions\": [\"sh\"]\n  },\n  \"application/x-shar\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"shar\"]\n  },\n  \"application/x-shockwave-flash\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"swf\"]\n  },\n  \"application/x-silverlight-app\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"xap\"]\n  },\n  \"application/x-sql\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sql\"]\n  },\n  \"application/x-stuffit\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"sit\"]\n  },\n  \"application/x-stuffitx\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sitx\"]\n  },\n  \"application/x-subrip\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"srt\"]\n  },\n  \"application/x-sv4cpio\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sv4cpio\"]\n  },\n  \"application/x-sv4crc\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sv4crc\"]\n  },\n  \"application/x-t3vm-image\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"t3\"]\n  },\n  \"application/x-tads\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"gam\"]\n  },\n  \"application/x-tar\": {\n    \"source\": \"apache\",\n    \"compressible\": true,\n    \"extensions\": [\"tar\"]\n  },\n  \"application/x-tcl\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"tcl\",\"tk\"]\n  },\n  \"application/x-tex\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"tex\"]\n  },\n  \"application/x-tex-tfm\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"tfm\"]\n  },\n  \"application/x-texinfo\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"texinfo\",\"texi\"]\n  },\n  \"application/x-tgif\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"obj\"]\n  },\n  \"application/x-ustar\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"ustar\"]\n  },\n  \"application/x-wais-source\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"src\"]\n  },\n  \"application/x-web-app-manifest+json\": {\n    \"compressible\": true,\n    \"extensions\": [\"webapp\"]\n  },\n  \"application/x-www-form-urlencoded\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"application/x-x509-ca-cert\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"der\",\"crt\",\"pem\"]\n  },\n  \"application/x-xfig\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"fig\"]\n  },\n  \"application/x-xliff+xml\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"xlf\"]\n  },\n  \"application/x-xpinstall\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"xpi\"]\n  },\n  \"application/x-xz\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"xz\"]\n  },\n  \"application/x-zmachine\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"z1\",\"z2\",\"z3\",\"z4\",\"z5\",\"z6\",\"z7\",\"z8\"]\n  },\n  \"application/x400-bp\": {\n    \"source\": \"iana\"\n  },\n  \"application/xacml+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/xaml+xml\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"xaml\"]\n  },\n  \"application/xcap-att+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/xcap-caps+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/xcap-diff+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xdf\"]\n  },\n  \"application/xcap-el+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/xcap-error+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/xcap-ns+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/xcon-conference-info+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/xcon-conference-info-diff+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/xenc+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xenc\"]\n  },\n  \"application/xhtml+xml\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"xhtml\",\"xht\"]\n  },\n  \"application/xhtml-voice+xml\": {\n    \"source\": \"apache\"\n  },\n  \"application/xml\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"xml\",\"xsl\",\"xsd\",\"rng\"]\n  },\n  \"application/xml-dtd\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"dtd\"]\n  },\n  \"application/xml-external-parsed-entity\": {\n    \"source\": \"iana\"\n  },\n  \"application/xml-patch+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/xmpp+xml\": {\n    \"source\": \"iana\"\n  },\n  \"application/xop+xml\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"xop\"]\n  },\n  \"application/xproc+xml\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"xpl\"]\n  },\n  \"application/xslt+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xslt\"]\n  },\n  \"application/xspf+xml\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"xspf\"]\n  },\n  \"application/xv+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mxml\",\"xhvml\",\"xvml\",\"xvm\"]\n  },\n  \"application/yang\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"yang\"]\n  },\n  \"application/yin+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"yin\"]\n  },\n  \"application/zip\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"zip\"]\n  },\n  \"application/zlib\": {\n    \"source\": \"iana\"\n  },\n  \"audio/1d-interleaved-parityfec\": {\n    \"source\": \"iana\"\n  },\n  \"audio/32kadpcm\": {\n    \"source\": \"iana\"\n  },\n  \"audio/3gpp\": {\n    \"source\": \"iana\"\n  },\n  \"audio/3gpp2\": {\n    \"source\": \"iana\"\n  },\n  \"audio/ac3\": {\n    \"source\": \"iana\"\n  },\n  \"audio/adpcm\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"adp\"]\n  },\n  \"audio/amr\": {\n    \"source\": \"iana\"\n  },\n  \"audio/amr-wb\": {\n    \"source\": \"iana\"\n  },\n  \"audio/amr-wb+\": {\n    \"source\": \"iana\"\n  },\n  \"audio/aptx\": {\n    \"source\": \"iana\"\n  },\n  \"audio/asc\": {\n    \"source\": \"iana\"\n  },\n  \"audio/atrac-advanced-lossless\": {\n    \"source\": \"iana\"\n  },\n  \"audio/atrac-x\": {\n    \"source\": \"iana\"\n  },\n  \"audio/atrac3\": {\n    \"source\": \"iana\"\n  },\n  \"audio/basic\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"au\",\"snd\"]\n  },\n  \"audio/bv16\": {\n    \"source\": \"iana\"\n  },\n  \"audio/bv32\": {\n    \"source\": \"iana\"\n  },\n  \"audio/clearmode\": {\n    \"source\": \"iana\"\n  },\n  \"audio/cn\": {\n    \"source\": \"iana\"\n  },\n  \"audio/dat12\": {\n    \"source\": \"iana\"\n  },\n  \"audio/dls\": {\n    \"source\": \"iana\"\n  },\n  \"audio/dsr-es201108\": {\n    \"source\": \"iana\"\n  },\n  \"audio/dsr-es202050\": {\n    \"source\": \"iana\"\n  },\n  \"audio/dsr-es202211\": {\n    \"source\": \"iana\"\n  },\n  \"audio/dsr-es202212\": {\n    \"source\": \"iana\"\n  },\n  \"audio/dv\": {\n    \"source\": \"iana\"\n  },\n  \"audio/dvi4\": {\n    \"source\": \"iana\"\n  },\n  \"audio/eac3\": {\n    \"source\": \"iana\"\n  },\n  \"audio/encaprtp\": {\n    \"source\": \"iana\"\n  },\n  \"audio/evrc\": {\n    \"source\": \"iana\"\n  },\n  \"audio/evrc-qcp\": {\n    \"source\": \"iana\"\n  },\n  \"audio/evrc0\": {\n    \"source\": \"iana\"\n  },\n  \"audio/evrc1\": {\n    \"source\": \"iana\"\n  },\n  \"audio/evrcb\": {\n    \"source\": \"iana\"\n  },\n  \"audio/evrcb0\": {\n    \"source\": \"iana\"\n  },\n  \"audio/evrcb1\": {\n    \"source\": \"iana\"\n  },\n  \"audio/evrcnw\": {\n    \"source\": \"iana\"\n  },\n  \"audio/evrcnw0\": {\n    \"source\": \"iana\"\n  },\n  \"audio/evrcnw1\": {\n    \"source\": \"iana\"\n  },\n  \"audio/evrcwb\": {\n    \"source\": \"iana\"\n  },\n  \"audio/evrcwb0\": {\n    \"source\": \"iana\"\n  },\n  \"audio/evrcwb1\": {\n    \"source\": \"iana\"\n  },\n  \"audio/evs\": {\n    \"source\": \"iana\"\n  },\n  \"audio/fwdred\": {\n    \"source\": \"iana\"\n  },\n  \"audio/g711-0\": {\n    \"source\": \"iana\"\n  },\n  \"audio/g719\": {\n    \"source\": \"iana\"\n  },\n  \"audio/g722\": {\n    \"source\": \"iana\"\n  },\n  \"audio/g7221\": {\n    \"source\": \"iana\"\n  },\n  \"audio/g723\": {\n    \"source\": \"iana\"\n  },\n  \"audio/g726-16\": {\n    \"source\": \"iana\"\n  },\n  \"audio/g726-24\": {\n    \"source\": \"iana\"\n  },\n  \"audio/g726-32\": {\n    \"source\": \"iana\"\n  },\n  \"audio/g726-40\": {\n    \"source\": \"iana\"\n  },\n  \"audio/g728\": {\n    \"source\": \"iana\"\n  },\n  \"audio/g729\": {\n    \"source\": \"iana\"\n  },\n  \"audio/g7291\": {\n    \"source\": \"iana\"\n  },\n  \"audio/g729d\": {\n    \"source\": \"iana\"\n  },\n  \"audio/g729e\": {\n    \"source\": \"iana\"\n  },\n  \"audio/gsm\": {\n    \"source\": \"iana\"\n  },\n  \"audio/gsm-efr\": {\n    \"source\": \"iana\"\n  },\n  \"audio/gsm-hr-08\": {\n    \"source\": \"iana\"\n  },\n  \"audio/ilbc\": {\n    \"source\": \"iana\"\n  },\n  \"audio/ip-mr_v2.5\": {\n    \"source\": \"iana\"\n  },\n  \"audio/isac\": {\n    \"source\": \"apache\"\n  },\n  \"audio/l16\": {\n    \"source\": \"iana\"\n  },\n  \"audio/l20\": {\n    \"source\": \"iana\"\n  },\n  \"audio/l24\": {\n    \"source\": \"iana\",\n    \"compressible\": false\n  },\n  \"audio/l8\": {\n    \"source\": \"iana\"\n  },\n  \"audio/lpc\": {\n    \"source\": \"iana\"\n  },\n  \"audio/midi\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"mid\",\"midi\",\"kar\",\"rmi\"]\n  },\n  \"audio/mobile-xmf\": {\n    \"source\": \"iana\"\n  },\n  \"audio/mp4\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"m4a\",\"mp4a\"]\n  },\n  \"audio/mp4a-latm\": {\n    \"source\": \"iana\"\n  },\n  \"audio/mpa\": {\n    \"source\": \"iana\"\n  },\n  \"audio/mpa-robust\": {\n    \"source\": \"iana\"\n  },\n  \"audio/mpeg\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"mpga\",\"mp2\",\"mp2a\",\"mp3\",\"m2a\",\"m3a\"]\n  },\n  \"audio/mpeg4-generic\": {\n    \"source\": \"iana\"\n  },\n  \"audio/musepack\": {\n    \"source\": \"apache\"\n  },\n  \"audio/ogg\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"oga\",\"ogg\",\"spx\"]\n  },\n  \"audio/opus\": {\n    \"source\": \"iana\"\n  },\n  \"audio/parityfec\": {\n    \"source\": \"iana\"\n  },\n  \"audio/pcma\": {\n    \"source\": \"iana\"\n  },\n  \"audio/pcma-wb\": {\n    \"source\": \"iana\"\n  },\n  \"audio/pcmu\": {\n    \"source\": \"iana\"\n  },\n  \"audio/pcmu-wb\": {\n    \"source\": \"iana\"\n  },\n  \"audio/prs.sid\": {\n    \"source\": \"iana\"\n  },\n  \"audio/qcelp\": {\n    \"source\": \"iana\"\n  },\n  \"audio/raptorfec\": {\n    \"source\": \"iana\"\n  },\n  \"audio/red\": {\n    \"source\": \"iana\"\n  },\n  \"audio/rtp-enc-aescm128\": {\n    \"source\": \"iana\"\n  },\n  \"audio/rtp-midi\": {\n    \"source\": \"iana\"\n  },\n  \"audio/rtploopback\": {\n    \"source\": \"iana\"\n  },\n  \"audio/rtx\": {\n    \"source\": \"iana\"\n  },\n  \"audio/s3m\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"s3m\"]\n  },\n  \"audio/silk\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sil\"]\n  },\n  \"audio/smv\": {\n    \"source\": \"iana\"\n  },\n  \"audio/smv-qcp\": {\n    \"source\": \"iana\"\n  },\n  \"audio/smv0\": {\n    \"source\": \"iana\"\n  },\n  \"audio/sp-midi\": {\n    \"source\": \"iana\"\n  },\n  \"audio/speex\": {\n    \"source\": \"iana\"\n  },\n  \"audio/t140c\": {\n    \"source\": \"iana\"\n  },\n  \"audio/t38\": {\n    \"source\": \"iana\"\n  },\n  \"audio/telephone-event\": {\n    \"source\": \"iana\"\n  },\n  \"audio/tone\": {\n    \"source\": \"iana\"\n  },\n  \"audio/uemclip\": {\n    \"source\": \"iana\"\n  },\n  \"audio/ulpfec\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vdvi\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vmr-wb\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.3gpp.iufp\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.4sb\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.audiokoz\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.celp\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.cisco.nse\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.cmles.radio-events\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.cns.anp1\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.cns.inf1\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.dece.audio\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"uva\",\"uvva\"]\n  },\n  \"audio/vnd.digital-winds\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"eol\"]\n  },\n  \"audio/vnd.dlna.adts\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.dolby.heaac.1\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.dolby.heaac.2\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.dolby.mlp\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.dolby.mps\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.dolby.pl2\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.dolby.pl2x\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.dolby.pl2z\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.dolby.pulse.1\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.dra\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"dra\"]\n  },\n  \"audio/vnd.dts\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"dts\"]\n  },\n  \"audio/vnd.dts.hd\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"dtshd\"]\n  },\n  \"audio/vnd.dvb.file\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.everad.plj\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.hns.audio\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.lucent.voice\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"lvp\"]\n  },\n  \"audio/vnd.ms-playready.media.pya\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"pya\"]\n  },\n  \"audio/vnd.nokia.mobile-xmf\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.nortel.vbk\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.nuera.ecelp4800\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ecelp4800\"]\n  },\n  \"audio/vnd.nuera.ecelp7470\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ecelp7470\"]\n  },\n  \"audio/vnd.nuera.ecelp9600\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ecelp9600\"]\n  },\n  \"audio/vnd.octel.sbc\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.qcelp\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.rhetorex.32kadpcm\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.rip\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"rip\"]\n  },\n  \"audio/vnd.rn-realaudio\": {\n    \"compressible\": false\n  },\n  \"audio/vnd.sealedmedia.softseal.mpeg\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.vmx.cvsd\": {\n    \"source\": \"iana\"\n  },\n  \"audio/vnd.wave\": {\n    \"compressible\": false\n  },\n  \"audio/vorbis\": {\n    \"source\": \"iana\",\n    \"compressible\": false\n  },\n  \"audio/vorbis-config\": {\n    \"source\": \"iana\"\n  },\n  \"audio/wav\": {\n    \"compressible\": false,\n    \"extensions\": [\"wav\"]\n  },\n  \"audio/wave\": {\n    \"compressible\": false,\n    \"extensions\": [\"wav\"]\n  },\n  \"audio/webm\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"weba\"]\n  },\n  \"audio/x-aac\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"aac\"]\n  },\n  \"audio/x-aiff\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"aif\",\"aiff\",\"aifc\"]\n  },\n  \"audio/x-caf\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"caf\"]\n  },\n  \"audio/x-flac\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"flac\"]\n  },\n  \"audio/x-m4a\": {\n    \"source\": \"nginx\",\n    \"extensions\": [\"m4a\"]\n  },\n  \"audio/x-matroska\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"mka\"]\n  },\n  \"audio/x-mpegurl\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"m3u\"]\n  },\n  \"audio/x-ms-wax\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"wax\"]\n  },\n  \"audio/x-ms-wma\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"wma\"]\n  },\n  \"audio/x-pn-realaudio\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"ram\",\"ra\"]\n  },\n  \"audio/x-pn-realaudio-plugin\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"rmp\"]\n  },\n  \"audio/x-realaudio\": {\n    \"source\": \"nginx\",\n    \"extensions\": [\"ra\"]\n  },\n  \"audio/x-tta\": {\n    \"source\": \"apache\"\n  },\n  \"audio/x-wav\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"wav\"]\n  },\n  \"audio/xm\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"xm\"]\n  },\n  \"chemical/x-cdx\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"cdx\"]\n  },\n  \"chemical/x-cif\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"cif\"]\n  },\n  \"chemical/x-cmdf\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"cmdf\"]\n  },\n  \"chemical/x-cml\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"cml\"]\n  },\n  \"chemical/x-csml\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"csml\"]\n  },\n  \"chemical/x-pdb\": {\n    \"source\": \"apache\"\n  },\n  \"chemical/x-xyz\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"xyz\"]\n  },\n  \"font/opentype\": {\n    \"compressible\": true,\n    \"extensions\": [\"otf\"]\n  },\n  \"image/bmp\": {\n    \"source\": \"apache\",\n    \"compressible\": true,\n    \"extensions\": [\"bmp\"]\n  },\n  \"image/cgm\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"cgm\"]\n  },\n  \"image/fits\": {\n    \"source\": \"iana\"\n  },\n  \"image/g3fax\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"g3\"]\n  },\n  \"image/gif\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"gif\"]\n  },\n  \"image/ief\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ief\"]\n  },\n  \"image/jp2\": {\n    \"source\": \"iana\"\n  },\n  \"image/jpeg\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"jpeg\",\"jpg\",\"jpe\"]\n  },\n  \"image/jpm\": {\n    \"source\": \"iana\"\n  },\n  \"image/jpx\": {\n    \"source\": \"iana\"\n  },\n  \"image/ktx\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ktx\"]\n  },\n  \"image/naplps\": {\n    \"source\": \"iana\"\n  },\n  \"image/pjpeg\": {\n    \"compressible\": false\n  },\n  \"image/png\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"png\"]\n  },\n  \"image/prs.btif\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"btif\"]\n  },\n  \"image/prs.pti\": {\n    \"source\": \"iana\"\n  },\n  \"image/pwg-raster\": {\n    \"source\": \"iana\"\n  },\n  \"image/sgi\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sgi\"]\n  },\n  \"image/svg+xml\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"svg\",\"svgz\"]\n  },\n  \"image/t38\": {\n    \"source\": \"iana\"\n  },\n  \"image/tiff\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"tiff\",\"tif\"]\n  },\n  \"image/tiff-fx\": {\n    \"source\": \"iana\"\n  },\n  \"image/vnd.adobe.photoshop\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"psd\"]\n  },\n  \"image/vnd.airzip.accelerator.azv\": {\n    \"source\": \"iana\"\n  },\n  \"image/vnd.cns.inf2\": {\n    \"source\": \"iana\"\n  },\n  \"image/vnd.dece.graphic\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"uvi\",\"uvvi\",\"uvg\",\"uvvg\"]\n  },\n  \"image/vnd.djvu\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"djvu\",\"djv\"]\n  },\n  \"image/vnd.dvb.subtitle\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"sub\"]\n  },\n  \"image/vnd.dwg\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"dwg\"]\n  },\n  \"image/vnd.dxf\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"dxf\"]\n  },\n  \"image/vnd.fastbidsheet\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"fbs\"]\n  },\n  \"image/vnd.fpx\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"fpx\"]\n  },\n  \"image/vnd.fst\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"fst\"]\n  },\n  \"image/vnd.fujixerox.edmics-mmr\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mmr\"]\n  },\n  \"image/vnd.fujixerox.edmics-rlc\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"rlc\"]\n  },\n  \"image/vnd.globalgraphics.pgb\": {\n    \"source\": \"iana\"\n  },\n  \"image/vnd.microsoft.icon\": {\n    \"source\": \"iana\"\n  },\n  \"image/vnd.mix\": {\n    \"source\": \"iana\"\n  },\n  \"image/vnd.mozilla.apng\": {\n    \"source\": \"iana\"\n  },\n  \"image/vnd.ms-modi\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mdi\"]\n  },\n  \"image/vnd.ms-photo\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"wdp\"]\n  },\n  \"image/vnd.net-fpx\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"npx\"]\n  },\n  \"image/vnd.radiance\": {\n    \"source\": \"iana\"\n  },\n  \"image/vnd.sealed.png\": {\n    \"source\": \"iana\"\n  },\n  \"image/vnd.sealedmedia.softseal.gif\": {\n    \"source\": \"iana\"\n  },\n  \"image/vnd.sealedmedia.softseal.jpg\": {\n    \"source\": \"iana\"\n  },\n  \"image/vnd.svf\": {\n    \"source\": \"iana\"\n  },\n  \"image/vnd.tencent.tap\": {\n    \"source\": \"iana\"\n  },\n  \"image/vnd.valve.source.texture\": {\n    \"source\": \"iana\"\n  },\n  \"image/vnd.wap.wbmp\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"wbmp\"]\n  },\n  \"image/vnd.xiff\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"xif\"]\n  },\n  \"image/vnd.zbrush.pcx\": {\n    \"source\": \"iana\"\n  },\n  \"image/webp\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"webp\"]\n  },\n  \"image/x-3ds\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"3ds\"]\n  },\n  \"image/x-cmu-raster\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"ras\"]\n  },\n  \"image/x-cmx\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"cmx\"]\n  },\n  \"image/x-freehand\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"fh\",\"fhc\",\"fh4\",\"fh5\",\"fh7\"]\n  },\n  \"image/x-icon\": {\n    \"source\": \"apache\",\n    \"compressible\": true,\n    \"extensions\": [\"ico\"]\n  },\n  \"image/x-jng\": {\n    \"source\": \"nginx\",\n    \"extensions\": [\"jng\"]\n  },\n  \"image/x-mrsid-image\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sid\"]\n  },\n  \"image/x-ms-bmp\": {\n    \"source\": \"nginx\",\n    \"compressible\": true,\n    \"extensions\": [\"bmp\"]\n  },\n  \"image/x-pcx\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"pcx\"]\n  },\n  \"image/x-pict\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"pic\",\"pct\"]\n  },\n  \"image/x-portable-anymap\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"pnm\"]\n  },\n  \"image/x-portable-bitmap\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"pbm\"]\n  },\n  \"image/x-portable-graymap\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"pgm\"]\n  },\n  \"image/x-portable-pixmap\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"ppm\"]\n  },\n  \"image/x-rgb\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"rgb\"]\n  },\n  \"image/x-tga\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"tga\"]\n  },\n  \"image/x-xbitmap\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"xbm\"]\n  },\n  \"image/x-xcf\": {\n    \"compressible\": false\n  },\n  \"image/x-xpixmap\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"xpm\"]\n  },\n  \"image/x-xwindowdump\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"xwd\"]\n  },\n  \"message/cpim\": {\n    \"source\": \"iana\"\n  },\n  \"message/delivery-status\": {\n    \"source\": \"iana\"\n  },\n  \"message/disposition-notification\": {\n    \"source\": \"iana\"\n  },\n  \"message/external-body\": {\n    \"source\": \"iana\"\n  },\n  \"message/feedback-report\": {\n    \"source\": \"iana\"\n  },\n  \"message/global\": {\n    \"source\": \"iana\"\n  },\n  \"message/global-delivery-status\": {\n    \"source\": \"iana\"\n  },\n  \"message/global-disposition-notification\": {\n    \"source\": \"iana\"\n  },\n  \"message/global-headers\": {\n    \"source\": \"iana\"\n  },\n  \"message/http\": {\n    \"source\": \"iana\",\n    \"compressible\": false\n  },\n  \"message/imdn+xml\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"message/news\": {\n    \"source\": \"iana\"\n  },\n  \"message/partial\": {\n    \"source\": \"iana\",\n    \"compressible\": false\n  },\n  \"message/rfc822\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"eml\",\"mime\"]\n  },\n  \"message/s-http\": {\n    \"source\": \"iana\"\n  },\n  \"message/sip\": {\n    \"source\": \"iana\"\n  },\n  \"message/sipfrag\": {\n    \"source\": \"iana\"\n  },\n  \"message/tracking-status\": {\n    \"source\": \"iana\"\n  },\n  \"message/vnd.si.simp\": {\n    \"source\": \"iana\"\n  },\n  \"message/vnd.wfa.wsc\": {\n    \"source\": \"iana\"\n  },\n  \"model/iges\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"igs\",\"iges\"]\n  },\n  \"model/mesh\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"msh\",\"mesh\",\"silo\"]\n  },\n  \"model/vnd.collada+xml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"dae\"]\n  },\n  \"model/vnd.dwf\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"dwf\"]\n  },\n  \"model/vnd.flatland.3dml\": {\n    \"source\": \"iana\"\n  },\n  \"model/vnd.gdl\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"gdl\"]\n  },\n  \"model/vnd.gs-gdl\": {\n    \"source\": \"apache\"\n  },\n  \"model/vnd.gs.gdl\": {\n    \"source\": \"iana\"\n  },\n  \"model/vnd.gtw\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"gtw\"]\n  },\n  \"model/vnd.moml+xml\": {\n    \"source\": \"iana\"\n  },\n  \"model/vnd.mts\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"mts\"]\n  },\n  \"model/vnd.opengex\": {\n    \"source\": \"iana\"\n  },\n  \"model/vnd.parasolid.transmit.binary\": {\n    \"source\": \"iana\"\n  },\n  \"model/vnd.parasolid.transmit.text\": {\n    \"source\": \"iana\"\n  },\n  \"model/vnd.rosette.annotated-data-model\": {\n    \"source\": \"iana\"\n  },\n  \"model/vnd.valve.source.compiled-map\": {\n    \"source\": \"iana\"\n  },\n  \"model/vnd.vtu\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"vtu\"]\n  },\n  \"model/vrml\": {\n    \"source\": \"iana\",\n    \"compressible\": false,\n    \"extensions\": [\"wrl\",\"vrml\"]\n  },\n  \"model/x3d+binary\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"x3db\",\"x3dbz\"]\n  },\n  \"model/x3d+fastinfoset\": {\n    \"source\": \"iana\"\n  },\n  \"model/x3d+vrml\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"x3dv\",\"x3dvz\"]\n  },\n  \"model/x3d+xml\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"x3d\",\"x3dz\"]\n  },\n  \"model/x3d-vrml\": {\n    \"source\": \"iana\"\n  },\n  \"multipart/alternative\": {\n    \"source\": \"iana\",\n    \"compressible\": false\n  },\n  \"multipart/appledouble\": {\n    \"source\": \"iana\"\n  },\n  \"multipart/byteranges\": {\n    \"source\": \"iana\"\n  },\n  \"multipart/digest\": {\n    \"source\": \"iana\"\n  },\n  \"multipart/encrypted\": {\n    \"source\": \"iana\",\n    \"compressible\": false\n  },\n  \"multipart/form-data\": {\n    \"source\": \"iana\",\n    \"compressible\": false\n  },\n  \"multipart/header-set\": {\n    \"source\": \"iana\"\n  },\n  \"multipart/mixed\": {\n    \"source\": \"iana\",\n    \"compressible\": false\n  },\n  \"multipart/parallel\": {\n    \"source\": \"iana\"\n  },\n  \"multipart/related\": {\n    \"source\": \"iana\",\n    \"compressible\": false\n  },\n  \"multipart/report\": {\n    \"source\": \"iana\"\n  },\n  \"multipart/signed\": {\n    \"source\": \"iana\",\n    \"compressible\": false\n  },\n  \"multipart/voice-message\": {\n    \"source\": \"iana\"\n  },\n  \"multipart/x-mixed-replace\": {\n    \"source\": \"iana\"\n  },\n  \"text/1d-interleaved-parityfec\": {\n    \"source\": \"iana\"\n  },\n  \"text/cache-manifest\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"appcache\",\"manifest\"]\n  },\n  \"text/calendar\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ics\",\"ifb\"]\n  },\n  \"text/calender\": {\n    \"compressible\": true\n  },\n  \"text/cmd\": {\n    \"compressible\": true\n  },\n  \"text/coffeescript\": {\n    \"extensions\": [\"coffee\",\"litcoffee\"]\n  },\n  \"text/css\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"css\"]\n  },\n  \"text/csv\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"csv\"]\n  },\n  \"text/csv-schema\": {\n    \"source\": \"iana\"\n  },\n  \"text/directory\": {\n    \"source\": \"iana\"\n  },\n  \"text/dns\": {\n    \"source\": \"iana\"\n  },\n  \"text/ecmascript\": {\n    \"source\": \"iana\"\n  },\n  \"text/encaprtp\": {\n    \"source\": \"iana\"\n  },\n  \"text/enriched\": {\n    \"source\": \"iana\"\n  },\n  \"text/fwdred\": {\n    \"source\": \"iana\"\n  },\n  \"text/grammar-ref-list\": {\n    \"source\": \"iana\"\n  },\n  \"text/hjson\": {\n    \"extensions\": [\"hjson\"]\n  },\n  \"text/html\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"html\",\"htm\",\"shtml\"]\n  },\n  \"text/jade\": {\n    \"extensions\": [\"jade\"]\n  },\n  \"text/javascript\": {\n    \"source\": \"iana\",\n    \"compressible\": true\n  },\n  \"text/jcr-cnd\": {\n    \"source\": \"iana\"\n  },\n  \"text/jsx\": {\n    \"compressible\": true,\n    \"extensions\": [\"jsx\"]\n  },\n  \"text/less\": {\n    \"extensions\": [\"less\"]\n  },\n  \"text/markdown\": {\n    \"source\": \"iana\"\n  },\n  \"text/mathml\": {\n    \"source\": \"nginx\",\n    \"extensions\": [\"mml\"]\n  },\n  \"text/mizar\": {\n    \"source\": \"iana\"\n  },\n  \"text/n3\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"n3\"]\n  },\n  \"text/parameters\": {\n    \"source\": \"iana\"\n  },\n  \"text/parityfec\": {\n    \"source\": \"iana\"\n  },\n  \"text/plain\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"txt\",\"text\",\"conf\",\"def\",\"list\",\"log\",\"in\",\"ini\"]\n  },\n  \"text/provenance-notation\": {\n    \"source\": \"iana\"\n  },\n  \"text/prs.fallenstein.rst\": {\n    \"source\": \"iana\"\n  },\n  \"text/prs.lines.tag\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"dsc\"]\n  },\n  \"text/raptorfec\": {\n    \"source\": \"iana\"\n  },\n  \"text/red\": {\n    \"source\": \"iana\"\n  },\n  \"text/rfc822-headers\": {\n    \"source\": \"iana\"\n  },\n  \"text/richtext\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"rtx\"]\n  },\n  \"text/rtf\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"rtf\"]\n  },\n  \"text/rtp-enc-aescm128\": {\n    \"source\": \"iana\"\n  },\n  \"text/rtploopback\": {\n    \"source\": \"iana\"\n  },\n  \"text/rtx\": {\n    \"source\": \"iana\"\n  },\n  \"text/sgml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"sgml\",\"sgm\"]\n  },\n  \"text/slim\": {\n    \"extensions\": [\"slim\",\"slm\"]\n  },\n  \"text/stylus\": {\n    \"extensions\": [\"stylus\",\"styl\"]\n  },\n  \"text/t140\": {\n    \"source\": \"iana\"\n  },\n  \"text/tab-separated-values\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"tsv\"]\n  },\n  \"text/troff\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"t\",\"tr\",\"roff\",\"man\",\"me\",\"ms\"]\n  },\n  \"text/turtle\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"ttl\"]\n  },\n  \"text/ulpfec\": {\n    \"source\": \"iana\"\n  },\n  \"text/uri-list\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"uri\",\"uris\",\"urls\"]\n  },\n  \"text/vcard\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"vcard\"]\n  },\n  \"text/vnd.a\": {\n    \"source\": \"iana\"\n  },\n  \"text/vnd.abc\": {\n    \"source\": \"iana\"\n  },\n  \"text/vnd.curl\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"curl\"]\n  },\n  \"text/vnd.curl.dcurl\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"dcurl\"]\n  },\n  \"text/vnd.curl.mcurl\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"mcurl\"]\n  },\n  \"text/vnd.curl.scurl\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"scurl\"]\n  },\n  \"text/vnd.debian.copyright\": {\n    \"source\": \"iana\"\n  },\n  \"text/vnd.dmclientscript\": {\n    \"source\": \"iana\"\n  },\n  \"text/vnd.dvb.subtitle\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"sub\"]\n  },\n  \"text/vnd.esmertec.theme-descriptor\": {\n    \"source\": \"iana\"\n  },\n  \"text/vnd.fly\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"fly\"]\n  },\n  \"text/vnd.fmi.flexstor\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"flx\"]\n  },\n  \"text/vnd.graphviz\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"gv\"]\n  },\n  \"text/vnd.in3d.3dml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"3dml\"]\n  },\n  \"text/vnd.in3d.spot\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"spot\"]\n  },\n  \"text/vnd.iptc.newsml\": {\n    \"source\": \"iana\"\n  },\n  \"text/vnd.iptc.nitf\": {\n    \"source\": \"iana\"\n  },\n  \"text/vnd.latex-z\": {\n    \"source\": \"iana\"\n  },\n  \"text/vnd.motorola.reflex\": {\n    \"source\": \"iana\"\n  },\n  \"text/vnd.ms-mediapackage\": {\n    \"source\": \"iana\"\n  },\n  \"text/vnd.net2phone.commcenter.command\": {\n    \"source\": \"iana\"\n  },\n  \"text/vnd.radisys.msml-basic-layout\": {\n    \"source\": \"iana\"\n  },\n  \"text/vnd.si.uricatalogue\": {\n    \"source\": \"iana\"\n  },\n  \"text/vnd.sun.j2me.app-descriptor\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"jad\"]\n  },\n  \"text/vnd.trolltech.linguist\": {\n    \"source\": \"iana\"\n  },\n  \"text/vnd.wap.si\": {\n    \"source\": \"iana\"\n  },\n  \"text/vnd.wap.sl\": {\n    \"source\": \"iana\"\n  },\n  \"text/vnd.wap.wml\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"wml\"]\n  },\n  \"text/vnd.wap.wmlscript\": {\n    \"source\": \"iana\",\n    \"extensions\": [\"wmls\"]\n  },\n  \"text/vtt\": {\n    \"charset\": \"UTF-8\",\n    \"compressible\": true,\n    \"extensions\": [\"vtt\"]\n  },\n  \"text/x-asm\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"s\",\"asm\"]\n  },\n  \"text/x-c\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"c\",\"cc\",\"cxx\",\"cpp\",\"h\",\"hh\",\"dic\"]\n  },\n  \"text/x-component\": {\n    \"source\": \"nginx\",\n    \"extensions\": [\"htc\"]\n  },\n  \"text/x-fortran\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"f\",\"for\",\"f77\",\"f90\"]\n  },\n  \"text/x-gwt-rpc\": {\n    \"compressible\": true\n  },\n  \"text/x-handlebars-template\": {\n    \"extensions\": [\"hbs\"]\n  },\n  \"text/x-java-source\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"java\"]\n  },\n  \"text/x-jquery-tmpl\": {\n    \"compressible\": true\n  },\n  \"text/x-lua\": {\n    \"extensions\": [\"lua\"]\n  },\n  \"text/x-markdown\": {\n    \"compressible\": true,\n    \"extensions\": [\"markdown\",\"md\",\"mkd\"]\n  },\n  \"text/x-nfo\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"nfo\"]\n  },\n  \"text/x-opml\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"opml\"]\n  },\n  \"text/x-pascal\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"p\",\"pas\"]\n  },\n  \"text/x-processing\": {\n    \"compressible\": true,\n    \"extensions\": [\"pde\"]\n  },\n  \"text/x-sass\": {\n    \"extensions\": [\"sass\"]\n  },\n  \"text/x-scss\": {\n    \"extensions\": [\"scss\"]\n  },\n  \"text/x-setext\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"etx\"]\n  },\n  \"text/x-sfv\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"sfv\"]\n  },\n  \"text/x-suse-ymp\": {\n    \"compressible\": true,\n    \"extensions\": [\"ymp\"]\n  },\n  \"text/x-uuencode\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"uu\"]\n  },\n  \"text/x-vcalendar\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"vcs\"]\n  },\n  \"text/x-vcard\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"vcf\"]\n  },\n  \"text/xml\": {\n    \"source\": \"iana\",\n    \"compressible\": true,\n    \"extensions\": [\"xml\"]\n  },\n  \"text/xml-external-parsed-entity\": {\n    \"source\": \"iana\"\n  },\n  \"text/yaml\": {\n    \"extensions\": [\"yaml\",\"yml\"]\n  },\n  \"video/1d-interleaved-parityfec\": {\n    \"source\": \"apache\"\n  },\n  \"video/3gpp\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"3gp\",\"3gpp\"]\n  },\n  \"video/3gpp-tt\": {\n    \"source\": \"apache\"\n  },\n  \"video/3gpp2\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"3g2\"]\n  },\n  \"video/bmpeg\": {\n    \"source\": \"apache\"\n  },\n  \"video/bt656\": {\n    \"source\": \"apache\"\n  },\n  \"video/celb\": {\n    \"source\": \"apache\"\n  },\n  \"video/dv\": {\n    \"source\": \"apache\"\n  },\n  \"video/h261\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"h261\"]\n  },\n  \"video/h263\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"h263\"]\n  },\n  \"video/h263-1998\": {\n    \"source\": \"apache\"\n  },\n  \"video/h263-2000\": {\n    \"source\": \"apache\"\n  },\n  \"video/h264\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"h264\"]\n  },\n  \"video/h264-rcdo\": {\n    \"source\": \"apache\"\n  },\n  \"video/h264-svc\": {\n    \"source\": \"apache\"\n  },\n  \"video/jpeg\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"jpgv\"]\n  },\n  \"video/jpeg2000\": {\n    \"source\": \"apache\"\n  },\n  \"video/jpm\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"jpm\",\"jpgm\"]\n  },\n  \"video/mj2\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"mj2\",\"mjp2\"]\n  },\n  \"video/mp1s\": {\n    \"source\": \"apache\"\n  },\n  \"video/mp2p\": {\n    \"source\": \"apache\"\n  },\n  \"video/mp2t\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"ts\"]\n  },\n  \"video/mp4\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"mp4\",\"mp4v\",\"mpg4\"]\n  },\n  \"video/mp4v-es\": {\n    \"source\": \"apache\"\n  },\n  \"video/mpeg\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"mpeg\",\"mpg\",\"mpe\",\"m1v\",\"m2v\"]\n  },\n  \"video/mpeg4-generic\": {\n    \"source\": \"apache\"\n  },\n  \"video/mpv\": {\n    \"source\": \"apache\"\n  },\n  \"video/nv\": {\n    \"source\": \"apache\"\n  },\n  \"video/ogg\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"ogv\"]\n  },\n  \"video/parityfec\": {\n    \"source\": \"apache\"\n  },\n  \"video/pointer\": {\n    \"source\": \"apache\"\n  },\n  \"video/quicktime\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"qt\",\"mov\"]\n  },\n  \"video/raw\": {\n    \"source\": \"apache\"\n  },\n  \"video/rtp-enc-aescm128\": {\n    \"source\": \"apache\"\n  },\n  \"video/rtx\": {\n    \"source\": \"apache\"\n  },\n  \"video/smpte292m\": {\n    \"source\": \"apache\"\n  },\n  \"video/ulpfec\": {\n    \"source\": \"apache\"\n  },\n  \"video/vc1\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.cctv\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.dece.hd\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"uvh\",\"uvvh\"]\n  },\n  \"video/vnd.dece.mobile\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"uvm\",\"uvvm\"]\n  },\n  \"video/vnd.dece.mp4\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.dece.pd\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"uvp\",\"uvvp\"]\n  },\n  \"video/vnd.dece.sd\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"uvs\",\"uvvs\"]\n  },\n  \"video/vnd.dece.video\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"uvv\",\"uvvv\"]\n  },\n  \"video/vnd.directv.mpeg\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.directv.mpeg-tts\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.dlna.mpeg-tts\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.dvb.file\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"dvb\"]\n  },\n  \"video/vnd.fvt\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"fvt\"]\n  },\n  \"video/vnd.hns.video\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.iptvforum.1dparityfec-1010\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.iptvforum.1dparityfec-2005\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.iptvforum.2dparityfec-1010\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.iptvforum.2dparityfec-2005\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.iptvforum.ttsavc\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.iptvforum.ttsmpeg2\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.motorola.video\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.motorola.videop\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.mpegurl\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"mxu\",\"m4u\"]\n  },\n  \"video/vnd.ms-playready.media.pyv\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"pyv\"]\n  },\n  \"video/vnd.nokia.interleaved-multimedia\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.nokia.videovoip\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.objectvideo\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.sealed.mpeg1\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.sealed.mpeg4\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.sealed.swf\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.sealedmedia.softseal.mov\": {\n    \"source\": \"apache\"\n  },\n  \"video/vnd.uvvu.mp4\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"uvu\",\"uvvu\"]\n  },\n  \"video/vnd.vivo\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"viv\"]\n  },\n  \"video/webm\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"webm\"]\n  },\n  \"video/x-f4v\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"f4v\"]\n  },\n  \"video/x-fli\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"fli\"]\n  },\n  \"video/x-flv\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"flv\"]\n  },\n  \"video/x-m4v\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"m4v\"]\n  },\n  \"video/x-matroska\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"mkv\",\"mk3d\",\"mks\"]\n  },\n  \"video/x-mng\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"mng\"]\n  },\n  \"video/x-ms-asf\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"asf\",\"asx\"]\n  },\n  \"video/x-ms-vob\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"vob\"]\n  },\n  \"video/x-ms-wm\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"wm\"]\n  },\n  \"video/x-ms-wmv\": {\n    \"source\": \"apache\",\n    \"compressible\": false,\n    \"extensions\": [\"wmv\"]\n  },\n  \"video/x-ms-wmx\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"wmx\"]\n  },\n  \"video/x-ms-wvx\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"wvx\"]\n  },\n  \"video/x-msvideo\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"avi\"]\n  },\n  \"video/x-sgi-movie\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"movie\"]\n  },\n  \"video/x-smv\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"smv\"]\n  },\n  \"x-conference/x-cooltalk\": {\n    \"source\": \"apache\",\n    \"extensions\": [\"ice\"]\n  },\n  \"x-shader/x-fragment\": {\n    \"compressible\": true\n  },\n  \"x-shader/x-vertex\": {\n    \"compressible\": true\n  }\n}\n","/*!\n * mime-db\n * Copyright(c) 2014 Jonathan Ong\n * MIT Licensed\n */\n\n/**\n * Module exports.\n */\n\nmodule.exports = require('./db.json')\n","/*!\n * mime-types\n * Copyright(c) 2014 Jonathan Ong\n * Copyright(c) 2015 Douglas Christopher Wilson\n * MIT Licensed\n */\n\n'use strict'\n\n/**\n * Module dependencies.\n * @private\n */\n\nvar db = require('mime-db')\nvar extname = require('path').extname\n\n/**\n * Module variables.\n * @private\n */\n\nvar extractTypeRegExp = /^\\s*([^;\\s]*)(?:;|\\s|$)/\nvar textTypeRegExp = /^text\\//i\n\n/**\n * Module exports.\n * @public\n */\n\nexports.charset = charset\nexports.charsets = { lookup: charset }\nexports.contentType = contentType\nexports.extension = extension\nexports.extensions = Object.create(null)\nexports.lookup = lookup\nexports.types = Object.create(null)\n\n// Populate the extensions/types maps\npopulateMaps(exports.extensions, exports.types)\n\n/**\n * Get the default charset for a MIME type.\n *\n * @param {string} type\n * @return {boolean|string}\n */\n\nfunction charset(type) {\n  if (!type || typeof type !== 'string') {\n    return false\n  }\n\n  // TODO: use media-typer\n  var match = extractTypeRegExp.exec(type)\n  var mime = match && db[match[1].toLowerCase()]\n\n  if (mime && mime.charset) {\n    return mime.charset\n  }\n\n  // default text/* to utf-8\n  if (match && textTypeRegExp.test(match[1])) {\n    return 'UTF-8'\n  }\n\n  return false\n}\n\n/**\n * Create a full Content-Type header given a MIME type or extension.\n *\n * @param {string} str\n * @return {boolean|string}\n */\n\nfunction contentType(str) {\n  // TODO: should this even be in this module?\n  if (!str || typeof str !== 'string') {\n    return false\n  }\n\n  var mime = str.indexOf('/') === -1\n    ? exports.lookup(str)\n    : str\n\n  if (!mime) {\n    return false\n  }\n\n  // TODO: use content-type or other module\n  if (mime.indexOf('charset') === -1) {\n    var charset = exports.charset(mime)\n    if (charset) mime += '; charset=' + charset.toLowerCase()\n  }\n\n  return mime\n}\n\n/**\n * Get the default extension for a MIME type.\n *\n * @param {string} type\n * @return {boolean|string}\n */\n\nfunction extension(type) {\n  if (!type || typeof type !== 'string') {\n    return false\n  }\n\n  // TODO: use media-typer\n  var match = extractTypeRegExp.exec(type)\n\n  // get extensions\n  var exts = match && exports.extensions[match[1].toLowerCase()]\n\n  if (!exts || !exts.length) {\n    return false\n  }\n\n  return exts[0]\n}\n\n/**\n * Lookup the MIME type for a file path/extension.\n *\n * @param {string} path\n * @return {boolean|string}\n */\n\nfunction lookup(path) {\n  if (!path || typeof path !== 'string') {\n    return false\n  }\n\n  // get the extension (\"ext\" or \".ext\" or full path)\n  var extension = extname('x.' + path)\n    .toLowerCase()\n    .substr(1)\n\n  if (!extension) {\n    return false\n  }\n\n  return exports.types[extension] || false\n}\n\n/**\n * Populate the extensions and types maps.\n * @private\n */\n\nfunction populateMaps(extensions, types) {\n  // source preference (least -> most)\n  var preference = ['nginx', 'apache', undefined, 'iana']\n\n  Object.keys(db).forEach(function forEachMimeType(type) {\n    var mime = db[type]\n    var exts = mime.extensions\n\n    if (!exts || !exts.length) {\n      return\n    }\n\n    // mime -> extensions\n    extensions[type] = exts\n\n    // extension -> mime\n    for (var i = 0; i < exts.length; i++) {\n      var extension = exts[i]\n\n      if (types[extension]) {\n        var from = preference.indexOf(db[types[extension]].source)\n        var to = preference.indexOf(mime.source)\n\n        if (types[extension] !== 'application/octet-stream'\n          && from > to || (from === to && types[extension].substr(0, 12) === 'application/')) {\n          // skip the remapping\n          continue\n        }\n      }\n\n      // set the extension -> mime\n      types[extension] = type\n    }\n  })\n}\n","module.exports = assert;\n\nfunction assert(val, msg) {\n  if (!val)\n    throw new Error(msg || 'Assertion failed');\n}\n\nassert.equal = function assertEqual(l, r, msg) {\n  if (l != r)\n    throw new Error(msg || ('Assertion failed: ' + l + ' != ' + r));\n};\n","module.exports = minimatch\nminimatch.Minimatch = Minimatch\n\nvar path = { sep: '/' }\ntry {\n  path = require('path')\n} catch (er) {}\n\nvar GLOBSTAR = minimatch.GLOBSTAR = Minimatch.GLOBSTAR = {}\nvar expand = require('brace-expansion')\n\n// any single thing other than /\n// don't need to escape / when using new RegExp()\nvar qmark = '[^/]'\n\n// * => any number of characters\nvar star = qmark + '*?'\n\n// ** when dots are allowed.  Anything goes, except .. and .\n// not (^ or / followed by one or two dots followed by $ or /),\n// followed by anything, any number of times.\nvar twoStarDot = '(?:(?!(?:\\\\\\/|^)(?:\\\\.{1,2})($|\\\\\\/)).)*?'\n\n// not a ^ or / followed by a dot,\n// followed by anything, any number of times.\nvar twoStarNoDot = '(?:(?!(?:\\\\\\/|^)\\\\.).)*?'\n\n// characters that need to be escaped in RegExp.\nvar reSpecials = charSet('().*{}+?[]^$\\\\!')\n\n// \"abc\" -> { a:true, b:true, c:true }\nfunction charSet (s) {\n  return s.split('').reduce(function (set, c) {\n    set[c] = true\n    return set\n  }, {})\n}\n\n// normalizes slashes.\nvar slashSplit = /\\/+/\n\nminimatch.filter = filter\nfunction filter (pattern, options) {\n  options = options || {}\n  return function (p, i, list) {\n    return minimatch(p, pattern, options)\n  }\n}\n\nfunction ext (a, b) {\n  a = a || {}\n  b = b || {}\n  var t = {}\n  Object.keys(b).forEach(function (k) {\n    t[k] = b[k]\n  })\n  Object.keys(a).forEach(function (k) {\n    t[k] = a[k]\n  })\n  return t\n}\n\nminimatch.defaults = function (def) {\n  if (!def || !Object.keys(def).length) return minimatch\n\n  var orig = minimatch\n\n  var m = function minimatch (p, pattern, options) {\n    return orig.minimatch(p, pattern, ext(def, options))\n  }\n\n  m.Minimatch = function Minimatch (pattern, options) {\n    return new orig.Minimatch(pattern, ext(def, options))\n  }\n\n  return m\n}\n\nMinimatch.defaults = function (def) {\n  if (!def || !Object.keys(def).length) return Minimatch\n  return minimatch.defaults(def).Minimatch\n}\n\nfunction minimatch (p, pattern, options) {\n  if (typeof pattern !== 'string') {\n    throw new TypeError('glob pattern string required')\n  }\n\n  if (!options) options = {}\n\n  // shortcut: comments match nothing.\n  if (!options.nocomment && pattern.charAt(0) === '#') {\n    return false\n  }\n\n  // \"\" only matches \"\"\n  if (pattern.trim() === '') return p === ''\n\n  return new Minimatch(pattern, options).match(p)\n}\n\nfunction Minimatch (pattern, options) {\n  if (!(this instanceof Minimatch)) {\n    return new Minimatch(pattern, options)\n  }\n\n  if (typeof pattern !== 'string') {\n    throw new TypeError('glob pattern string required')\n  }\n\n  if (!options) options = {}\n  pattern = pattern.trim()\n\n  // windows support: need to use /, not \\\n  if (path.sep !== '/') {\n    pattern = pattern.split(path.sep).join('/')\n  }\n\n  this.options = options\n  this.set = []\n  this.pattern = pattern\n  this.regexp = null\n  this.negate = false\n  this.comment = false\n  this.empty = false\n\n  // make the set of regexps etc.\n  this.make()\n}\n\nMinimatch.prototype.debug = function () {}\n\nMinimatch.prototype.make = make\nfunction make () {\n  // don't do it more than once.\n  if (this._made) return\n\n  var pattern = this.pattern\n  var options = this.options\n\n  // empty patterns and comments match nothing.\n  if (!options.nocomment && pattern.charAt(0) === '#') {\n    this.comment = true\n    return\n  }\n  if (!pattern) {\n    this.empty = true\n    return\n  }\n\n  // step 1: figure out negation, etc.\n  this.parseNegate()\n\n  // step 2: expand braces\n  var set = this.globSet = this.braceExpand()\n\n  if (options.debug) this.debug = console.error\n\n  this.debug(this.pattern, set)\n\n  // step 3: now we have a set, so turn each one into a series of path-portion\n  // matching patterns.\n  // These will be regexps, except in the case of \"**\", which is\n  // set to the GLOBSTAR object for globstar behavior,\n  // and will not contain any / characters\n  set = this.globParts = set.map(function (s) {\n    return s.split(slashSplit)\n  })\n\n  this.debug(this.pattern, set)\n\n  // glob --> regexps\n  set = set.map(function (s, si, set) {\n    return s.map(this.parse, this)\n  }, this)\n\n  this.debug(this.pattern, set)\n\n  // filter out everything that didn't compile properly.\n  set = set.filter(function (s) {\n    return s.indexOf(false) === -1\n  })\n\n  this.debug(this.pattern, set)\n\n  this.set = set\n}\n\nMinimatch.prototype.parseNegate = parseNegate\nfunction parseNegate () {\n  var pattern = this.pattern\n  var negate = false\n  var options = this.options\n  var negateOffset = 0\n\n  if (options.nonegate) return\n\n  for (var i = 0, l = pattern.length\n    ; i < l && pattern.charAt(i) === '!'\n    ; i++) {\n    negate = !negate\n    negateOffset++\n  }\n\n  if (negateOffset) this.pattern = pattern.substr(negateOffset)\n  this.negate = negate\n}\n\n// Brace expansion:\n// a{b,c}d -> abd acd\n// a{b,}c -> abc ac\n// a{0..3}d -> a0d a1d a2d a3d\n// a{b,c{d,e}f}g -> abg acdfg acefg\n// a{b,c}d{e,f}g -> abdeg acdeg abdeg abdfg\n//\n// Invalid sets are not expanded.\n// a{2..}b -> a{2..}b\n// a{b}c -> a{b}c\nminimatch.braceExpand = function (pattern, options) {\n  return braceExpand(pattern, options)\n}\n\nMinimatch.prototype.braceExpand = braceExpand\n\nfunction braceExpand (pattern, options) {\n  if (!options) {\n    if (this instanceof Minimatch) {\n      options = this.options\n    } else {\n      options = {}\n    }\n  }\n\n  pattern = typeof pattern === 'undefined'\n    ? this.pattern : pattern\n\n  if (typeof pattern === 'undefined') {\n    throw new Error('undefined pattern')\n  }\n\n  if (options.nobrace ||\n    !pattern.match(/\\{.*\\}/)) {\n    // shortcut. no need to expand.\n    return [pattern]\n  }\n\n  return expand(pattern)\n}\n\n// parse a component of the expanded set.\n// At this point, no pattern may contain \"/\" in it\n// so we're going to return a 2d array, where each entry is the full\n// pattern, split on '/', and then turned into a regular expression.\n// A regexp is made at the end which joins each array with an\n// escaped /, and another full one which joins each regexp with |.\n//\n// Following the lead of Bash 4.1, note that \"**\" only has special meaning\n// when it is the *only* thing in a path portion.  Otherwise, any series\n// of * is equivalent to a single *.  Globstar behavior is enabled by\n// default, and can be disabled by setting options.noglobstar.\nMinimatch.prototype.parse = parse\nvar SUBPARSE = {}\nfunction parse (pattern, isSub) {\n  var options = this.options\n\n  // shortcuts\n  if (!options.noglobstar && pattern === '**') return GLOBSTAR\n  if (pattern === '') return ''\n\n  var re = ''\n  var hasMagic = !!options.nocase\n  var escaping = false\n  // ? => one single character\n  var patternListStack = []\n  var negativeLists = []\n  var plType\n  var stateChar\n  var inClass = false\n  var reClassStart = -1\n  var classStart = -1\n  // . and .. never match anything that doesn't start with .,\n  // even when options.dot is set.\n  var patternStart = pattern.charAt(0) === '.' ? '' // anything\n  // not (start or / followed by . or .. followed by / or end)\n  : options.dot ? '(?!(?:^|\\\\\\/)\\\\.{1,2}(?:$|\\\\\\/))'\n  : '(?!\\\\.)'\n  var self = this\n\n  function clearStateChar () {\n    if (stateChar) {\n      // we had some state-tracking character\n      // that wasn't consumed by this pass.\n      switch (stateChar) {\n        case '*':\n          re += star\n          hasMagic = true\n        break\n        case '?':\n          re += qmark\n          hasMagic = true\n        break\n        default:\n          re += '\\\\' + stateChar\n        break\n      }\n      self.debug('clearStateChar %j %j', stateChar, re)\n      stateChar = false\n    }\n  }\n\n  for (var i = 0, len = pattern.length, c\n    ; (i < len) && (c = pattern.charAt(i))\n    ; i++) {\n    this.debug('%s\\t%s %s %j', pattern, i, re, c)\n\n    // skip over any that are escaped.\n    if (escaping && reSpecials[c]) {\n      re += '\\\\' + c\n      escaping = false\n      continue\n    }\n\n    switch (c) {\n      case '/':\n        // completely not allowed, even escaped.\n        // Should already be path-split by now.\n        return false\n\n      case '\\\\':\n        clearStateChar()\n        escaping = true\n      continue\n\n      // the various stateChar values\n      // for the \"extglob\" stuff.\n      case '?':\n      case '*':\n      case '+':\n      case '@':\n      case '!':\n        this.debug('%s\\t%s %s %j <-- stateChar', pattern, i, re, c)\n\n        // all of those are literals inside a class, except that\n        // the glob [!a] means [^a] in regexp\n        if (inClass) {\n          this.debug('  in class')\n          if (c === '!' && i === classStart + 1) c = '^'\n          re += c\n          continue\n        }\n\n        // if we already have a stateChar, then it means\n        // that there was something like ** or +? in there.\n        // Handle the stateChar, then proceed with this one.\n        self.debug('call clearStateChar %j', stateChar)\n        clearStateChar()\n        stateChar = c\n        // if extglob is disabled, then +(asdf|foo) isn't a thing.\n        // just clear the statechar *now*, rather than even diving into\n        // the patternList stuff.\n        if (options.noext) clearStateChar()\n      continue\n\n      case '(':\n        if (inClass) {\n          re += '('\n          continue\n        }\n\n        if (!stateChar) {\n          re += '\\\\('\n          continue\n        }\n\n        plType = stateChar\n        patternListStack.push({\n          type: plType,\n          start: i - 1,\n          reStart: re.length\n        })\n        // negation is (?:(?!js)[^/]*)\n        re += stateChar === '!' ? '(?:(?!(?:' : '(?:'\n        this.debug('plType %j %j', stateChar, re)\n        stateChar = false\n      continue\n\n      case ')':\n        if (inClass || !patternListStack.length) {\n          re += '\\\\)'\n          continue\n        }\n\n        clearStateChar()\n        hasMagic = true\n        re += ')'\n        var pl = patternListStack.pop()\n        plType = pl.type\n        // negation is (?:(?!js)[^/]*)\n        // The others are (?:<pattern>)<type>\n        switch (plType) {\n          case '!':\n            negativeLists.push(pl)\n            re += ')[^/]*?)'\n            pl.reEnd = re.length\n            break\n          case '?':\n          case '+':\n          case '*':\n            re += plType\n            break\n          case '@': break // the default anyway\n        }\n      continue\n\n      case '|':\n        if (inClass || !patternListStack.length || escaping) {\n          re += '\\\\|'\n          escaping = false\n          continue\n        }\n\n        clearStateChar()\n        re += '|'\n      continue\n\n      // these are mostly the same in regexp and glob\n      case '[':\n        // swallow any state-tracking char before the [\n        clearStateChar()\n\n        if (inClass) {\n          re += '\\\\' + c\n          continue\n        }\n\n        inClass = true\n        classStart = i\n        reClassStart = re.length\n        re += c\n      continue\n\n      case ']':\n        //  a right bracket shall lose its special\n        //  meaning and represent itself in\n        //  a bracket expression if it occurs\n        //  first in the list.  -- POSIX.2 2.8.3.2\n        if (i === classStart + 1 || !inClass) {\n          re += '\\\\' + c\n          escaping = false\n          continue\n        }\n\n        // handle the case where we left a class open.\n        // \"[z-a]\" is valid, equivalent to \"\\[z-a\\]\"\n        if (inClass) {\n          // split where the last [ was, make sure we don't have\n          // an invalid re. if so, re-walk the contents of the\n          // would-be class to re-translate any characters that\n          // were passed through as-is\n          // TODO: It would probably be faster to determine this\n          // without a try/catch and a new RegExp, but it's tricky\n          // to do safely.  For now, this is safe and works.\n          var cs = pattern.substring(classStart + 1, i)\n          try {\n            RegExp('[' + cs + ']')\n          } catch (er) {\n            // not a valid class!\n            var sp = this.parse(cs, SUBPARSE)\n            re = re.substr(0, reClassStart) + '\\\\[' + sp[0] + '\\\\]'\n            hasMagic = hasMagic || sp[1]\n            inClass = false\n            continue\n          }\n        }\n\n        // finish up the class.\n        hasMagic = true\n        inClass = false\n        re += c\n      continue\n\n      default:\n        // swallow any state char that wasn't consumed\n        clearStateChar()\n\n        if (escaping) {\n          // no need\n          escaping = false\n        } else if (reSpecials[c]\n          && !(c === '^' && inClass)) {\n          re += '\\\\'\n        }\n\n        re += c\n\n    } // switch\n  } // for\n\n  // handle the case where we left a class open.\n  // \"[abc\" is valid, equivalent to \"\\[abc\"\n  if (inClass) {\n    // split where the last [ was, and escape it\n    // this is a huge pita.  We now have to re-walk\n    // the contents of the would-be class to re-translate\n    // any characters that were passed through as-is\n    cs = pattern.substr(classStart + 1)\n    sp = this.parse(cs, SUBPARSE)\n    re = re.substr(0, reClassStart) + '\\\\[' + sp[0]\n    hasMagic = hasMagic || sp[1]\n  }\n\n  // handle the case where we had a +( thing at the *end*\n  // of the pattern.\n  // each pattern list stack adds 3 chars, and we need to go through\n  // and escape any | chars that were passed through as-is for the regexp.\n  // Go through and escape them, taking care not to double-escape any\n  // | chars that were already escaped.\n  for (pl = patternListStack.pop(); pl; pl = patternListStack.pop()) {\n    var tail = re.slice(pl.reStart + 3)\n    // maybe some even number of \\, then maybe 1 \\, followed by a |\n    tail = tail.replace(/((?:\\\\{2})*)(\\\\?)\\|/g, function (_, $1, $2) {\n      if (!$2) {\n        // the | isn't already escaped, so escape it.\n        $2 = '\\\\'\n      }\n\n      // need to escape all those slashes *again*, without escaping the\n      // one that we need for escaping the | character.  As it works out,\n      // escaping an even number of slashes can be done by simply repeating\n      // it exactly after itself.  That's why this trick works.\n      //\n      // I am sorry that you have to see this.\n      return $1 + $1 + $2 + '|'\n    })\n\n    this.debug('tail=%j\\n   %s', tail, tail)\n    var t = pl.type === '*' ? star\n      : pl.type === '?' ? qmark\n      : '\\\\' + pl.type\n\n    hasMagic = true\n    re = re.slice(0, pl.reStart) + t + '\\\\(' + tail\n  }\n\n  // handle trailing things that only matter at the very end.\n  clearStateChar()\n  if (escaping) {\n    // trailing \\\\\n    re += '\\\\\\\\'\n  }\n\n  // only need to apply the nodot start if the re starts with\n  // something that could conceivably capture a dot\n  var addPatternStart = false\n  switch (re.charAt(0)) {\n    case '.':\n    case '[':\n    case '(': addPatternStart = true\n  }\n\n  // Hack to work around lack of negative lookbehind in JS\n  // A pattern like: *.!(x).!(y|z) needs to ensure that a name\n  // like 'a.xyz.yz' doesn't match.  So, the first negative\n  // lookahead, has to look ALL the way ahead, to the end of\n  // the pattern.\n  for (var n = negativeLists.length - 1; n > -1; n--) {\n    var nl = negativeLists[n]\n\n    var nlBefore = re.slice(0, nl.reStart)\n    var nlFirst = re.slice(nl.reStart, nl.reEnd - 8)\n    var nlLast = re.slice(nl.reEnd - 8, nl.reEnd)\n    var nlAfter = re.slice(nl.reEnd)\n\n    nlLast += nlAfter\n\n    // Handle nested stuff like *(*.js|!(*.json)), where open parens\n    // mean that we should *not* include the ) in the bit that is considered\n    // \"after\" the negated section.\n    var openParensBefore = nlBefore.split('(').length - 1\n    var cleanAfter = nlAfter\n    for (i = 0; i < openParensBefore; i++) {\n      cleanAfter = cleanAfter.replace(/\\)[+*?]?/, '')\n    }\n    nlAfter = cleanAfter\n\n    var dollar = ''\n    if (nlAfter === '' && isSub !== SUBPARSE) {\n      dollar = '$'\n    }\n    var newRe = nlBefore + nlFirst + nlAfter + dollar + nlLast\n    re = newRe\n  }\n\n  // if the re is not \"\" at this point, then we need to make sure\n  // it doesn't match against an empty path part.\n  // Otherwise a/* will match a/, which it should not.\n  if (re !== '' && hasMagic) {\n    re = '(?=.)' + re\n  }\n\n  if (addPatternStart) {\n    re = patternStart + re\n  }\n\n  // parsing just a piece of a larger pattern.\n  if (isSub === SUBPARSE) {\n    return [re, hasMagic]\n  }\n\n  // skip the regexp for non-magical patterns\n  // unescape anything in it, though, so that it'll be\n  // an exact match against a file etc.\n  if (!hasMagic) {\n    return globUnescape(pattern)\n  }\n\n  var flags = options.nocase ? 'i' : ''\n  var regExp = new RegExp('^' + re + '$', flags)\n\n  regExp._glob = pattern\n  regExp._src = re\n\n  return regExp\n}\n\nminimatch.makeRe = function (pattern, options) {\n  return new Minimatch(pattern, options || {}).makeRe()\n}\n\nMinimatch.prototype.makeRe = makeRe\nfunction makeRe () {\n  if (this.regexp || this.regexp === false) return this.regexp\n\n  // at this point, this.set is a 2d array of partial\n  // pattern strings, or \"**\".\n  //\n  // It's better to use .match().  This function shouldn't\n  // be used, really, but it's pretty convenient sometimes,\n  // when you just want to work with a regex.\n  var set = this.set\n\n  if (!set.length) {\n    this.regexp = false\n    return this.regexp\n  }\n  var options = this.options\n\n  var twoStar = options.noglobstar ? star\n    : options.dot ? twoStarDot\n    : twoStarNoDot\n  var flags = options.nocase ? 'i' : ''\n\n  var re = set.map(function (pattern) {\n    return pattern.map(function (p) {\n      return (p === GLOBSTAR) ? twoStar\n      : (typeof p === 'string') ? regExpEscape(p)\n      : p._src\n    }).join('\\\\\\/')\n  }).join('|')\n\n  // must match entire pattern\n  // ending in a * or ** will make it less strict.\n  re = '^(?:' + re + ')$'\n\n  // can match anything, as long as it's not this.\n  if (this.negate) re = '^(?!' + re + ').*$'\n\n  try {\n    this.regexp = new RegExp(re, flags)\n  } catch (ex) {\n    this.regexp = false\n  }\n  return this.regexp\n}\n\nminimatch.match = function (list, pattern, options) {\n  options = options || {}\n  var mm = new Minimatch(pattern, options)\n  list = list.filter(function (f) {\n    return mm.match(f)\n  })\n  if (mm.options.nonull && !list.length) {\n    list.push(pattern)\n  }\n  return list\n}\n\nMinimatch.prototype.match = match\nfunction match (f, partial) {\n  this.debug('match', f, this.pattern)\n  // short-circuit in the case of busted things.\n  // comments, etc.\n  if (this.comment) return false\n  if (this.empty) return f === ''\n\n  if (f === '/' && partial) return true\n\n  var options = this.options\n\n  // windows: need to use /, not \\\n  if (path.sep !== '/') {\n    f = f.split(path.sep).join('/')\n  }\n\n  // treat the test path as a set of pathparts.\n  f = f.split(slashSplit)\n  this.debug(this.pattern, 'split', f)\n\n  // just ONE of the pattern sets in this.set needs to match\n  // in order for it to be valid.  If negating, then just one\n  // match means that we have failed.\n  // Either way, return on the first hit.\n\n  var set = this.set\n  this.debug(this.pattern, 'set', set)\n\n  // Find the basename of the path by looking for the last non-empty segment\n  var filename\n  var i\n  for (i = f.length - 1; i >= 0; i--) {\n    filename = f[i]\n    if (filename) break\n  }\n\n  for (i = 0; i < set.length; i++) {\n    var pattern = set[i]\n    var file = f\n    if (options.matchBase && pattern.length === 1) {\n      file = [filename]\n    }\n    var hit = this.matchOne(file, pattern, partial)\n    if (hit) {\n      if (options.flipNegate) return true\n      return !this.negate\n    }\n  }\n\n  // didn't get any hits.  this is success if it's a negative\n  // pattern, failure otherwise.\n  if (options.flipNegate) return false\n  return this.negate\n}\n\n// set partial to true to test if, for example,\n// \"/a/b\" matches the start of \"/*/b/*/d\"\n// Partial means, if you run out of file before you run\n// out of pattern, then that's fine, as long as all\n// the parts match.\nMinimatch.prototype.matchOne = function (file, pattern, partial) {\n  var options = this.options\n\n  this.debug('matchOne',\n    { 'this': this, file: file, pattern: pattern })\n\n  this.debug('matchOne', file.length, pattern.length)\n\n  for (var fi = 0,\n      pi = 0,\n      fl = file.length,\n      pl = pattern.length\n      ; (fi < fl) && (pi < pl)\n      ; fi++, pi++) {\n    this.debug('matchOne loop')\n    var p = pattern[pi]\n    var f = file[fi]\n\n    this.debug(pattern, p, f)\n\n    // should be impossible.\n    // some invalid regexp stuff in the set.\n    if (p === false) return false\n\n    if (p === GLOBSTAR) {\n      this.debug('GLOBSTAR', [pattern, p, f])\n\n      // \"**\"\n      // a/**/b/**/c would match the following:\n      // a/b/x/y/z/c\n      // a/x/y/z/b/c\n      // a/b/x/b/x/c\n      // a/b/c\n      // To do this, take the rest of the pattern after\n      // the **, and see if it would match the file remainder.\n      // If so, return success.\n      // If not, the ** \"swallows\" a segment, and try again.\n      // This is recursively awful.\n      //\n      // a/**/b/**/c matching a/b/x/y/z/c\n      // - a matches a\n      // - doublestar\n      //   - matchOne(b/x/y/z/c, b/**/c)\n      //     - b matches b\n      //     - doublestar\n      //       - matchOne(x/y/z/c, c) -> no\n      //       - matchOne(y/z/c, c) -> no\n      //       - matchOne(z/c, c) -> no\n      //       - matchOne(c, c) yes, hit\n      var fr = fi\n      var pr = pi + 1\n      if (pr === pl) {\n        this.debug('** at the end')\n        // a ** at the end will just swallow the rest.\n        // We have found a match.\n        // however, it will not swallow /.x, unless\n        // options.dot is set.\n        // . and .. are *never* matched by **, for explosively\n        // exponential reasons.\n        for (; fi < fl; fi++) {\n          if (file[fi] === '.' || file[fi] === '..' ||\n            (!options.dot && file[fi].charAt(0) === '.')) return false\n        }\n        return true\n      }\n\n      // ok, let's see if we can swallow whatever we can.\n      while (fr < fl) {\n        var swallowee = file[fr]\n\n        this.debug('\\nglobstar while', file, fr, pattern, pr, swallowee)\n\n        // XXX remove this slice.  Just pass the start index.\n        if (this.matchOne(file.slice(fr), pattern.slice(pr), partial)) {\n          this.debug('globstar found match!', fr, fl, swallowee)\n          // found a match.\n          return true\n        } else {\n          // can't swallow \".\" or \"..\" ever.\n          // can only swallow \".foo\" when explicitly asked.\n          if (swallowee === '.' || swallowee === '..' ||\n            (!options.dot && swallowee.charAt(0) === '.')) {\n            this.debug('dot detected!', file, fr, pattern, pr)\n            break\n          }\n\n          // ** swallows a segment, and continue.\n          this.debug('globstar swallow a segment, and continue')\n          fr++\n        }\n      }\n\n      // no match was found.\n      // However, in partial mode, we can't say this is necessarily over.\n      // If there's more *pattern* left, then\n      if (partial) {\n        // ran out of file\n        this.debug('\\n>>> no match, partial?', file, fr, pattern, pr)\n        if (fr === fl) return true\n      }\n      return false\n    }\n\n    // something other than **\n    // non-magic patterns just have to match exactly\n    // patterns with magic have been turned into regexps.\n    var hit\n    if (typeof p === 'string') {\n      if (options.nocase) {\n        hit = f.toLowerCase() === p.toLowerCase()\n      } else {\n        hit = f === p\n      }\n      this.debug('string match', p, f, hit)\n    } else {\n      hit = f.match(p)\n      this.debug('pattern match', p, f, hit)\n    }\n\n    if (!hit) return false\n  }\n\n  // Note: ending in / means that we'll get a final \"\"\n  // at the end of the pattern.  This can only match a\n  // corresponding \"\" at the end of the file.\n  // If the file ends in /, then it can only match a\n  // a pattern that ends in /, unless the pattern just\n  // doesn't have any more for it. But, a/b/ should *not*\n  // match \"a/b/*\", even though \"\" matches against the\n  // [^/]*? pattern, except in partial mode, where it might\n  // simply not be reached yet.\n  // However, a/b/ should still satisfy a/*\n\n  // now either we fell off the end of the pattern, or we're done.\n  if (fi === fl && pi === pl) {\n    // ran out of pattern and filename at the same time.\n    // an exact hit!\n    return true\n  } else if (fi === fl) {\n    // ran out of file, but still had pattern left.\n    // this is ok if we're doing the match as part of\n    // a glob fs traversal.\n    return partial\n  } else if (pi === pl) {\n    // ran out of pattern, still have file left.\n    // this is only acceptable if we're on the very last\n    // empty segment of a file with a trailing slash.\n    // a/* should match a/b/\n    var emptyFileEnd = (fi === fl - 1) && (file[fi] === '')\n    return emptyFileEnd\n  }\n\n  // should be unreachable.\n  throw new Error('wtf?')\n}\n\n// replace stuff like \\* with *\nfunction globUnescape (s) {\n  return s.replace(/\\\\(.)/g, '$1')\n}\n\nfunction regExpEscape (s) {\n  return s.replace(/[-[\\]{}()*+?.,\\\\^$|#\\s]/g, '\\\\$&')\n}\n","var path = require('path');\nvar fs = require('fs');\nvar _0777 = parseInt('0777', 8);\n\nmodule.exports = mkdirP.mkdirp = mkdirP.mkdirP = mkdirP;\n\nfunction mkdirP (p, opts, f, made) {\n    if (typeof opts === 'function') {\n        f = opts;\n        opts = {};\n    }\n    else if (!opts || typeof opts !== 'object') {\n        opts = { mode: opts };\n    }\n    \n    var mode = opts.mode;\n    var xfs = opts.fs || fs;\n    \n    if (mode === undefined) {\n        mode = _0777 & (~process.umask());\n    }\n    if (!made) made = null;\n    \n    var cb = f || function () {};\n    p = path.resolve(p);\n    \n    xfs.mkdir(p, mode, function (er) {\n        if (!er) {\n            made = made || p;\n            return cb(null, made);\n        }\n        switch (er.code) {\n            case 'ENOENT':\n                mkdirP(path.dirname(p), opts, function (er, made) {\n                    if (er) cb(er, made);\n                    else mkdirP(p, opts, cb, made);\n                });\n                break;\n\n            // In the case of any other error, just see if there's a dir\n            // there already.  If so, then hooray!  If not, then something\n            // is borked.\n            default:\n                xfs.stat(p, function (er2, stat) {\n                    // if the stat fails, then that's super weird.\n                    // let the original error be the failure reason.\n                    if (er2 || !stat.isDirectory()) cb(er, made)\n                    else cb(null, made);\n                });\n                break;\n        }\n    });\n}\n\nmkdirP.sync = function sync (p, opts, made) {\n    if (!opts || typeof opts !== 'object') {\n        opts = { mode: opts };\n    }\n    \n    var mode = opts.mode;\n    var xfs = opts.fs || fs;\n    \n    if (mode === undefined) {\n        mode = _0777 & (~process.umask());\n    }\n    if (!made) made = null;\n\n    p = path.resolve(p);\n\n    try {\n        xfs.mkdirSync(p, mode);\n        made = made || p;\n    }\n    catch (err0) {\n        switch (err0.code) {\n            case 'ENOENT' :\n                made = sync(path.dirname(p), opts, made);\n                sync(p, opts, made);\n                break;\n\n            // In the case of any other error, just see if there's a dir\n            // there already.  If so, then hooray!  If not, then something\n            // is borked.\n            default:\n                var stat;\n                try {\n                    stat = xfs.statSync(p);\n                }\n                catch (err1) {\n                    throw err0;\n                }\n                if (!stat.isDirectory()) throw err0;\n                break;\n        }\n    }\n\n    return made;\n};\n","// If `Date.now()` is invoked twice quickly, it's possible to get two\n// identical time stamps. To avoid generation duplications, subsequent\n// calls are manually ordered to force uniqueness.\n\nvar _last = 0\nvar _count = 1\nvar adjusted = 0\nvar _adjusted = 0\n\nmodule.exports =\nfunction timestamp() {\n  /**\n  Returns NOT an accurate representation of the current time.\n  Since js only measures time as ms, if you call `Date.now()`\n  twice quickly, it's possible to get two identical time stamps.\n  This function guarantees unique but maybe inaccurate results\n  on each call.\n  **/\n  //uncomment this wen\n  var time = Date.now()\n  //time = ~~ (time / 1000) \n  //^^^uncomment when testing...\n\n  /**\n  If time returned is same as in last call, adjust it by\n  adding a number based on the counter. \n  Counter is incremented so that next call get's adjusted properly.\n  Because floats have restricted precision, \n  may need to step past some values...\n  **/\n  if (_last === time)  {\n    do {\n      adjusted = time + ((_count++) / (_count + 999))\n    } while (adjusted === _adjusted)\n    _adjusted = adjusted\n  }\n  // If last time was different reset timer back to `1`.\n  else {\n    _count = 1\n    adjusted = time\n  }\n  _adjusted = adjusted\n  _last = time\n  return adjusted\n}\n","var cont     = require('cont')\nvar pull     = require('pull-stream')\nvar defer    = require('pull-defer')\nvar path     = require('path')\nvar explain  = require('explain-error')\nvar mkdirp   = require('mkdirp')\nvar rimraf   = require('rimraf')\nvar fs       = require('fs')\nvar glob     = require('pull-glob')\nvar paramap  = require('pull-paramap')\nvar cat      = require('pull-cat')\nvar Notify   = require('pull-notify')\n\nvar Write    = require('pull-write-file')\nvar Read     = require('pull-file')\n\nvar u = require('./util')\nvar createHash = u.createHash\n\nfunction write (filename, cb) {\n  return WriteFile(filename, cb)\n  return toPull.sink(fs.createWriteStream(filename), cb)\n}\n\nfunction read (filename) {\n  return ReadFile(filename)\n//  return toPull.source(fs.createReadStream(filename))\n}\n\nfunction toArray (h) {\n  return Array.isArray(h) ? h : [h]\n}\n\nvar Blobs = module.exports = function (config) {\n  var dir\n  if('string' === typeof config)\n    dir = config, config = {dir: dir}\n\n  var encode = config.encode || u.encode\n  var decode = config.decode || u.decode\n  var isHash = config.isHash || u.isHash\n\n  function toPath (dir, string) {\n    var d = decode(string)\n    var h = d.hash.toString('hex')\n    return path.join(dir, d.alg, h.substring(0,2), h.substring(2))\n  }\n\n  function toHash(filename) {\n    var parts = path.relative(dir, filename).split(path.sep)\n    var alg = parts.shift()\n    return encode(new Buffer(parts.join(''), 'hex'), alg)\n  }\n\n  var newBlob = Notify()\n\n  config = config || {}\n  var alg = config.hash = config.hash || config.alg || 'blake2s'\n\n  dir = config.dir\n\n  var n = 0\n  var waiting = [], tmp = false, clean = false\n\n  function init (cb) {\n    if(tmp) return cb()\n    else waiting.push(cb)\n  }\n\n  var tmpdir = path.join(dir, 'tmp')\n\n  rimraf(tmpdir, function () {\n    mkdirp(tmpdir, function () {\n      tmp = true; while(waiting.length) waiting.shift()()\n    })\n  })\n\n  function has (hash) {\n    return function (cb) {\n      fs.stat(toPath(dir, hash), function (err, stat) {\n        cb(null, !!stat)\n      })\n    }\n  }\n\n  function size (hash) {\n    return function (cb) {\n      fs.stat(toPath(dir, hash), function (err, stat) {\n        cb(null, stat ? stat.size : null)\n      })\n    }\n  }\n\n  function createTester (test) {\n    return function (hashes, cb) {\n      var n = !Array.isArray(hashes)\n      cont.para(toArray(hashes).map(test)) (function (_, ary) {\n        // This will only error if the hash is not present,\n        // so never callback an error.\n        // PS. if you have a situation where you never error\n        // add a comment like this one to explain why.\n        if(n) cb(null, ary[0])\n        else  cb(null, ary)\n      })\n      return cb\n    }\n  }\n\n  var listeners = []\n\n\n  return {\n    get: function (opts) {\n      if(isHash(opts))\n        return Read(toPath(dir, opts))\n\n      var hash = opts.key || opts.hash\n      if(!isHash(hash))\n        return pull.error(new Error(\n          'multiblob.get: {hash} is mandatory'\n        ))\n\n      var stream = defer.source()\n      fs.stat(toPath(dir, hash), function (err, stat) {\n        if(opts.size != null && opts.size !== stat.size)\n          stream.abort(new Error('incorrect file length,'\n            + ' requested:' + opts.size + ' file was:' + stat.size\n            + ' for file:' + hash\n          ))\n\n        else if(opts.max != null && opts.max < stat.size)\n          stream.abort(new Error('incorrect file length,'\n            + ' requested:' + opts.size + ' file was:' + stat.size\n            + ' for file:' + hash\n          ))\n\n        else\n          stream.resolve(Read(toPath(dir, hash)))\n      })\n\n      return stream\n    },\n\n    size: createTester(size),\n\n    has: createTester(has),\n\n    add: function (hash, cb) {\n      if(!cb) cb = hash, hash = null\n\n      if(!cb) cb = function (err) {\n        if(err) explain(err, 'no callback provided')\n      }\n\n      var deferred = defer.sink()\n      init(function () {\n        var tmpfile = path.join(dir, 'tmp', Date.now() + '-' + n++)\n        var hasher = createHash(alg, true)\n        var size = 0\n\n        deferred.resolve(pull(\n          hasher,\n          pull.through(function (data) {\n            size += data.length\n          }),\n          Write(tmpfile, function (err) {\n            if(err) return cb(explain(err, 'could not write to tmpfile'))\n\n            var _hash = encode(hasher.digest, alg)\n\n            if(hash && hash !== _hash)\n              return cb(new Error('actual hash:'+ _hash\n                + ' did not match expected hash:'+hash), _hash)\n\n            var p = toPath(dir, hash || _hash)\n\n            mkdirp(path.dirname(p), function () {\n              fs.rename(tmpfile, p, function (err) {\n                if(err) cb(explain(err, 'could not move file'))\n                else    newBlob({id:toHash(p), size: size, ts: Date.now()}), cb(null, _hash)\n              })\n            })\n          })\n        ))\n      })\n\n      return deferred\n    },\n    ls: function (opts) {\n      opts = opts || {}\n      var long = (opts.size || opts.long)\n      var source = pull(\n        glob(path.join(dir, '*', '*', '*')),\n        long\n        ? paramap(function (filename, cb) {\n            fs.stat(filename, function (err, stat) {\n              cb(err, {id: toHash(filename), size: stat.size, ts: +stat.ctime})\n            })\n          }, 32)\n        : pull.map(toHash)\n      )\n\n      if(!opts.live) return source\n\n      return cat([\n        source,\n        pull.once({sync: true}),\n          long\n          ? newBlob.listen()\n          : pull(newBlob.listen(), pull.map(function (e) { return e.id }))\n      ])\n      \n    },\n    rm: function (hash, cb) {\n      fs.unlink(toPath(dir, hash), cb)\n    },\n    resolve: function (hash) {\n      return toPath(dir, hash)\n    }\n  }\n}\n\n\n","\nvar pushable = require('pull-pushable')\n\nmodule.exports = function () {\n\n  var listeners = {}, n = 0\n\n  function notify (msg) {\n    for(var k in listeners) listeners[k].push(msg)\n  }\n\n  notify.listen = function () {\n    var k = ++n\n    return listeners[k] = pushable(function () {\n      delete listeners[k]\n    })\n  }\n\n  notify.abort = function (err) {\n    for(var k in listeners) listeners[k].end(err)\n  }\n\n  notify.end = function () {\n    return notify.abort(true)\n  }\n\n  return notify\n}\n","module.exports = rimraf\nrimraf.sync = rimrafSync\n\nvar assert = require(\"assert\")\nvar path = require(\"path\")\nvar fs = require(\"fs\")\n\n// for EMFILE handling\nvar timeout = 0\nexports.EMFILE_MAX = 1000\nexports.BUSYTRIES_MAX = 3\n\nvar isWindows = (process.platform === \"win32\")\n\nfunction defaults (options) {\n  var methods = [\n    'unlink',\n    'chmod',\n    'stat',\n    'rmdir',\n    'readdir'\n  ]\n  methods.forEach(function(m) {\n    options[m] = options[m] || fs[m]\n    m = m + 'Sync'\n    options[m] = options[m] || fs[m]\n  })\n}\n\nfunction rimraf (p, options, cb) {\n  if (typeof options === 'function') {\n    cb = options\n    options = {}\n  }\n  assert(p)\n  assert(options)\n  assert(typeof cb === 'function')\n\n  defaults(options)\n\n  if (!cb) throw new Error(\"No callback passed to rimraf()\")\n\n  var busyTries = 0\n  rimraf_(p, options, function CB (er) {\n    if (er) {\n      if (isWindows && (er.code === \"EBUSY\" || er.code === \"ENOTEMPTY\") &&\n          busyTries < exports.BUSYTRIES_MAX) {\n        busyTries ++\n        var time = busyTries * 100\n        // try again, with the same exact callback as this one.\n        return setTimeout(function () {\n          rimraf_(p, options, CB)\n        }, time)\n      }\n\n      // this one won't happen if graceful-fs is used.\n      if (er.code === \"EMFILE\" && timeout < exports.EMFILE_MAX) {\n        return setTimeout(function () {\n          rimraf_(p, options, CB)\n        }, timeout ++)\n      }\n\n      // already gone\n      if (er.code === \"ENOENT\") er = null\n    }\n\n    timeout = 0\n    cb(er)\n  })\n}\n\n// Two possible strategies.\n// 1. Assume it's a file.  unlink it, then do the dir stuff on EPERM or EISDIR\n// 2. Assume it's a directory.  readdir, then do the file stuff on ENOTDIR\n//\n// Both result in an extra syscall when you guess wrong.  However, there\n// are likely far more normal files in the world than directories.  This\n// is based on the assumption that a the average number of files per\n// directory is >= 1.\n//\n// If anyone ever complains about this, then I guess the strategy could\n// be made configurable somehow.  But until then, YAGNI.\nfunction rimraf_ (p, options, cb) {\n  assert(p)\n  assert(options)\n  assert(typeof cb === 'function')\n\n  options.unlink(p, function (er) {\n    if (er) {\n      if (er.code === \"ENOENT\")\n        return cb(null)\n      if (er.code === \"EPERM\")\n        return (isWindows)\n          ? fixWinEPERM(p, options, er, cb)\n          : rmdir(p, options, er, cb)\n      if (er.code === \"EISDIR\")\n        return rmdir(p, options, er, cb)\n    }\n    return cb(er)\n  })\n}\n\nfunction fixWinEPERM (p, options, er, cb) {\n  assert(p)\n  assert(options)\n  assert(typeof cb === 'function')\n  if (er)\n    assert(er instanceof Error)\n\n  options.chmod(p, 666, function (er2) {\n    if (er2)\n      cb(er2.code === \"ENOENT\" ? null : er)\n    else\n      options.stat(p, function(er3, stats) {\n        if (er3)\n          cb(er3.code === \"ENOENT\" ? null : er)\n        else if (stats.isDirectory())\n          rmdir(p, options, er, cb)\n        else\n          options.unlink(p, cb)\n      })\n  })\n}\n\nfunction fixWinEPERMSync (p, options, er) {\n  assert(p)\n  assert(options)\n  if (er)\n    assert(er instanceof Error)\n\n  try {\n    options.chmodSync(p, 666)\n  } catch (er2) {\n    if (er2.code === \"ENOENT\")\n      return\n    else\n      throw er\n  }\n\n  try {\n    var stats = options.statSync(p)\n  } catch (er3) {\n    if (er3.code === \"ENOENT\")\n      return\n    else\n      throw er\n  }\n\n  if (stats.isDirectory())\n    rmdirSync(p, options, er)\n  else\n    options.unlinkSync(p)\n}\n\nfunction rmdir (p, options, originalEr, cb) {\n  assert(p)\n  assert(options)\n  if (originalEr)\n    assert(originalEr instanceof Error)\n  assert(typeof cb === 'function')\n\n  // try to rmdir first, and only readdir on ENOTEMPTY or EEXIST (SunOS)\n  // if we guessed wrong, and it's not a directory, then\n  // raise the original error.\n  options.rmdir(p, function (er) {\n    if (er && (er.code === \"ENOTEMPTY\" || er.code === \"EEXIST\" || er.code === \"EPERM\"))\n      rmkids(p, options, cb)\n    else if (er && er.code === \"ENOTDIR\")\n      cb(originalEr)\n    else\n      cb(er)\n  })\n}\n\nfunction rmkids(p, options, cb) {\n  assert(p)\n  assert(options)\n  assert(typeof cb === 'function')\n\n  options.readdir(p, function (er, files) {\n    if (er)\n      return cb(er)\n    var n = files.length\n    if (n === 0)\n      return options.rmdir(p, cb)\n    var errState\n    files.forEach(function (f) {\n      rimraf(path.join(p, f), options, function (er) {\n        if (errState)\n          return\n        if (er)\n          return cb(errState = er)\n        if (--n === 0)\n          options.rmdir(p, cb)\n      })\n    })\n  })\n}\n\n// this looks simpler, and is strictly *faster*, but will\n// tie up the JavaScript thread and fail on excessively\n// deep directory trees.\nfunction rimrafSync (p, options) {\n  options = options || {}\n  defaults(options)\n\n  assert(p)\n  assert(options)\n\n  try {\n    options.unlinkSync(p)\n  } catch (er) {\n    if (er.code === \"ENOENT\")\n      return\n    if (er.code === \"EPERM\")\n      return isWindows ? fixWinEPERMSync(p, options, er) : rmdirSync(p, options, er)\n    if (er.code !== \"EISDIR\")\n      throw er\n    rmdirSync(p, options, er)\n  }\n}\n\nfunction rmdirSync (p, options, originalEr) {\n  assert(p)\n  assert(options)\n  if (originalEr)\n    assert(originalEr instanceof Error)\n\n  try {\n    options.rmdirSync(p)\n  } catch (er) {\n    if (er.code === \"ENOENT\")\n      return\n    if (er.code === \"ENOTDIR\")\n      throw originalEr\n    if (er.code === \"ENOTEMPTY\" || er.code === \"EEXIST\" || er.code === \"EPERM\")\n      rmkidsSync(p, options)\n  }\n}\n\nfunction rmkidsSync (p, options) {\n  assert(p)\n  assert(options)\n  options.readdirSync(p).forEach(function (f) {\n    rimrafSync(path.join(p, f), options)\n  })\n  options.rmdirSync(p, options)\n}\n","var Blake2s = require('blake2s')\nvar createHash = require('crypto').createHash\nvar hash    = require('crypto')\nvar path    = require('path')\nvar pull    = require('pull-stream')\n\nvar isBuffer = Buffer.isBuffer\n\nvar algs = {\n  blake2s: function () { return new Blake2s() },\n  sha256: function () { return createHash('sha256') }\n}\n\nexports.encode = function (buf, alg) {\n  if(!isBuffer(buf)) throw new Error('hash should be a buffer, was:'+buf)\n  return buf.toString('base64')+'.'+alg\n}\n\nexports.decode = function (str) {\n  var i = str.indexOf('.')\n  var alg = str.substring(i+1)\n  return {hash: new Buffer(str.substring(0, i), 'base64'), alg: alg}\n}\n\nexports.createHash = function (alg, noCompat) {\n  alg = alg || 'blake2s'\n  var hash = algs[alg]()\n\n  var hasher = pull.through(function (data) {\n    data = isBuffer(data) ? data : new Buffer(data)\n    hasher.size += data.length\n    hash.update(data)\n  }, function () {\n    return hasher.digest = noCompat === true ? hash.digest() : hash.digest('base64') + '.' + alg\n//    hasher.digest = digest\n  })\n\n  hasher.size = 0\n  return hasher\n}\n\nfunction isString (s) {\n  return 'string' === typeof s\n}\n\nexports.isHash = function (data) {\n  return isString(data) && /^[A-Za-z0-9\\/+]{43}=\\.(?:blake2s|sha256)$/.test(data)\n}\n\n\n","var zerr = require('zerr')\nvar pull = require('pull-stream')\n\nmodule.exports = function (addedValidators) {\n  var api = {}\n  var validators = {}\n\n  // validator control\n  api.get = function (name) {\n    return validators[name]\n  }\n  api.set = function (name, fn) {\n    if (name && typeof name == 'object')\n      for (var k in name) \n        api.set(k, name[k].bind(api))\n    else\n      validators[name] = fn\n  }\n\n  // set validator registry\n  api.set({\n    number: function (param, n) {\n      var asNum = +param\n      if (isNaN(asNum) || asNum != param)\n        return 'type'\n    },\n    string: function (param, n) {\n      var asString = ''+param\n      if (asString != param)\n        return 'type'\n    },\n    boolean: function (param, n) {\n      if (typeof param != 'boolean')\n        return 'type'\n    },\n    object: function (param, n) {\n      if (typeof param != 'object' || !param)\n        return 'type'\n    },\n    array: function (param, n) {\n      if (!Array.isArray(param))\n        return 'type'\n    },\n    function: function (param, n) {\n      if (typeof param != 'function')\n        return 'type'\n    }\n  })\n  api.set(addedValidators)\n\n  // rpc method wrappers\n  api.sync = function (fn) {\n    var spec = Array.prototype.slice.call(arguments, 1)\n    return function () {\n      var args = Array.prototype.slice.call(arguments)\n\n      // run validation\n      var err = validate(args, spec)\n      if (err) throw err\n\n      // run sync fn\n      return apply(this, fn, args)\n    }\n  }\n  api.sink = \n  api.async = function (fn) {\n    var spec = Array.prototype.slice.call(arguments, 1)\n    return function () {\n      var args = Array.prototype.slice.call(arguments)\n      var hasCb = (typeof args[args.length - 1] == 'function')\n\n      // get cb\n      var cb = (hasCb)\n        ? args[args.length - 1]\n        : function (err) { if (err) { throw err; } }\n\n      // run validation\n      var err = validate((hasCb) ? args.slice(0,args.length-1) : args, spec)\n      if (err) return cb(err)\n\n      // run async fn\n      return apply(this, fn, args)\n    }\n  }\n  api.source = function (fn) {\n    var spec = Array.prototype.slice.call(arguments, 1)\n    return function () {\n      var args = Array.prototype.slice.call(arguments)\n\n      // run validation\n      var err = validate(args, spec)\n      if (err) return pull.error(err)\n\n      // run stream fn\n      return apply(this, fn, args)\n    }\n  }\n\n  // run validation against a spec\n  function validate (args, spec) {\n    var err\n\n    // multiple specs?\n    if (Array.isArray(spec[0])) {\n      for (var i=0; i < spec.length; i++) {\n        err = validate(args, spec[i])\n        if (!err)\n          return false // spec passed\n      }\n      return err // give the last error\n    }\n\n    // iterate the spec\n    for (var i=0; i < spec.length; i++) {\n      var types = parse(spec[i])\n\n      for (var j=0; j < types.length; j++) {\n        var type = types[j]\n\n        // falsey?\n        if (!args[i]) {\n          err = (type.optional) ? false : errs.MissingParam(''+i)\n          break\n        }\n\n        // get & run validator\n        var validator = validators[type.name]\n        if (!validator)\n          throw new Error('Validator not found: ' + type.name)\n        err = validator(args[i], ''+i)\n\n        // did the validator pass? break out of this type\n        if (!err)\n          break\n\n        // error aliases\n        if (err == 'type')\n          err = errs.Type(''+i, type.name)\n      }\n\n      // none of the types passed? return the error\n      if (err)\n        return err\n    }\n    return false\n  }\n\n  return api\n}\n\nvar errs =\nmodule.exports.errors = {\n  MissingParam: zerr('Usage', 'Param % is required'),\n  Type: zerr('Type', 'Param % must by of type %')\n}\n\n// parse spec token\nfunction parse (token) {\n  return token.split('|').map(function (token) {\n    if (token.charAt(token.length - 1) == '?')\n      return { name: token.slice(0, token.length - 1), optional: true }\n    return { name: token, optional: false }\n  })\n}\n\n// helper to avoid apply, for performance\nfunction apply (self, fn, args) {\n  if (args.length == 0)\n    return fn.call(self)\n  if (args.length == 1)\n    return fn.call(self, args[0])\n  if (args.length == 2)\n    return fn.call(self, args[0], args[1])\n  if (args.length == 3)\n    return fn.call(self, args[0], args[1], args[2])\n  if (args.length == 4)\n    return fn.call(self, args[0], args[1], args[2], args[3])\n  return fn.apply(self, args)\n}","'use strict';\nvar EventEmitter = require('events').EventEmitter\nvar u = require('./util')\nvar explain = require('explain-error')\n\nfunction isFunction (f) {\n  return 'function' === typeof f\n}\n\nfunction isObject (o) {\n  return o && 'object' === typeof o\n}\n\nfunction noop (err) {\n  if (err) throw explain(err, 'callback not provided')\n}\n\nmodule.exports = function (path, remoteApi, _remoteCall) {\n\n  var emitter = new EventEmitter()\n\n  function remoteCall(type, name, args) {\n    var cb = isFunction (args[args.length - 1]) ? args.pop() : noop\n    var value\n\n    try { value = _remoteCall(type, name, args, cb) }\n    catch(err) { return u.errorAsStreamOrCb(type, err, cb)}\n\n    return value\n  }\n\n  //add all the api methods to emitter recursively\n  ;(function recurse (obj, api, path) {\n    for(var name in api) (function (name, type) {\n      var _path = path ? path.concat(name) : [name]\n      obj[name] =\n          isObject(type)\n        ? recurse({}, type, _path)\n        : function () {\n            return remoteCall(type, _path, [].slice.call(arguments))\n          }\n    })(name, api[name])\n    return obj\n  })(emitter, remoteApi, path)\n\n  //legacy local emit, from when remote emit was supported.\n  emitter._emit = emitter.emit\n\n  return emitter\n}\n\n","'use strict'\nvar PSC          = require('packet-stream-codec')\nvar u            = require('./util')\nvar initStream   = require('./stream')\nvar createApi    = require('./api')\nvar createLocalCall = require('./local-api')\n\nfunction createMuxrpc (remoteApi, localApi, local, id, perms, codec, legacy) {\n  localApi = localApi || {}\n  remoteApi = remoteApi || {}\n  var emitter\n  if(!codec) codec = PSC\n\n  //pass the manifest to the permissions so that it can know\n  //what something should be.\n\n  var _cb, ws\n  var context = {\n      _emit: function (event, value) {\n        emitter && emitter._emit(event, value)\n        return context\n      },\n      id: id\n    }\n\n  var ws = initStream(\n    createLocalCall(local, localApi, perms).bind(context),\n    codec, function (err) {\n      if(emitter.closed) return\n      emitter.closed = true\n      emitter.emit('closed')\n      if(_cb) {\n        var cb = _cb; _cb = null; cb(err)\n      }\n    }\n  )\n\n  emitter = createApi([], remoteApi, function (type, name, args, cb) {\n    if(ws.closed) throw new Error('stream is closed')\n    return ws.remoteCall(type, name, args, cb)\n  })\n\n  if(legacy) {\n    Object.__defineGetter__.call(emitter, 'id', function () {\n      return context.id\n    })\n\n    Object.__defineSetter__.call(emitter, 'id', function (value) {\n      context.id =  value\n    })\n\n    var first = true\n\n    emitter.createStream = function (cb) {\n      _cb = cb\n      if(first) {\n        first = false; return ws\n      }\n      else\n        throw new Error('one stream per rpc')\n    }\n  }\n  else\n    emitter.stream = ws\n\n  emitter.closed = false\n\n  emitter.close = function (err, cb) {\n    ws.close(err, cb)\n    return this\n  }\n\n  return emitter\n\n}\n\nmodule.exports = function (remoteApi, localApi, codec) {\n  if(arguments.length > 3)\n    return createMuxrpc.apply(this, arguments)\n  return function (local, perms, id) {\n    return createMuxrpc(remoteApi, localApi, local, id, perms, codec, true)\n  }\n}\n\n","\nvar Permissions  = require('./permissions')\nvar u            = require('./util')\n\nmodule.exports = \n\nfunction createLocalCall(local, localApi, perms) {\n  perms = Permissions(perms)\n\n  function has(type, name) {\n    return type === u.get(localApi, name)\n  }\n\n  function localCall(type, name, args) {\n\n    if(name === 'emit')\n      throw new Error('emit has been removed')\n\n    //is there a way to know whether it's sync or async?\n    if(type === 'async')\n      if(has('sync', name)) {\n        var cb = args.pop(), value\n        try { value = u.get(local, name).apply(this, args) }\n        catch (err) { return cb(err) }\n        return cb(null, value)\n      }\n\n    if (!has(type, name))\n      throw new Error('no '+type+':'+name)\n\n    return u.get(local, name).apply(this, args)\n  }\n\n  return function (type, name, args) {\n    var err = perms.pre(name, args)\n    if(err) throw err\n    return localCall.call(this, type, name, args)\n  }\n}\n\n\n","'use strict';\nvar u = require('./util')\n\nvar isArray = Array.isArray\n\nfunction isFunction (f) {\n  return 'function' === typeof f\n}\n\nfunction join (str) {\n  return Array.isArray(str) ? str.join('.') : str\n}\n\nfunction toArray(str) {\n  return isArray(str) ? str : str.split('.')\n}\n\nfunction isPerms (p) {\n  return (\n    p &&\n    isFunction(p.pre) &&\n    isFunction(p.test) &&\n    isFunction(p.post)\n  )\n}\n\n/*\n\nperms:\n\na given capability may be permitted to call a particular api.\nbut only if a perms function returns true for the arguments\nit passes.\n\nsuppose, an app may be given access, but may only create functions\nwith it's own properties.\n\ncreate perms:\n  {\n    allow: ['add', 'query'], deny: [...],\n    rules: {\n      add: {\n        call: function (value) {\n          return (value.type === 'task' || value.type === '_task')\n        },\n      query: {\n        call: function (value) {\n          safe.contains(value, {path: ['content', 'type'], eq: 'task'}) ||\n          safe.contains(value, {path: ['content', 'type'], eq: '_task'})\n        },\n        filter: function (value) {\n          return (value.type === 'task' || value.type === '_task')\n        }\n      }\n    }\n  }\n*/\n\nmodule.exports = function (opts) {\n  if(isPerms(opts)) return opts\n  if(isFunction(opts)) return {pre: opts}\n  var allow = null\n  var deny = {}\n\n  function perms (opts) {\n    if(opts.allow) {\n      allow = {}\n      opts.allow.forEach(function (path) {\n        u.set(allow, toArray(path), true)\n      })\n    }\n    else allow = null\n\n    if(opts.deny)\n      opts.deny.forEach(function (path) {\n        u.set(deny, toArray(path), true)\n      })\n    else deny = {}\n\n    return this\n  }\n\n  if(opts) perms(opts)\n\n  perms.pre = function (name, args) {\n    name = isArray(name) ? name : [name]\n    if(allow && !u.prefix(allow, name))\n      return new Error('method:'+name + ' is not on whitelist')\n\n    if(deny && u.prefix(deny, name))\n      return new Error('method:'+name + ' is on blacklist')\n  }\n\n  perms.post = function (err, value) {\n    //TODO\n  }\n\n  //alias for pre, used in tests.\n  perms.test = function (name, args) {\n    return perms.pre(name, args)\n  }\n\n  perms.get = function () {\n    return {allow: allow, deny: deny}\n  }\n\n  return perms\n}\n\n\n","'use strict'\nvar pull = require('pull-stream')\n// wrap pull streams around packet-stream's weird streams.\n\nfunction once (fn) {\n  var done = false\n  return function (err, val) {\n    if(done) return\n    done = true\n    fn(err, val)\n  }\n}\n\nmodule.exports = function (weird, _done) {\n  var buffer = [], ended = false, waiting, abort\n\n  var done = once(function (err, v) {\n    _done && _done(err, v)\n    // deallocate\n    weird = null\n    _done = null    \n    waiting = null\n\n    if(abort) abort(err || true, function () {})\n  })\n\n  weird.read = function (data, end) {\n    ended = ended || end\n\n    if(waiting) {\n      var cb = waiting\n      waiting = null\n      cb(ended, data)\n    }\n    else if(!ended) buffer.push(data)\n\n    if(ended) done(ended !== true ? ended : null)\n  }\n\n  return {\n    source: function (abort, cb) {\n      if(abort) {\n        weird && weird.write(null, abort)\n        cb(abort); done(abort !== true ? abort : null)\n      }\n      else if(buffer.length) cb(null, buffer.shift())\n      else if(ended) cb(ended)\n      else waiting = cb\n    },\n    sink  : function (read) {\n      if(ended) return read(ended, function () {}), abort = null\n      abort = read\n      pull.drain(function (data) {\n        //TODO: make this should only happen on a UNIPLEX stream.\n        if(ended) return false\n        weird.write(data)\n      }, function (err) {\n        if(weird && !weird.writeEnd) weird.write(null, err || true)\n        done && done(err)\n      })\n      (read)\n    }\n  }\n}\n\nfunction uniplex (s, done) {\n  return module.exports(s, function (err) {\n    if(!s.writeEnd) s.write(null, err || true)\n    if(done) done(err)\n  })\n}\n\nmodule.exports.source = function (s) {\n  return uniplex(s).source\n}\nmodule.exports.sink = function (s, done) {\n  return uniplex(s, done).sink\n}\n\nmodule.exports.duplex = module.exports\n","'use strict';\nvar PacketStream = require('packet-stream')\nvar pull         = require('pull-stream')\nvar pullWeird    = require('./pull-weird')\nvar goodbye      = require('pull-goodbye')\nvar u            = require('./util')\nvar explain      = require('explain-error')\n\nfunction isFunction (f) {\n  return 'function' === typeof f\n}\n\nfunction isString (s) {\n  return 'string' === typeof s\n}\n\nfunction isObject (o) {\n  return o && 'object' === typeof o\n}\n\nfunction isSource    (t) { return 'source' === t }\nfunction isSink      (t) { return 'sink'   === t }\nfunction isDuplex    (t) { return 'duplex' === t }\nfunction isSync      (t) { return 'sync'  === t }\nfunction isAsync     (t) { return 'async'  === t }\nfunction isRequest   (t) { return isSync(t) || isAsync(t) }\nfunction isStream    (t) { return isSource(t) || isSink(t) || isDuplex(t) }\n\nmodule.exports = function initStream (localCall, codec, onClose) {\n\n  var ps = PacketStream({\n    message: function (msg) {\n//      if(isString(msg)) return\n//      if(msg.length > 0 && isString(msg[0]))\n//        localCall('msg', 'emit', msg)\n    },\n    request: function (opts, cb) {\n      var name = opts.name, args = opts.args\n      var inCB = false, called = false, async = false, value\n\n      args.push(function (err, value) {\n        called = true\n        inCB = true; cb(err, value)\n      })\n      try {\n        value = localCall('async', name, args)\n      } catch (err) {\n        if(inCB || called) throw explain(err, 'no callback provided to muxrpc async funtion')\n        return cb(err)\n      }\n\n    },\n    stream: function (stream) {\n      stream.read = function (data, end) {\n        var name = data.name\n        var type = data.type\n        var err, value\n\n        stream.read = null\n\n        if(!isStream(type))\n          return stream.write(null, new Error('unsupported stream type:'+type))\n\n        //how would this actually happen?\n        if(end) return stream.write(null, end)\n\n        try { value = localCall(type, name, data.args) }\n        catch (_err) { err = _err }\n\n        var _stream = pullWeird[\n          {source: 'sink', sink: 'source'}[type] || 'duplex'\n        ](stream)\n\n        return u.pipeToStream(\n          type, _stream,\n          err ? u.errorAsStream(type, err) : value\n        )\n\n//        if(isSource(type))\n//          _stream(err ? pull.error(err) : value)\n//        else if (isSink(type))\n//          (err ? abortSink(err) : value)(_stream)\n//        else if (isDuplex(type))\n//          pull(_stream, err ? abortDuplex(err) : value, _stream)\n      }\n    },\n\n    close: function (err) {\n        ps = null // deallocate\n        ws.ended = true\n        if(ws.closed) return\n        ws.closed = true\n        if(onClose) {\n          var close = onClose; onClose = null; close(err)\n        }\n      }\n  })\n\n  var ws = goodbye(pullWeird(ps, function (_) {\n    //this error will be handled in PacketStream.close\n  }))\n\n  ws = codec ? codec(ws) : ws\n\n  ws.remoteCall = function (type, name, args, cb) {\n    if(name === 'emit') return ps.message(args)\n\n    if(!(isRequest(type) || isStream(type)))\n      throw new Error('unsupported type:' + JSON.stringify(type))\n\n    if(isRequest(type))\n      return ps.request({name: name, args: args}, cb)\n\n    var ws = ps.stream(), s = pullWeird[type](ws, cb)\n    ws.write({name: name, args: args, type: type})\n    return s\n  }\n\n\n  //hack to work around ordering in setting ps.ended.\n  //Question: if an object has subobjects, which\n  //all have close events, should the subobjects fire close\n  //before the parent? or should parents close after?\n  //should there be a preclose event on the parent\n  //that fires when it's about to close all the children?\n  ws.isOpen = function () {\n    return !ps.ended\n  }\n\n  ws.close = function (err, cb) {\n    if(isFunction(err))\n      cb = err, err = false\n    if(!ps) return (cb && cb())\n    if(err) return ps.destroy(err), (cb && cb())\n\n    ps.close(function (err) {\n      if(cb) cb(err)\n      else if(err) throw explain(err, 'no callback provided for muxrpc close')\n    })\n\n    return this\n  }\n  ws.closed = false\n\n  return ws\n}\n\n\n\n","'use strict';\nvar pull = require('pull-stream')\n\nfunction isString (s) {\n  return 'string' === typeof s\n}\n\nvar isArray = Array.isArray\n\nfunction isObject (o) {\n  return o && 'object' === typeof o && !isArray(o)\n}\n\nfunction isEmpty (obj) {\n  for(var k in obj) return false;\n  return true\n}\n\n//I wrote set as part of permissions.js\n//and then later mount, they do nearly the same thing\n//but not quite. this should be refactored sometime.\n//what differs is that set updates the last key in the path\n//to the new value, but mount merges the last value\n//which makes sense if it's an object, and set makes sense if it's\n//a string/number/boolean.\n\nexports.set = function (obj, path, value) {\n  var _obj, _k\n  for(var i = 0; i < path.length; i++) {\n    var k = path[i]\n    obj[k] = obj[k] || {}\n    _obj = obj; _k = k\n    obj = obj[k]\n  }\n  _obj[_k] = value\n}\n\nexports.get = function (obj, path) {\n  if(isString(path)) return obj[path]\n  var value\n  for(var i = 0; i < path.length; i++) {\n    var k = path[i]\n    value = obj = obj[k]\n    if(null == obj) return obj\n  }\n  return value\n}\n\nexports.prefix = function (obj, path) {\n  var value, parent = obj\n\n  for(var i = 0; i < path.length; i++) {\n    var k = path[i]\n    value = obj = obj[k]\n    if('object' !== typeof obj) {\n      return obj\n    }\n    parent = obj\n  }\n  return 'object' !== typeof value ? !!value : false\n}\n\n\nfunction mkPath(obj, path) {\n  for(var i in path) {\n    var key = path[i]\n    if(!obj[key]) obj[key]={}\n    obj = obj[key]\n  }\n\n  return obj\n}\n\nfunction rmPath (obj, path) {\n  (function r (obj, i) {\n    var key = path[i]\n    if(!obj) return\n    else if(path.length - 1 === i)\n      delete obj[key]\n    else if(i < path.length) r(obj[key], i+1)\n    if(isEmpty(obj[key])) delete obj[key]\n  })(obj, 0)\n}\n\nfunction merge (obj, _obj) {\n  for(var k in _obj)\n    obj[k] = _obj[k]\n  return obj\n}\n\nvar mount = exports.mount = function (obj, path, _obj) {\n  if(!Array.isArray(path))\n    throw new Error('path must be array of strings')\n  return merge(mkPath(obj, path), _obj)\n}\nvar unmount = exports.unmount = function (obj, path) {\n  return rmPath(obj, path)\n}\n\nfunction isSource    (t) { return 'source' === t }\nfunction isSink      (t) { return 'sink'   === t }\nfunction isDuplex    (t) { return 'duplex' === t }\nfunction isSync      (t) { return 'sync'  === t }\nfunction isAsync     (t) { return 'async'  === t }\nfunction isRequest   (t) { return isSync(t) || isAsync(t) }\nfunction isStream    (t) { return isSource(t) || isSink(t) || isDuplex(t) }\n\nfunction abortSink (err) {\n  return function (read) {\n    read(err || true, function () {})\n  }\n}\n\nfunction abortDuplex (err) {\n  return {source: pull.error(err), sink: abortSink(err)}\n}\n\nexports.errorAsStream = function (type, err) {\n  return (\n      isSource(type)  ? pull.error(err)\n    : isSink(type)    ? abortSink(err)\n    :                   abortDuplex(err)\n  )\n}\n\n\nexports.errorAsStreamOrCb = function (type, err, cb) {\n  return (\n      isRequest(type) ? cb(err)\n    : isSource(type)  ? pull.error(err)\n    : isSink(type)    ? abortSink(err)\n    :                   cb(err), abortDuplex(err)\n  )\n}\n\nexports.pipeToStream = function (type, _stream, stream) {\n  if(isSource(type))\n    _stream(stream)\n  else if (isSink(type))\n    stream(_stream)\n  else if (isDuplex(type))\n    pull(_stream, stream, _stream)\n}\n\n","var os = require('os')\nvar ip = require('ip')\n//pick the first reasonable looking host.\n//this should *just work* when running on a vps.\n\nvar isPrivate = ip.isPrivate\n\nfunction isNonPrivate (e) {\n  return !isPrivate(e)\n}\n\n\nmodule.exports = function (inter, filter) {\n  inter = inter || os.networkInterfaces()\n  filter = filter || isNonPrivate\n  for(var k in inter) {\n    for(var i in inter[k]) {\n      var e = inter[k][i]\n      // find a reasonable looking address\n      if(!e.internal && filter(e.address))\n          return e.address\n    }\n  }\n}\n\nmodule.exports.private = function (inter) {\n  return module.exports(inter, isPrivate)\n}\n\nif(!module.parent) {\n  var h = module.exports()\n  if(!h) {\n    console.error('no non-private address')\n    console.error('private:', module.exports.private())\n    process.exit(1)\n  }\n  console.log(h)\n}\n","'use strict';\n\n/**\n * Normalize `uri`. This only works when both `encodeURI`\n * and `decodeURI` are available, and when\n * decoding/encoding fails, just returns `uri`.\n *\n * @example\n *   normalizeURI('foo bar'); // 'foo%20bar'\n *   normalizeURI('foo%20bar'); // 'foo%20bar'\n *\n * @param {string} uri - Value with and/or without\n *   encoded, entities.\n * @return {string} - Encoded URI (when encoding succeeds,\n * or `uri`).\n */\nfunction normalizeURI(uri) {\n    try {\n        uri = encodeURI(decodeURI(uri));\n    } catch (exception) { /* empty */ }\n\n    return uri;\n}\n\n/*\n * Expose.\n */\n\nmodule.exports = normalizeURI;\n","/* eslint-disable no-unused-vars */\n'use strict';\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nmodule.exports = Object.assign || function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (Object.getOwnPropertySymbols) {\n\t\t\tsymbols = Object.getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n","\nvar Observ = require('observ')\n\nmodule.exports = function (delay) {\n\n  delay = delay || 200\n  var o = Observ(),  set = o.set, ts = 0, timer, v\n\n  o.set = function (v) {\n    value = v\n    var next = (ts + delay) - Date.now()\n    if(next >= 0) {\n      if(!timer)\n        timer = setTimeout(function () {\n          timer = null\n          ts = Date.now()\n          set(value)\n        }, next)\n      return\n    }\n\n    ts = Date.now()\n    set(v)\n  }\n\n  o.immediate = function (v) {\n    ts = 0\n    clearTimeout(timer)\n    return o.set(v)\n  }\n\n  return o\n}\n","module.exports = Observable\n\nfunction Observable(value) {\n    var listeners = []\n    value = value === undefined ? null : value\n\n    observable.set = function (v) {\n        value = v\n        listeners.forEach(function (f) {\n            f(v)\n        })\n    }\n\n    return observable\n\n    function observable(listener) {\n        if (!listener) {\n            return value\n        }\n\n        listeners.push(listener)\n\n        return function remove() {\n            listeners.splice(listeners.indexOf(listener), 1)\n        }\n    }\n}\n","var sleepCheckInterval\nvar lastSleepCheck = false\nvar SLEEP_CHECK_INTERVAL = 10e3\nvar NUM_MISSABLE_INTERVALS = 3\nvar EE = require('events')\nvar emitter = new EE()\n\nmodule.exports = function (cb) {\n  emitter.on('wakeup', cb)\n\n  if (!sleepCheckInterval) {\n    // setup interval\n    sleepCheckInterval = setInterval(function () {\n      var t = Date.now()\n      if (lastSleepCheck && (t - lastSleepCheck) > SLEEP_CHECK_INTERVAL*NUM_MISSABLE_INTERVALS)\n        emitter.emit('wakeup') // missed NUM_MISSABLE_INTERVALS checks, let's run the callbacks \n      lastSleepCheck = t\n    }, SLEEP_CHECK_INTERVAL)\n  }\n  \n  // unreference the timer so that the program can close\n  if (sleepCheckInterval.unref)\n    sleepCheckInterval.unref()\n\n  return sleepCheckInterval\n}\n","var wrappy = require('wrappy')\nmodule.exports = wrappy(once)\n\nonce.proto = once(function () {\n  Object.defineProperty(Function.prototype, 'once', {\n    value: function () {\n      return once(this)\n    },\n    configurable: true\n  })\n})\n\nfunction once (fn) {\n  var f = function () {\n    if (f.called) return f.value\n    f.called = true\n    return f.value = fn.apply(this, arguments)\n  }\n  f.called = false\n  return f\n}\n","exports.endianness = function () { return 'LE' };\n\nexports.hostname = function () {\n    if (typeof location !== 'undefined') {\n        return location.hostname\n    }\n    else return '';\n};\n\nexports.loadavg = function () { return [] };\n\nexports.uptime = function () { return 0 };\n\nexports.freemem = function () {\n    return Number.MAX_VALUE;\n};\n\nexports.totalmem = function () {\n    return Number.MAX_VALUE;\n};\n\nexports.cpus = function () { return [] };\n\nexports.type = function () { return 'Browser' };\n\nexports.release = function () {\n    if (typeof navigator !== 'undefined') {\n        return navigator.appVersion;\n    }\n    return '';\n};\n\nexports.networkInterfaces\n= exports.getNetworkInterfaces\n= function () { return {} };\n\nexports.arch = function () { return 'javascript' };\n\nexports.platform = function () { return 'browser' };\n\nexports.tmpdir = exports.tmpDir = function () {\n    return '/tmp';\n};\n\nexports.EOL = '\\n';\n","'use strict';\nvar os = require('os');\n\nfunction homedir() {\n\tvar env = process.env;\n\tvar home = env.HOME;\n\tvar user = env.LOGNAME || env.USER || env.LNAME || env.USERNAME;\n\n\tif (process.platform === 'win32') {\n\t\treturn env.USERPROFILE || env.HOMEDRIVE + env.HOMEPATH || home || null;\n\t}\n\n\tif (process.platform === 'darwin') {\n\t\treturn home || (user ? '/Users/' + user : null);\n\t}\n\n\tif (process.platform === 'linux') {\n\t\treturn home || (process.getuid() === 0 ? '/root' : (user ? '/home/' + user : null));\n\t}\n\n\treturn home || null;\n}\n\nmodule.exports = typeof os.homedir === 'function' ? os.homedir : homedir;\n","'use strict';\nvar isWindows = process.platform === 'win32';\nvar trailingSlashRe = isWindows ? /[^:]\\\\$/ : /.\\/$/;\n\n// https://github.com/nodejs/io.js/blob/3e7a14381497a3b73dda68d05b5130563cdab420/lib/os.js#L25-L43\nmodule.exports = function () {\n\tvar path;\n\n\tif (isWindows) {\n\t\tpath = process.env.TEMP ||\n\t\t\tprocess.env.TMP ||\n\t\t\t(process.env.SystemRoot || process.env.windir) + '\\\\temp';\n\t} else {\n\t\tpath = process.env.TMPDIR ||\n\t\t\tprocess.env.TMP ||\n\t\t\tprocess.env.TEMP ||\n\t\t\t'/tmp';\n\t}\n\n\tif (trailingSlashRe.test(path)) {\n\t\tpath = path.slice(0, -1);\n\t}\n\n\treturn path;\n};\n","var isWindows = process.platform === 'win32'\nvar path = require('path')\nvar exec = require('child_process').exec\nvar osTmpdir = require('os-tmpdir')\nvar osHomedir = require('os-homedir')\n\n// looking up envs is a bit costly.\n// Also, sometimes we want to have a fallback\n// Pass in a callback to wait for the fallback on failures\n// After the first lookup, always returns the same thing.\nfunction memo (key, lookup, fallback) {\n  var fell = false\n  var falling = false\n  exports[key] = function (cb) {\n    var val = lookup()\n    if (!val && !fell && !falling && fallback) {\n      fell = true\n      falling = true\n      exec(fallback, function (er, output, stderr) {\n        falling = false\n        if (er) return // oh well, we tried\n        val = output.trim()\n      })\n    }\n    exports[key] = function (cb) {\n      if (cb) process.nextTick(cb.bind(null, null, val))\n      return val\n    }\n    if (cb && !falling) process.nextTick(cb.bind(null, null, val))\n    return val\n  }\n}\n\nmemo('user', function () {\n  return ( isWindows\n         ? process.env.USERDOMAIN + '\\\\' + process.env.USERNAME\n         : process.env.USER\n         )\n}, 'whoami')\n\nmemo('prompt', function () {\n  return isWindows ? process.env.PROMPT : process.env.PS1\n})\n\nmemo('hostname', function () {\n  return isWindows ? process.env.COMPUTERNAME : process.env.HOSTNAME\n}, 'hostname')\n\nmemo('tmpdir', function () {\n  return osTmpdir()\n})\n\nmemo('home', function () {\n  return osHomedir()\n})\n\nmemo('path', function () {\n  return (process.env.PATH ||\n          process.env.Path ||\n          process.env.path).split(isWindows ? ';' : ':')\n})\n\nmemo('editor', function () {\n  return process.env.EDITOR ||\n         process.env.VISUAL ||\n         (isWindows ? 'notepad.exe' : 'vi')\n})\n\nmemo('shell', function () {\n  return isWindows ? process.env.ComSpec || 'cmd'\n         : process.env.SHELL || 'bash'\n})\n","\nvar Through = require('pull-through')\nvar Reader = require('pull-reader')\n\nvar BUFFER = 0, STRING = 1, OBJECT = 2\n\nvar GOODBYE = 'GOODBYE'\nvar isBuffer = Buffer.isBuffer\n\nfunction isString (s) {\n  return 'string' === typeof s\n}\n\nfunction encodePair (msg) {\n\n  var head = new Buffer(9)\n  var flags = 0\n  var value = msg.value !== undefined ? msg.value : msg.end\n\n  //final packet\n  if(isString(msg) && msg === GOODBYE) {\n    head.fill(0)\n    return [head, null]\n  }\n\n  if(isString(value)) {\n    flags = STRING\n    value = new Buffer(value)\n  }\n  else if(isBuffer(value)) {\n    flags = BUFFER\n  }\n  else {\n    flags = OBJECT\n    value = new Buffer(JSON.stringify(value))\n  }\n\n  // does this frame represent a msg, a req, or a stream?\n\n  //end, stream\n\n  flags = msg.stream << 3 | msg.end << 2 | flags\n\n  head[0] = flags\n\n  head.writeUInt32BE(value.length, 1)\n  head.writeInt32BE(msg.req || 0, 5)\n\n  return [head, value]\n}\n\nfunction decodeHead (bytes) {\n  if(bytes.length != 9)\n    throw new Error('expected header to be 9 bytes long')\n  var flags = bytes[0]\n  var length = bytes.readUInt32BE(1)\n  var req = bytes.readInt32BE(5)\n\n  return {\n    req    : req,\n    stream : !!(flags & 8),\n    end    : !!(flags & 4),\n    value  : null,\n    length : length,\n    type   : flags & 3\n  }\n}\n\nfunction decodeBody (bytes, msg) {\n  if(bytes.length !== msg.length)\n    throw new Error('incorrect length, expected:'+msg.length+' found:'+bytes.length)\n  if(BUFFER === msg.type) msg.value = bytes\n  else if(STRING === msg.type) msg.value = bytes.toString()\n  else if(OBJECT === msg.type) msg.value = JSON.parse(bytes.toString())\n  else throw new Error('unknown message type')\n  return msg\n}\n\nfunction encode () {\n  return Through(function (d) {\n    var c = encodePair(d)\n    this.queue(c[0])\n    if(c[1] !== null)\n      this.queue(c[1])\n  })\n}\n\nfunction decode () {\n  var reader = Reader(), ended = false\n\n  return function (read) {\n    reader(read)\n\n    return function (abort, cb) {\n      if(ended) return cb(true)\n      if(abort) return reader.abort(abort, cb)\n      reader.read(9, function (err, head) {\n        if(err) return cb(err)\n        var msg = decodeHead(head)\n        if(msg.length === 0) { //final packet\n          ended = true\n          return cb(null, GOODBYE)\n        }\n        reader.read(msg.length, function (err, body) {\n          if(err) return cb(err)\n          decodeBody(body, msg)\n          cb(null, msg)\n        })\n      })\n    }\n  }\n}\n\nexports = module.exports = function (stream) {\n  return {\n    source: encode()(stream.source),\n    sink: function (read) { return stream.sink(decode()(read)) }\n  }\n}\n\nexports.encodePair = encodePair\nexports.decodeHead = decodeHead\nexports.decodeBody = decodeBody\n\nexports.encode = encode\nexports.decode = decode\n\n","function flat(err) {\n  if(!err) return err\n  if(err === true) return true\n  return {message: err.message, name: err.name, stack: err.stack}\n}\n\nmodule.exports = function (opts) {\n  return new PacketStream(opts)\n}\n\nfunction PacketStream (opts) {\n  this.ended = false\n  this.opts  = opts // must release, may capture `this`\n\n  this._req_counter = 1\n  this._requests    = {} // must release, may capture `this`\n  this._instreams   = {} // must release, may capture `this`\n  this._outstreams  = {} // must release, may capture `this`\n  this._closecbs    = [] // must release, may capture `this`\n  this._closing     = false\n  this._closed      = false\n  if (opts.close)\n    this._closecbs.push(opts.close)\n}\n\n// Sends a single message to the other end\nPacketStream.prototype.message = function (obj) {\n  this.read({req: 0, stream: false, end: false, value: obj})\n}\n\n// Sends a message to the other end, expects an (err, obj) response\nPacketStream.prototype.request = function (obj, cb) {\n  var rid = this._req_counter++\n  var self = this\n  this._requests[rid] = function (err, value) {\n    delete self._requests[rid]\n    cb(err, value)\n    self._maybedone()\n  }\n  this.read({ req:rid, stream: false, end: false, value: obj })\n}\n\n// Sends a request to the other end for a stream\nPacketStream.prototype.stream = function () {\n  var rid = this._req_counter++\n  var self = this\n  this._outstreams[rid] = new PacketStreamSubstream(rid, this, function() { delete self._outstreams[rid] })\n  return this._outstreams[rid]\n}\n\n// Marks the packetstream to close when all current IO is finished\nPacketStream.prototype.close = function (cb) {\n  if(!cb) throw new Error('packet-stream.close *must* have callback')\n  if (this._closed)\n    return cb()\n  this._closecbs.push(cb)\n  this._closing = true\n  this._maybedone()\n}\n\n// Forces immediate close of the PacketStream\n// - usually triggered by an `end` packet from the other end\nPacketStream.prototype.destroy = function (end) {\n  end = end || flat(end)\n  this.ended = end\n\n  var err = (end === true)\n    ? new Error('unexpected end of parent stream')\n    : end\n\n  // force-close all requests and substreams\n  var numended = 0\n  for (var k in this._requests)   { numended++; this._requests[k](err) }\n  for (var k in this._instreams)  { numended++; this._instreams[k].destroy(err) }\n  for (var k in this._outstreams) { numended++; this._outstreams[k].destroy(err) }\n\n  //from the perspective of the outside stream it's not an error\n  //if the stream was in a state that where end was okay. (no open requests/streams)\n  if (numended === 0 && end === true)\n    err = null\n  this._closing = true\n  this._maybedone(err)\n}\n\nPacketStream.prototype._maybedone = function (err) {\n  if (this._closed || !this._closing)\n    return\n\n  // check if all requests and streams finished\n  if (Object.keys(this._requests).length !== 0 ||\n      Object.keys(this._instreams).length !== 0 ||\n      Object.keys(this._outstreams).length !== 0)\n    return // not yet\n\n  // close\n  this._closed = true\n  this._closecbs.forEach(function (cb) { cb(err) })\n  this.read(null, err || true)\n\n  // deallocate\n  this.opts = null\n  this._closecbs.length = 0\n  this.read = closedread\n}\n\nfunction closedread (msg) {\n  console.error('packet-stream asked to read after closed', msg)\n}\n\n// Sends data out to the other end\n// - to be overridden by the PacketStream consumer\nPacketStream.prototype.read = function (msg) {\n  console.error('please overwrite read method to do IO', msg)\n}\n\n// Accepts data from the other end\nPacketStream.prototype.write = function (msg, end) {\n  if (this.ended)\n    return\n\n  if (end)                         this.destroy(end)\n  else if (msg.req && !msg.stream) this._onrequest(msg)\n  else if (msg.req && msg.stream)  this._onstream(msg)\n  else                             this._onmessage(msg)\n}\n\n// Internal handler of incoming message msgs\nPacketStream.prototype._onmessage = function (msg) {\n  if (this.opts && 'function' === typeof this.opts.message)\n    this.opts.message(msg.value)\n}\n\n// Internal handler of incoming request msgs\nPacketStream.prototype._onrequest = function (msg) {\n  var rid = msg.req*-1\n  if(msg.req < 0) {\n    // A incoming response\n    if (typeof this._requests[rid] == 'function')\n      this._requests[rid](\n        msg.end ? msg.value: null,\n        msg.end ? null : msg.value\n      )\n  }\n  else {\n    // An incoming request\n    if (this.opts && typeof this.opts.request == 'function') {\n      var once = false\n      var self = this\n      this.opts.request(msg.value, function (err, value) {\n        if(once) throw new Error('cb called twice from local api')\n        once = true\n        if(err) self.read({ value: flat(err), end: true, req: rid })\n        else    self.read({ value: value, end: false, req: rid })\n        self._maybedone()\n      })\n    } else {\n      if (this.ended) {\n        var err = (this.ended === true)\n          ? new Error('unexpected end of parent stream')\n          : this.ended\n        this.read({ value: flat(err), end: true, stream: false, req: rid })\n      }\n      else\n        this.read({ value: {\n            message: 'Unable to handle requests',\n            name: 'NO_REQUEST_HANDLER', stack: null\n          },\n          end: true, stream: false, req: rid\n        })\n      this._maybedone()\n    }\n  }\n}\n\n// Internal handler of incoming stream msgs\nPacketStream.prototype._onstream = function (msg) {\n  if(msg.req < 0) {\n    // Incoming stream data\n    var rid = msg.req*-1\n    var outs = this._outstreams[rid]\n    if (!outs)\n      return console.error('no stream for incoming msg', msg)\n\n    if (msg.end) {\n      if (outs.writeEnd)\n        delete this._outstreams[rid]\n      outs.readEnd = true\n      outs.read(null, msg.value)\n      this._maybedone()\n    }\n    else\n      outs.read(msg.value)\n  }\n  else {\n    // Incoming stream request\n    var rid = msg.req\n    var ins = this._instreams[rid]\n\n    if (!ins) {\n      // New stream\n      var self = this\n      ins = this._instreams[rid] = new PacketStreamSubstream(rid*-1, this, function() { delete self._instreams[rid] })\n      if (this.opts && typeof this.opts.stream == 'function')\n        this.opts.stream(ins)\n    }\n\n    if (!ins.read)\n      return console.error('no .read for stream:', ins.id, 'dropped:', msg)\n\n    if (msg.end) {\n      if (ins.writeEnd)\n        delete this._instreams[rid]\n      ins.readEnd = true\n      ins.read(null, msg.value)\n      this._maybedone()\n    }\n    else\n      ins.read(msg.value)\n  }\n}\n\n\nfunction PacketStreamSubstream (id, ps, remove) {\n  this.id       = id\n  this.read     = null // must release, may capture `this`\n  this.writeEnd = null\n  this.readEnd  = null\n\n  this._ps          = ps     // must release, may capture `this`\n  this._remove      = remove // must release, may capture `this`\n  this._seq_counter = 1\n}\n\nPacketStreamSubstream.prototype.write = function (data, err) {\n  if (err) {\n    this.writeEnd = err\n    var ps = this._ps\n    if (ps) {\n      ps.read({ req: this.id, stream: true, end: true, value: flat(err) })\n      if (this.readEnd)\n        this.destroy()\n      ps._maybedone()\n    }\n  }\n  else {\n    if (this._ps) this._ps.read({ req: this.id, stream: true, end: false, value: data })\n  }\n}\n\n// Send the `end` message for the substream\nPacketStreamSubstream.prototype.end = function (err) {\n  this.write(null, flat(err || true))\n}\n\nPacketStreamSubstream.prototype.destroy = function (err) {\n  if (!this.writeEnd) {\n    this.writeEnd = true\n    if (!this.readEnd) {\n      this.readEnd = true\n      try {\n        // catch errors to ensure cleanup\n        this.read(null, err)\n      } catch (e) {\n        console.error('Exception thrown by PacketStream substream end handler', e)\n        console.error(e.stack)\n      }\n    }\n    this.write(null, err)\n  }\n  else if (!this.readEnd) {\n    this.readEnd = true\n    try {\n      // catch errors to ensure cleanup\n      this.read(null, err)\n    } catch (e) {\n      console.error('Exception thrown by PacketStream substream end handler', e)\n      console.error(e.stack)\n    }\n  }\n\n  // deallocate\n  if (this._ps) {\n    this._remove()\n    this._remove = null\n    this.read = closedread\n    this._ps = null\n  }\n}\n","module.exports={\"2.16.840.1.101.3.4.1.1\": \"aes-128-ecb\",\n\"2.16.840.1.101.3.4.1.2\": \"aes-128-cbc\",\n\"2.16.840.1.101.3.4.1.3\": \"aes-128-ofb\",\n\"2.16.840.1.101.3.4.1.4\": \"aes-128-cfb\",\n\"2.16.840.1.101.3.4.1.21\": \"aes-192-ecb\",\n\"2.16.840.1.101.3.4.1.22\": \"aes-192-cbc\",\n\"2.16.840.1.101.3.4.1.23\": \"aes-192-ofb\",\n\"2.16.840.1.101.3.4.1.24\": \"aes-192-cfb\",\n\"2.16.840.1.101.3.4.1.41\": \"aes-256-ecb\",\n\"2.16.840.1.101.3.4.1.42\": \"aes-256-cbc\",\n\"2.16.840.1.101.3.4.1.43\": \"aes-256-ofb\",\n\"2.16.840.1.101.3.4.1.44\": \"aes-256-cfb\"\n}","// from https://github.com/indutny/self-signed/blob/gh-pages/lib/asn1.js\n// Fedor, you are amazing.\n\nvar asn1 = require('asn1.js')\n\nvar RSAPrivateKey = asn1.define('RSAPrivateKey', function () {\n  this.seq().obj(\n    this.key('version').int(),\n    this.key('modulus').int(),\n    this.key('publicExponent').int(),\n    this.key('privateExponent').int(),\n    this.key('prime1').int(),\n    this.key('prime2').int(),\n    this.key('exponent1').int(),\n    this.key('exponent2').int(),\n    this.key('coefficient').int()\n  )\n})\nexports.RSAPrivateKey = RSAPrivateKey\n\nvar RSAPublicKey = asn1.define('RSAPublicKey', function () {\n  this.seq().obj(\n    this.key('modulus').int(),\n    this.key('publicExponent').int()\n  )\n})\nexports.RSAPublicKey = RSAPublicKey\n\nvar PublicKey = asn1.define('SubjectPublicKeyInfo', function () {\n  this.seq().obj(\n    this.key('algorithm').use(AlgorithmIdentifier),\n    this.key('subjectPublicKey').bitstr()\n  )\n})\nexports.PublicKey = PublicKey\n\nvar AlgorithmIdentifier = asn1.define('AlgorithmIdentifier', function () {\n  this.seq().obj(\n    this.key('algorithm').objid(),\n    this.key('none').null_().optional(),\n    this.key('curve').objid().optional(),\n    this.key('params').seq().obj(\n      this.key('p').int(),\n      this.key('q').int(),\n      this.key('g').int()\n    ).optional()\n  )\n})\n\nvar PrivateKeyInfo = asn1.define('PrivateKeyInfo', function () {\n  this.seq().obj(\n    this.key('version').int(),\n    this.key('algorithm').use(AlgorithmIdentifier),\n    this.key('subjectPrivateKey').octstr()\n  )\n})\nexports.PrivateKey = PrivateKeyInfo\nvar EncryptedPrivateKeyInfo = asn1.define('EncryptedPrivateKeyInfo', function () {\n  this.seq().obj(\n    this.key('algorithm').seq().obj(\n      this.key('id').objid(),\n      this.key('decrypt').seq().obj(\n        this.key('kde').seq().obj(\n          this.key('id').objid(),\n          this.key('kdeparams').seq().obj(\n            this.key('salt').octstr(),\n            this.key('iters').int()\n          )\n        ),\n        this.key('cipher').seq().obj(\n          this.key('algo').objid(),\n          this.key('iv').octstr()\n        )\n      )\n    ),\n    this.key('subjectPrivateKey').octstr()\n  )\n})\n\nexports.EncryptedPrivateKey = EncryptedPrivateKeyInfo\n\nvar DSAPrivateKey = asn1.define('DSAPrivateKey', function () {\n  this.seq().obj(\n    this.key('version').int(),\n    this.key('p').int(),\n    this.key('q').int(),\n    this.key('g').int(),\n    this.key('pub_key').int(),\n    this.key('priv_key').int()\n  )\n})\nexports.DSAPrivateKey = DSAPrivateKey\n\nexports.DSAparam = asn1.define('DSAparam', function () {\n  this.int()\n})\nvar ECPrivateKey = asn1.define('ECPrivateKey', function () {\n  this.seq().obj(\n    this.key('version').int(),\n    this.key('privateKey').octstr(),\n    this.key('parameters').optional().explicit(0).use(ECParameters),\n    this.key('publicKey').optional().explicit(1).bitstr()\n  )\n})\nexports.ECPrivateKey = ECPrivateKey\nvar ECParameters = asn1.define('ECParameters', function () {\n  this.choice({\n    namedCurve: this.objid()\n  })\n})\n\nexports.signature = asn1.define('signature', function () {\n  this.seq().obj(\n    this.key('r').int(),\n    this.key('s').int()\n  )\n})\n","// adapted from https://github.com/apatil/pemstrip\nvar findProc = /Proc-Type: 4,ENCRYPTED\\r?\\nDEK-Info: AES-((?:128)|(?:192)|(?:256))-CBC,([0-9A-H]+)\\r?\\n\\r?\\n([0-9A-z\\n\\r\\+\\/\\=]+)\\r?\\n/m\nvar startRegex = /^-----BEGIN (.*) KEY-----\\r?\\n/m\nvar fullRegex = /^-----BEGIN (.*) KEY-----\\r?\\n([0-9A-z\\n\\r\\+\\/\\=]+)\\r?\\n-----END \\1 KEY-----$/m\nvar evp = require('evp_bytestokey')\nvar ciphers = require('browserify-aes')\nmodule.exports = function (okey, password) {\n  var key = okey.toString()\n  var match = key.match(findProc)\n  var decrypted\n  if (!match) {\n    var match2 = key.match(fullRegex)\n    decrypted = new Buffer(match2[2].replace(/\\r?\\n/g, ''), 'base64')\n  } else {\n    var suite = 'aes' + match[1]\n    var iv = new Buffer(match[2], 'hex')\n    var cipherText = new Buffer(match[3].replace(/\\r?\\n/g, ''), 'base64')\n    var cipherKey = evp(password, iv.slice(0, 8), parseInt(match[1], 10)).key\n    var out = []\n    var cipher = ciphers.createDecipheriv(suite, cipherKey, iv)\n    out.push(cipher.update(cipherText))\n    out.push(cipher.final())\n    decrypted = Buffer.concat(out)\n  }\n  var tag = key.match(startRegex)[1] + ' KEY'\n  return {\n    tag: tag,\n    data: decrypted\n  }\n}\n","var asn1 = require('./asn1')\nvar aesid = require('./aesid.json')\nvar fixProc = require('./fixProc')\nvar ciphers = require('browserify-aes')\nvar compat = require('pbkdf2')\nmodule.exports = parseKeys\n\nfunction parseKeys (buffer) {\n  var password\n  if (typeof buffer === 'object' && !Buffer.isBuffer(buffer)) {\n    password = buffer.passphrase\n    buffer = buffer.key\n  }\n  if (typeof buffer === 'string') {\n    buffer = new Buffer(buffer)\n  }\n\n  var stripped = fixProc(buffer, password)\n\n  var type = stripped.tag\n  var data = stripped.data\n  var subtype, ndata\n  switch (type) {\n    case 'PUBLIC KEY':\n      ndata = asn1.PublicKey.decode(data, 'der')\n      subtype = ndata.algorithm.algorithm.join('.')\n      switch (subtype) {\n        case '1.2.840.113549.1.1.1':\n          return asn1.RSAPublicKey.decode(ndata.subjectPublicKey.data, 'der')\n        case '1.2.840.10045.2.1':\n          ndata.subjectPrivateKey = ndata.subjectPublicKey\n          return {\n            type: 'ec',\n            data: ndata\n          }\n        case '1.2.840.10040.4.1':\n          ndata.algorithm.params.pub_key = asn1.DSAparam.decode(ndata.subjectPublicKey.data, 'der')\n          return {\n            type: 'dsa',\n            data: ndata.algorithm.params\n          }\n        default: throw new Error('unknown key id ' + subtype)\n      }\n      throw new Error('unknown key type ' + type)\n    case 'ENCRYPTED PRIVATE KEY':\n      data = asn1.EncryptedPrivateKey.decode(data, 'der')\n      data = decrypt(data, password)\n      // falls through\n    case 'PRIVATE KEY':\n      ndata = asn1.PrivateKey.decode(data, 'der')\n      subtype = ndata.algorithm.algorithm.join('.')\n      switch (subtype) {\n        case '1.2.840.113549.1.1.1':\n          return asn1.RSAPrivateKey.decode(ndata.subjectPrivateKey, 'der')\n        case '1.2.840.10045.2.1':\n          return {\n            curve: ndata.algorithm.curve,\n            privateKey: asn1.ECPrivateKey.decode(ndata.subjectPrivateKey, 'der').privateKey\n          }\n        case '1.2.840.10040.4.1':\n          ndata.algorithm.params.priv_key = asn1.DSAparam.decode(ndata.subjectPrivateKey, 'der')\n          return {\n            type: 'dsa',\n            params: ndata.algorithm.params\n          }\n        default: throw new Error('unknown key id ' + subtype)\n      }\n      throw new Error('unknown key type ' + type)\n    case 'RSA PUBLIC KEY':\n      return asn1.RSAPublicKey.decode(data, 'der')\n    case 'RSA PRIVATE KEY':\n      return asn1.RSAPrivateKey.decode(data, 'der')\n    case 'DSA PRIVATE KEY':\n      return {\n        type: 'dsa',\n        params: asn1.DSAPrivateKey.decode(data, 'der')\n      }\n    case 'EC PRIVATE KEY':\n      data = asn1.ECPrivateKey.decode(data, 'der')\n      return {\n        curve: data.parameters.value,\n        privateKey: data.privateKey\n      }\n    default: throw new Error('unknown key type ' + type)\n  }\n}\nparseKeys.signature = asn1.signature\nfunction decrypt (data, password) {\n  var salt = data.algorithm.decrypt.kde.kdeparams.salt\n  var iters = parseInt(data.algorithm.decrypt.kde.kdeparams.iters.toString(), 10)\n  var algo = aesid[data.algorithm.decrypt.cipher.algo.join('.')]\n  var iv = data.algorithm.decrypt.cipher.iv\n  var cipherText = data.subjectPrivateKey\n  var keylen = parseInt(algo.split('-')[1], 10) / 8\n  var key = compat.pbkdf2Sync(password, salt, iters, keylen)\n  var cipher = ciphers.createDecipheriv(algo, key, iv)\n  var out = []\n  out.push(cipher.update(cipherText))\n  out.push(cipher.final())\n  return Buffer.concat(out)\n}\n","/**\n * @author Titus Wormer\n * @copyright 2015 Titus Wormer\n * @license MIT\n * @module parse-entities\n * @fileoverview Parse HTML character references: fast, spec-compliant,\n *   positional information.\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\n/*\n * Dependencies.\n */\n\nvar characterEntities = require('character-entities');\nvar legacy = require('character-entities-legacy');\nvar invalid = require('character-reference-invalid');\n\n/*\n * Methods.\n */\n\nvar fromCharCode = String.fromCharCode;\nvar has = Object.prototype.hasOwnProperty;\nvar noop = Function.prototype;\n\n/*\n * Reference types.\n */\n\nvar NAMED = 'named';\nvar HEXADECIMAL = 'hexadecimal';\nvar DECIMAL = 'decimal';\n\n/*\n * Map of bases.\n */\n\nvar BASE = {};\n\nBASE[HEXADECIMAL] = 16;\nBASE[DECIMAL] = 10;\n\n/*\n * Warning messages.\n */\n\nvar NUMERIC_REFERENCE = 'Numeric character references';\nvar NAMED_REFERENCE = 'Named character references';\nvar TERMINATED = ' must be terminated by a semicolon';\nvar VOID = ' cannot be empty';\n\nvar NAMED_NOT_TERMINATED = 1;\nvar NUMERIC_NOT_TERMINATED = 2;\nvar NAMED_EMPTY = 3;\nvar NUMERIC_EMPTY = 4;\nvar NAMED_UNKNOWN = 5;\nvar NUMERIC_DISALLOWED = 6;\nvar NUMERIC_PROHIBITED = 7;\n\nvar MESSAGES = {};\n\nMESSAGES[NAMED_NOT_TERMINATED] = NAMED_REFERENCE + TERMINATED;\nMESSAGES[NUMERIC_NOT_TERMINATED] = NUMERIC_REFERENCE + TERMINATED;\nMESSAGES[NAMED_EMPTY] = NAMED_REFERENCE + VOID;\nMESSAGES[NUMERIC_EMPTY] = NUMERIC_REFERENCE + VOID;\nMESSAGES[NAMED_UNKNOWN] = NAMED_REFERENCE + ' must be known';\nMESSAGES[NUMERIC_DISALLOWED] = NUMERIC_REFERENCE + ' cannot be disallowed';\nMESSAGES[NUMERIC_PROHIBITED] = NUMERIC_REFERENCE + ' cannot be outside the ' +\n    'permissible Unicode range';\n\n/*\n * Characters.\n */\n\nvar REPLACEMENT = '\\uFFFD';\nvar FORM_FEED = '\\f';\nvar AMPERSAND = '&';\nvar OCTOTHORP = '#';\nvar SEMICOLON = ';';\nvar NEWLINE = '\\n';\nvar X_LOWER = 'x';\nvar X_UPPER = 'X';\nvar SPACE = ' ';\nvar LESS_THAN = '<';\nvar EQUAL = '=';\nvar EMPTY = '';\nvar TAB = '\\t';\n\n/**\n * Get the character-code at the first indice in\n * `character`.\n *\n * @param {string} character - Value.\n * @return {number} - Character-code at the first indice\n *   in `character`.\n */\nfunction charCode(character) {\n    return character.charCodeAt(0);\n}\n\n/**\n * Check whether `character` is a decimal.\n *\n * @param {string} character - Value.\n * @return {boolean} - Whether `character` is a decimal.\n */\nfunction isDecimal(character) {\n    var code = charCode(character);\n\n    return code >= 48 /* 0 */ && code <= 57 /* 9 */;\n}\n\n/**\n * Check whether `character` is a hexadecimal.\n *\n * @param {string} character - Value.\n * @return {boolean} - Whether `character` is a\n *   hexadecimal.\n */\nfunction isHexadecimal(character) {\n    var code = charCode(character);\n\n    return (code >= 48 /* 0 */ && code <= 57 /* 9 */) ||\n        (code >= 65 /* A */ && code <= 70 /* F */) ||\n        (code >= 97 /* a */ && code <= 102 /* f */);\n}\n\n/**\n * Check whether `character` is an alphanumeric.\n *\n * @param {string} character - Value.\n * @return {boolean} - Whether `character` is an\n *   alphanumeric.\n */\nfunction isAlphanumeric(character) {\n    var code = charCode(character);\n\n    return (code >= 48 /* 0 */ && code <= 57 /* 9 */) ||\n        (code >= 65 /* A */ && code <= 90 /* Z */) ||\n        (code >= 97 /* a */ && code <= 122 /* z */);\n}\n\n/**\n * Check whether `character` is outside the permissible\n * unicode range.\n *\n * @param {number} characterCode - Value.\n * @return {boolean} - Whether `character` is an\n *   outside the permissible unicode range.\n */\nfunction isProhibited(characterCode) {\n    return (characterCode >= 0xD800 && characterCode <= 0xDFFF) ||\n        (characterCode > 0x10FFFF);\n}\n\n/**\n * Check whether `character` is disallowed.\n *\n * @param {number} characterCode - Value.\n * @return {boolean} - Whether `character` is disallowed.\n */\nfunction isWarning(characterCode) {\n    return (characterCode >= 0x0001 && characterCode <= 0x0008) ||\n        (characterCode >= 0x000D && characterCode <= 0x001F) ||\n        (characterCode >= 0x007F && characterCode <= 0x009F) ||\n        (characterCode >= 0xFDD0 && characterCode <= 0xFDEF) ||\n        characterCode === 0x000B ||\n        characterCode === 0xFFFE ||\n        characterCode === 0xFFFF ||\n        characterCode === 0x1FFFE ||\n        characterCode === 0x1FFFF ||\n        characterCode === 0x2FFFE ||\n        characterCode === 0x2FFFF ||\n        characterCode === 0x3FFFE ||\n        characterCode === 0x3FFFF ||\n        characterCode === 0x4FFFE ||\n        characterCode === 0x4FFFF ||\n        characterCode === 0x5FFFE ||\n        characterCode === 0x5FFFF ||\n        characterCode === 0x6FFFE ||\n        characterCode === 0x6FFFF ||\n        characterCode === 0x7FFFE ||\n        characterCode === 0x7FFFF ||\n        characterCode === 0x8FFFE ||\n        characterCode === 0x8FFFF ||\n        characterCode === 0x9FFFE ||\n        characterCode === 0x9FFFF ||\n        characterCode === 0xAFFFE ||\n        characterCode === 0xAFFFF ||\n        characterCode === 0xBFFFE ||\n        characterCode === 0xBFFFF ||\n        characterCode === 0xCFFFE ||\n        characterCode === 0xCFFFF ||\n        characterCode === 0xDFFFE ||\n        characterCode === 0xDFFFF ||\n        characterCode === 0xEFFFE ||\n        characterCode === 0xEFFFF ||\n        characterCode === 0xFFFFE ||\n        characterCode === 0xFFFFF ||\n        characterCode === 0x10FFFE ||\n        characterCode === 0x10FFFF;\n}\n\n/*\n * Map of types to tests. Each type of character reference\n * accepts different characters. This test is used to\n * detect whether a reference has ended (as the semicolon\n * is not strictly needed).\n */\n\nvar TESTS = {};\n\nTESTS[NAMED] = isAlphanumeric;\nTESTS[DECIMAL] = isDecimal;\nTESTS[HEXADECIMAL] = isHexadecimal;\n\n/**\n * Parse entities.\n *\n * @param {string} value - Value to tokenise.\n * @param {Object?} [settings] - Configuration.\n */\nfunction parse(value, settings) {\n    var additional = settings.additional;\n    var handleText = settings.text;\n    var handleReference = settings.reference;\n    var handleWarning = settings.warning;\n    var textContext = settings.textContext;\n    var referenceContext = settings.referenceContext;\n    var warningContext = settings.warningContext;\n    var pos = settings.position;\n    var indent = settings.indent || [];\n    var length = value.length;\n    var index = 0;\n    var lines = -1;\n    var column = pos.column || 1;\n    var line = pos.line || 1;\n    var queue = EMPTY;\n    var result = [];\n    var entityCharacters;\n    var terminated;\n    var characters;\n    var character;\n    var reference;\n    var following;\n    var warning;\n    var reason;\n    var output;\n    var entity;\n    var begin;\n    var start;\n    var type;\n    var test;\n    var prev;\n    var next;\n    var diff;\n    var end;\n\n    /**\n     * Get current position.\n     *\n     * @return {Object} - Positional information of a\n     *   single point.\n     */\n    function now() {\n        return {\n            'line': line,\n            'column': column,\n            'offset': index + (pos.offset || 0)\n        };\n    }\n\n    /**\n     * “Throw” a parse-error: a warning.\n     *\n     * @param {number} code - Identifier of reason for\n     *   failing.\n     * @param {number} offset - Offset in characters from\n     *   the current position point at which the\n     *   parse-error ocurred, cannot point past newlines.\n     */\n    function parseError(code, offset) {\n        var position = now();\n\n        position.column += offset;\n        position.offset += offset;\n\n        handleWarning.call(warningContext, MESSAGES[code], position, code);\n    }\n\n    /**\n     * Get character at position.\n     *\n     * @param {number} position - Indice of character in `value`.\n     * @return {string} - Character at `position` in\n     *   `value`.\n     */\n    function at(position) {\n        return value.charAt(position);\n    }\n\n    /**\n     * Flush `queue` (normal text). Macro invoked before\n     * each entity and at the end of `value`.\n     *\n     * Does nothing when `queue` is empty.\n     */\n    function flush() {\n        if (queue) {\n            result.push(queue);\n\n            if (handleText) {\n                handleText.call(textContext, queue, {\n                    'start': prev,\n                    'end': now()\n                });\n            }\n\n            queue = EMPTY;\n        }\n    }\n\n    /*\n     * Cache the current point.\n     */\n\n    prev = now();\n\n    /*\n     * Wrap `handleWarning`.\n     */\n\n    warning = handleWarning ? parseError : noop;\n\n    /*\n     * Ensure the algorithm walks over the first character\n     * and the end (inclusive).\n     */\n\n    index--;\n    length++;\n\n    while (++index < length) {\n        /*\n         * If the previous character was a newline.\n         */\n\n        if (character === NEWLINE) {\n            column = indent[lines] || 1;\n        }\n\n        character = at(index);\n\n        /*\n         * Handle anything other than an ampersand,\n         * including newlines and EOF.\n         */\n\n        if (character !== AMPERSAND) {\n            if (character === NEWLINE) {\n                line++;\n                lines++;\n                column = 0;\n            }\n\n            if (character) {\n                queue += character;\n                column++;\n            } else {\n                flush();\n            }\n        } else {\n            following = at(index + 1);\n\n            /*\n             * The behaviour depends on the identity of the next character.\n             */\n\n            if (\n                following === TAB ||\n                following === NEWLINE ||\n                following === FORM_FEED ||\n                following === SPACE ||\n                following === LESS_THAN ||\n                following === AMPERSAND ||\n                following === EMPTY ||\n                (additional && following === additional)\n            ) {\n                /*\n                 * Not a character reference. No characters\n                 * are consumed, and nothing is returned.\n                 * This is not an error, either.\n                 */\n\n                queue += character;\n                column++;\n\n                continue;\n            }\n\n            start = begin = end = index + 1;\n\n            /*\n             * Numerical entity.\n             */\n\n            if (following !== OCTOTHORP) {\n                type = NAMED;\n            } else {\n                end = ++begin;\n\n                /*\n                 * The behaviour further depends on the\n                 * character after the U+0023 NUMBER SIGN.\n                 */\n\n                following = at(end);\n\n                if (following === X_LOWER || following === X_UPPER) {\n                    /*\n                     * ASCII hex digits.\n                     */\n\n                    type = HEXADECIMAL;\n                    end = ++begin;\n                } else {\n                    /*\n                     * ASCII digits.\n                     */\n\n                    type = DECIMAL;\n                }\n            }\n\n            entityCharacters = entity = characters = EMPTY;\n            test = TESTS[type];\n            end--;\n\n            while (++end < length) {\n                following = at(end);\n\n                if (!test(following)) {\n                    break;\n                }\n\n                characters += following;\n\n                /*\n                 * Check if we can match a legacy named\n                 * reference.  If so, we cache that as the\n                 * last viable named reference.  This\n                 * ensures we do not need to walk backwards\n                 * later.\n                 */\n\n                if (\n                    type === NAMED &&\n                    has.call(legacy, characters)\n                ) {\n                    entityCharacters = characters;\n                    entity = legacy[characters];\n                }\n            }\n\n            terminated = at(end) === SEMICOLON;\n\n            if (terminated) {\n                end++;\n\n                if (\n                    type === NAMED &&\n                    has.call(characterEntities, characters)\n                ) {\n                    entityCharacters = characters;\n                    entity = characterEntities[characters];\n                }\n            }\n\n            diff = 1 + end - start;\n\n            if (!characters) {\n                /*\n                 * An empty (possible) entity is valid, unless\n                 * its numeric (thus an ampersand followed by\n                 * an octothorp).\n                 */\n\n                if (type !== NAMED) {\n                    warning(NUMERIC_EMPTY, diff);\n                }\n            } else if (type === NAMED) {\n                /*\n                 * An ampersand followed by anything\n                 * unknown, and not terminated, is invalid.\n                 */\n\n                if (terminated && !entity) {\n                    warning(NAMED_UNKNOWN, 1);\n                } else {\n                    /*\n                     * If theres something after an entity\n                     * name which is not known, cap the\n                     * reference.\n                     */\n\n                    if (entityCharacters !== characters) {\n                        end = begin + entityCharacters.length;\n                        diff = 1 + end - begin;\n                        terminated = false;\n                    }\n\n                    /*\n                     * If the reference is not terminated,\n                     * warn.\n                     */\n\n                    if (!terminated) {\n                        reason = entityCharacters ?\n                            NAMED_NOT_TERMINATED :\n                            NAMED_EMPTY;\n\n                        if (!settings.attribute) {\n                            warning(reason, diff);\n                        } else {\n                            following = at(end);\n\n                            if (following === EQUAL) {\n                                warning(reason, diff);\n                                entity = null;\n                            } else if (isAlphanumeric(following)) {\n                                entity = null;\n                            } else {\n                                warning(reason, diff);\n                            }\n                        }\n                    }\n                }\n\n                reference = entity;\n            } else {\n                if (!terminated) {\n                    /*\n                     * All non-terminated numeric entities are\n                     * not rendered, and trigger a warning.\n                     */\n\n                    warning(NUMERIC_NOT_TERMINATED, diff);\n                }\n\n                /*\n                 * When terminated and number, parse as\n                 * either hexadecimal or decimal.\n                 */\n\n                reference = parseInt(characters, BASE[type]);\n\n                /*\n                 * Trigger a warning when the parsed number\n                 * is prohibited, and replace with\n                 * replacement character.\n                 */\n\n                if (isProhibited(reference)) {\n                    warning(NUMERIC_PROHIBITED, diff);\n\n                    reference = REPLACEMENT;\n                } else if (reference in invalid) {\n                    /*\n                     * Trigger a warning when the parsed number\n                     * is disallowed, and replace by an\n                     * alternative.\n                     */\n\n                    warning(NUMERIC_DISALLOWED, diff);\n\n                    reference = invalid[reference];\n                } else {\n                    /*\n                     * Parse the number.\n                     */\n\n                    output = EMPTY;\n\n                    /*\n                     * Trigger a warning when the parsed\n                     * number should not be used.\n                     */\n\n                    if (isWarning(reference)) {\n                        warning(NUMERIC_DISALLOWED, diff);\n                    }\n\n                    /*\n                     * Stringify the number.\n                     */\n\n                    if (reference > 0xFFFF) {\n                        reference -= 0x10000;\n                        output += fromCharCode(\n                            reference >>> 10 & 0x3FF | 0xD800\n                        );\n\n                        reference = 0xDC00 | reference & 0x3FF;\n                    }\n\n                    reference = output + fromCharCode(reference);\n                }\n            }\n\n            /*\n             * If we could not find a reference, queue the\n             * checked characters (as normal characters),\n             * and move the pointer to their end. This is\n             * possible because we can be certain neither\n             * newlines nor ampersands are included.\n             */\n\n            if (!reference) {\n                characters = value.slice(start - 1, end);\n                queue += characters;\n                column += characters.length;\n                index = end - 1;\n            } else {\n                /*\n                 * Found it! First eat the queued\n                 * characters as normal text, then eat\n                 * an entity.\n                 */\n\n                flush();\n\n                prev = now();\n                index = end - 1;\n                column += end - start + 1;\n                result.push(reference);\n                next = now();\n                next.offset++;\n\n                if (handleReference) {\n                    handleReference.call(referenceContext, reference, {\n                        'start': prev,\n                        'end': next\n                    }, value.slice(start - 1, end));\n                }\n\n                prev = next;\n            }\n        }\n    }\n\n    /*\n     * Return the reduced nodes, and any possible warnings.\n     */\n\n    return result.join(EMPTY);\n}\n\nvar defaults = {\n    'warning': null,\n    'reference': null,\n    'text': null,\n    'warningContext': null,\n    'referenceContext': null,\n    'textContext': null,\n    'position': {},\n    'additional': null,\n    'attribute': false\n};\n\n/**\n * Wrap to ensure clean parameters are given to `parse`.\n *\n * @param {string} value - Value with entities.\n * @param {Object?} [options] - Configuration.\n */\nfunction wrapper(value, options) {\n    var settings = {};\n    var key;\n\n    if (!options) {\n        options = {};\n    }\n\n    for (key in defaults) {\n        settings[key] = options[key] || defaults[key];\n    }\n\n    if (settings.position.indent || settings.position.start) {\n        settings.indent = settings.position.indent || [];\n        settings.position = settings.position.start;\n    }\n\n    return parse(value, settings);\n}\n\n/*\n * Expose.\n */\n\nmodule.exports = wrapper;\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// resolves . and .. elements in a path array with directory names there\n// must be no slashes, empty elements, or device names (c:\\) in the array\n// (so also no leading and trailing slashes - it does not distinguish\n// relative and absolute paths)\nfunction normalizeArray(parts, allowAboveRoot) {\n  // if the path tries to go above the root, `up` ends up > 0\n  var up = 0;\n  for (var i = parts.length - 1; i >= 0; i--) {\n    var last = parts[i];\n    if (last === '.') {\n      parts.splice(i, 1);\n    } else if (last === '..') {\n      parts.splice(i, 1);\n      up++;\n    } else if (up) {\n      parts.splice(i, 1);\n      up--;\n    }\n  }\n\n  // if the path is allowed to go above the root, restore leading ..s\n  if (allowAboveRoot) {\n    for (; up--; up) {\n      parts.unshift('..');\n    }\n  }\n\n  return parts;\n}\n\n// Split a filename into [root, dir, basename, ext], unix version\n// 'root' is just a slash, or nothing.\nvar splitPathRe =\n    /^(\\/?|)([\\s\\S]*?)((?:\\.{1,2}|[^\\/]+?|)(\\.[^.\\/]*|))(?:[\\/]*)$/;\nvar splitPath = function(filename) {\n  return splitPathRe.exec(filename).slice(1);\n};\n\n// path.resolve([from ...], to)\n// posix version\nexports.resolve = function() {\n  var resolvedPath = '',\n      resolvedAbsolute = false;\n\n  for (var i = arguments.length - 1; i >= -1 && !resolvedAbsolute; i--) {\n    var path = (i >= 0) ? arguments[i] : process.cwd();\n\n    // Skip empty and invalid entries\n    if (typeof path !== 'string') {\n      throw new TypeError('Arguments to path.resolve must be strings');\n    } else if (!path) {\n      continue;\n    }\n\n    resolvedPath = path + '/' + resolvedPath;\n    resolvedAbsolute = path.charAt(0) === '/';\n  }\n\n  // At this point the path should be resolved to a full absolute path, but\n  // handle relative paths to be safe (might happen when process.cwd() fails)\n\n  // Normalize the path\n  resolvedPath = normalizeArray(filter(resolvedPath.split('/'), function(p) {\n    return !!p;\n  }), !resolvedAbsolute).join('/');\n\n  return ((resolvedAbsolute ? '/' : '') + resolvedPath) || '.';\n};\n\n// path.normalize(path)\n// posix version\nexports.normalize = function(path) {\n  var isAbsolute = exports.isAbsolute(path),\n      trailingSlash = substr(path, -1) === '/';\n\n  // Normalize the path\n  path = normalizeArray(filter(path.split('/'), function(p) {\n    return !!p;\n  }), !isAbsolute).join('/');\n\n  if (!path && !isAbsolute) {\n    path = '.';\n  }\n  if (path && trailingSlash) {\n    path += '/';\n  }\n\n  return (isAbsolute ? '/' : '') + path;\n};\n\n// posix version\nexports.isAbsolute = function(path) {\n  return path.charAt(0) === '/';\n};\n\n// posix version\nexports.join = function() {\n  var paths = Array.prototype.slice.call(arguments, 0);\n  return exports.normalize(filter(paths, function(p, index) {\n    if (typeof p !== 'string') {\n      throw new TypeError('Arguments to path.join must be strings');\n    }\n    return p;\n  }).join('/'));\n};\n\n\n// path.relative(from, to)\n// posix version\nexports.relative = function(from, to) {\n  from = exports.resolve(from).substr(1);\n  to = exports.resolve(to).substr(1);\n\n  function trim(arr) {\n    var start = 0;\n    for (; start < arr.length; start++) {\n      if (arr[start] !== '') break;\n    }\n\n    var end = arr.length - 1;\n    for (; end >= 0; end--) {\n      if (arr[end] !== '') break;\n    }\n\n    if (start > end) return [];\n    return arr.slice(start, end - start + 1);\n  }\n\n  var fromParts = trim(from.split('/'));\n  var toParts = trim(to.split('/'));\n\n  var length = Math.min(fromParts.length, toParts.length);\n  var samePartsLength = length;\n  for (var i = 0; i < length; i++) {\n    if (fromParts[i] !== toParts[i]) {\n      samePartsLength = i;\n      break;\n    }\n  }\n\n  var outputParts = [];\n  for (var i = samePartsLength; i < fromParts.length; i++) {\n    outputParts.push('..');\n  }\n\n  outputParts = outputParts.concat(toParts.slice(samePartsLength));\n\n  return outputParts.join('/');\n};\n\nexports.sep = '/';\nexports.delimiter = ':';\n\nexports.dirname = function(path) {\n  var result = splitPath(path),\n      root = result[0],\n      dir = result[1];\n\n  if (!root && !dir) {\n    // No dirname whatsoever\n    return '.';\n  }\n\n  if (dir) {\n    // It has a dirname, strip trailing slash\n    dir = dir.substr(0, dir.length - 1);\n  }\n\n  return root + dir;\n};\n\n\nexports.basename = function(path, ext) {\n  var f = splitPath(path)[2];\n  // TODO: make this comparison case-insensitive on windows?\n  if (ext && f.substr(-1 * ext.length) === ext) {\n    f = f.substr(0, f.length - ext.length);\n  }\n  return f;\n};\n\n\nexports.extname = function(path) {\n  return splitPath(path)[3];\n};\n\nfunction filter (xs, f) {\n    if (xs.filter) return xs.filter(f);\n    var res = [];\n    for (var i = 0; i < xs.length; i++) {\n        if (f(xs[i], i, xs)) res.push(xs[i]);\n    }\n    return res;\n}\n\n// String.prototype.substr - negative index don't work in IE8\nvar substr = 'ab'.substr(-1) === 'b'\n    ? function (str, start, len) { return str.substr(start, len) }\n    : function (str, start, len) {\n        if (start < 0) start = str.length + start;\n        return str.substr(start, len);\n    }\n;\n","'use strict';\n\nfunction posix(path) {\n\treturn path.charAt(0) === '/';\n};\n\nfunction win32(path) {\n\t// https://github.com/joyent/node/blob/b3fcc245fb25539909ef1d5eaa01dbf92e168633/lib/path.js#L56\n\tvar splitDeviceRe = /^([a-zA-Z]:|[\\\\\\/]{2}[^\\\\\\/]+[\\\\\\/]+[^\\\\\\/]+)?([\\\\\\/])?([\\s\\S]*?)$/;\n\tvar result = splitDeviceRe.exec(path);\n\tvar device = result[1] || '';\n\tvar isUnc = !!device && device.charAt(1) !== ':';\n\n\t// UNC paths are always absolute\n\treturn !!result[2] || isUnc;\n};\n\nmodule.exports = process.platform === 'win32' ? win32 : posix;\nmodule.exports.posix = posix;\nmodule.exports.win32 = win32;\n","var createHmac = require('create-hmac')\nvar MAX_ALLOC = Math.pow(2, 30) - 1 // default in iojs\n\nexports.pbkdf2 = pbkdf2\nfunction pbkdf2 (password, salt, iterations, keylen, digest, callback) {\n  if (typeof digest === 'function') {\n    callback = digest\n    digest = undefined\n  }\n\n  if (typeof callback !== 'function') {\n    throw new Error('No callback provided to pbkdf2')\n  }\n\n  var result = pbkdf2Sync(password, salt, iterations, keylen, digest)\n  setTimeout(function () {\n    callback(undefined, result)\n  })\n}\n\nexports.pbkdf2Sync = pbkdf2Sync\nfunction pbkdf2Sync (password, salt, iterations, keylen, digest) {\n  if (typeof iterations !== 'number') {\n    throw new TypeError('Iterations not a number')\n  }\n\n  if (iterations < 0) {\n    throw new TypeError('Bad iterations')\n  }\n\n  if (typeof keylen !== 'number') {\n    throw new TypeError('Key length not a number')\n  }\n\n  if (keylen < 0 || keylen > MAX_ALLOC) {\n    throw new TypeError('Bad key length')\n  }\n\n  digest = digest || 'sha1'\n\n  if (!Buffer.isBuffer(password)) password = new Buffer(password, 'binary')\n  if (!Buffer.isBuffer(salt)) salt = new Buffer(salt, 'binary')\n\n  var hLen\n  var l = 1\n  var DK = new Buffer(keylen)\n  var block1 = new Buffer(salt.length + 4)\n  salt.copy(block1, 0, 0, salt.length)\n\n  var r\n  var T\n\n  for (var i = 1; i <= l; i++) {\n    block1.writeUInt32BE(i, salt.length)\n    var U = createHmac(digest, password).update(block1).digest()\n\n    if (!hLen) {\n      hLen = U.length\n      T = new Buffer(hLen)\n      l = Math.ceil(keylen / hLen)\n      r = keylen - (l - 1) * hLen\n    }\n\n    U.copy(T, 0, 0, hLen)\n\n    for (var j = 1; j < iterations; j++) {\n      U = createHmac(digest, password).update(U).digest()\n\n      for (var k = 0; k < hLen; k++) {\n        T[k] ^= U[k]\n      }\n    }\n\n    var destPos = (i - 1) * hLen\n    var len = (i === l ? r : hLen)\n    T.copy(DK, destPos, 0, len)\n  }\n\n  return DK\n}\n","\nvar sodium = require('chloride')\nvar crypto = require('crypto')\nvar scalarmult = sodium.crypto_scalarmult\nvar box  = sodium.crypto_box_easy\nvar secretbox = sodium.crypto_secretbox_easy\nvar secretbox_open = sodium.crypto_secretbox_open_easy\nvar keypair = sodium.crypto_box_keypair\nvar concat = Buffer.concat\n\nfunction randombytes(n) {\n  return crypto.randomBytes(n)\n}\n\nconst MAX = 7\n\nexports.multibox = function (msg, recipients) {\n\n  if(recipients.length > MAX)\n    throw new Error('max recipients is:'+MAX+' found:'+recipients.length)\n\n  var nonce = randombytes(24)\n  var key = randombytes(32)\n  var onetime = keypair()\n\n  var _key = concat([new Buffer([recipients.length & MAX]), key])\n  return concat([\n    nonce,\n    onetime.publicKey,\n    concat(recipients.map(function (r_pk, i) {\n      return secretbox(_key, nonce, scalarmult(onetime.secretKey, r_pk))\n    })),\n    secretbox(msg, nonce, key)\n  ])\n}\n\nfunction get_key(ctxt, my_key) {\n\n}\n\nexports.multibox_open = function (ctxt, sk) { //, groups...\n\n  var nonce = ctxt.slice(0, 24)\n  var onetime_pk = ctxt.slice(24, 24+32)\n  var my_key = scalarmult(sk, onetime_pk)\n  var _key, key, length, start = 24+32, size = 32+1+16\n  for(var i = 0; i <= MAX; i++) {\n    var s = start+size*i\n    if(s + size > (ctxt.length - 16)) continue\n    _key = secretbox_open(ctxt.slice(s, s + size), nonce, my_key)\n    if(_key) {\n      length = _key[0]\n      key = _key.slice(1)\n      continue\n    }\n  }\n\n  if(!key) return\n  return secretbox_open(ctxt.slice(start+length*size), nonce, key)\n}\n","'use strict';\n\nif (!process.version ||\n    process.version.indexOf('v0.') === 0 ||\n    process.version.indexOf('v1.') === 0 && process.version.indexOf('v1.8.') !== 0) {\n  module.exports = nextTick;\n} else {\n  module.exports = process.nextTick;\n}\n\nfunction nextTick(fn) {\n  var args = new Array(arguments.length - 1);\n  var i = 0;\n  while (i < args.length) {\n    args[i++] = arguments[i];\n  }\n  process.nextTick(function afterTick() {\n    fn.apply(null, args);\n  });\n}\n","// shim for using process in browser\n\nvar process = module.exports = {};\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = setTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    clearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        setTimeout(drainQueue, 0);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","exports.publicEncrypt = require('./publicEncrypt');\nexports.privateDecrypt = require('./privateDecrypt');\n\nexports.privateEncrypt = function privateEncrypt(key, buf) {\n  return exports.publicEncrypt(key, buf, true);\n};\n\nexports.publicDecrypt = function publicDecrypt(key, buf) {\n  return exports.privateDecrypt(key, buf, true);\n};","var createHash = require('create-hash');\nmodule.exports = function (seed, len) {\n  var t = new Buffer('');\n  var  i = 0, c;\n  while (t.length < len) {\n    c = i2ops(i++);\n    t = Buffer.concat([t, createHash('sha1').update(seed).update(c).digest()]);\n  }\n  return t.slice(0, len);\n};\n\nfunction i2ops(c) {\n  var out = new Buffer(4);\n  out.writeUInt32BE(c,0);\n  return out;\n}","var parseKeys = require('parse-asn1');\nvar mgf = require('./mgf');\nvar xor = require('./xor');\nvar bn = require('bn.js');\nvar crt = require('browserify-rsa');\nvar createHash = require('create-hash');\nvar withPublic = require('./withPublic');\nmodule.exports = function privateDecrypt(private_key, enc, reverse) {\n  var padding;\n  if (private_key.padding) {\n    padding = private_key.padding;\n  } else if (reverse) {\n    padding = 1;\n  } else {\n    padding = 4;\n  }\n  \n  var key = parseKeys(private_key);\n  var k = key.modulus.byteLength();\n  if (enc.length > k || new bn(enc).cmp(key.modulus) >= 0) {\n    throw new Error('decryption error');\n  }\n  var msg;\n  if (reverse) {\n    msg = withPublic(new bn(enc), key);\n  } else {\n    msg = crt(enc, key);\n  }\n  var zBuffer = new Buffer(k - msg.length);\n  zBuffer.fill(0);\n  msg = Buffer.concat([zBuffer, msg], k);\n  if (padding === 4) {\n    return oaep(key, msg);\n  } else if (padding === 1) {\n    return pkcs1(key, msg, reverse);\n  } else if (padding === 3) {\n    return msg;\n  } else {\n    throw new Error('unknown padding');\n  }\n};\n\nfunction oaep(key, msg){\n  var n = key.modulus;\n  var k = key.modulus.byteLength();\n  var mLen = msg.length;\n  var iHash = createHash('sha1').update(new Buffer('')).digest();\n  var hLen = iHash.length;\n  var hLen2 = 2 * hLen;\n  if (msg[0] !== 0) {\n    throw new Error('decryption error');\n  }\n  var maskedSeed = msg.slice(1, hLen + 1);\n  var maskedDb =  msg.slice(hLen + 1);\n  var seed = xor(maskedSeed, mgf(maskedDb, hLen));\n  var db = xor(maskedDb, mgf(seed, k - hLen - 1));\n  if (compare(iHash, db.slice(0, hLen))) {\n    throw new Error('decryption error');\n  }\n  var i = hLen;\n  while (db[i] === 0) {\n    i++;\n  }\n  if (db[i++] !== 1) {\n    throw new Error('decryption error');\n  }\n  return db.slice(i);\n}\n\nfunction pkcs1(key, msg, reverse){\n  var p1 = msg.slice(0, 2);\n  var i = 2;\n  var status = 0;\n  while (msg[i++] !== 0) {\n    if (i >= msg.length) {\n      status++;\n      break;\n    }\n  }\n  var ps = msg.slice(2, i - 1);\n  var p2 = msg.slice(i - 1, i);\n\n  if ((p1.toString('hex') !== '0002' && !reverse) || (p1.toString('hex') !== '0001' && reverse)){\n    status++;\n  }\n  if (ps.length < 8) {\n    status++;\n  }\n  if (status) {\n    throw new Error('decryption error');\n  }\n  return  msg.slice(i);\n}\nfunction compare(a, b){\n  a = new Buffer(a);\n  b = new Buffer(b);\n  var dif = 0;\n  var len = a.length;\n  if (a.length !== b.length) {\n    dif++;\n    len = Math.min(a.length, b.length);\n  }\n  var i = -1;\n  while (++i < len) {\n    dif += (a[i] ^ b[i]);\n  }\n  return dif;\n}","var parseKeys = require('parse-asn1');\nvar randomBytes = require('randombytes');\nvar createHash = require('create-hash');\nvar mgf = require('./mgf');\nvar xor = require('./xor');\nvar bn = require('bn.js');\nvar withPublic = require('./withPublic');\nvar crt = require('browserify-rsa');\n\nvar constants = {\n  RSA_PKCS1_OAEP_PADDING: 4,\n  RSA_PKCS1_PADDIN: 1,\n  RSA_NO_PADDING: 3\n};\n\nmodule.exports = function publicEncrypt(public_key, msg, reverse) {\n  var padding;\n  if (public_key.padding) {\n    padding = public_key.padding;\n  } else if (reverse) {\n    padding = 1;\n  } else {\n    padding = 4;\n  }\n  var key = parseKeys(public_key);\n  var paddedMsg;\n  if (padding === 4) {\n    paddedMsg = oaep(key, msg);\n  } else if (padding === 1) {\n    paddedMsg = pkcs1(key, msg, reverse);\n  } else if (padding === 3) {\n    paddedMsg = new bn(msg);\n    if (paddedMsg.cmp(key.modulus) >= 0) {\n      throw new Error('data too long for modulus');\n    }\n  } else {\n    throw new Error('unknown padding');\n  }\n  if (reverse) {\n    return crt(paddedMsg, key);\n  } else {\n    return withPublic(paddedMsg, key);\n  }\n};\n\nfunction oaep(key, msg){\n  var k = key.modulus.byteLength();\n  var mLen = msg.length;\n  var iHash = createHash('sha1').update(new Buffer('')).digest();\n  var hLen = iHash.length;\n  var hLen2 = 2 * hLen;\n  if (mLen > k - hLen2 - 2) {\n    throw new Error('message too long');\n  }\n  var ps = new Buffer(k - mLen - hLen2 - 2);\n  ps.fill(0);\n  var dblen = k - hLen - 1;\n  var seed = randomBytes(hLen);\n  var maskedDb = xor(Buffer.concat([iHash, ps, new Buffer([1]), msg], dblen), mgf(seed, dblen));\n  var maskedSeed = xor(seed, mgf(maskedDb, hLen));\n  return new bn(Buffer.concat([new Buffer([0]), maskedSeed, maskedDb], k));\n}\nfunction pkcs1(key, msg, reverse){\n  var mLen = msg.length;\n  var k = key.modulus.byteLength();\n  if (mLen > k - 11) {\n    throw new Error('message too long');\n  }\n  var ps;\n  if (reverse) {\n    ps = new Buffer(k - mLen - 3);\n    ps.fill(0xff);\n  } else {\n    ps = nonZero(k - mLen - 3);\n  }\n  return new bn(Buffer.concat([new Buffer([0, reverse?1:2]), ps, new Buffer([0]), msg], k));\n}\nfunction nonZero(len, crypto) {\n  var out = new Buffer(len);\n  var i = 0;\n  var cache = randomBytes(len*2);\n  var cur = 0;\n  var num;\n  while (i < len) {\n    if (cur === cache.length) {\n      cache = randomBytes(len*2);\n      cur = 0;\n    }\n    num = cache[cur++];\n    if (num) {\n      out[i++] = num;\n    }\n  }\n  return out;\n}","var bn = require('bn.js');\nfunction withPublic(paddedMsg, key) {\n  return new Buffer(paddedMsg\n    .toRed(bn.mont(key.modulus))\n    .redPow(new bn(key.publicExponent))\n    .fromRed()\n    .toArray());\n}\n\nmodule.exports = withPublic;","module.exports = function xor(a, b) {\n  var len = a.length;\n  var i = -1;\n  while (++i < len) {\n    a[i] ^= b[i];\n  }\n  return a\n};","function abortable(onEnd) {\n  var aborted = false, reading = false, ended = false, _cb, _read\n\n  function terminate (err) {\n    if(onEnd) onEnd(ended === true ? null :  ended)\n    var cb = _cb; _cb = null\n    if(cb) cb(ended)\n  }\n\n  function cancel () {\n    ended = ended || true\n    terminate(aborted || ended)\n    _read(aborted, function (err) {\n      if(_cb) _cb(err)\n    })\n  }\n\n  function reader (read) {\n    _read = read\n    return function (abort, cb) {\n      _cb = cb\n      if(abort)   aborted = abort\n      if(ended)   return cb(ended)\n      if(aborted) return\n      reading = true\n      read(abort, function (end, data) {\n        reading = false\n        if(aborted) return !abort && read(aborted, function () {})\n        if(!_cb) return\n        var cb = _cb\n        _cb = null\n        if(end) {\n          ended = end\n          onEnd && onEnd(ended === true ? null :  ended)\n          cb(end)\n        }\n        else {\n          cb(end, data)\n        }\n      })\n    }\n  }\n\n  reader.abort = function () {\n    aborted = true\n    if(ended) return\n    cancel()\n  }\n\n  return reader\n}\n\nmodule.exports = abortable\n\n","'use strict'\nvar sodium = require('chloride')\nvar Reader = require('pull-reader')\nvar increment = require('increment-buffer')\nvar through = require('pull-through')\nvar split = require('split-buffer')\n\nvar isBuffer = Buffer.isBuffer\nvar concat = Buffer.concat\n\nvar box = sodium.crypto_secretbox_easy\nvar unbox = sodium.crypto_secretbox_open_easy  \n\nfunction unbox_detached (mac, boxed, nonce, key) {\n  return sodium.crypto_secretbox_open_easy(concat([mac, boxed]), nonce, key)\n}\n\nvar max = 1024*4\n\nvar NONCE_LEN = 24\nvar HEADER_LEN = 2+16+16\n\nfunction isZeros(b) {\n  for(var i = 0; i < b.length; i++)\n    if(b[i] !== 0) return false\n  return true\n}\n\nfunction randomSecret(n) {\n  var rand = new Buffer(n)\n  sodium.randombytes(rand)\n  return rand\n}\n\nfunction copy (a) {\n  var b = new Buffer(a.length)\n  a.copy(b, 0, 0, a.length)\n  return b\n}\n\nexports.createBoxStream =\nexports.createEncryptStream = function (key, init_nonce) {\n\n  if(key.length === 56) {\n    init_nonce = key.slice(32, 56)\n    key = key.slice(0, 32)\n  }\n  else if(!(key.length === 32 && init_nonce.length === 24))\n    throw new Error('nonce must be 24 bytes')\n\n  // we need two nonces because increment mutates,\n  // and we need the next for the header,\n  // and the next next nonce for the packet\n  var nonce1 = copy(init_nonce), nonce2 = copy(init_nonce)\n  var head = new Buffer(18)\n\n  return through(function (data) {\n\n    if('string' === typeof data)\n      data = new Buffer(data, 'utf8')\n    else if(!isBuffer(data))\n      return this.emit('error', new Error('must be buffer'))\n\n    if(data.length === 0) return\n\n    var input = split(data, max)\n\n    for(var i = 0; i < input.length; i++) {\n      head.writeUInt16BE(input[i].length, 0)\n      var boxed = box(input[i], increment(nonce2), key)\n      //write the mac into the header.\n      boxed.copy(head, 2, 0, 16)\n\n      this.queue(box(head, nonce1, key))\n      this.queue(boxed.slice(16, 16 + input[i].length))\n\n      increment(increment(nonce1)); increment(nonce2)\n    }\n  }, function (err) {\n    if(err) return this.queue(null)\n\n    //handle special-case of empty session\n    //final header is same length as header except all zeros (inside box)\n    var final = new Buffer(2+16); final.fill(0)\n    this.queue(box(final, nonce1, key))\n    this.queue(null)\n  })\n\n}\nexports.createUnboxStream =\nexports.createDecryptStream = function (key, nonce) {\n\n\n  if(key.length == 56) {\n    nonce = key.slice(32, 56)\n    key = key.slice(0, 32)\n  }\n  else if(!(key.length === 32 && nonce.length === 24))\n    throw new Error('nonce must be 24 bytes')\n\n  var reader = Reader(), first = true,  ended\n  var first = true\n\n  return function (read) {\n    reader(read)\n    return function (end, cb) {\n      if(end) return reader.abort(end, cb)\n      //use abort when the input was invalid,\n      //but the source hasn't actually ended yet.\n      function abort(err) {\n        reader.abort(ended = err || true, cb)\n      }\n\n      if(ended) return cb(ended)\n      reader.read(HEADER_LEN, function (err, cipherheader) {\n        if(err === true) return cb(ended = new Error('unexpected hangup'))\n        if(err) return cb(ended = err)\n\n        var header = unbox(cipherheader, nonce, key)\n\n        if(!header)\n          return abort(new Error('invalid header'))\n\n        //valid end of stream\n        if(isZeros(header))\n          return cb(ended = true)\n\n        var length = header.readUInt16BE(0)\n        var mac = header.slice(2, 34)\n\n        reader.read(length, function (err, cipherpacket) {\n          if(err) return cb(ended = err)\n          //recreate a valid packet\n          //TODO: PR to sodium bindings for detached box/open\n          var plainpacket = unbox_detached(mac, cipherpacket, increment(nonce), key)\n          if(!plainpacket)\n            return abort(new Error('invalid packet'))\n\n          increment(nonce)\n          cb(null, plainpacket)\n        })\n      })\n    }\n  }\n}\n","var noop = function () {}\n\nfunction abortAll(ary, abort, cb) {\n  var n = ary.length\n  if(!n) return cb(abort)\n  ary.forEach(function (f) {\n    if(f) f(abort, next)\n    else next()\n  })\n\n  function next() {\n    if(--n) return\n    cb(abort)\n  }\n  if(!n) next()\n}\n\nmodule.exports = function (streams) {\n  return function (abort, cb) {\n    ;(function next () {\n      if(abort)\n        abortAll(streams, abort, cb)\n      else if(!streams.length)\n        cb(true)\n      else if(!streams[0])\n        streams.shift(), next()\n      else\n        streams[0](null, function (err, data) {\n          if(err) {\n            streams.shift() //drop the first, has already ended.\n            if(err === true) next()\n            else             abortAll(streams, err, cb)\n          }\n          else\n            cb(null, data)\n        })\n    })()\n  }\n}\n\n\n\n\n","exports.id = \nfunction (item) {\n  return item\n}\n\nexports.prop = \nfunction (map) {  \n  if('string' == typeof map) {\n    var key = map\n    return function (data) { return data[key] }\n  }\n  return map\n}\n\nexports.tester = function (test) {\n  if(!test) return exports.id\n  if('object' === typeof test\n    && 'function' === typeof test.test)\n      return test.test.bind(test)\n  return exports.prop(test) || exports.id\n}\n\nexports.addPipe = addPipe\n\nfunction addPipe(read) {\n  if('function' !== typeof read)\n    return read\n\n  read.pipe = read.pipe || function (reader) {\n    if('function' != typeof reader && 'function' != typeof reader.sink)\n      throw new Error('must pipe to reader')\n    var pipe = addPipe(reader.sink ? reader.sink(read) : reader(read))\n    return reader.source || pipe;\n  }\n  \n  read.type = 'Source'\n  return read\n}\n\nvar Source =\nexports.Source =\nfunction Source (createRead) {\n  function s() {\n    var args = [].slice.call(arguments)\n    return addPipe(createRead.apply(null, args))\n  }\n  s.type = 'Source'\n  return s\n}\n\n\nvar Through =\nexports.Through = \nfunction (createRead) {\n  return function () {\n    var args = [].slice.call(arguments)\n    var piped = []\n    function reader (read) {\n      args.unshift(read)\n      read = createRead.apply(null, args)\n      while(piped.length)\n        read = piped.shift()(read)\n      return read\n      //pipeing to from this reader should compose...\n    }\n    reader.pipe = function (read) {\n      piped.push(read) \n      if(read.type === 'Source')\n        throw new Error('cannot pipe ' + reader.type + ' to Source')\n      reader.type = read.type === 'Sink' ? 'Sink' : 'Through'\n      return reader\n    }\n    reader.type = 'Through'\n    return reader\n  }\n}\n\nvar Sink =\nexports.Sink = \nfunction Sink(createReader) {\n  return function () {\n    var args = [].slice.call(arguments)\n    if(!createReader)\n      throw new Error('must be createReader function')\n    function s (read) {\n      args.unshift(read)\n      return createReader.apply(null, args)\n    }\n    s.type = 'Sink'\n    return s\n  }\n}\n\n\nexports.maybeSink = \nexports.maybeDrain = \nfunction (createSink, cb) {\n  if(!cb)\n    return Through(function (read) {\n      var ended\n      return function (close, cb) {\n        if(close) return read(close, cb)\n        if(ended) return cb(ended)\n\n        createSink(function (err, data) {\n          ended = err || true\n          if(!err) cb(null, data)\n          else     cb(ended)\n        }) (read)\n      }\n    })()\n\n  return Sink(function (read) {\n    return createSink(cb) (read)\n  })()\n}\n\n","\nvar Source = require('./source')\nvar Sink = require('./sink')\n\nmodule.exports = function () {\n\n  var source = Source()\n  var sink = Sink()\n\n  return {\n    source: source,\n    sink: sink,\n    resolve: function (duplex) {\n      source.resolve(duplex.source)\n      sink.resolve(duplex.sink)\n\n    }\n  }\n\n\n}\n","\nexports.source = require('./source')\nexports.through = require('./through')\nexports.sink = require('./sink')\nexports.duplex = require('./duplex')\n","module.exports = function (stream) {\n  var read, started = false, id = Math.random()\n\n  function consume (_read) {\n    if(!_read) throw new Error('must be passed a readable')\n    read = _read\n    if(started) stream(read)\n  }\n\n  consume.resolve =\n  consume.ready =\n  consume.start = function (_stream) {\n    started = true; stream = _stream || stream\n    if(read) stream(read)\n    return consume\n  }\n\n  return consume\n}\n","\nmodule.exports = function () {\n  var _read, _cb, abortCb, _end\n\n  var read = function (end, cb) {\n    if(!_read) {\n      if(end) {\n        _end = end\n        abortCb = cb\n      }\n      else\n        _cb = cb\n    }\n    else _read(end, cb)\n  }\n  read.resolve = function (read) {\n    if(_read) throw new Error('already resolved')\n    _read = read\n    if(!_read) throw new Error('no read cannot resolve!' + _read)\n    if(_cb) read(null, _cb)\n    if(abortCb) read(_end, abortCb)\n  }\n  read.abort = function(err) {\n    read.resolve(function (_, cb) {\n      cb(err || true)\n    })\n  }\n  return read\n}\n\n","\nmodule.exports = function () {\n  var read, reader, cb, abort, stream\n\n  function delayed (_read) {\n    //if we already have the stream, go!\n    if(stream) return stream(_read)\n\n    read = _read\n    return function (_abort, _cb) {\n      if(reader) reader(_abort, _cb)\n      else abort = _abort, cb = _cb\n\n    }\n  }\n\n  delayed.resolve = function (_stream) {\n    if(stream) throw new Error('already resolved')\n    stream = _stream\n    if(!stream) throw new Error('resolve *must* be passed a transform stream')\n    if(read) {\n      reader = stream(read)\n      if(cb) reader(abort, cb)\n    }\n  }\n\n  return delayed\n}\n","\n/* jshint node: true */\n'use strict';\n\nvar fs = require('fs');\nvar Decoder = require('pull-utf8-decoder')\n/**\n  # pull-file\n\n  This is a simple module which uses raw file reading methods available in\n  the node `fs` module to read files on-demand.  It's a work in progress\n  and feedback is welcome :)\n\n  ## Example Usage\n\n  <<< examples/ipsum-chunks.js\n\n**/\nmodule.exports = function(filename, opts) {\n  var mode = opts && opts.mode || 0x1B6; // 0666\n  var bufferSize = opts && opts.bufferSize || 1024*64;\n  var start = opts && opts.start || 0\n  var end = opts && opts.end || Number.MAX_SAFE_INTEGER\n  var fd = opts && opts.fd\n  var ended, closeNext, busy, _cb;\n  var _buffer = new Buffer(bufferSize)\n\n  var flags = opts && opts.flags || 'r'\n\n  function readNext(cb) {\n    if(closeNext) return close(cb)\n    var toRead = Math.min(end - start, bufferSize);\n    busy = true\n\n    fs.read(\n      fd,\n      _buffer,\n      0,\n      toRead,\n      start,\n      function(err, count, buffer) {\n        busy = false\n        start += count;\n        // if we have received an end noticiation, just discard this data\n        if(closeNext) {\n          close(_cb)\n          return cb(closeNext)\n        }\n\n        if (ended) {\n          return cb(err || ended);\n        }\n\n        // if we encountered a read error pass it on\n        if (err) {\n          return cb(err);\n        }\n\n        if(count === buffer.length) {\n          cb(null, buffer);\n        } else {\n          closeNext = true;\n          cb(null, buffer.slice(0, count));\n        }\n      }\n    );\n    _buffer = new Buffer(Math.min(end - start, bufferSize))\n  }\n\n  function open(cb) {\n    busy = true\n    fs.open(filename, flags, mode, function(err, descriptor) {\n      // save the file descriptor\n      fd = descriptor;\n\n      busy = false\n      if(closeNext) {\n        close(_cb)\n        return cb(closeNext)\n      }\n\n      if (err) {\n        return cb(err);\n      }\n\n      // read the next bytes\n      return readNext(cb);\n    });\n  }\n\n  function close (cb) {\n    //if auto close is disabled, then user manages fd.\n    if(opts && opts.autoClose === false) return cb(true)\n\n    //wait until we have got out of bed, then go back to bed.\n    //or if we are reading, wait till we read, then go back to bed.\n    else if(busy) {\n      _cb = cb\n      return closeNext = true\n    }\n\n    //first read was close, don't even get out of bed.\n    else if(!fd) {\n      return cb(true)\n    }\n\n    //go back to bed\n    else {\n      fs.close(fd, function(err) {\n        fd = null;\n        cb(err || true);\n      });\n    }\n  }\n\n  function source (end, cb) {\n    if (end) {\n      ended = end;\n      close(cb);\n    }\n    // if we have already received the end notification, abort further\n    else if (ended) {\n      cb(ended)\n    }\n\n    else if (! fd) {\n      open(cb);\n    }\n\n    else\n      readNext(cb);\n  };\n\n  //read directly to text\n  if(opts && opts.encoding)\n    return Decoder(opts.encoding)(source)\n\n  return source\n\n};\n\n\n\n\n\n\n\n\n\n\n","var pull = require('pull-stream')\nvar fs   = require('fs')\nvar path = require('path')\nvar Read = require('pull-file')\nvar Write = require('pull-write-file')\n\nvar readdir =\nexports.readdir =\nfunction (dir, match, ignore) {\n  var ls, ended = false\n  match = (\n    !match                           ? null\n  : 'function' === typeof match      ? match\n  : 'function' === typeof match.test ? match.test.bind(match)\n  :                                    null\n  )\n  return function (abort, cb) {\n    if(ended || abort) {\n      cb(ended = ended || abort)\n    }\n    else if(!ls)\n      fs.readdir(dir, function (err, _ls) {\n        if(err && err.code == 'ENOTDIR') cb(ended = true)\n        else if(err)             cb(ended = err)\n        else if(!_ls.length) cb(ended = true)\n        else {\n          if(match)\n            _ls = _ls.filter(match)\n          ls = _ls.map(function (f) {\n            return path.resolve(dir, f)\n          })\n          if(ls.length)\n            cb(null, ls.shift())\n          else\n            cb(true)\n        }\n      })\n    else if(!ls.length) cb(ended = true)\n    else                cb(null, ls.shift())\n  }\n}\n\nvar blocksize = 512\n\nvar read = exports.read = Read\nvar write = exports.write = Write\n\nvar exists =\nexports.exists =\nfunction (test) {\n  test = test || function (e) {\n    return !!e\n  }\n  return pull(\n    pull.asyncMap(function (e, cb) {\n      fs.stat(e, function (err, stat) {\n        if(stat && test(stat))\n          cb(null, e)\n        else\n          cb(null, null)\n      })\n    }),\n    pull.filter(Boolean)\n  )\n}\n\nfunction testStat(test) {\n  return function () {\n    return exists(test)\n  }\n}\n\n\nvar isFile = \nexports.isFile =\ntestStat(function (e) { return e.isFile() })\n\nvar isDirectory = \nexports.isDirectory =\ntestStat(function (e) { return e.isDirectory() })\n\nvar isBlockDevice = \nexports.isBlockDevice =\ntestStat(function (e) { return e.isBlockDevice() })\n\nvar isCharacterDevice = \nexports.isCharacterDevice =\ntestStat(function (e) { return e.isCharacterDevice() })\n\nvar isSymbolicLink = \nexports.isSymbolicLink =\ntestStat(function (e) { return e.isSymbolicLink() })\n\nvar isFIFO = \nexports.isFIFO =\ntestStat(function (e) { return e.isFIFO() })\n\nvar isSocket = \nexports.isSocket =\ntestStat(function (e) { return e.isSocket() })\n\n\n","\nvar core = require('./core')\nvar util = require('./util')\n\nfor(var k in core)\n  exports[k] = core[k]\nfor(var k in util)\n  exports[k] = util[k]\n\n","var path = require('path')\nvar pull = require('pull-stream')\nvar core  = require('./core')\nvar fs    = require('fs')\nvar DepthFirst = require('pull-traverse').depthFirst\n\nvar ancestors = exports.ancestors = function (dir) {\n  dir = dir || process.cwd()\n  var paths = []\n\n  while(dir) {\n    paths.push(dir)\n    dir = path.dirname(dir)\n    if(dir === '/') {\n      paths.push(dir) \n      break\n    }\n  }\n\n  return pull.values(paths)\n}\n\nvar star = exports.star = function (match) {\n  return pull(\n    pull.map(function (dir) {\n      return core.readdir(dir, match)\n    }),\n    pull.flatten(),\n    pull.filter()\n  )\n}\n\nvar starStar =\nexports.starStar =\nfunction (match) {\n  var seen = {}\n  return pull(\n    pull.map(function (dir) {\n      var first = true\n      return DepthFirst(path.resolve(dir), function (_dir) {\n        return pull(\n          core.readdir(_dir, match, true),\n          pull.filter(function (e) {\n            if(seen[e]) return false\n            return seen[e] = true\n          })\n        )\n      })\n    }),\n    pull.flatten(),\n    pull.filter()\n  )\n}\n\nvar resolve = exports.resolve = function (rel) {\n return pull.map(function (dir) { //map to $dir/node_modules\n    if(rel)\n      return path.resolve(dir, rel)\n    return path.resolve(dir)\n  })\n}\n\nvar relative = exports.relative = function (rel) {\n  rel = rel || process.cwd()\n  return pull.map(function (file) {\n    return path.relative(rel, file)\n  })\n}\n\nvar absolute = exports.absolute =\nfunction () {\n  return resolve()\n}\n\nvar readFile =\nexports.readFile = function (parse) {\n  return pull.asyncMap(function (file, cb) {\n    fs.readFile(file, 'utf-8', function (err, data) {\n      if(err) return cb(err) \n      try {\n         data = parse ? parse(data) : data\n      } catch (err) {\n        return cb(err)\n      }\n      return cb(null, data)\n    })\n  })\n}\n\nif(!module.parent) {\n  pull(\n    pull.values(['.']),\n    starStar(),\n    pull.drain(console.log)\n  )\n}\n\n\n","var pfs  = require('pull-fs')\nvar pull = require('pull-stream')\nvar path = require('path')\n\nvar glob = module.exports = function (x) {\n\n  var rest = path.normalize(x).split('/')\n  var stream\n\n  var pipe = []\n\n  if(rest[0] == '...') {\n    pipe.push(pfs.ancestors())\n    rest.shift()\n  } else if(rest[0] === '~' || rest[0] === '') {\n    pipe.push(pull.values([rest.shift() ? process.env.HOME : '/']))\n  } else {\n    pipe.push(pull.values(['.']))\n  }\n\n  //this should be tidied up.\n  //need a more betterer glob parser\n  //that handles escapes...\n  rest.forEach(function (e) {\n    if('**' === e) {\n      pipe.push(pfs.starStar())\n    } else if(/[*?{}]/.test(e)) {\n      //literal\n      e = e\n        .split('.').join('\\\\.')\n        .split('?').join('.')\n        .split(/({.*?})/).map(function (e, i) {\n        if(i % 2)\n          return e.replace('{', '(?:')\n                  .replace('}', ')')\n                  .split(',').join('|')\n        return e\n      }).join('')\n\n      var x = new RegExp('^'+e.split('*').join('.*')+'$')\n      pipe.push(pfs.star(x))\n    } else if(e === '')\n      //will only happen in the last position\n      //if you do */\n      pipe.push(pfs.isDirectory())\n    else\n      pipe.push(pull(pfs.resolve(e), pfs.exists()))\n  })\n\n  return pull.apply(null, pipe)\n}\n\n","\nmodule.exports = function endable (goodbye) {\n  var ended, waiting, sentEnd\n  function h (read) {\n    return function (abort, cb) {\n      read(abort, function (end, data) {\n        if(end && !sentEnd) {\n          sentEnd = true\n          return cb(null, goodbye)\n        }\n        //send end message...\n\n        if(end && ended) cb(end)\n        else if(end)     waiting = cb\n        else             cb(null, data)\n      })\n    }\n  }\n  h.end = function () {\n    ended = true\n    if(waiting) waiting(ended)\n    return h\n  }\n  return h\n}\n\n","\nvar endable = require('./endable')\nvar pull = require('pull-stream')\nmodule.exports = function (stream, goodbye) {\n  goodbye = goodbye || 'GOODBYE'\n  var e = endable(goodbye)\n\n  return {\n    // when the source ends,\n    // send the goodbye and then wait to recieve\n    // the other goodbye.\n    source: pull(stream.source, e),\n    sink: pull(\n      //when the goodbye is received, allow the source to end.\n      pull.filter(function (data) {\n        if(data !== goodbye) return true\n        e.end()\n      }),\n      stream.sink\n    )\n  }\n\n}\n","\nvar Reader = require('pull-reader')\nvar pull = require('pull-stream')\nvar deferred = require('pull-defer')\nvar Writer = require('pull-pushable')\nvar cat = require('pull-cat')\nvar pair = require('pull-pair')\n\nfunction once (cb) {\n  var called = 0\n  return function (a, b, c) {\n    if(called++) return\n    cb(a, b, c)\n  }\n}\n\nfunction isFunction (f) {\n  return 'function' === typeof f\n}\n\nmodule.exports = function (opts, _cb) {\n  if(isFunction(opts)) _cb = opts, opts = {}\n  _cb = once(_cb)\n  var reader = Reader(opts && opts.timeout || 5e3)\n  var writer = Writer(function (err) {\n    if(err) _cb(err)\n  })\n\n  var source = deferred.source()\n\n  var p = pair()\n\n  return {\n    handshake: {\n      read: reader.read,\n      abort: function (err) {\n        writer.end(err)\n        reader.abort(err, function (err) {\n        })\n        _cb(err)\n      },\n      write: writer.push,\n      rest: function () {\n        writer.end()\n        return {\n          source: reader.read(),\n          sink: p.sink\n        }\n      }\n    },\n    sink: reader,\n    source: cat([writer, p.source])\n  }\n}\n\n","var pull = require('pull-stream')\nvar mns  = require('./magic-numbers')\n\nmodule.exports = function (cb) {\n  var done = false\n  return pull.through(function (buf) {\n    if (done) return\n    done = true\n\n    if (!Buffer.isBuffer(buf))\n      return cb(false)\n\n    // compare the first bytes against the magic numbers\n    var hex = buf.slice(0, (buf.length > 10) ? 10 : buf.length).toString('hex')\n    for (var magicNumber in mns) {\n      if (hex.indexOf(magicNumber) === 0)\n        return cb(mns[magicNumber])\n    }\n\n    // convert to string, check the plaintext types\n    var asStr = buf.slice(0, (buf.length > 512) ? 512 : buf.length).toString('utf-8')\n    if (asStr.indexOf('<svg') !== -1)\n      return cb('svg')\n    if (asStr.indexOf('<html') !== -1)\n      return cb('html')\n    \n    cb(false)\n  })\n}","// thanks to https://github.com/bibig/whether\n\n// http://www.astro.keele.ac.uk/oldusers/rno/computing/file_magic.html\n// http://en.wikipedia.org/wiki/list_of_file_signatures\n// http://asecuritysite.com/forensics/magic\n\nmodule.exports = {\n  'ffd8ff': 'jpg',\n  '89504e47': 'png',\n  '47494638': 'gif',\n  '424d': 'bmp',\n  '4949': 'tif',\n  '4d4d': 'tif',\n  '49494e31': 'nif',\n  '00000100': 'ico',\n  '38425053': 'psd',\n  '526172211a07': 'rar',\n  '504b0304': 'zip',\n  '1f8b08': 'gz',\n  '7573746172': 'tar',\n  'd0cf11e0a1b11ae1': 'msi',\n  '4344303031': 'iso',\n  '7b5c72746631': 'rtf',\n  '52494646': 'avi',\n  '6d6f6f76': 'mov',\n  '3026b2758e66cf': 'wmv',\n  '3026b2758e66cf': 'wma',\n  '465753': 'swf',\n  '464c56': 'flv',\n  '4d546864': 'mid',\n  '25504446': 'pdf',\n  'd0cf11e0a1b11ae1': 'doc',\n  '504b0304': 'docx',\n  '494443': 'mp3'\n}\n\n/*\navi\nwmv\nwma\nswf\nflv\nmid\nmp3\n*/","\nvar pull = require('pull-stream')\nvar Abortable = require('pull-abortable')\nvar Rate = require('./rate')\n\nmodule.exports = function (duplex, min, onEnd) {\n  if('function' === typeof min)\n    onEnd = min, min = null\n\n  var n = 2, error, interval\n\n  function done (err) {\n    error = error || err\n    if(--n) return\n    clearInterval(interval)\n    onEnd && onEnd(error)\n  }\n\n  min = min || 1000 //close after 1 second inactivity.\n\n  var sourceAbort = Abortable(done)\n  var sinkAbort   = Abortable(done)\n  var sourceRate  = Rate()\n  var sinkRate    = Rate()\n\n  function rate () {\n    return sourceRate.rate() + sinkRate.rate()\n  }\n\n  function abort () {\n    clearInterval(interval)\n    sourceAbort.abort()\n    sinkAbort.abort()\n  }\n\n  interval = setInterval(function () {\n    if(!min) return\n    if(Math.max(sourceRate.ts, sinkRate.ts) + min < Date.now())\n      abort()\n  }, 200)\n\n  return {\n    source: pull(duplex.source, sourceRate, sourceAbort),\n    sink  : pull(sinkRate, sinkAbort, duplex.sink),\n    rate  : rate,\n    setTTL: function (_min) {\n      if(!_min) clearInterval(interval)\n      min = _min\n      return this\n    },\n    abort : abort\n  }\n\n}\n\nmodule.exports.through = function (min, onEnd) {\n  min = min || 0.002 //2k per second\n  var abortable = Abortable(onEnd)\n  var flow = Rate()\n  var interval = setInterval(function () {\n    if(flow.rate() < min) {\n      clearInterval(interval)\n      abortable.abort()\n    }\n  }, 500)\n\n  var stream = pull(\n    flow,\n    abortable,\n    pull.through(null, function () {\n      clearInterval(interval)\n    })\n  )\n\n  stream.rate = flow.rate\n\n  return stream\n}\n","var u      = require('pull-core')\nvar sources = require('./sources')\nvar sinks = require('./sinks')\n\nvar prop   = u.prop\nvar id     = u.id\nvar tester = u.tester\n\nvar map = exports.map =\nfunction (read, map) {\n  map = prop(map) || id\n  return function (abort, cb) {\n    read(abort, function (end, data) {\n      try {\n      data = !end ? map(data) : null\n      } catch (err) {\n        return read(err, function () {\n          return cb(err)\n        })\n      }\n      cb(end, data)\n    })\n  }\n}\n\nvar asyncMap = exports.asyncMap =\nfunction (read, map) {\n  if(!map) return read\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    read(null, function (end, data) {\n      if(end) return cb(end, data)\n      map(data, cb)\n    })\n  }\n}\n\nvar paraMap = exports.paraMap =\nfunction (read, map, width) {\n  if(!map) return read\n  var ended = false, queue = [], _cb\n\n  function drain () {\n    if(!_cb) return\n    var cb = _cb\n    _cb = null\n    if(queue.length)\n      return cb(null, queue.shift())\n    else if(ended && !n)\n      return cb(ended)\n    _cb = cb\n  }\n\n  function pull () {\n    read(null, function (end, data) {\n      if(end) {\n        ended = end\n        return drain()\n      }\n      n++\n      map(data, function (err, data) {\n        n--\n\n        queue.push(data)\n        drain()\n      })\n\n      if(n < width && !ended)\n        pull()\n    })\n  }\n\n  var n = 0\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    //continue to read while there are less than 3 maps in flight\n    _cb = cb\n    if(queue.length || ended)\n      pull(), drain()\n    else pull()\n  }\n  return highWaterMark(asyncMap(read, map), width)\n}\n\nvar filter = exports.filter =\nfunction (read, test) {\n  //regexp\n  test = tester(test)\n  return function next (end, cb) {\n    var sync, loop = true\n    while(loop) {\n      loop = false\n      sync = true\n      read(end, function (end, data) {\n        if(!end && !test(data))\n          return sync ? loop = true : next(end, cb)\n        cb(end, data)\n      })\n      sync = false\n    }\n  }\n}\n\nvar filterNot = exports.filterNot =\nfunction (read, test) {\n  test = tester(test)\n  return filter(read, function (e) {\n    return !test(e)\n  })\n}\n\nvar through = exports.through =\nfunction (read, op, onEnd) {\n  var a = false\n  function once (abort) {\n    if(a || !onEnd) return\n    a = true\n    onEnd(abort === true ? null : abort)\n  }\n\n  return function (end, cb) {\n    if(end) once(end)\n    return read(end, function (end, data) {\n      if(!end) op && op(data)\n      else once(end)\n      cb(end, data)\n    })\n  }\n}\n\nvar take = exports.take =\nfunction (read, test) {\n  var ended = false\n  if('number' === typeof test) {\n    var n = test; test = function () {\n      return n --\n    }\n  }\n\n  return function (end, cb) {\n    if(ended) return cb(ended)\n    if(ended = end) return read(ended, cb)\n\n    read(null, function (end, data) {\n      if(ended = ended || end) return cb(ended)\n      if(!test(data)) {\n        ended = true\n        read(true, function (end, data) {\n          cb(ended, data)\n        })\n      }\n      else\n        cb(null, data)\n    })\n  }\n}\n\nvar unique = exports.unique = function (read, field, invert) {\n  field = prop(field) || id\n  var seen = {}\n  return filter(read, function (data) {\n    var key = field(data)\n    if(seen[key]) return !!invert //false, by default\n    else seen[key] = true\n    return !invert //true by default\n  })\n}\n\nvar nonUnique = exports.nonUnique = function (read, field) {\n  return unique(read, field, true)\n}\n\nvar group = exports.group =\nfunction (read, size) {\n  var ended; size = size || 5\n  var queue = []\n\n  return function (end, cb) {\n    //this means that the upstream is sending an error.\n    if(end) return read(ended = end, cb)\n    //this means that we read an end before.\n    if(ended) return cb(ended)\n\n    read(null, function next(end, data) {\n      if(ended = ended || end) {\n        if(!queue.length)\n          return cb(ended)\n\n        var _queue = queue; queue = []\n        return cb(null, _queue)\n      }\n      queue.push(data)\n      if(queue.length < size)\n        return read(null, next)\n\n      var _queue = queue; queue = []\n      cb(null, _queue)\n    })\n  }\n}\n\nvar flatten = exports.flatten = function (read) {\n  var _read\n  return function (abort, cb) {\n    if(_read) nextChunk()\n    else      nextStream()\n\n    function nextChunk () {\n      _read(null, function (end, data) {\n        if(end) nextStream()\n        else    cb(null, data)\n      })\n    }\n    function nextStream () {\n      read(null, function (end, stream) {\n        if(end)\n          return cb(end)\n        if(Array.isArray(stream) || stream && 'object' === typeof stream)\n          stream = sources.values(stream)\n        else if('function' != typeof stream)\n          throw new Error('expected stream of streams')\n        _read = stream\n        nextChunk()\n      })\n    }\n  }\n}\n\nvar prepend =\nexports.prepend =\nfunction (read, head) {\n\n  return function (abort, cb) {\n    if(head !== null) {\n      if(abort)\n        return read(abort, cb)\n      var _head = head\n      head = null\n      cb(null, _head)\n    } else {\n      read(abort, cb)\n    }\n  }\n\n}\n\n//var drainIf = exports.drainIf = function (op, done) {\n//  sinks.drain(\n//}\n\nvar _reduce = exports._reduce = function (read, reduce, initial) {\n  return function (close, cb) {\n    if(close) return read(close, cb)\n    if(ended) return cb(ended)\n\n    sinks.drain(function (item) {\n      initial = reduce(initial, item)\n    }, function (err, data) {\n      ended = err || true\n      if(!err) cb(null, initial)\n      else     cb(ended)\n    })\n    (read)\n  }\n}\n\nvar nextTick = process.nextTick\n\nvar highWaterMark = exports.highWaterMark =\nfunction (read, highWaterMark) {\n  var buffer = [], waiting = [], ended, ending, reading = false\n  highWaterMark = highWaterMark || 10\n\n  function readAhead () {\n    while(waiting.length && (buffer.length || ended))\n      waiting.shift()(ended, ended ? null : buffer.shift())\n\n    if (!buffer.length && ending) ended = ending;\n  }\n\n  function next () {\n    if(ended || ending || reading || buffer.length >= highWaterMark)\n      return\n    reading = true\n    return read(ended || ending, function (end, data) {\n      reading = false\n      ending = ending || end\n      if(data != null) buffer.push(data)\n\n      next(); readAhead()\n    })\n  }\n\n  process.nextTick(next)\n\n  return function (end, cb) {\n    ended = ended || end\n    waiting.push(cb)\n\n    next(); readAhead()\n  }\n}\n\nvar flatMap = exports.flatMap =\nfunction (read, mapper) {\n  mapper = mapper || id\n  var queue = [], ended\n\n  return function (abort, cb) {\n    if(queue.length) return cb(null, queue.shift())\n    else if(ended)   return cb(ended)\n\n    read(abort, function next (end, data) {\n      if(end) ended = end\n      else {\n        var add = mapper(data)\n        while(add && add.length)\n          queue.push(add.shift())\n      }\n\n      if(queue.length) cb(null, queue.shift())\n      else if(ended)   cb(ended)\n      else             read(null, next)\n    })\n  }\n}\n\n","var pull = require('pull-stream')\n\nfunction rate (s) {\n  var recent = []\n  var stream = pull.through(function (d) {\n    stream.ts = Date.now()\n    recent.push({size: d.length, ts: stream.ts})\n    if(recent.length > 5)\n      recent.shift()\n\n  })\n\n  stream.ts = Date.now()\n\n  stream.rate = function () {\n    var ts = Date.now()\n    if(recent.length > 1) {\n      var rate = (recent.reduce(function (size, item) {\n        return size + item.size\n      }, 0)/1000000) / ((ts - recent[0].ts)/1000)\n\n      return rate\n    }\n  }\n\n  return stream\n}\n\nmodule.exports = rate\n","var pull     = require('pull-stream')\nvar toPull   = require('stream-to-pull-stream')\nvar pushable = require('pull-pushable')\nvar cat      = require('pull-cat')\nvar pw       = require('pull-window')\nvar post     = require('level-post')\n\nfunction read(db, opts) {\n  return toPull.read1(db.createReadStream(opts))\n}\n\nvar live =\nexports.live =\nfunction (db, opts) {\n  opts = opts || {}\n\n  var l = pushable()\n\n  var cleanup = post(db, opts, function (ch) {\n    if(opts.keys === false)\n      l.push(ch.value)\n    else if(opts.values === false)\n      l.push(ch.key)\n    else\n      l.push(ch)\n  })\n\n  return pull(l, pull.through(null, cleanup))\n\n}\n\nexports.read =\nexports.readStream =\nexports.createReadStream = function (db, opts) {\n  opts = opts || {}\n  if(!(opts.tail || opts.live))\n    return read(db, opts)\n\n  //optionally notify when we switch from reading history to realtime\n  var sync = opts.onSync && function (abort, cb) {\n      opts.onSync(abort); cb(abort || true)\n    }\n\n  return cat([read(db, opts), sync, live(db, opts)])\n}\n\nexports.write =\nexports.writeStream =\nexports.createWriteStream = function (db, opts, done) {\n  if('function' === typeof opts)\n    done = opts, opts = null\n  opts = opts || {}\n  return pull(\n    pull.map(function (e) {\n      if(e.type) return e\n      return {\n        key   : e.key, \n        value : e.value,\n        type  : e.value == null ? 'del' : 'put'\n      }\n    }),\n    pw.recent(opts.windowSize, opts.windowTime),\n    pull.asyncMap(function (batch, cb) {\n      db.batch(batch, cb)\n    }),\n    pull.drain(null, done)\n  )\n}\n\n","exports.id = \nfunction (item) {\n  return item\n}\n\nexports.prop = \nfunction (map) {  \n  if('string' == typeof map) {\n    var key = map\n    return function (data) { return data[key] }\n  }\n  return map\n}\n\nexports.tester = function (test) {\n  if(!test) return exports.id\n  if('object' === typeof test\n    && 'function' === typeof test.test)\n      return test.test.bind(test)\n  return exports.prop(test) || exports.id\n}\n\nexports.addPipe = addPipe\n\nfunction addPipe(read) {\n  if('function' !== typeof read)\n    return read\n\n  read.pipe = read.pipe || function (reader) {\n    if('function' != typeof reader)\n      throw new Error('must pipe to reader')\n    return addPipe(reader(read))\n  }\n  read.type = 'Source'\n  return read\n}\n\nvar Source =\nexports.Source =\nfunction Source (createRead) {\n  function s() {\n    var args = [].slice.call(arguments)\n    return addPipe(createRead.apply(null, args))\n  }\n  s.type = 'Source'\n  return s\n}\n\n\nvar Through =\nexports.Through = \nfunction (createRead) {\n  return function () {\n    var args = [].slice.call(arguments)\n    var piped = []\n    function reader (read) {\n      args.unshift(read)\n      read = createRead.apply(null, args)\n      while(piped.length)\n        read = piped.shift()(read)\n      return read\n      //pipeing to from this reader should compose...\n    }\n    reader.pipe = function (read) {\n      piped.push(read) \n      if(read.type === 'Source')\n        throw new Error('cannot pipe ' + reader.type + ' to Source')\n      reader.type = read.type === 'Sink' ? 'Sink' : 'Through'\n      return reader\n    }\n    reader.type = 'Through'\n    return reader\n  }\n}\n\nvar Sink =\nexports.Sink = \nfunction Sink(createReader) {\n  return function () {\n    var args = [].slice.call(arguments)\n    if(!createReader)\n      throw new Error('must be createReader function')\n    function s (read) {\n      args.unshift(read)\n      return createReader.apply(null, args)\n    }\n    s.type = 'Sink'\n    return s\n  }\n}\n\n\nexports.maybeSink = \nexports.maybeDrain = \nfunction (createSink, cb) {\n  if(!cb)\n    return Through(function (read) {\n      var ended\n      return function (close, cb) {\n        if(close) return read(close, cb)\n        if(ended) return cb(ended)\n\n        createSink(function (err, data) {\n          ended = err || true\n          if(!err) cb(null, data)\n          else     cb(ended)\n        }) (read)\n      }\n    })()\n\n  return Sink(function (read) {\n    return createSink(cb) (read)\n  })()\n}\n\n","var pull = require('pull-stream')\n\nmodule.exports = pull.Source(function (onClose) {\n  var buffer = [], cbs = [], waiting = [], ended\n\n  function drain() {\n    var l\n    while(waiting.length && ((l = buffer.length) || ended)) {\n      var data = buffer.shift()\n      var cb   = cbs.shift()\n      waiting.shift()(l ? null : ended, data)\n      cb && cb(ended === true ? null : ended)\n    }\n  }\n\n  function read (end, cb) {\n    ended = ended || end\n    waiting.push(cb)\n    drain()\n    if(ended)\n      onClose && onClose(ended === true ? null : ended)\n  }\n\n  read.push = function (data, cb) {\n    if(ended)\n      return cb && cb(ended === true ? null : ended)\n    buffer.push(data); cbs.push(cb)\n    drain()\n  }\n\n  read.end = function (end, cb) {\n    if('function' === typeof end)\n      cb = end, end = true\n    ended = ended || end || true;\n    if(cb) cbs.push(cb)\n    drain()\n    if(ended)\n      onClose && onClose(ended === true ? null : ended)\n  }\n\n  return read\n})\n\n","\nvar sources  = require('./sources')\nvar sinks    = require('./sinks')\nvar throughs = require('./throughs')\nvar u        = require('pull-core')\n\nfor(var k in sources)\n  exports[k] = u.Source(sources[k])\n\nfor(var k in throughs)\n  exports[k] = u.Through(throughs[k])\n\nfor(var k in sinks)\n  exports[k] = u.Sink(sinks[k])\n\nvar maybe = require('./maybe')(exports)\n\nfor(var k in maybe)\n  exports[k] = maybe[k]\n\nexports.Duplex  = \nexports.Through = exports.pipeable       = u.Through\nexports.Source  = exports.pipeableSource = u.Source\nexports.Sink    = exports.pipeableSink   = u.Sink\n\n\n","var u = require('pull-core')\nvar prop = u.prop\nvar id   = u.id\nvar maybeSink = u.maybeSink\n\nmodule.exports = function (pull) {\n\n  var exports = {}\n  var drain = pull.drain\n\n  var find = \n  exports.find = function (test, cb) {\n    return maybeSink(function (cb) {\n      var ended = false\n      if(!cb)\n        cb = test, test = id\n      else\n        test = prop(test) || id\n\n      return drain(function (data) {\n        if(test(data)) {\n          ended = true\n          cb(null, data)\n        return false\n        }\n      }, function (err) {\n        if(ended) return //already called back\n        cb(err === true ? null : err, null)\n      })\n\n    }, cb)\n  }\n\n  var reduce = exports.reduce = \n  function (reduce, acc, cb) {\n    \n    return maybeSink(function (cb) {\n      return drain(function (data) {\n        acc = reduce(acc, data)\n      }, function (err) {\n        cb(err, acc)\n      })\n\n    }, cb)\n  }\n\n  var collect = exports.collect = exports.writeArray =\n  function (cb) {\n    return reduce(function (arr, item) {\n      arr.push(item)\n      return arr\n    }, [], cb)\n  }\n\n  return exports\n}\n","var drain = exports.drain = function (read, op, done) {\n\n  ;(function next() {\n    var loop = true, cbed = false\n    while(loop) {\n      cbed = false\n      read(null, function (end, data) {\n        cbed = true\n        if(end) {\n          loop = false\n          done && done(end === true ? null : end)\n        }\n        else if(op && false === op(data)) {\n          loop = false\n          read(true, done || function () {})\n        }\n        else if(!loop){\n          next()\n        }\n      })\n      if(!cbed) {\n        loop = false\n        return\n      }\n    }\n  })()\n}\n\nvar onEnd = exports.onEnd = function (read, done) {\n  return drain(read, null, done)\n}\n\nvar log = exports.log = function (read, done) {\n  return drain(read, function (data) {\n    console.log(data)\n  }, done)\n}\n\n","\nvar keys = exports.keys =\nfunction (object) {\n  return values(Object.keys(object))\n}\n\nvar once = exports.once =\nfunction (value) {\n  return function (abort, cb) {\n    if(abort) return cb(abort)\n    if(value != null) {\n      var _value = value; value = null\n      cb(null, _value)\n    } else\n      cb(true)\n  }\n}\n\nvar values = exports.values = exports.readArray =\nfunction (array) {\n  if(!Array.isArray(array))\n    array = Object.keys(array).map(function (k) {\n      return array[k]\n    })\n  var i = 0\n  return function (end, cb) {\n    if(end)\n      return cb && cb(end)  \n    cb(i >= array.length || null, array[i++])\n  }\n}\n\n\nvar count = exports.count = \nfunction (max) {\n  var i = 0; max = max || Infinity\n  return function (end, cb) {\n    if(end) return cb && cb(end)\n    if(i > max)\n      return cb(true)\n    cb(null, i++)\n  }\n}\n\nvar infinite = exports.infinite = \nfunction (generate) {\n  generate = generate || Math.random\n  return function (end, cb) {\n    if(end) return cb && cb(end)\n    return cb(null, generate())\n  }\n}\n\nvar defer = exports.defer = function () {\n  var _read, cbs = [], _end\n\n  var read = function (end, cb) {\n    if(!_read) {\n      _end = end\n      cbs.push(cb)\n    } \n    else _read(end, cb)\n  }\n  read.resolve = function (read) {\n    if(_read) throw new Error('already resolved')\n    _read = read\n    if(!_read) throw new Error('no read cannot resolve!' + _read)\n    while(cbs.length)\n      _read(_end, cbs.shift())\n  }\n  read.abort = function(err) {\n    read.resolve(function (_, cb) {\n      cb(err || true)\n    })\n  }\n  return read\n}\n\nvar empty = exports.empty = function () {\n  return function (abort, cb) {\n    cb(true)\n  }\n}\n\nvar depthFirst = exports.depthFirst =\nfunction (start, createStream) {\n  var reads = []\n\n  reads.unshift(once(start))\n\n  return function next (end, cb) {\n    if(!reads.length)\n      return cb(true)\n    reads[0](end, function (end, data) {\n      if(end) {\n        //if this stream has ended, go to the next queue\n        reads.shift()\n        return next(null, cb)\n      }\n      reads.unshift(createStream(data))\n      cb(end, data)\n    })\n  }\n}\n//width first is just like depth first,\n//but push each new stream onto the end of the queue\nvar widthFirst = exports.widthFirst = \nfunction (start, createStream) {\n  var reads = []\n\n  reads.push(once(start))\n\n  return function next (end, cb) {\n    if(!reads.length)\n      return cb(true)\n    reads[0](end, function (end, data) {\n      if(end) {\n        reads.shift()\n        return next(null, cb)\n      }\n      reads.push(createStream(data))\n      cb(end, data)\n    })\n  }\n}\n\n//this came out different to the first (strm)\n//attempt at leafFirst, but it's still a valid\n//topological sort.\nvar leafFirst = exports.leafFirst = \nfunction (start, createStream) {\n  var reads = []\n  var output = []\n  reads.push(once(start))\n  \n  return function next (end, cb) {\n    reads[0](end, function (end, data) {\n      if(end) {\n        reads.shift()\n        if(!output.length)\n          return cb(true)\n        return cb(null, output.shift())\n      }\n      reads.unshift(createStream(data))\n      output.unshift(data)\n      next(null, cb)\n    })\n  }\n}\n\n","var u      = require('pull-core')\nvar sources = require('./sources')\nvar sinks = require('./sinks')\n\nvar prop   = u.prop\nvar id     = u.id\nvar tester = u.tester\n\nvar map = exports.map = \nfunction (read, map) {\n  map = prop(map) || id\n  return function (end, cb) {\n    read(end, function (end, data) {\n      var data = !end ? map(data) : null\n      cb(end, data)\n    })\n  }\n}\n\nvar asyncMap = exports.asyncMap =\nfunction (read, map) {\n  if(!map) return read\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    read(null, function (end, data) {\n      if(end) return cb(end, data)\n      map(data, cb)\n    })\n  }\n}\n\nvar paraMap = exports.paraMap =\nfunction (read, map, width) {\n  if(!map) return read\n  var ended = false, queue = [], _cb\n\n  function drain () {\n    if(!_cb) return\n    var cb = _cb\n    _cb = null\n    if(queue.length)\n      return cb(null, queue.shift())\n    else if(ended && !n)\n      return cb(ended)\n    _cb = cb\n  }\n\n  function pull () {\n    read(null, function (end, data) {\n      if(end) {\n        ended = end\n        return drain()\n      }\n      n++\n      map(data, function (err, data) {\n        n--\n\n        queue.push(data)\n        drain()\n      })\n\n      if(n < width && !ended)\n        pull()\n    })\n  }\n\n  var n = 0\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    //continue to read while there are less than 3 maps in flight\n    _cb = cb\n    if(queue.length || ended)\n      pull(), drain()\n    else pull()\n  }\n  return highWaterMark(asyncMap(read, map), width)\n}\n\nvar filter = exports.filter =\nfunction (read, test) {\n  //regexp\n  test = tester(test)\n  return function next (end, cb) {\n    read(end, function (end, data) {\n      if(!end && !test(data))\n        return next(end, cb)\n      cb(end, data)\n    })\n  }\n}\n\nvar filterNot = exports.filterNot =\nfunction (read, test) {\n  test = tester(test)\n  return filter(read, function (e) {\n    return !test(e)\n  })\n}\n\nvar through = exports.through = \nfunction (read, op, onEnd) {\n  var a = false\n  function once (abort) {\n    if(a || !onEnd) return\n    a = true\n    onEnd(abort === true ? null : abort)\n  }\n\n  return function (end, cb) {\n    if(end) once(end)\n    return read(end, function (end, data) {\n      if(!end) op && op(data)\n      else once(end)\n      cb(end, data)\n    })\n  }\n}\n\nvar take = exports.take =\nfunction (read, test) {\n  var ended = false\n  if('number' === typeof test) {\n    var n = test; test = function () {\n      return n --\n    }\n  }\n\n  return function (end, cb) {\n    if(ended) return cb(ended)\n    if(ended = end) return read(ended, cb)\n\n    read(null, function (end, data) {\n      if(ended = ended || end) return cb(ended)\n      if(!test(data)) {\n        ended = true\n        read(true, function (end, data) {\n          cb(ended, data)\n        })\n      }\n      else\n        cb(null, data)\n    })\n  }\n}\n\nvar unique = exports.unique = function (read, field, invert) {\n  field = prop(field) || id\n  var seen = {}\n  return filter(read, function (data) {\n    var key = field(data)\n    if(seen[key]) return !!invert //false, by default\n    else seen[key] = true\n    return !invert //true by default\n  })\n}\n\nvar nonUnique = exports.nonUnique = function (read, field) {\n  return unique(read, field, true)\n}\n\nvar group = exports.group =\nfunction (read, size) {\n  var ended; size = size || 5\n  var queue = []\n\n  return function (end, cb) {\n    //this means that the upstream is sending an error.\n    if(end) return read(ended = end, cb)\n    //this means that we read an end before.\n    if(ended) return cb(ended)\n\n    read(null, function next(end, data) {\n      if(ended = ended || end) {\n        if(!queue.length)\n          return cb(ended)\n\n        var _queue = queue; queue = []\n        return cb(null, _queue)\n      }\n      queue.push(data)\n      if(queue.length < size)\n        return read(null, next)\n\n      var _queue = queue; queue = []\n      cb(null, _queue)\n    })\n  }\n}\n\nvar flatten = exports.flatten = function (read) {\n  var _read\n  return function (abort, cb) {\n    if(_read) nextChunk()\n    else      nextStream()\n\n    function nextChunk () {\n      _read(null, function (end, data) {\n        if(end) nextStream()\n        else    cb(null, data)\n      })\n    }\n    function nextStream () {\n      read(null, function (end, stream) {\n        if(end)\n          return cb(end)\n        if(Array.isArray(stream))\n          stream = sources.values(stream)\n        else if('function' != typeof stream)\n          throw new Error('expected stream of streams')\n        \n        _read = stream\n        nextChunk()\n      })\n    }\n  }\n}\n\nvar prepend =\nexports.prepend =\nfunction (read, head) {\n\n  return function (abort, cb) {\n    if(head !== null) {\n      if(abort)\n        return read(abort, cb)\n      var _head = head\n      head = null\n      cb(null, _head)\n    } else {\n      read(abort, cb)\n    }\n  }\n\n}\n\n//var drainIf = exports.drainIf = function (op, done) {\n//  sinks.drain(\n//}\n\nvar _reduce = exports._reduce = function (read, reduce, initial) {\n  return function (close, cb) {\n    if(close) return read(close, cb)\n    if(ended) return cb(ended)\n\n    sinks.drain(function (item) {\n      initial = reduce(initial, item)\n    }, function (err, data) {\n      ended = err || true\n      if(!err) cb(null, initial)\n      else     cb(ended)\n    })\n    (read)\n  }\n}\n\nvar nextTick = process.nextTick\n\nvar highWaterMark = exports.highWaterMark = \nfunction (read, highWaterMark) {\n  var buffer = [], waiting = [], ended, reading = false\n  highWaterMark = highWaterMark || 10\n\n  function readAhead () {\n    while(waiting.length && (buffer.length || ended))\n      waiting.shift()(ended, ended ? null : buffer.shift())\n  }\n\n  function next () {\n    if(ended || reading || buffer.length >= highWaterMark)\n      return\n    reading = true\n    return read(ended, function (end, data) {\n      reading = false\n      ended = ended || end\n      if(data != null) buffer.push(data)\n      \n      next(); readAhead()\n    })\n  }\n\n  nextTick(next)\n\n  return function (end, cb) {\n    ended = ended || end\n    waiting.push(cb)\n\n    next(); readAhead()\n  }\n}\n\n\n\n","var pull = require('pull-core')\n\nfunction destroy(stream, cb) {\n  function onClose () {\n    cleanup(); cb()\n  }\n  function onError (err) {\n    cleanup(); cb(err)\n  }\n  function cleanup() {\n    stream.removeListener('close', onClose)\n    stream.removeListener('error', onError)\n  }\n  stream.on('close', onClose)\n  stream.on('error', onError)\n}\n\nfunction write(read, stream) {\n  var ended\n  function onClose () {\n    cleanup()\n    if(!ended) read(ended = true, function () {})\n  }\n  function onError (err) {\n    cleanup()\n    if(!ended) read(ended = err, function () {})\n  }\n  function cleanup() {\n    stream.removeListener('close', onClose)\n    stream.removeListener('error', onError)\n  }\n  stream.on('close', onClose)\n  stream.on('error', onError)\n  process.nextTick(function next() {\n    read(null, function (end, data) {\n      if(end === true)\n        return stream._isStdio || stream.end()\n      if(ended = ended || end)\n        return stream.emit('error', end)\n\n      var pause = stream.write(data)\n      if(pause === false)\n        stream.once('drain', next)\n      else next()\n    })\n  })\n}\n\nfunction first (emitter, events, handler) {\n  function listener (val) {\n    events.forEach(function (e) {\n      emitter.removeListener(e, listener)\n    })\n    handler(val)\n  } \n  events.forEach(function (e) {\n    emitter.on(e, listener)\n  })\n  return emitter\n}\n\nfunction read2(stream) {\n  var ended = false, waiting = false\n  var _cb\n\n  function read () {\n    var data = stream.read()\n    if(data !== null && _cb) {\n      var cb = _cb; _cb = null\n      cb(null, data)\n    }\n  }\n\n  stream.on('readable', function () {\n    waiting = true\n    _cb && read()\n  })\n  .on('end', function () {\n    ended = true\n    _cb && _cb(ended)\n  })\n  .on('error', function (err) {\n    ended = err\n    _cb && _cb(ended)\n  })\n\n  return function (end, cb) {\n    _cb = cb\n    if(ended)\n      cb(ended)\n    else if(waiting)\n      read()\n  }\n}\n\nfunction read1(stream) {\n  var buffer = [], cbs = [], ended, paused = false\n\n  var draining\n  function drain() {\n    while((buffer.length || ended) && cbs.length)\n      cbs.shift()(buffer.length ? null : ended, buffer.shift())\n    if(!buffer.length && (paused)) {\n      paused = false\n      stream.resume()\n    }\n  }\n\n  stream.on('data', function (data) {\n    buffer.push(data)\n    drain()\n    if(buffer.length && stream.pause) {\n      paused = true\n      stream.pause()\n    }\n  })\n  stream.on('end', function () {\n    ended = true\n    drain()\n  })\n  stream.on('error', function (err) {\n    ended = err\n    drain()\n  })\n  return function (abort, cb) {\n    if(!cb) throw new Error('*must* provide cb')\n    if(abort) {\n      stream.once('close', function () {\n        cb(abort)\n      })\n      stream.destroy()\n    }\n    cbs.push(cb)\n    drain()\n  }\n}\n\nfunction read (stream) {\n  if('function' === typeof stream.read)\n    return read2(stream)\n  return read1(stream)\n}\n\nvar sink = function (stream) {\n  return pull.Sink(function (read) {\n    return write(read, stream)\n  })()\n}\n\nvar source = function (stream) {\n  return pull.Source(function () { return read(stream) })()\n}\n\nexports = module.exports = function (stream) {\n  return (\n    stream.writable\n    ? stream.readable\n      ? pull.Through(function(_read) {\n          write(_read, stream); \n          return read(stream) \n        })()  \n      : sink(stream)\n    : source(stream)\n  )\n}\n\nexports.sink = sink\nexports.source = source\nexports.read = read\nexports.read1 = read1\nexports.read2 = read2\n\n","\n\n/*\nall pull streams have these states:\n\n{\n  START: {\n    read: READING,\n    abort: ABORTING\n  },\n  READY: {\n    read: READING,\n    abort: ABORTING\n  },\n  READING: {\n    cb: READY,\n    err: ERROR,\n    end: END\n  },\n  ABORTING: {\n    cb: END\n  },\n  ERROR: {},\n  END: {}\n}\n\nthis module takes a collection of pull-streams,\nand interleaves their states.\nif all the streams have ended, it ends.\nIf it is in reading state, and one stream goes has READING->cb\nit goes into READY\n\non read, trigger read on every stream in START or READY\n\non abort, trigger abort on every stream in START or READY\n\nif a stream is in READY, and big stream is in ABORT,\ntrigger abort\n\nif every stream is in END or ERROR, trigger end or error\n\ncould you describe this declaritively or something?\n*/\n\nmodule.exports = function (ary) {\n\n  var capped = !!ary\n  var inputs = (ary || []).map(create), i = 0, abort, cb\n\n  function create (stream) {\n    return {ready: false, reading: false, ended: false, read: stream, data: null}\n  }\n\n  function check () {\n    if(!cb) return\n    clean()\n    var l = inputs.length\n    var _cb = cb\n    if(l === 0 && (abort || capped)) {\n      cb = null; _cb(abort ||  true)\n      return\n    }\n\n    //scan the inputs to check whether there is one we can use.\n    for(var j = 0; j < l; j++) {\n      var current = inputs[(i + j) % l]\n      if(current.ready && !current.ended) {\n        var data = current.data\n        current.ready = false\n        current.data = null\n        i ++; cb = null\n        return _cb(null, data)\n      }\n    }\n  }\n\n  function clean () {\n    var l = inputs.length\n    //iterate backwards so that we can remove items.\n    while(l--) {\n      if(inputs[l].ended)\n        inputs.splice(l, 1)\n    }\n  }\n\n  function next () {\n    var l = inputs.length\n    while(l--)\n      (function (current) {\n        //read the next item if we aren't already\n        if(l > inputs.length) throw new Error('this should never happen')\n        if(current.reading || current.ended || current.ready) return\n        current.reading = true\n        var sync = true\n        current.read(abort, function next (end, data) {\n          current.data = data\n          current.ready = true\n          current.reading = false\n\n          if(end === true || abort) current.ended = true\n          else if(end) abort = current.ended = end\n          //check whether we need to abort this stream.\n          if(abort && !end) current.read(abort, next)\n          if(!sync) check()\n        })\n        sync = false\n      })(inputs[l])\n\n    //scan the feed\n    check()\n  }\n\n  function read (_abort, _cb) {\n    abort = abort || _abort; cb = _cb; next()\n  }\n\n  read.add = function (stream) {\n    if(!stream) {\n      //the stream will now end when all the streams end.\n      capped = true\n      //we just changed state, so we may need to cb\n      return next()\n    }\n    inputs.push(create(stream))\n    next()\n  }\n\n  read.cap = function (err) {\n    read.add(null)\n  }\n\n  return read\n}\n","var u      = require('pull-core')\nvar sources = require('./sources')\nvar sinks = require('./sinks')\n\nvar prop   = u.prop\nvar id     = u.id\nvar tester = u.tester\n\nvar map = exports.map = \nfunction (read, map) {\n  map = prop(map) || id\n  return function (end, cb) {\n    read(end, function (end, data) {\n      var data = !end ? map(data) : null\n      cb(end, data)\n    })\n  }\n}\n\nvar asyncMap = exports.asyncMap =\nfunction (read, map) {\n  if(!map) return read\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    read(null, function (end, data) {\n      if(end) return cb(end, data)\n      map(data, cb)\n    })\n  }\n}\n\nvar paraMap = exports.paraMap =\nfunction (read, map, width) {\n  if(!map) return read\n  var ended = false, queue = [], _cb\n\n  function drain () {\n    if(!_cb) return\n    var cb = _cb\n    _cb = null\n    if(queue.length)\n      return cb(null, queue.shift())\n    else if(ended && !n)\n      return cb(ended)\n    _cb = cb\n  }\n\n  function pull () {\n    read(null, function (end, data) {\n      if(end) {\n        ended = end\n        return drain()\n      }\n      n++\n      map(data, function (err, data) {\n        n--\n\n        queue.push(data)\n        drain()\n      })\n\n      if(n < width && !ended)\n        pull()\n    })\n  }\n\n  var n = 0\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    //continue to read while there are less than 3 maps in flight\n    _cb = cb\n    if(queue.length || ended)\n      pull(), drain()\n    else pull()\n  }\n  return highWaterMark(asyncMap(read, map), width)\n}\n\nvar filter = exports.filter =\nfunction (read, test) {\n  //regexp\n  test = tester(test)\n  return function next (end, cb) {\n    read(end, function (end, data) {\n      if(!end && !test(data))\n        return next(end, cb)\n      cb(end, data)\n    })\n  }\n}\n\nvar filterNot = exports.filterNot =\nfunction (read, test) {\n  test = tester(test)\n  return filter(read, function (e) {\n    return !test(e)\n  })\n}\n\nvar through = exports.through = \nfunction (read, op, onEnd) {\n  var a = false\n  function once (abort) {\n    if(a || !onEnd) return\n    a = true\n    onEnd(abort === true ? null : abort)\n  }\n\n  return function (end, cb) {\n    if(end) once(end)\n    return read(end, function (end, data) {\n      if(!end) op && op(data)\n      else once(end)\n      cb(end, data)\n    })\n  }\n}\n\nvar take = exports.take =\nfunction (read, test) {\n  var ended = false\n  if('number' === typeof test) {\n    var n = test; test = function () {\n      return n --\n    }\n  }\n\n  return function (end, cb) {\n    if(ended) return cb(ended)\n    if(ended = end) return read(ended, cb)\n\n    read(null, function (end, data) {\n      if(ended = ended || end) return cb(ended)\n      if(!test(data)) {\n        ended = true\n        read(true, function (end, data) {\n          cb(ended, data)\n        })\n      }\n      else\n        cb(null, data)\n    })\n  }\n}\n\nvar unique = exports.unique = function (read, field, invert) {\n  field = prop(field) || id\n  var seen = {}\n  return filter(read, function (data) {\n    var key = field(data)\n    if(seen[key]) return !!invert //false, by default\n    else seen[key] = true\n    return !invert //true by default\n  })\n}\n\nvar nonUnique = exports.nonUnique = function (read, field) {\n  return unique(read, field, true)\n}\n\nvar group = exports.group =\nfunction (read, size) {\n  var ended; size = size || 5\n  var queue = []\n\n  return function (end, cb) {\n    //this means that the upstream is sending an error.\n    if(end) return read(ended = end, cb)\n    //this means that we read an end before.\n    if(ended) return cb(ended)\n\n    read(null, function next(end, data) {\n      if(ended = ended || end) {\n        if(!queue.length)\n          return cb(ended)\n\n        var _queue = queue; queue = []\n        return cb(null, _queue)\n      }\n      queue.push(data)\n      if(queue.length < size)\n        return read(null, next)\n\n      var _queue = queue; queue = []\n      cb(null, _queue)\n    })\n  }\n}\n\nvar flatten = exports.flatten = function (read) {\n  var _read\n  return function (abort, cb) {\n    if(_read) nextChunk()\n    else      nextStream()\n\n    function nextChunk () {\n      _read(null, function (end, data) {\n        if(end) nextStream()\n        else    cb(null, data)\n      })\n    }\n    function nextStream () {\n      read(null, function (end, stream) {\n        if(end)\n          return cb(end)\n        if(Array.isArray(stream))\n          stream = sources.values(stream)\n        else if('function' != typeof stream)\n          throw new Error('expected stream of streams')\n        \n        _read = stream\n        nextChunk()\n      })\n    }\n  }\n}\n\nvar prepend =\nexports.prepend =\nfunction (read, head) {\n\n  return function (abort, cb) {\n    if(head !== null) {\n      if(abort)\n        return read(abort, cb)\n      var _head = head\n      head = null\n      cb(null, _head)\n    } else {\n      read(abort, cb)\n    }\n  }\n\n}\n\n//var drainIf = exports.drainIf = function (op, done) {\n//  sinks.drain(\n//}\n\nvar _reduce = exports._reduce = function (read, reduce, initial) {\n  return function (close, cb) {\n    if(close) return read(close, cb)\n    if(ended) return cb(ended)\n\n    sinks.drain(function (item) {\n      initial = reduce(initial, item)\n    }, function (err, data) {\n      ended = err || true\n      if(!err) cb(null, initial)\n      else     cb(ended)\n    })\n    (read)\n  }\n}\n\nvar nextTick = process.nextTick\n\nvar highWaterMark = exports.highWaterMark = \nfunction (read, highWaterMark) {\n  var buffer = [], waiting = [], ended, reading = false\n  highWaterMark = highWaterMark || 10\n\n  function readAhead () {\n    while(waiting.length && (buffer.length || ended))\n      waiting.shift()(ended, ended ? null : buffer.shift())\n  }\n\n  function next () {\n    if(ended || reading || buffer.length >= highWaterMark)\n      return\n    reading = true\n    return read(ended, function (end, data) {\n      reading = false\n      ended = ended || end\n      if(data != null) buffer.push(data)\n      \n      next(); readAhead()\n    })\n  }\n\n  nextTick(next)\n\n  return function (end, cb) {\n    ended = ended || end\n    waiting.push(cb)\n\n    next(); readAhead()\n  }\n}\n\n\n\n","'use strict'\n\n//a pair of pull streams where one drains from the other\nmodule.exports = function () {\n  var _read, waiting\n  function sink (read) {\n    if('function' !== typeof read)\n      throw new Error('read must be function')\n\n    if(_read)\n      throw new Error('already piped')\n    _read = read\n    if(waiting) {\n      var _waiting = waiting\n      waiting = null\n      _read.apply(null, _waiting)\n    }\n  }\n  function source (abort, cb) {\n    if(_read)\n      _read(abort, cb)\n    else\n      waiting = [abort, cb]\n  }\n\n  return {\n    source: source, sink: sink\n  }\n}\n\n","module.exports = function (map, width) {\n  var reading = false, abort\n  return function (read) {\n    var i = 0, j = 0, last = 0\n    var seen = [], started = false, ended = false, _cb, error\n\n    function drain () {\n      if(_cb) {\n        var cb = _cb\n        if(error) {\n          _cb = null\n          return cb(error)\n        }\n        if(Object.hasOwnProperty.call(seen, j)) {\n          _cb = null\n          var data = seen[j]; delete seen[j]; j++\n          cb(null, data)\n          if(width) start()\n        } else if(j >= last && ended) {\n          _cb = null\n          cb(true)\n        }\n      }\n    }\n\n    function start () {\n      started = true\n      if(ended) return drain()\n      if(reading || width && (i - width >= j)) return\n      reading = true\n      read(abort, function (end, data) {\n        reading = false\n        if(end) {\n          last = i; ended = end\n          drain()\n        } else {\n          var k = i++\n\n          map(data, function (err, data) {\n            seen[k] = data\n            if(err) error = err\n            drain()\n          })\n\n          if(!ended)\n            start()\n\n        }\n      })\n    }\n\n    return function (_abort, cb) {\n      if(_abort) {\n        return read(ended = abort = _abort, function (err) {\n          if(_cb) return cb(err)\n        })\n      }\n      _cb = cb\n      if(!started) start()\n      drain()\n    }\n  }\n}\n\n","var Pushable = require('pull-pushable')\nvar Stats = require('statistics')\nvar pull = require('pull-stream')\n\nmodule.exports = function (opts) {\n  var timeout = opts && opts.timeout || 5*60*1000 //default: 5 minutes\n  var serve = false, timer\n  var source = Pushable()\n  var rtt = Stats(), skew = Stats()\n\n  function ping () {\n    //serve the ping pong, opponent\n    //will volley it back to us, keeping connection alive\n    //and revealing clock skew.\n    serve = true\n    source.push(ts = Date.now())\n  }\n\n  //we send the first ping\n  if(opts && opts.serve) ping()\n\n  return {\n    source: source,\n    sink: pull.drain(function (remote_ts) {\n      if(serve) {\n        var ts2 = Date.now()\n        rtt.value(ts2 - ts)\n        //if their time is behind half a round trip behing ts2\n        //consider that to be negative skew.\n        skew.value(remote_ts - ((ts2 + ts)/2))\n        serve = false\n      }\n      else {\n        //volley timestamp back to opponent.\n        source.push(ts = Date.now())\n        //we'll serve next time.\n        timer = setTimeout(ping, timeout)\n      }\n    }, function (err) {\n      clearTimeout(timer)\n    }),\n    rtt: rtt, skew: skew\n  }\n\n}\n","module.exports = function (onClose) {\n  var buffer = [], ended, abort, cb\n\n  function callback (err, val) {\n    var _cb = cb\n    if(err && onClose) {\n      var c = onClose\n      onClose = null\n      c(err === true ? null : err)\n    }\n    cb = null\n    _cb(err, val)\n\n  }\n\n  function drain() {\n    if(!cb) return\n\n    if(abort)                        callback(abort)\n    else if(!buffer.length && ended) callback(ended)\n    else if(buffer.length)           callback(null, buffer.shift())\n  }\n\n  function read (_abort, _cb) {\n    if(_abort) {\n      abort = _abort\n      //if there is already a cb waiting, abort it.\n      if(cb) callback(abort)\n    }\n    cb = _cb\n    drain()\n  }\n\n  read.push = function (data) {\n    if(ended) return\n    buffer.push(data)\n    drain()\n  }\n\n  read.end = function (end) {\n    ended = ended || end || true;\n    drain()\n  }\n\n  return read\n}\n\n\n","\nvar BufferList = require('bl')\n\nmodule.exports = function () {\n\n  var bl = new BufferList()\n\n  function get (n) {\n    var len = n == null ? bl.length : n\n    var data = bl.slice(0, len)\n    bl.consume(n)\n    return data\n  }\n\n  return {\n    data: bl,\n    add: function (data) {\n      bl.append(data)\n      return this\n    },\n    has: function (n) {\n      if(n == null) return bl.length > 0\n      return bl.length >= n\n\n    },\n    get: function (n) {\n      if(n == null) return get()\n      if(!this.has(n))\n        throw new Error(\n          'current length is:'+bl.length\n          + ', could not get:'+n + ' bytes'\n        )\n      return get(n)\n    }\n  }\n\n  var soFar = new Buffer(0)\n\n  return {\n    data: soFar,\n    add: function (data) {\n      if(!Buffer.isBuffer(data))\n        throw new Error('data must be a buffer, was: ' + JSON.stringify(data))\n      this.data = soFar = Buffer.concat([soFar, data])\n      return this\n    },\n    has: function (n) {\n      if(null == n) return soFar.length > 0\n      return soFar.length - (n || 0) >= 0\n    },\n    get: function (n) {\n      var next\n      if(null == n) {\n        next = soFar\n        soFar = new Buffer(0)\n        return next\n      }\n      next = soFar.slice(0, n)\n      if(soFar.length < n) throw new Error('current length is:'+soFar.length + ', could not get:'+n + ' bytes')\n      soFar = soFar.slice(n, soFar.length)\n      return next\n    }\n  }\n\n}\n","'use strict'\nvar State = require('./bl-state')\n\nfunction isInteger (i) {\n  return Number.isFinite(i)\n}\n\nfunction isFunction (f) {\n  return 'function' === typeof f\n}\n\nfunction maxDelay(fn, delay) {\n  if(!delay) return fn\n  return function (a, cb) {\n    var timer = setTimeout(function () {\n      fn(new Error('pull-reader: read exceeded timeout'), cb)\n    }, delay)\n    fn(a, function (err, value) {\n      clearTimeout(timer)\n      cb(err, value)\n    })\n\n  }\n\n}\n\nmodule.exports = function (timeout) {\n\n  var queue = [], read, readTimed, reading = false\n  var state = State(), ended, streaming, abort\n\n  function drain () {\n    while (queue.length) {\n      if(null == queue[0].length && state.has(1)) {\n        queue.shift().cb(null, state.get())\n      }\n      else if(state.has(queue[0].length)) {\n        var next = queue.shift()\n        next.cb(null, state.get(next.length))\n      }\n      else if(ended)\n        queue.shift().cb(ended)\n      else\n        return !!queue.length\n    }\n    //always read a little data\n    return queue.length || !state.has(1) || abort\n  }\n\n  function more () {\n    var d = drain()\n    if(d && !reading)\n    if(read && !reading && !streaming) {\n      reading = true\n      readTimed (null, function (err, data) {\n        reading = false\n        if(err) {\n          ended = err\n          return drain()\n        }\n        state.add(data)\n        more()\n      })\n    }\n  }\n\n  function reader (_read) {\n    if(abort) {\n      while(queue.length) queue.shift().cb(abort)\n      return cb && cb(abort)\n    }\n    readTimed = maxDelay(_read, timeout)\n    read = _read\n    more()\n  }\n\n  reader.abort = function (err, cb) {\n    abort = err || true\n    if(read) {\n      reading = true\n      read(abort, function () {\n        while(queue.length) queue.shift().cb(abort)\n        cb && cb(abort)\n      })\n    }\n    else\n      cb()\n  }\n\n  reader.read = function (len, timeout, cb) {\n    if(isFunction(timeout))\n      cb = timeout, timeout = 0\n    if(isFunction(cb)) {\n      queue.push({length: isInteger(len) ? len : null, cb: cb})\n      more()\n    }\n    else {\n      //switch into streaming mode for the rest of the stream.\n      streaming = true\n      //wait for the current read to complete\n      return function (abort, cb) {\n        //if there is anything still in the queue,\n        if(reading || state.has(1)) {\n          if(abort) return read(abort, cb)\n          queue.push({length: null, cb: cb})\n          more()\n        }\n        else\n          maxDelay(read, timeout)(abort, function (err, data) {\n            cb(err, data)\n          })\n      }\n    }\n  }\n\n  return reader\n}\n\n\n\n","var pull = require('pull-stream')\nvar splitter = require('pull-split')\n\nmodule.exports = function (ps, _JSON, opts) {\n  _JSON = _JSON || JSON\n  opts = opts || {}\n  var separator = opts.separator || '\\n'\n  return {\n    sink: pull(\n      splitter(separator),\n      pull.map(function(data) {\n        if (data === '')\n          return data\n        try { return _JSON.parse(data) }\n        catch (e) {\n          if (!opts.ignoreErrors)\n            throw e\n        }\n      }),\n      pull.filter(),\n      ps.sink\n    ),\n    source: pull(\n      ps.source,\n      pull.map(function(data) {\n        if (data !== void 0)\n          return _JSON.stringify(data) + separator\n      })\n    )\n  }\n}\n","var u      = require('pull-core')\nvar sources = require('./sources')\nvar sinks = require('./sinks')\n\nvar prop   = u.prop\nvar id     = u.id\nvar tester = u.tester\n\nvar map = exports.map =\nfunction (read, map) {\n  map = prop(map) || id\n  return function (abort, cb) {\n    read(abort, function (end, data) {\n      try {\n      data = !end ? map(data) : null\n      } catch (err) {\n        return read(err, function () {\n          return cb(err)\n        })\n      }\n      cb(end, data)\n    })\n  }\n}\n\nvar asyncMap = exports.asyncMap =\nfunction (read, map) {\n  if(!map) return read\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    read(null, function (end, data) {\n      if(end) return cb(end, data)\n      map(data, cb)\n    })\n  }\n}\n\nvar paraMap = exports.paraMap =\nfunction (read, map, width) {\n  if(!map) return read\n  var ended = false, queue = [], _cb\n\n  function drain () {\n    if(!_cb) return\n    var cb = _cb\n    _cb = null\n    if(queue.length)\n      return cb(null, queue.shift())\n    else if(ended && !n)\n      return cb(ended)\n    _cb = cb\n  }\n\n  function pull () {\n    read(null, function (end, data) {\n      if(end) {\n        ended = end\n        return drain()\n      }\n      n++\n      map(data, function (err, data) {\n        n--\n\n        queue.push(data)\n        drain()\n      })\n\n      if(n < width && !ended)\n        pull()\n    })\n  }\n\n  var n = 0\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    //continue to read while there are less than 3 maps in flight\n    _cb = cb\n    if(queue.length || ended)\n      pull(), drain()\n    else pull()\n  }\n  return highWaterMark(asyncMap(read, map), width)\n}\n\nvar filter = exports.filter =\nfunction (read, test) {\n  //regexp\n  test = tester(test)\n  return function next (end, cb) {\n    var sync, loop = true\n    while(loop) {\n      loop = false\n      sync = true\n      read(end, function (end, data) {\n        if(!end && !test(data))\n          return sync ? loop = true : next(end, cb)\n        cb(end, data)\n      })\n      sync = false\n    }\n  }\n}\n\nvar filterNot = exports.filterNot =\nfunction (read, test) {\n  test = tester(test)\n  return filter(read, function (e) {\n    return !test(e)\n  })\n}\n\nvar through = exports.through =\nfunction (read, op, onEnd) {\n  var a = false\n  function once (abort) {\n    if(a || !onEnd) return\n    a = true\n    onEnd(abort === true ? null : abort)\n  }\n\n  return function (end, cb) {\n    if(end) once(end)\n    return read(end, function (end, data) {\n      if(!end) op && op(data)\n      else once(end)\n      cb(end, data)\n    })\n  }\n}\n\nvar take = exports.take =\nfunction (read, test) {\n  var ended = false\n  if('number' === typeof test) {\n    var n = test; test = function () {\n      return n --\n    }\n  }\n\n  return function (end, cb) {\n    if(ended) return cb(ended)\n    if(ended = end) return read(ended, cb)\n\n    read(null, function (end, data) {\n      if(ended = ended || end) return cb(ended)\n      if(!test(data)) {\n        ended = true\n        read(true, function (end, data) {\n          cb(ended, data)\n        })\n      }\n      else\n        cb(null, data)\n    })\n  }\n}\n\nvar unique = exports.unique = function (read, field, invert) {\n  field = prop(field) || id\n  var seen = {}\n  return filter(read, function (data) {\n    var key = field(data)\n    if(seen[key]) return !!invert //false, by default\n    else seen[key] = true\n    return !invert //true by default\n  })\n}\n\nvar nonUnique = exports.nonUnique = function (read, field) {\n  return unique(read, field, true)\n}\n\nvar group = exports.group =\nfunction (read, size) {\n  var ended; size = size || 5\n  var queue = []\n\n  return function (end, cb) {\n    //this means that the upstream is sending an error.\n    if(end) return read(ended = end, cb)\n    //this means that we read an end before.\n    if(ended) return cb(ended)\n\n    read(null, function next(end, data) {\n      if(ended = ended || end) {\n        if(!queue.length)\n          return cb(ended)\n\n        var _queue = queue; queue = []\n        return cb(null, _queue)\n      }\n      queue.push(data)\n      if(queue.length < size)\n        return read(null, next)\n\n      var _queue = queue; queue = []\n      cb(null, _queue)\n    })\n  }\n}\n\nvar flatten = exports.flatten = function (read) {\n  var _read\n  return function (abort, cb) {\n    if(_read) nextChunk()\n    else      nextStream()\n\n    function nextChunk () {\n      _read(null, function (end, data) {\n        if(end) nextStream()\n        else    cb(null, data)\n      })\n    }\n    function nextStream () {\n      read(null, function (end, stream) {\n        if(end)\n          return cb(end)\n        if(Array.isArray(stream) || stream && 'object' === typeof stream)\n          stream = sources.values(stream)\n        else if('function' != typeof stream)\n          throw new Error('expected stream of streams')\n        _read = stream\n        nextChunk()\n      })\n    }\n  }\n}\n\nvar prepend =\nexports.prepend =\nfunction (read, head) {\n\n  return function (abort, cb) {\n    if(head !== null) {\n      if(abort)\n        return read(abort, cb)\n      var _head = head\n      head = null\n      cb(null, _head)\n    } else {\n      read(abort, cb)\n    }\n  }\n\n}\n\n//var drainIf = exports.drainIf = function (op, done) {\n//  sinks.drain(\n//}\n\nvar _reduce = exports._reduce = function (read, reduce, initial) {\n  return function (close, cb) {\n    if(close) return read(close, cb)\n    if(ended) return cb(ended)\n\n    sinks.drain(function (item) {\n      initial = reduce(initial, item)\n    }, function (err, data) {\n      ended = err || true\n      if(!err) cb(null, initial)\n      else     cb(ended)\n    })\n    (read)\n  }\n}\n\nvar nextTick = process.nextTick\n\nvar highWaterMark = exports.highWaterMark =\nfunction (read, highWaterMark) {\n  var buffer = [], waiting = [], ended, ending, reading = false\n  highWaterMark = highWaterMark || 10\n\n  function readAhead () {\n    while(waiting.length && (buffer.length || ended))\n      waiting.shift()(ended, ended ? null : buffer.shift())\n\n    if (!buffer.length && ending) ended = ending;\n  }\n\n  function next () {\n    if(ended || ending || reading || buffer.length >= highWaterMark)\n      return\n    reading = true\n    return read(ended || ending, function (end, data) {\n      reading = false\n      ending = ending || end\n      if(data != null) buffer.push(data)\n\n      next(); readAhead()\n    })\n  }\n\n  process.nextTick(next)\n\n  return function (end, cb) {\n    ended = ended || end\n    waiting.push(cb)\n\n    next(); readAhead()\n  }\n}\n\nvar flatMap = exports.flatMap =\nfunction (read, mapper) {\n  mapper = mapper || id\n  var queue = [], ended\n\n  return function (abort, cb) {\n    if(queue.length) return cb(null, queue.shift())\n    else if(ended)   return cb(ended)\n\n    read(abort, function next (end, data) {\n      if(end) ended = end\n      else {\n        var add = mapper(data)\n        while(add && add.length)\n          queue.push(add.shift())\n      }\n\n      if(queue.length) cb(null, queue.shift())\n      else if(ended)   cb(ended)\n      else             read(null, next)\n    })\n  }\n}\n\n","\nmodule.exports = function (create) {\n  var reader = null\n  return function (read) {\n    if('function' !== typeof read) throw new Error('read must be function')\n    return function (abort, cb) {\n      if(abort) (reader ? reader.abort : read)(abort, cb)\n      else if(!reader) (reader = create(cb))(read)\n      else //there will only be one value, so assume this is the end\n        cb(true)\n    }\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n","var through = require('pull-through')\n\nmodule.exports = function split (matcher, mapper, reverse) {\n  var soFar = ''\n  if('function' === typeof matcher)\n    mapper = matcher, matcher = null\n  if (!matcher)\n    matcher = '\\n'\n\n  return through(function (buffer) {\n    var stream = this\n      , pieces = ( reverse\n        ? buffer + soFar\n        : soFar + buffer\n      ).split(matcher)\n\n    soFar = reverse ? pieces.shift() : pieces.pop()\n\n    var l = pieces.length\n    for (var i = 0; i < l; i++) {\n      var piece = pieces[reverse ? l - 1 - i : i ]\n      if(mapper) {\n        piece = mapper(piece)\n        if('undefined' !== typeof piece)\n          stream.queue(piece)\n      }\n      else\n        stream.queue(piece)\n    }\n  },\n  function () {\n    if(soFar != null)\n      this.queue(soFar)\n    this.queue(null)\n  })\n}\n\n","\nvar keys = exports.keys =\nfunction (object) {\n  return values(Object.keys(object))\n}\n\nfunction abortCb(cb, abort, onAbort) {\n  cb(abort)\n  onAbort && onAbort(abort === true ? null: abort)\n  return\n}\n\nvar once = exports.once =\nfunction (value, onAbort) {\n  return function (abort, cb) {\n    if(abort)\n      return abortCb(cb, abort, onAbort)\n    if(value != null) {\n      var _value = value; value = null\n      cb(null, _value)\n    } else\n      cb(true)\n  }\n}\n\nvar values = exports.values = exports.readArray =\nfunction (array, onAbort) {\n  if(!array)\n    return function (abort, cb) {\n      if(abort) return abortCb(cb, abort, onAbort)\n      return cb(true)\n    }\n  if(!Array.isArray(array))\n    array = Object.keys(array).map(function (k) {\n      return array[k]\n    })\n  var i = 0\n  return function (abort, cb) {\n    if(abort)\n      return abortCb(cb, abort, onAbort)\n    cb(i >= array.length || null, array[i++])\n  }\n}\n\n\nvar count = exports.count =\nfunction (max) {\n  var i = 0; max = max || Infinity\n  return function (end, cb) {\n    if(end) return cb && cb(end)\n    if(i > max)\n      return cb(true)\n    cb(null, i++)\n  }\n}\n\nvar infinite = exports.infinite =\nfunction (generate) {\n  generate = generate || Math.random\n  return function (end, cb) {\n    if(end) return cb && cb(end)\n    return cb(null, generate())\n  }\n}\n\nvar defer = exports.defer = function () {\n  var _read, cbs = [], _end\n\n  var read = function (end, cb) {\n    if(!_read) {\n      _end = end\n      cbs.push(cb)\n    } \n    else _read(end, cb)\n  }\n  read.resolve = function (read) {\n    if(_read) throw new Error('already resolved')\n    _read = read\n    if(!_read) throw new Error('no read cannot resolve!' + _read)\n    while(cbs.length)\n      _read(_end, cbs.shift())\n  }\n  read.abort = function(err) {\n    read.resolve(function (_, cb) {\n      cb(err || true)\n    })\n  }\n  return read\n}\n\nvar empty = exports.empty = function () {\n  return function (abort, cb) {\n    cb(true)\n  }\n}\n\nvar error = exports.error = function (err) {\n  return function (abort, cb) {\n    cb(err)\n  }\n}\n\nvar depthFirst = exports.depthFirst =\nfunction (start, createStream) {\n  var reads = []\n\n  reads.unshift(once(start))\n\n  return function next (end, cb) {\n    if(!reads.length)\n      return cb(true)\n    reads[0](end, function (end, data) {\n      if(end) {\n        //if this stream has ended, go to the next queue\n        reads.shift()\n        return next(null, cb)\n      }\n      reads.unshift(createStream(data))\n      cb(end, data)\n    })\n  }\n}\n//width first is just like depth first,\n//but push each new stream onto the end of the queue\nvar widthFirst = exports.widthFirst =\nfunction (start, createStream) {\n  var reads = []\n\n  reads.push(once(start))\n\n  return function next (end, cb) {\n    if(!reads.length)\n      return cb(true)\n    reads[0](end, function (end, data) {\n      if(end) {\n        reads.shift()\n        return next(null, cb)\n      }\n      reads.push(createStream(data))\n      cb(end, data)\n    })\n  }\n}\n\n//this came out different to the first (strm)\n//attempt at leafFirst, but it's still a valid\n//topological sort.\nvar leafFirst = exports.leafFirst =\nfunction (start, createStream) {\n  var reads = []\n  var output = []\n  reads.push(once(start))\n\n  return function next (end, cb) {\n    reads[0](end, function (end, data) {\n      if(end) {\n        reads.shift()\n        if(!output.length)\n          return cb(true)\n        return cb(null, output.shift())\n      }\n      reads.unshift(createStream(data))\n      output.unshift(data)\n      next(null, cb)\n    })\n  }\n}\n\n","var u      = require('pull-core')\nvar sources = require('./sources')\nvar sinks = require('./sinks')\n\nvar prop   = u.prop\nvar id     = u.id\nvar tester = u.tester\n\nvar map = exports.map =\nfunction (read, map) {\n  map = prop(map) || id\n  return function (abort, cb) {\n    read(abort, function (end, data) {\n      try {\n      data = !end ? map(data) : null\n      } catch (err) {\n        return read(err, function () {\n          return cb(err)\n        })\n      }\n      cb(end, data)\n    })\n  }\n}\n\nvar asyncMap = exports.asyncMap =\nfunction (read, map) {\n  if(!map) return read\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    read(null, function (end, data) {\n      if(end) return cb(end, data)\n      map(data, cb)\n    })\n  }\n}\n\nvar paraMap = exports.paraMap =\nfunction (read, map, width) {\n  if(!map) return read\n  var ended = false, queue = [], _cb\n\n  function drain () {\n    if(!_cb) return\n    var cb = _cb\n    _cb = null\n    if(queue.length)\n      return cb(null, queue.shift())\n    else if(ended && !n)\n      return cb(ended)\n    _cb = cb\n  }\n\n  function pull () {\n    read(null, function (end, data) {\n      if(end) {\n        ended = end\n        return drain()\n      }\n      n++\n      map(data, function (err, data) {\n        n--\n\n        queue.push(data)\n        drain()\n      })\n\n      if(n < width && !ended)\n        pull()\n    })\n  }\n\n  var n = 0\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    //continue to read while there are less than 3 maps in flight\n    _cb = cb\n    if(queue.length || ended)\n      pull(), drain()\n    else pull()\n  }\n  return highWaterMark(asyncMap(read, map), width)\n}\n\nvar filter = exports.filter =\nfunction (read, test) {\n  //regexp\n  test = tester(test)\n  return function next (end, cb) {\n    var sync, loop = true\n    while(loop) {\n      loop = false\n      sync = true\n      read(end, function (end, data) {\n        if(!end && !test(data))\n          return sync ? loop = true : next(end, cb)\n        cb(end, data)\n      })\n      sync = false\n    }\n  }\n}\n\nvar filterNot = exports.filterNot =\nfunction (read, test) {\n  test = tester(test)\n  return filter(read, function (e) {\n    return !test(e)\n  })\n}\n\nvar through = exports.through =\nfunction (read, op, onEnd) {\n  var a = false\n  function once (abort) {\n    if(a || !onEnd) return\n    a = true\n    onEnd(abort === true ? null : abort)\n  }\n\n  return function (end, cb) {\n    if(end) once(end)\n    return read(end, function (end, data) {\n      if(!end) op && op(data)\n      else once(end)\n      cb(end, data)\n    })\n  }\n}\n\nvar take = exports.take =\nfunction (read, test, opts) {\n  opts = opts || {}\n  var last = opts.last || false // whether the first item for which !test(item) should still pass\n  var ended = false\n  if('number' === typeof test) {\n    last = true\n    var n = test; test = function () {\n      return --n\n    }\n  }\n\n  function terminate (cb) {\n    read(true, function (err) {\n      last = false; cb(err || true)\n    })\n  }\n\n  return function (end, cb) {\n    if(ended)            last ? terminate(cb) : cb(ended)\n    else if(ended = end) read(ended, cb)\n    else\n      read(null, function (end, data) {\n        if(ended = ended || end) {\n          //last ? terminate(cb) :\n          cb(ended)\n        }\n        else if(!test(data)) {\n          ended = true\n          last ? cb(null, data) : terminate(cb)\n        }\n        else\n          cb(null, data)\n      })\n  }\n}\n\nvar unique = exports.unique = function (read, field, invert) {\n  field = prop(field) || id\n  var seen = {}\n  return filter(read, function (data) {\n    var key = field(data)\n    if(seen[key]) return !!invert //false, by default\n    else seen[key] = true\n    return !invert //true by default\n  })\n}\n\nvar nonUnique = exports.nonUnique = function (read, field) {\n  return unique(read, field, true)\n}\n\nvar group = exports.group =\nfunction (read, size) {\n  var ended; size = size || 5\n  var queue = []\n\n  return function (end, cb) {\n    //this means that the upstream is sending an error.\n    if(end) return read(ended = end, cb)\n    //this means that we read an end before.\n    if(ended) return cb(ended)\n\n    read(null, function next(end, data) {\n      if(ended = ended || end) {\n        if(!queue.length)\n          return cb(ended)\n\n        var _queue = queue; queue = []\n        return cb(null, _queue)\n      }\n      queue.push(data)\n      if(queue.length < size)\n        return read(null, next)\n\n      var _queue = queue; queue = []\n      cb(null, _queue)\n    })\n  }\n}\n\nvar flatten = exports.flatten = function (read) {\n  var _read\n  return function (abort, cb) {\n    if (abort) {\n      _read ? _read(abort, function(err) {\n        read(err || abort, cb)\n      }) : read(abort, cb)\n    }\n    else if(_read) nextChunk()\n    else nextStream()\n\n    function nextChunk () {\n      _read(null, function (err, data) {\n        if (err === true) nextStream()\n        else if (err) {\n          read(true, function(abortErr) {\n            // TODO: what do we do with the abortErr?\n            cb(err)\n          })\n        }\n        else cb(null, data)\n      })\n    }\n    function nextStream () {\n      read(null, function (end, stream) {\n        if(end)\n          return cb(end)\n        if(Array.isArray(stream) || stream && 'object' === typeof stream)\n          stream = sources.values(stream)\n        else if('function' != typeof stream)\n          throw new Error('expected stream of streams')\n        _read = stream\n        nextChunk()\n      })\n    }\n  }\n}\n\nvar prepend =\nexports.prepend =\nfunction (read, head) {\n\n  return function (abort, cb) {\n    if(head !== null) {\n      if(abort)\n        return read(abort, cb)\n      var _head = head\n      head = null\n      cb(null, _head)\n    } else {\n      read(abort, cb)\n    }\n  }\n\n}\n\n//var drainIf = exports.drainIf = function (op, done) {\n//  sinks.drain(\n//}\n\nvar _reduce = exports._reduce = function (read, reduce, initial) {\n  return function (close, cb) {\n    if(close) return read(close, cb)\n    if(ended) return cb(ended)\n\n    sinks.drain(function (item) {\n      initial = reduce(initial, item)\n    }, function (err, data) {\n      ended = err || true\n      if(!err) cb(null, initial)\n      else     cb(ended)\n    })\n    (read)\n  }\n}\n\nvar nextTick = process.nextTick\n\nvar highWaterMark = exports.highWaterMark =\nfunction (read, highWaterMark) {\n  var buffer = [], waiting = [], ended, ending, reading = false\n  highWaterMark = highWaterMark || 10\n\n  function readAhead () {\n    while(waiting.length && (buffer.length || ended))\n      waiting.shift()(ended, ended ? null : buffer.shift())\n\n    if (!buffer.length && ending) ended = ending;\n  }\n\n  function next () {\n    if(ended || ending || reading || buffer.length >= highWaterMark)\n      return\n    reading = true\n    return read(ended || ending, function (end, data) {\n      reading = false\n      ending = ending || end\n      if(data != null) buffer.push(data)\n\n      next(); readAhead()\n    })\n  }\n\n  process.nextTick(next)\n\n  return function (end, cb) {\n    ended = ended || end\n    waiting.push(cb)\n\n    next(); readAhead()\n  }\n}\n\nvar flatMap = exports.flatMap =\nfunction (read, mapper) {\n  mapper = mapper || id\n  var queue = [], ended\n\n  return function (abort, cb) {\n    if(queue.length) return cb(null, queue.shift())\n    else if(ended)   return cb(ended)\n\n    read(abort, function next (end, data) {\n      if(end) ended = end\n      else {\n        var add = mapper(data)\n        while(add && add.length)\n          queue.push(add.shift())\n      }\n\n      if(queue.length) cb(null, queue.shift())\n      else if(ended)   cb(ended)\n      else             read(null, next)\n    })\n  }\n}\n\n","var looper = require('looper')\n\nmodule.exports = function (writer, ender) {\n  return function (read) {\n    var queue = [], ended, error\n\n    function enqueue (data) {\n      queue.push(data)\n    }\n\n    writer = writer || function (data) {\n      this.queue(data)\n    }\n\n    ender = ender || function () {\n      this.queue(null)\n    }\n\n    var emitter = {\n      emit: function (event, data) {\n        if(event == 'data') enqueue(data)\n        if(event == 'end')  ended = true, enqueue(null)\n        if(event == 'error') error = data\n      },\n      queue: enqueue\n    }\n    var _cb\n    return function (end, cb) {\n      ended = ended || end\n      if(end)\n        return read(end, function () {\n          if(_cb) {\n            var t = _cb; _cb = null; t(end)\n          }\n          cb(end)\n        })\n\n      _cb = cb\n      looper(function pull (next) {\n        //if it's an error\n        if(!_cb) return\n        cb = _cb\n        if(error) _cb = null, cb(error)\n        else if(queue.length) {\n          var data = queue.shift()\n          _cb = null,cb(data === null, data)\n        }\n        else {\n          read(ended, function (end, data) {\n             //null has no special meaning for pull-stream\n            if(end && end !== true) {\n              error = end; return next()\n            }\n            if(ended = ended || end)  ender.call(emitter)\n            else if(data !== null) {\n              writer.call(emitter, data)\n              if(error || ended)\n                return read(error || ended, function () {\n                  _cb = null; cb(error || ended)\n                })\n            }\n            next(pull)\n          })\n        }\n      })\n    }\n  }\n}\n\n","\nvar looper = module.exports = function (fun) {\n  (function next () {\n    var loop = true, returned = false, sync = false\n    do {\n      sync = true; loop = false\n      fun.call(this, function () {\n        if(sync) loop = true\n        else     next()\n      })\n      sync = false\n    } while(loop)\n  })()\n}\n","\nvar once = exports.once =\nfunction (value) {\n  return function (abort, cb) {\n    if(abort) return cb(abort)\n    if(value != null) {\n      var _value = value; value = null\n      cb(null, _value)\n    } else\n      cb(true)\n  }\n}\n\nvar depthFirst = exports.depthFirst =\nfunction (start, createStream) {\n  var reads = [], ended\n\n  reads.unshift(once(start))\n\n  return function next (end, cb) {\n    if(!reads.length)\n      return cb(true)\n    if(ended)\n      return cb(ended)\n\n    reads[0](end, function (end, data) {\n      if(end) {\n        if(end !== true) {\n          ended = end\n          reads.shift()\n\n          while(reads.length)\n            reads.shift()(end, function () {})\n          \n          return cb(end)\n        }\n        //if this stream has ended, go to the next queue\n        reads.shift()\n        return next(null, cb)\n      }\n      reads.unshift(createStream(data))\n      cb(end, data)\n    })\n  }\n}\n//width first is just like depth first,\n//but push each new stream onto the end of the queue\nvar widthFirst = exports.widthFirst = \nfunction (start, createStream) {\n  var reads = []\n\n  reads.push(once(start))\n\n  return function next (end, cb) {\n    if(!reads.length)\n      return cb(true)\n    reads[0](end, function (end, data) {\n      if(end) {\n        reads.shift()\n        return next(null, cb)\n      }\n      reads.push(createStream(data))\n      cb(end, data)\n    })\n  }\n}\n\n//this came out different to the first (strm)\n//attempt at leafFirst, but it's still a valid\n//topological sort.\nvar leafFirst = exports.leafFirst = \nfunction (start, createStream) {\n  var reads = []\n  var output = []\n  reads.push(once(start))\n  \n  return function next (end, cb) {\n    reads[0](end, function (end, data) {\n      if(end) {\n        reads.shift()\n        if(!output.length)\n          return cb(true)\n        return cb(null, output.shift())\n      }\n      reads.unshift(createStream(data))\n      output.unshift(data)\n      next(null, cb)\n    })\n  }\n}\n\n","\nvar Decode = require('string_decoder').StringDecoder\n\nmodule.exports = function (enc) {\n  var decoder = new Decode(enc), ended\n  return function (read) {\n    return function (abort, cb) {\n      if(ended) return cb(ended)\n      read(abort, function (end, data) {\n        ended = end\n        if(true === end) {\n          if(data = decoder.end()) cb(null, data)\n          else                     cb(true)\n        }\n        else if(end && (true !== end))\n          cb(end)\n        else\n          cb(null, decoder.write(data))\n      })\n    }\n  }\n}\n","var looper = require('looper')\nvar Through = require('pull-core').Through\n\nvar window = module.exports =\nThrough(function (read, init, start) {\n  start = start || function (start, data) {\n    return {start: start, data: data}\n  }\n  var windows = [], output = [], ended = null\n  var data, end\n  var j = 0\n\n  return function (abort, cb) {\n    if(output.length)\n      return cb(null, output.shift())\n    if(ended)\n      return cb(ended)\n    var i = 0\n    var k = j ++\n    read(abort, looper(function (end, data) {\n      var next = this\n      var reduce, update, once = false\n      if(end)\n        ended = end\n\n      function _update (end, _data) {\n        if(once) return\n        once = true\n        delete windows[windows.indexOf(update)]\n        output.push(start(data, _data))\n      }\n\n      if(!ended)\n        update = init(data, _update)\n\n      if(update)\n        windows.push(update)\n      else\n        //don't allow data unless a window started here!\n        once = true\n\n      windows.forEach(function (update, i) {\n        update(end, data)\n      })\n\n      if(output.length)\n        return cb(null, output.shift())\n      else if(ended)\n        return cb(ended)\n      else\n        read(null, next)\n\n  }))\n  }\n})\n\nwindow.recent = function (size, time) {\n  var current = null\n  return window(function (data, cb) {\n    if(current) return\n    current = []\n    var timer\n      \n    function done () {\n      var _current = current\n      current = null\n      clearTimeout(timer)\n      cb(null, _current)\n    }\n\n    if(time)\n      timer = setTimeout(done, time)\n\n    return function (end, data) {\n      if(end) return done()\n      current.push(data)\n      if(size != null && current.length >= size)\n        done()\n    }\n  }, function (_, data) {\n    return data\n  })\n}\n\nwindow.sliding = function (reduce, width) {\n  width = width || 10\n  var k = 0\n  return window(function (data, cb) {\n    var acc\n    var i = 0\n    var l = k++\n    return function (end, data) {\n      if(end) return\n      acc = reduce(acc, data)\n      if(width <= ++ i)\n        cb(null, acc)\n    }\n  })\n}\n","var fs = require('fs')\n\nmodule.exports = function (path, opts, cb) {\n  if('function' == typeof opts)\n    cb = opts, opts = null\n  var flags = opts && opts.flags || 'w'\n  var mode = opts && opts.mode || 0666\n  var pos = 0\n  return function (read) {\n    fs.open(path, flags, mode, function (err, fd) {\n      read(null, function next (end, data) {\n        if(end === true) fs.close(fd, cb)\n        else if(end)     cb(end) //error!\n        else\n          fs.write(fd, data, 0, data.length, pos, function (err, bytes) {\n            if(err) read(err, function () { fs.close(fd, cb) })\n            else    pos += bytes, read(null, next)\n          })\n      })\n    })\n  }\n}\n\n\n","//another idea: buffer 2* the max, but only call write with half of that,\n//this could manage cases where the read ahead is latent. Hmm, we probably\n//shouldn't guess at that here, just handle write latency.\n\n//how would we measure this anyway?\n\nfunction append (array, item) {\n  (array = array || []).push(item)\n  return array\n}\n\nmodule.exports = function (write, reduce, max, cb) {\n  reduce = reduce || append\n  var ended\n  return function (read) {\n    var queue = null, writing = false, length = 0\n\n    function flush () {\n      if(writing) return\n      var _queue = queue\n      queue = null; writing = true; length = 0\n      write(_queue, function (err) {\n        writing = false\n\n        if(ended === true && !length) cb(err)\n        else if(ended && ended !== true) cb(err || ended)\n        else if(err) read(ended = err, cb) //abort upstream.\n        else if(length) flush()\n        else read(null, next)\n      })\n    }\n    function next (end, data) {\n      if(ended) return\n      ended = end\n      if(!ended) {\n        queue = reduce(queue, data)\n        length = (queue && queue.length) || 0\n        if(queue != null) flush()\n        if(length < max) read(null, next)\n      }\n      else if(!writing) cb(ended === true ? null : ended)\n    }\n    read(null, next)\n  }\n}\n\n\n","'use strict';\nvar ws = require('pull-ws')\nvar WebSocket = require('ws')\nvar url = require('url')\n\n\nfunction isFunction (f) {\n  return 'function' === typeof f\n}\n\nexports.connect = function (addr, opts) {\n  var stream\n  if(isFunction(opts)) {\n    var cb = opts\n    var called = false\n    opts = {\n      onOpen: function () {\n        if(called) return\n        called = true\n        cb(null, stream)\n      },\n      onClose: function (err) {\n        if(called) return\n        called = true\n        cb(err)\n      }\n    }\n  }\n  var u = (\n    'string' === typeof addr\n  ? addr\n  : url.format({\n      protocol: 'ws', slashes: true,\n      hostname: addr.host || addr.hostname,\n      port: addr.port,\n      pathname: addr.pathname\n    })\n  )\n\n  var socket = new WebSocket(u)\n  stream = ws(socket)\n  stream.remoteAddress = u\n\n  if (opts && typeof opts.onOpen == 'function') {\n    socket.addEventListener('open', opts.onOpen)\n  }\n  if (opts && typeof opts.onClose == 'function') {\n    socket.addEventListener('close', opts.onClose)\n  }\n\n  stream.close = function (cb) {\n    if (cb && typeof cb == 'function')\n      socket.addEventListener('close', cb)\n    socket.close()\n  }\n\n  return stream\n}\n\n","exports = module.exports = duplex;\n\nexports.source = require('./source');\nexports.sink = require('./sink');\n\nfunction duplex (ws, opts) {\n  return {\n    source: exports.source(ws),\n    sink: exports.sink(ws, opts)\n  };\n};\n","module.exports = function(socket, callback) {\n  var remove = socket && (socket.removeEventListener || socket.removeListener);\n\n  function cleanup () {\n    if (typeof remove == 'function') {\n      remove.call(socket, 'open', handleOpen);\n      remove.call(socket, 'error', handleErr);\n    }\n  }\n\n  function handleOpen(evt) {\n    cleanup(); callback();\n  }\n\n  function handleErr (evt) {\n    cleanup(); callback(evt);\n  }\n\n  // if the socket is closing or closed, return end\n  if (socket.readyState >= 2) {\n    return callback(true);\n  }\n\n  // if open, trigger the callback\n  if (socket.readyState === 1) {\n    return callback();\n  }\n\n  socket.addEventListener('open', handleOpen);\n  socket.addEventListener('error', handleErr);\n};\n","var pull = require('pull-core');\nvar ready = require('./ready');\n\n/**\n  ### `sink(socket, opts?)`\n\n  Create a pull-stream `Sink` that will write data to the `socket`.\n\n  <<< examples/write.js\n\n**/\nmodule.exports = pull.Sink(function(read, socket, opts) {\n  opts = opts || {}\n  var closeOnEnd = opts.closeOnEnd !== false;\n  var onClose = 'function' === typeof opts ? opts : opts.onClose;\n\n  function next(end, data) {\n    // if the stream has ended, simply return\n    if (end) {\n      if (closeOnEnd && socket.readyState <= 1) {\n        if(onClose)\n          socket.addEventListener('close', function (ev) {\n            if(ev.wasClean) onClose()\n            else {\n              var err = new Error('ws error')\n              err.event = ev\n              onClose(err)\n            }\n          });\n\n        socket.close();\n      }\n\n      return;\n    }\n\n    // socket ready?\n    ready(socket, function(end) {\n      if (end) {\n        return read(end, function () {});\n      }\n\n      socket.send(data);\n      process.nextTick(function() {\n        read(null, next);\n      });\n    });\n  }\n\n  read(null, next);\n});\n","var pull = require('pull-core');\nvar ready = require('./ready');\n\n/**\n  ### `source(socket)`\n\n  Create a pull-stream `Source` that will read data from the `socket`.\n\n  <<< examples/read.js\n\n**/\nmodule.exports = pull.Source(function(socket) {\n  var buffer = [];\n  var receiver;\n  var ended;\n\n  socket.addEventListener('message', function(evt) {\n    if (receiver) {\n      return receiver(null, evt.data);\n    }\n\n    buffer.push(evt.data);\n  });\n\n  socket.addEventListener('close', function(evt) {\n    if (ended) return;\n    if (receiver) {\n      return receiver(ended = true);\n    }\n  });\n\n  socket.addEventListener('error', function (evt) {\n    if (ended) return;\n    ended = evt;\n    if (receiver) {\n      receiver(ended);\n    }\n  });\n\n  function read(abort, cb) {\n    receiver = null;\n\n    //if stream has already ended.\n    if (ended)\n      return cb(ended)\n\n    // if ended, abort\n    if (abort) {\n      //this will callback when socket closes\n      receiver = cb\n      return socket.close()\n    }\n\n    ready(socket, function(end) {\n      if (end) {\n        return cb(ended = end);\n      }\n\n      // read from the socket\n      if (ended && ended !== true) {\n        return cb(ended);\n      }\n      else if (buffer.length > 0) {\n        return cb(null, buffer.shift());\n      }\n      else if (ended) {\n        return cb(true);\n      }\n\n      receiver = cb;\n    });\n  };\n\n  return read;\n});\n","/*! https://mths.be/punycode v1.3.2 by @mathias */\n;(function(root) {\n\n\t/** Detect free variables */\n\tvar freeExports = typeof exports == 'object' && exports &&\n\t\t!exports.nodeType && exports;\n\tvar freeModule = typeof module == 'object' && module &&\n\t\t!module.nodeType && module;\n\tvar freeGlobal = typeof global == 'object' && global;\n\tif (\n\t\tfreeGlobal.global === freeGlobal ||\n\t\tfreeGlobal.window === freeGlobal ||\n\t\tfreeGlobal.self === freeGlobal\n\t) {\n\t\troot = freeGlobal;\n\t}\n\n\t/**\n\t * The `punycode` object.\n\t * @name punycode\n\t * @type Object\n\t */\n\tvar punycode,\n\n\t/** Highest positive signed 32-bit float value */\n\tmaxInt = 2147483647, // aka. 0x7FFFFFFF or 2^31-1\n\n\t/** Bootstring parameters */\n\tbase = 36,\n\ttMin = 1,\n\ttMax = 26,\n\tskew = 38,\n\tdamp = 700,\n\tinitialBias = 72,\n\tinitialN = 128, // 0x80\n\tdelimiter = '-', // '\\x2D'\n\n\t/** Regular expressions */\n\tregexPunycode = /^xn--/,\n\tregexNonASCII = /[^\\x20-\\x7E]/, // unprintable ASCII chars + non-ASCII chars\n\tregexSeparators = /[\\x2E\\u3002\\uFF0E\\uFF61]/g, // RFC 3490 separators\n\n\t/** Error messages */\n\terrors = {\n\t\t'overflow': 'Overflow: input needs wider integers to process',\n\t\t'not-basic': 'Illegal input >= 0x80 (not a basic code point)',\n\t\t'invalid-input': 'Invalid input'\n\t},\n\n\t/** Convenience shortcuts */\n\tbaseMinusTMin = base - tMin,\n\tfloor = Math.floor,\n\tstringFromCharCode = String.fromCharCode,\n\n\t/** Temporary variable */\n\tkey;\n\n\t/*--------------------------------------------------------------------------*/\n\n\t/**\n\t * A generic error utility function.\n\t * @private\n\t * @param {String} type The error type.\n\t * @returns {Error} Throws a `RangeError` with the applicable error message.\n\t */\n\tfunction error(type) {\n\t\tthrow RangeError(errors[type]);\n\t}\n\n\t/**\n\t * A generic `Array#map` utility function.\n\t * @private\n\t * @param {Array} array The array to iterate over.\n\t * @param {Function} callback The function that gets called for every array\n\t * item.\n\t * @returns {Array} A new array of values returned by the callback function.\n\t */\n\tfunction map(array, fn) {\n\t\tvar length = array.length;\n\t\tvar result = [];\n\t\twhile (length--) {\n\t\t\tresult[length] = fn(array[length]);\n\t\t}\n\t\treturn result;\n\t}\n\n\t/**\n\t * A simple `Array#map`-like wrapper to work with domain name strings or email\n\t * addresses.\n\t * @private\n\t * @param {String} domain The domain name or email address.\n\t * @param {Function} callback The function that gets called for every\n\t * character.\n\t * @returns {Array} A new string of characters returned by the callback\n\t * function.\n\t */\n\tfunction mapDomain(string, fn) {\n\t\tvar parts = string.split('@');\n\t\tvar result = '';\n\t\tif (parts.length > 1) {\n\t\t\t// In email addresses, only the domain name should be punycoded. Leave\n\t\t\t// the local part (i.e. everything up to `@`) intact.\n\t\t\tresult = parts[0] + '@';\n\t\t\tstring = parts[1];\n\t\t}\n\t\t// Avoid `split(regex)` for IE8 compatibility. See #17.\n\t\tstring = string.replace(regexSeparators, '\\x2E');\n\t\tvar labels = string.split('.');\n\t\tvar encoded = map(labels, fn).join('.');\n\t\treturn result + encoded;\n\t}\n\n\t/**\n\t * Creates an array containing the numeric code points of each Unicode\n\t * character in the string. While JavaScript uses UCS-2 internally,\n\t * this function will convert a pair of surrogate halves (each of which\n\t * UCS-2 exposes as separate characters) into a single code point,\n\t * matching UTF-16.\n\t * @see `punycode.ucs2.encode`\n\t * @see <https://mathiasbynens.be/notes/javascript-encoding>\n\t * @memberOf punycode.ucs2\n\t * @name decode\n\t * @param {String} string The Unicode input string (UCS-2).\n\t * @returns {Array} The new array of code points.\n\t */\n\tfunction ucs2decode(string) {\n\t\tvar output = [],\n\t\t    counter = 0,\n\t\t    length = string.length,\n\t\t    value,\n\t\t    extra;\n\t\twhile (counter < length) {\n\t\t\tvalue = string.charCodeAt(counter++);\n\t\t\tif (value >= 0xD800 && value <= 0xDBFF && counter < length) {\n\t\t\t\t// high surrogate, and there is a next character\n\t\t\t\textra = string.charCodeAt(counter++);\n\t\t\t\tif ((extra & 0xFC00) == 0xDC00) { // low surrogate\n\t\t\t\t\toutput.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000);\n\t\t\t\t} else {\n\t\t\t\t\t// unmatched surrogate; only append this code unit, in case the next\n\t\t\t\t\t// code unit is the high surrogate of a surrogate pair\n\t\t\t\t\toutput.push(value);\n\t\t\t\t\tcounter--;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\toutput.push(value);\n\t\t\t}\n\t\t}\n\t\treturn output;\n\t}\n\n\t/**\n\t * Creates a string based on an array of numeric code points.\n\t * @see `punycode.ucs2.decode`\n\t * @memberOf punycode.ucs2\n\t * @name encode\n\t * @param {Array} codePoints The array of numeric code points.\n\t * @returns {String} The new Unicode string (UCS-2).\n\t */\n\tfunction ucs2encode(array) {\n\t\treturn map(array, function(value) {\n\t\t\tvar output = '';\n\t\t\tif (value > 0xFFFF) {\n\t\t\t\tvalue -= 0x10000;\n\t\t\t\toutput += stringFromCharCode(value >>> 10 & 0x3FF | 0xD800);\n\t\t\t\tvalue = 0xDC00 | value & 0x3FF;\n\t\t\t}\n\t\t\toutput += stringFromCharCode(value);\n\t\t\treturn output;\n\t\t}).join('');\n\t}\n\n\t/**\n\t * Converts a basic code point into a digit/integer.\n\t * @see `digitToBasic()`\n\t * @private\n\t * @param {Number} codePoint The basic numeric code point value.\n\t * @returns {Number} The numeric value of a basic code point (for use in\n\t * representing integers) in the range `0` to `base - 1`, or `base` if\n\t * the code point does not represent a value.\n\t */\n\tfunction basicToDigit(codePoint) {\n\t\tif (codePoint - 48 < 10) {\n\t\t\treturn codePoint - 22;\n\t\t}\n\t\tif (codePoint - 65 < 26) {\n\t\t\treturn codePoint - 65;\n\t\t}\n\t\tif (codePoint - 97 < 26) {\n\t\t\treturn codePoint - 97;\n\t\t}\n\t\treturn base;\n\t}\n\n\t/**\n\t * Converts a digit/integer into a basic code point.\n\t * @see `basicToDigit()`\n\t * @private\n\t * @param {Number} digit The numeric value of a basic code point.\n\t * @returns {Number} The basic code point whose value (when used for\n\t * representing integers) is `digit`, which needs to be in the range\n\t * `0` to `base - 1`. If `flag` is non-zero, the uppercase form is\n\t * used; else, the lowercase form is used. The behavior is undefined\n\t * if `flag` is non-zero and `digit` has no uppercase form.\n\t */\n\tfunction digitToBasic(digit, flag) {\n\t\t//  0..25 map to ASCII a..z or A..Z\n\t\t// 26..35 map to ASCII 0..9\n\t\treturn digit + 22 + 75 * (digit < 26) - ((flag != 0) << 5);\n\t}\n\n\t/**\n\t * Bias adaptation function as per section 3.4 of RFC 3492.\n\t * http://tools.ietf.org/html/rfc3492#section-3.4\n\t * @private\n\t */\n\tfunction adapt(delta, numPoints, firstTime) {\n\t\tvar k = 0;\n\t\tdelta = firstTime ? floor(delta / damp) : delta >> 1;\n\t\tdelta += floor(delta / numPoints);\n\t\tfor (/* no initialization */; delta > baseMinusTMin * tMax >> 1; k += base) {\n\t\t\tdelta = floor(delta / baseMinusTMin);\n\t\t}\n\t\treturn floor(k + (baseMinusTMin + 1) * delta / (delta + skew));\n\t}\n\n\t/**\n\t * Converts a Punycode string of ASCII-only symbols to a string of Unicode\n\t * symbols.\n\t * @memberOf punycode\n\t * @param {String} input The Punycode string of ASCII-only symbols.\n\t * @returns {String} The resulting string of Unicode symbols.\n\t */\n\tfunction decode(input) {\n\t\t// Don't use UCS-2\n\t\tvar output = [],\n\t\t    inputLength = input.length,\n\t\t    out,\n\t\t    i = 0,\n\t\t    n = initialN,\n\t\t    bias = initialBias,\n\t\t    basic,\n\t\t    j,\n\t\t    index,\n\t\t    oldi,\n\t\t    w,\n\t\t    k,\n\t\t    digit,\n\t\t    t,\n\t\t    /** Cached calculation results */\n\t\t    baseMinusT;\n\n\t\t// Handle the basic code points: let `basic` be the number of input code\n\t\t// points before the last delimiter, or `0` if there is none, then copy\n\t\t// the first basic code points to the output.\n\n\t\tbasic = input.lastIndexOf(delimiter);\n\t\tif (basic < 0) {\n\t\t\tbasic = 0;\n\t\t}\n\n\t\tfor (j = 0; j < basic; ++j) {\n\t\t\t// if it's not a basic code point\n\t\t\tif (input.charCodeAt(j) >= 0x80) {\n\t\t\t\terror('not-basic');\n\t\t\t}\n\t\t\toutput.push(input.charCodeAt(j));\n\t\t}\n\n\t\t// Main decoding loop: start just after the last delimiter if any basic code\n\t\t// points were copied; start at the beginning otherwise.\n\n\t\tfor (index = basic > 0 ? basic + 1 : 0; index < inputLength; /* no final expression */) {\n\n\t\t\t// `index` is the index of the next character to be consumed.\n\t\t\t// Decode a generalized variable-length integer into `delta`,\n\t\t\t// which gets added to `i`. The overflow checking is easier\n\t\t\t// if we increase `i` as we go, then subtract off its starting\n\t\t\t// value at the end to obtain `delta`.\n\t\t\tfor (oldi = i, w = 1, k = base; /* no condition */; k += base) {\n\n\t\t\t\tif (index >= inputLength) {\n\t\t\t\t\terror('invalid-input');\n\t\t\t\t}\n\n\t\t\t\tdigit = basicToDigit(input.charCodeAt(index++));\n\n\t\t\t\tif (digit >= base || digit > floor((maxInt - i) / w)) {\n\t\t\t\t\terror('overflow');\n\t\t\t\t}\n\n\t\t\t\ti += digit * w;\n\t\t\t\tt = k <= bias ? tMin : (k >= bias + tMax ? tMax : k - bias);\n\n\t\t\t\tif (digit < t) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tbaseMinusT = base - t;\n\t\t\t\tif (w > floor(maxInt / baseMinusT)) {\n\t\t\t\t\terror('overflow');\n\t\t\t\t}\n\n\t\t\t\tw *= baseMinusT;\n\n\t\t\t}\n\n\t\t\tout = output.length + 1;\n\t\t\tbias = adapt(i - oldi, out, oldi == 0);\n\n\t\t\t// `i` was supposed to wrap around from `out` to `0`,\n\t\t\t// incrementing `n` each time, so we'll fix that now:\n\t\t\tif (floor(i / out) > maxInt - n) {\n\t\t\t\terror('overflow');\n\t\t\t}\n\n\t\t\tn += floor(i / out);\n\t\t\ti %= out;\n\n\t\t\t// Insert `n` at position `i` of the output\n\t\t\toutput.splice(i++, 0, n);\n\n\t\t}\n\n\t\treturn ucs2encode(output);\n\t}\n\n\t/**\n\t * Converts a string of Unicode symbols (e.g. a domain name label) to a\n\t * Punycode string of ASCII-only symbols.\n\t * @memberOf punycode\n\t * @param {String} input The string of Unicode symbols.\n\t * @returns {String} The resulting Punycode string of ASCII-only symbols.\n\t */\n\tfunction encode(input) {\n\t\tvar n,\n\t\t    delta,\n\t\t    handledCPCount,\n\t\t    basicLength,\n\t\t    bias,\n\t\t    j,\n\t\t    m,\n\t\t    q,\n\t\t    k,\n\t\t    t,\n\t\t    currentValue,\n\t\t    output = [],\n\t\t    /** `inputLength` will hold the number of code points in `input`. */\n\t\t    inputLength,\n\t\t    /** Cached calculation results */\n\t\t    handledCPCountPlusOne,\n\t\t    baseMinusT,\n\t\t    qMinusT;\n\n\t\t// Convert the input in UCS-2 to Unicode\n\t\tinput = ucs2decode(input);\n\n\t\t// Cache the length\n\t\tinputLength = input.length;\n\n\t\t// Initialize the state\n\t\tn = initialN;\n\t\tdelta = 0;\n\t\tbias = initialBias;\n\n\t\t// Handle the basic code points\n\t\tfor (j = 0; j < inputLength; ++j) {\n\t\t\tcurrentValue = input[j];\n\t\t\tif (currentValue < 0x80) {\n\t\t\t\toutput.push(stringFromCharCode(currentValue));\n\t\t\t}\n\t\t}\n\n\t\thandledCPCount = basicLength = output.length;\n\n\t\t// `handledCPCount` is the number of code points that have been handled;\n\t\t// `basicLength` is the number of basic code points.\n\n\t\t// Finish the basic string - if it is not empty - with a delimiter\n\t\tif (basicLength) {\n\t\t\toutput.push(delimiter);\n\t\t}\n\n\t\t// Main encoding loop:\n\t\twhile (handledCPCount < inputLength) {\n\n\t\t\t// All non-basic code points < n have been handled already. Find the next\n\t\t\t// larger one:\n\t\t\tfor (m = maxInt, j = 0; j < inputLength; ++j) {\n\t\t\t\tcurrentValue = input[j];\n\t\t\t\tif (currentValue >= n && currentValue < m) {\n\t\t\t\t\tm = currentValue;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Increase `delta` enough to advance the decoder's <n,i> state to <m,0>,\n\t\t\t// but guard against overflow\n\t\t\thandledCPCountPlusOne = handledCPCount + 1;\n\t\t\tif (m - n > floor((maxInt - delta) / handledCPCountPlusOne)) {\n\t\t\t\terror('overflow');\n\t\t\t}\n\n\t\t\tdelta += (m - n) * handledCPCountPlusOne;\n\t\t\tn = m;\n\n\t\t\tfor (j = 0; j < inputLength; ++j) {\n\t\t\t\tcurrentValue = input[j];\n\n\t\t\t\tif (currentValue < n && ++delta > maxInt) {\n\t\t\t\t\terror('overflow');\n\t\t\t\t}\n\n\t\t\t\tif (currentValue == n) {\n\t\t\t\t\t// Represent delta as a generalized variable-length integer\n\t\t\t\t\tfor (q = delta, k = base; /* no condition */; k += base) {\n\t\t\t\t\t\tt = k <= bias ? tMin : (k >= bias + tMax ? tMax : k - bias);\n\t\t\t\t\t\tif (q < t) {\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tqMinusT = q - t;\n\t\t\t\t\t\tbaseMinusT = base - t;\n\t\t\t\t\t\toutput.push(\n\t\t\t\t\t\t\tstringFromCharCode(digitToBasic(t + qMinusT % baseMinusT, 0))\n\t\t\t\t\t\t);\n\t\t\t\t\t\tq = floor(qMinusT / baseMinusT);\n\t\t\t\t\t}\n\n\t\t\t\t\toutput.push(stringFromCharCode(digitToBasic(q, 0)));\n\t\t\t\t\tbias = adapt(delta, handledCPCountPlusOne, handledCPCount == basicLength);\n\t\t\t\t\tdelta = 0;\n\t\t\t\t\t++handledCPCount;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t++delta;\n\t\t\t++n;\n\n\t\t}\n\t\treturn output.join('');\n\t}\n\n\t/**\n\t * Converts a Punycode string representing a domain name or an email address\n\t * to Unicode. Only the Punycoded parts of the input will be converted, i.e.\n\t * it doesn't matter if you call it on a string that has already been\n\t * converted to Unicode.\n\t * @memberOf punycode\n\t * @param {String} input The Punycoded domain name or email address to\n\t * convert to Unicode.\n\t * @returns {String} The Unicode representation of the given Punycode\n\t * string.\n\t */\n\tfunction toUnicode(input) {\n\t\treturn mapDomain(input, function(string) {\n\t\t\treturn regexPunycode.test(string)\n\t\t\t\t? decode(string.slice(4).toLowerCase())\n\t\t\t\t: string;\n\t\t});\n\t}\n\n\t/**\n\t * Converts a Unicode string representing a domain name or an email address to\n\t * Punycode. Only the non-ASCII parts of the domain name will be converted,\n\t * i.e. it doesn't matter if you call it with a domain that's already in\n\t * ASCII.\n\t * @memberOf punycode\n\t * @param {String} input The domain name or email address to convert, as a\n\t * Unicode string.\n\t * @returns {String} The Punycode representation of the given domain name or\n\t * email address.\n\t */\n\tfunction toASCII(input) {\n\t\treturn mapDomain(input, function(string) {\n\t\t\treturn regexNonASCII.test(string)\n\t\t\t\t? 'xn--' + encode(string)\n\t\t\t\t: string;\n\t\t});\n\t}\n\n\t/*--------------------------------------------------------------------------*/\n\n\t/** Define the public API */\n\tpunycode = {\n\t\t/**\n\t\t * A string representing the current Punycode.js version number.\n\t\t * @memberOf punycode\n\t\t * @type String\n\t\t */\n\t\t'version': '1.3.2',\n\t\t/**\n\t\t * An object of methods to convert from JavaScript's internal character\n\t\t * representation (UCS-2) to Unicode code points, and back.\n\t\t * @see <https://mathiasbynens.be/notes/javascript-encoding>\n\t\t * @memberOf punycode\n\t\t * @type Object\n\t\t */\n\t\t'ucs2': {\n\t\t\t'decode': ucs2decode,\n\t\t\t'encode': ucs2encode\n\t\t},\n\t\t'decode': decode,\n\t\t'encode': encode,\n\t\t'toASCII': toASCII,\n\t\t'toUnicode': toUnicode\n\t};\n\n\t/** Expose `punycode` */\n\t// Some AMD build optimizers, like r.js, check for specific condition patterns\n\t// like the following:\n\tif (\n\t\ttypeof define == 'function' &&\n\t\ttypeof define.amd == 'object' &&\n\t\tdefine.amd\n\t) {\n\t\tdefine('punycode', function() {\n\t\t\treturn punycode;\n\t\t});\n\t} else if (freeExports && freeModule) {\n\t\tif (module.exports == freeExports) { // in Node.js or RingoJS v0.8.0+\n\t\t\tfreeModule.exports = punycode;\n\t\t} else { // in Narwhal or RingoJS v0.7.0-\n\t\t\tfor (key in punycode) {\n\t\t\t\tpunycode.hasOwnProperty(key) && (freeExports[key] = punycode[key]);\n\t\t\t}\n\t\t}\n\t} else { // in Rhino or a web browser\n\t\troot.punycode = punycode;\n\t}\n\n}(this));\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\n// If obj.hasOwnProperty has been overridden, then calling\n// obj.hasOwnProperty(prop) will break.\n// See: https://github.com/joyent/node/issues/1707\nfunction hasOwnProperty(obj, prop) {\n  return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nmodule.exports = function(qs, sep, eq, options) {\n  sep = sep || '&';\n  eq = eq || '=';\n  var obj = {};\n\n  if (typeof qs !== 'string' || qs.length === 0) {\n    return obj;\n  }\n\n  var regexp = /\\+/g;\n  qs = qs.split(sep);\n\n  var maxKeys = 1000;\n  if (options && typeof options.maxKeys === 'number') {\n    maxKeys = options.maxKeys;\n  }\n\n  var len = qs.length;\n  // maxKeys <= 0 means that we should not limit keys count\n  if (maxKeys > 0 && len > maxKeys) {\n    len = maxKeys;\n  }\n\n  for (var i = 0; i < len; ++i) {\n    var x = qs[i].replace(regexp, '%20'),\n        idx = x.indexOf(eq),\n        kstr, vstr, k, v;\n\n    if (idx >= 0) {\n      kstr = x.substr(0, idx);\n      vstr = x.substr(idx + 1);\n    } else {\n      kstr = x;\n      vstr = '';\n    }\n\n    k = decodeURIComponent(kstr);\n    v = decodeURIComponent(vstr);\n\n    if (!hasOwnProperty(obj, k)) {\n      obj[k] = v;\n    } else if (isArray(obj[k])) {\n      obj[k].push(v);\n    } else {\n      obj[k] = [obj[k], v];\n    }\n  }\n\n  return obj;\n};\n\nvar isArray = Array.isArray || function (xs) {\n  return Object.prototype.toString.call(xs) === '[object Array]';\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar stringifyPrimitive = function(v) {\n  switch (typeof v) {\n    case 'string':\n      return v;\n\n    case 'boolean':\n      return v ? 'true' : 'false';\n\n    case 'number':\n      return isFinite(v) ? v : '';\n\n    default:\n      return '';\n  }\n};\n\nmodule.exports = function(obj, sep, eq, name) {\n  sep = sep || '&';\n  eq = eq || '=';\n  if (obj === null) {\n    obj = undefined;\n  }\n\n  if (typeof obj === 'object') {\n    return map(objectKeys(obj), function(k) {\n      var ks = encodeURIComponent(stringifyPrimitive(k)) + eq;\n      if (isArray(obj[k])) {\n        return map(obj[k], function(v) {\n          return ks + encodeURIComponent(stringifyPrimitive(v));\n        }).join(sep);\n      } else {\n        return ks + encodeURIComponent(stringifyPrimitive(obj[k]));\n      }\n    }).join(sep);\n\n  }\n\n  if (!name) return '';\n  return encodeURIComponent(stringifyPrimitive(name)) + eq +\n         encodeURIComponent(stringifyPrimitive(obj));\n};\n\nvar isArray = Array.isArray || function (xs) {\n  return Object.prototype.toString.call(xs) === '[object Array]';\n};\n\nfunction map (xs, f) {\n  if (xs.map) return xs.map(f);\n  var res = [];\n  for (var i = 0; i < xs.length; i++) {\n    res.push(f(xs[i], i));\n  }\n  return res;\n}\n\nvar objectKeys = Object.keys || function (obj) {\n  var res = [];\n  for (var key in obj) {\n    if (Object.prototype.hasOwnProperty.call(obj, key)) res.push(key);\n  }\n  return res;\n};\n","'use strict';\n\nexports.decode = exports.parse = require('./decode');\nexports.encode = exports.stringify = require('./encode');\n","'use strict'\n\nfunction oldBrowser () {\n  throw new Error('secure random number generation not supported by this browser\\nuse chrome, FireFox or Internet Explorer 11')\n}\n\nvar crypto = global.crypto || global.msCrypto\n\nif (crypto && crypto.getRandomValues) {\n  module.exports = randomBytes\n} else {\n  module.exports = oldBrowser\n}\n\nfunction randomBytes (size, cb) {\n  // phantomjs needs to throw\n  if (size > 65536) throw new Error('requested too many random bytes')\n  // in case browserify  isn't using the Uint8Array version\n  var rawBytes = new global.Uint8Array(size)\n\n  // This will not work in older browsers.\n  // See https://developer.mozilla.org/en-US/docs/Web/API/window.crypto.getRandomValues\n  if (size > 0) {  // getRandomValues fails on IE if size == 0\n    crypto.getRandomValues(rawBytes)\n  }\n  // phantomjs doesn't like a buffer being passed here\n  var bytes = new Buffer(rawBytes.buffer)\n\n  if (typeof cb === 'function') {\n    return process.nextTick(function () {\n      cb(null, bytes)\n    })\n  }\n\n  return bytes\n}\n","\n// when this is loaded into the browser, \n// just use the defaults...\n\nmodule.exports = function (name, defaults) {\n  return defaults\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// a duplex stream is just a stream that is both readable and writable.\n// Since JS doesn't have multiple prototypal inheritance, this class\n// prototypally inherits from Readable, and then parasitically from\n// Writable.\n\nmodule.exports = Duplex;\n\n/*<replacement>*/\nvar objectKeys = Object.keys || function (obj) {\n  var keys = [];\n  for (var key in obj) keys.push(key);\n  return keys;\n}\n/*</replacement>*/\n\n\n/*<replacement>*/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/*</replacement>*/\n\nvar Readable = require('./_stream_readable');\nvar Writable = require('./_stream_writable');\n\nutil.inherits(Duplex, Readable);\n\nforEach(objectKeys(Writable.prototype), function(method) {\n  if (!Duplex.prototype[method])\n    Duplex.prototype[method] = Writable.prototype[method];\n});\n\nfunction Duplex(options) {\n  if (!(this instanceof Duplex))\n    return new Duplex(options);\n\n  Readable.call(this, options);\n  Writable.call(this, options);\n\n  if (options && options.readable === false)\n    this.readable = false;\n\n  if (options && options.writable === false)\n    this.writable = false;\n\n  this.allowHalfOpen = true;\n  if (options && options.allowHalfOpen === false)\n    this.allowHalfOpen = false;\n\n  this.once('end', onend);\n}\n\n// the no-half-open enforcer\nfunction onend() {\n  // if we allow half-open state, or if the writable side ended,\n  // then we're ok.\n  if (this.allowHalfOpen || this._writableState.ended)\n    return;\n\n  // no more data can be written.\n  // But allow more writes to happen in this tick.\n  process.nextTick(this.end.bind(this));\n}\n\nfunction forEach (xs, f) {\n  for (var i = 0, l = xs.length; i < l; i++) {\n    f(xs[i], i);\n  }\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nmodule.exports = Readable;\n\n/*<replacement>*/\nvar isArray = require('isarray');\n/*</replacement>*/\n\n\n/*<replacement>*/\nvar Buffer = require('buffer').Buffer;\n/*</replacement>*/\n\nReadable.ReadableState = ReadableState;\n\nvar EE = require('events').EventEmitter;\n\n/*<replacement>*/\nif (!EE.listenerCount) EE.listenerCount = function(emitter, type) {\n  return emitter.listeners(type).length;\n};\n/*</replacement>*/\n\nvar Stream = require('stream');\n\n/*<replacement>*/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/*</replacement>*/\n\nvar StringDecoder;\n\n\n/*<replacement>*/\nvar debug = require('util');\nif (debug && debug.debuglog) {\n  debug = debug.debuglog('stream');\n} else {\n  debug = function () {};\n}\n/*</replacement>*/\n\n\nutil.inherits(Readable, Stream);\n\nfunction ReadableState(options, stream) {\n  var Duplex = require('./_stream_duplex');\n\n  options = options || {};\n\n  // the point at which it stops calling _read() to fill the buffer\n  // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n  var hwm = options.highWaterMark;\n  var defaultHwm = options.objectMode ? 16 : 16 * 1024;\n  this.highWaterMark = (hwm || hwm === 0) ? hwm : defaultHwm;\n\n  // cast to ints.\n  this.highWaterMark = ~~this.highWaterMark;\n\n  this.buffer = [];\n  this.length = 0;\n  this.pipes = null;\n  this.pipesCount = 0;\n  this.flowing = null;\n  this.ended = false;\n  this.endEmitted = false;\n  this.reading = false;\n\n  // a flag to be able to tell if the onwrite cb is called immediately,\n  // or on a later tick.  We set this to true at first, because any\n  // actions that shouldn't happen until \"later\" should generally also\n  // not happen before the first write call.\n  this.sync = true;\n\n  // whenever we return null, then we set a flag to say\n  // that we're awaiting a 'readable' event emission.\n  this.needReadable = false;\n  this.emittedReadable = false;\n  this.readableListening = false;\n\n\n  // object stream flag. Used to make read(n) ignore n and to\n  // make all the buffer merging and length checks go away\n  this.objectMode = !!options.objectMode;\n\n  if (stream instanceof Duplex)\n    this.objectMode = this.objectMode || !!options.readableObjectMode;\n\n  // Crypto is kind of old and crusty.  Historically, its default string\n  // encoding is 'binary' so we have to make this configurable.\n  // Everything else in the universe uses 'utf8', though.\n  this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n  // when piping, we only care about 'readable' events that happen\n  // after read()ing all the bytes and not getting any pushback.\n  this.ranOut = false;\n\n  // the number of writers that are awaiting a drain event in .pipe()s\n  this.awaitDrain = 0;\n\n  // if true, a maybeReadMore has been scheduled\n  this.readingMore = false;\n\n  this.decoder = null;\n  this.encoding = null;\n  if (options.encoding) {\n    if (!StringDecoder)\n      StringDecoder = require('string_decoder/').StringDecoder;\n    this.decoder = new StringDecoder(options.encoding);\n    this.encoding = options.encoding;\n  }\n}\n\nfunction Readable(options) {\n  var Duplex = require('./_stream_duplex');\n\n  if (!(this instanceof Readable))\n    return new Readable(options);\n\n  this._readableState = new ReadableState(options, this);\n\n  // legacy\n  this.readable = true;\n\n  Stream.call(this);\n}\n\n// Manually shove something into the read() buffer.\n// This returns true if the highWaterMark has not been hit yet,\n// similar to how Writable.write() returns true if you should\n// write() some more.\nReadable.prototype.push = function(chunk, encoding) {\n  var state = this._readableState;\n\n  if (util.isString(chunk) && !state.objectMode) {\n    encoding = encoding || state.defaultEncoding;\n    if (encoding !== state.encoding) {\n      chunk = new Buffer(chunk, encoding);\n      encoding = '';\n    }\n  }\n\n  return readableAddChunk(this, state, chunk, encoding, false);\n};\n\n// Unshift should *always* be something directly out of read()\nReadable.prototype.unshift = function(chunk) {\n  var state = this._readableState;\n  return readableAddChunk(this, state, chunk, '', true);\n};\n\nfunction readableAddChunk(stream, state, chunk, encoding, addToFront) {\n  var er = chunkInvalid(state, chunk);\n  if (er) {\n    stream.emit('error', er);\n  } else if (util.isNullOrUndefined(chunk)) {\n    state.reading = false;\n    if (!state.ended)\n      onEofChunk(stream, state);\n  } else if (state.objectMode || chunk && chunk.length > 0) {\n    if (state.ended && !addToFront) {\n      var e = new Error('stream.push() after EOF');\n      stream.emit('error', e);\n    } else if (state.endEmitted && addToFront) {\n      var e = new Error('stream.unshift() after end event');\n      stream.emit('error', e);\n    } else {\n      if (state.decoder && !addToFront && !encoding)\n        chunk = state.decoder.write(chunk);\n\n      if (!addToFront)\n        state.reading = false;\n\n      // if we want the data now, just emit it.\n      if (state.flowing && state.length === 0 && !state.sync) {\n        stream.emit('data', chunk);\n        stream.read(0);\n      } else {\n        // update the buffer info.\n        state.length += state.objectMode ? 1 : chunk.length;\n        if (addToFront)\n          state.buffer.unshift(chunk);\n        else\n          state.buffer.push(chunk);\n\n        if (state.needReadable)\n          emitReadable(stream);\n      }\n\n      maybeReadMore(stream, state);\n    }\n  } else if (!addToFront) {\n    state.reading = false;\n  }\n\n  return needMoreData(state);\n}\n\n\n\n// if it's past the high water mark, we can push in some more.\n// Also, if we have no data yet, we can stand some\n// more bytes.  This is to work around cases where hwm=0,\n// such as the repl.  Also, if the push() triggered a\n// readable event, and the user called read(largeNumber) such that\n// needReadable was set, then we ought to push more, so that another\n// 'readable' event will be triggered.\nfunction needMoreData(state) {\n  return !state.ended &&\n         (state.needReadable ||\n          state.length < state.highWaterMark ||\n          state.length === 0);\n}\n\n// backwards compatibility.\nReadable.prototype.setEncoding = function(enc) {\n  if (!StringDecoder)\n    StringDecoder = require('string_decoder/').StringDecoder;\n  this._readableState.decoder = new StringDecoder(enc);\n  this._readableState.encoding = enc;\n  return this;\n};\n\n// Don't raise the hwm > 128MB\nvar MAX_HWM = 0x800000;\nfunction roundUpToNextPowerOf2(n) {\n  if (n >= MAX_HWM) {\n    n = MAX_HWM;\n  } else {\n    // Get the next highest power of 2\n    n--;\n    for (var p = 1; p < 32; p <<= 1) n |= n >> p;\n    n++;\n  }\n  return n;\n}\n\nfunction howMuchToRead(n, state) {\n  if (state.length === 0 && state.ended)\n    return 0;\n\n  if (state.objectMode)\n    return n === 0 ? 0 : 1;\n\n  if (isNaN(n) || util.isNull(n)) {\n    // only flow one buffer at a time\n    if (state.flowing && state.buffer.length)\n      return state.buffer[0].length;\n    else\n      return state.length;\n  }\n\n  if (n <= 0)\n    return 0;\n\n  // If we're asking for more than the target buffer level,\n  // then raise the water mark.  Bump up to the next highest\n  // power of 2, to prevent increasing it excessively in tiny\n  // amounts.\n  if (n > state.highWaterMark)\n    state.highWaterMark = roundUpToNextPowerOf2(n);\n\n  // don't have that much.  return null, unless we've ended.\n  if (n > state.length) {\n    if (!state.ended) {\n      state.needReadable = true;\n      return 0;\n    } else\n      return state.length;\n  }\n\n  return n;\n}\n\n// you can override either this method, or the async _read(n) below.\nReadable.prototype.read = function(n) {\n  debug('read', n);\n  var state = this._readableState;\n  var nOrig = n;\n\n  if (!util.isNumber(n) || n > 0)\n    state.emittedReadable = false;\n\n  // if we're doing read(0) to trigger a readable event, but we\n  // already have a bunch of data in the buffer, then just trigger\n  // the 'readable' event and move on.\n  if (n === 0 &&\n      state.needReadable &&\n      (state.length >= state.highWaterMark || state.ended)) {\n    debug('read: emitReadable', state.length, state.ended);\n    if (state.length === 0 && state.ended)\n      endReadable(this);\n    else\n      emitReadable(this);\n    return null;\n  }\n\n  n = howMuchToRead(n, state);\n\n  // if we've ended, and we're now clear, then finish it up.\n  if (n === 0 && state.ended) {\n    if (state.length === 0)\n      endReadable(this);\n    return null;\n  }\n\n  // All the actual chunk generation logic needs to be\n  // *below* the call to _read.  The reason is that in certain\n  // synthetic stream cases, such as passthrough streams, _read\n  // may be a completely synchronous operation which may change\n  // the state of the read buffer, providing enough data when\n  // before there was *not* enough.\n  //\n  // So, the steps are:\n  // 1. Figure out what the state of things will be after we do\n  // a read from the buffer.\n  //\n  // 2. If that resulting state will trigger a _read, then call _read.\n  // Note that this may be asynchronous, or synchronous.  Yes, it is\n  // deeply ugly to write APIs this way, but that still doesn't mean\n  // that the Readable class should behave improperly, as streams are\n  // designed to be sync/async agnostic.\n  // Take note if the _read call is sync or async (ie, if the read call\n  // has returned yet), so that we know whether or not it's safe to emit\n  // 'readable' etc.\n  //\n  // 3. Actually pull the requested chunks out of the buffer and return.\n\n  // if we need a readable event, then we need to do some reading.\n  var doRead = state.needReadable;\n  debug('need readable', doRead);\n\n  // if we currently have less than the highWaterMark, then also read some\n  if (state.length === 0 || state.length - n < state.highWaterMark) {\n    doRead = true;\n    debug('length less than watermark', doRead);\n  }\n\n  // however, if we've ended, then there's no point, and if we're already\n  // reading, then it's unnecessary.\n  if (state.ended || state.reading) {\n    doRead = false;\n    debug('reading or ended', doRead);\n  }\n\n  if (doRead) {\n    debug('do read');\n    state.reading = true;\n    state.sync = true;\n    // if the length is currently zero, then we *need* a readable event.\n    if (state.length === 0)\n      state.needReadable = true;\n    // call internal read method\n    this._read(state.highWaterMark);\n    state.sync = false;\n  }\n\n  // If _read pushed data synchronously, then `reading` will be false,\n  // and we need to re-evaluate how much data we can return to the user.\n  if (doRead && !state.reading)\n    n = howMuchToRead(nOrig, state);\n\n  var ret;\n  if (n > 0)\n    ret = fromList(n, state);\n  else\n    ret = null;\n\n  if (util.isNull(ret)) {\n    state.needReadable = true;\n    n = 0;\n  }\n\n  state.length -= n;\n\n  // If we have nothing in the buffer, then we want to know\n  // as soon as we *do* get something into the buffer.\n  if (state.length === 0 && !state.ended)\n    state.needReadable = true;\n\n  // If we tried to read() past the EOF, then emit end on the next tick.\n  if (nOrig !== n && state.ended && state.length === 0)\n    endReadable(this);\n\n  if (!util.isNull(ret))\n    this.emit('data', ret);\n\n  return ret;\n};\n\nfunction chunkInvalid(state, chunk) {\n  var er = null;\n  if (!util.isBuffer(chunk) &&\n      !util.isString(chunk) &&\n      !util.isNullOrUndefined(chunk) &&\n      !state.objectMode) {\n    er = new TypeError('Invalid non-string/buffer chunk');\n  }\n  return er;\n}\n\n\nfunction onEofChunk(stream, state) {\n  if (state.decoder && !state.ended) {\n    var chunk = state.decoder.end();\n    if (chunk && chunk.length) {\n      state.buffer.push(chunk);\n      state.length += state.objectMode ? 1 : chunk.length;\n    }\n  }\n  state.ended = true;\n\n  // emit 'readable' now to make sure it gets picked up.\n  emitReadable(stream);\n}\n\n// Don't emit readable right away in sync mode, because this can trigger\n// another read() call => stack overflow.  This way, it might trigger\n// a nextTick recursion warning, but that's not so bad.\nfunction emitReadable(stream) {\n  var state = stream._readableState;\n  state.needReadable = false;\n  if (!state.emittedReadable) {\n    debug('emitReadable', state.flowing);\n    state.emittedReadable = true;\n    if (state.sync)\n      process.nextTick(function() {\n        emitReadable_(stream);\n      });\n    else\n      emitReadable_(stream);\n  }\n}\n\nfunction emitReadable_(stream) {\n  debug('emit readable');\n  stream.emit('readable');\n  flow(stream);\n}\n\n\n// at this point, the user has presumably seen the 'readable' event,\n// and called read() to consume some data.  that may have triggered\n// in turn another _read(n) call, in which case reading = true if\n// it's in progress.\n// However, if we're not ended, or reading, and the length < hwm,\n// then go ahead and try to read some more preemptively.\nfunction maybeReadMore(stream, state) {\n  if (!state.readingMore) {\n    state.readingMore = true;\n    process.nextTick(function() {\n      maybeReadMore_(stream, state);\n    });\n  }\n}\n\nfunction maybeReadMore_(stream, state) {\n  var len = state.length;\n  while (!state.reading && !state.flowing && !state.ended &&\n         state.length < state.highWaterMark) {\n    debug('maybeReadMore read 0');\n    stream.read(0);\n    if (len === state.length)\n      // didn't get any data, stop spinning.\n      break;\n    else\n      len = state.length;\n  }\n  state.readingMore = false;\n}\n\n// abstract method.  to be overridden in specific implementation classes.\n// call cb(er, data) where data is <= n in length.\n// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n// arbitrary, and perhaps not very meaningful.\nReadable.prototype._read = function(n) {\n  this.emit('error', new Error('not implemented'));\n};\n\nReadable.prototype.pipe = function(dest, pipeOpts) {\n  var src = this;\n  var state = this._readableState;\n\n  switch (state.pipesCount) {\n    case 0:\n      state.pipes = dest;\n      break;\n    case 1:\n      state.pipes = [state.pipes, dest];\n      break;\n    default:\n      state.pipes.push(dest);\n      break;\n  }\n  state.pipesCount += 1;\n  debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);\n\n  var doEnd = (!pipeOpts || pipeOpts.end !== false) &&\n              dest !== process.stdout &&\n              dest !== process.stderr;\n\n  var endFn = doEnd ? onend : cleanup;\n  if (state.endEmitted)\n    process.nextTick(endFn);\n  else\n    src.once('end', endFn);\n\n  dest.on('unpipe', onunpipe);\n  function onunpipe(readable) {\n    debug('onunpipe');\n    if (readable === src) {\n      cleanup();\n    }\n  }\n\n  function onend() {\n    debug('onend');\n    dest.end();\n  }\n\n  // when the dest drains, it reduces the awaitDrain counter\n  // on the source.  This would be more elegant with a .once()\n  // handler in flow(), but adding and removing repeatedly is\n  // too slow.\n  var ondrain = pipeOnDrain(src);\n  dest.on('drain', ondrain);\n\n  function cleanup() {\n    debug('cleanup');\n    // cleanup event handlers once the pipe is broken\n    dest.removeListener('close', onclose);\n    dest.removeListener('finish', onfinish);\n    dest.removeListener('drain', ondrain);\n    dest.removeListener('error', onerror);\n    dest.removeListener('unpipe', onunpipe);\n    src.removeListener('end', onend);\n    src.removeListener('end', cleanup);\n    src.removeListener('data', ondata);\n\n    // if the reader is waiting for a drain event from this\n    // specific writer, then it would cause it to never start\n    // flowing again.\n    // So, if this is awaiting a drain, then we just call it now.\n    // If we don't know, then assume that we are waiting for one.\n    if (state.awaitDrain &&\n        (!dest._writableState || dest._writableState.needDrain))\n      ondrain();\n  }\n\n  src.on('data', ondata);\n  function ondata(chunk) {\n    debug('ondata');\n    var ret = dest.write(chunk);\n    if (false === ret) {\n      debug('false write response, pause',\n            src._readableState.awaitDrain);\n      src._readableState.awaitDrain++;\n      src.pause();\n    }\n  }\n\n  // if the dest has an error, then stop piping into it.\n  // however, don't suppress the throwing behavior for this.\n  function onerror(er) {\n    debug('onerror', er);\n    unpipe();\n    dest.removeListener('error', onerror);\n    if (EE.listenerCount(dest, 'error') === 0)\n      dest.emit('error', er);\n  }\n  // This is a brutally ugly hack to make sure that our error handler\n  // is attached before any userland ones.  NEVER DO THIS.\n  if (!dest._events || !dest._events.error)\n    dest.on('error', onerror);\n  else if (isArray(dest._events.error))\n    dest._events.error.unshift(onerror);\n  else\n    dest._events.error = [onerror, dest._events.error];\n\n\n\n  // Both close and finish should trigger unpipe, but only once.\n  function onclose() {\n    dest.removeListener('finish', onfinish);\n    unpipe();\n  }\n  dest.once('close', onclose);\n  function onfinish() {\n    debug('onfinish');\n    dest.removeListener('close', onclose);\n    unpipe();\n  }\n  dest.once('finish', onfinish);\n\n  function unpipe() {\n    debug('unpipe');\n    src.unpipe(dest);\n  }\n\n  // tell the dest that it's being piped to\n  dest.emit('pipe', src);\n\n  // start the flow if it hasn't been started already.\n  if (!state.flowing) {\n    debug('pipe resume');\n    src.resume();\n  }\n\n  return dest;\n};\n\nfunction pipeOnDrain(src) {\n  return function() {\n    var state = src._readableState;\n    debug('pipeOnDrain', state.awaitDrain);\n    if (state.awaitDrain)\n      state.awaitDrain--;\n    if (state.awaitDrain === 0 && EE.listenerCount(src, 'data')) {\n      state.flowing = true;\n      flow(src);\n    }\n  };\n}\n\n\nReadable.prototype.unpipe = function(dest) {\n  var state = this._readableState;\n\n  // if we're not piping anywhere, then do nothing.\n  if (state.pipesCount === 0)\n    return this;\n\n  // just one destination.  most common case.\n  if (state.pipesCount === 1) {\n    // passed in one, but it's not the right one.\n    if (dest && dest !== state.pipes)\n      return this;\n\n    if (!dest)\n      dest = state.pipes;\n\n    // got a match.\n    state.pipes = null;\n    state.pipesCount = 0;\n    state.flowing = false;\n    if (dest)\n      dest.emit('unpipe', this);\n    return this;\n  }\n\n  // slow case. multiple pipe destinations.\n\n  if (!dest) {\n    // remove all.\n    var dests = state.pipes;\n    var len = state.pipesCount;\n    state.pipes = null;\n    state.pipesCount = 0;\n    state.flowing = false;\n\n    for (var i = 0; i < len; i++)\n      dests[i].emit('unpipe', this);\n    return this;\n  }\n\n  // try to find the right one.\n  var i = indexOf(state.pipes, dest);\n  if (i === -1)\n    return this;\n\n  state.pipes.splice(i, 1);\n  state.pipesCount -= 1;\n  if (state.pipesCount === 1)\n    state.pipes = state.pipes[0];\n\n  dest.emit('unpipe', this);\n\n  return this;\n};\n\n// set up data events if they are asked for\n// Ensure readable listeners eventually get something\nReadable.prototype.on = function(ev, fn) {\n  var res = Stream.prototype.on.call(this, ev, fn);\n\n  // If listening to data, and it has not explicitly been paused,\n  // then call resume to start the flow of data on the next tick.\n  if (ev === 'data' && false !== this._readableState.flowing) {\n    this.resume();\n  }\n\n  if (ev === 'readable' && this.readable) {\n    var state = this._readableState;\n    if (!state.readableListening) {\n      state.readableListening = true;\n      state.emittedReadable = false;\n      state.needReadable = true;\n      if (!state.reading) {\n        var self = this;\n        process.nextTick(function() {\n          debug('readable nexttick read 0');\n          self.read(0);\n        });\n      } else if (state.length) {\n        emitReadable(this, state);\n      }\n    }\n  }\n\n  return res;\n};\nReadable.prototype.addListener = Readable.prototype.on;\n\n// pause() and resume() are remnants of the legacy readable stream API\n// If the user uses them, then switch into old mode.\nReadable.prototype.resume = function() {\n  var state = this._readableState;\n  if (!state.flowing) {\n    debug('resume');\n    state.flowing = true;\n    if (!state.reading) {\n      debug('resume read 0');\n      this.read(0);\n    }\n    resume(this, state);\n  }\n  return this;\n};\n\nfunction resume(stream, state) {\n  if (!state.resumeScheduled) {\n    state.resumeScheduled = true;\n    process.nextTick(function() {\n      resume_(stream, state);\n    });\n  }\n}\n\nfunction resume_(stream, state) {\n  state.resumeScheduled = false;\n  stream.emit('resume');\n  flow(stream);\n  if (state.flowing && !state.reading)\n    stream.read(0);\n}\n\nReadable.prototype.pause = function() {\n  debug('call pause flowing=%j', this._readableState.flowing);\n  if (false !== this._readableState.flowing) {\n    debug('pause');\n    this._readableState.flowing = false;\n    this.emit('pause');\n  }\n  return this;\n};\n\nfunction flow(stream) {\n  var state = stream._readableState;\n  debug('flow', state.flowing);\n  if (state.flowing) {\n    do {\n      var chunk = stream.read();\n    } while (null !== chunk && state.flowing);\n  }\n}\n\n// wrap an old-style stream as the async data source.\n// This is *not* part of the readable stream interface.\n// It is an ugly unfortunate mess of history.\nReadable.prototype.wrap = function(stream) {\n  var state = this._readableState;\n  var paused = false;\n\n  var self = this;\n  stream.on('end', function() {\n    debug('wrapped end');\n    if (state.decoder && !state.ended) {\n      var chunk = state.decoder.end();\n      if (chunk && chunk.length)\n        self.push(chunk);\n    }\n\n    self.push(null);\n  });\n\n  stream.on('data', function(chunk) {\n    debug('wrapped data');\n    if (state.decoder)\n      chunk = state.decoder.write(chunk);\n    if (!chunk || !state.objectMode && !chunk.length)\n      return;\n\n    var ret = self.push(chunk);\n    if (!ret) {\n      paused = true;\n      stream.pause();\n    }\n  });\n\n  // proxy all the other methods.\n  // important when wrapping filters and duplexes.\n  for (var i in stream) {\n    if (util.isFunction(stream[i]) && util.isUndefined(this[i])) {\n      this[i] = function(method) { return function() {\n        return stream[method].apply(stream, arguments);\n      }}(i);\n    }\n  }\n\n  // proxy certain important events.\n  var events = ['error', 'close', 'destroy', 'pause', 'resume'];\n  forEach(events, function(ev) {\n    stream.on(ev, self.emit.bind(self, ev));\n  });\n\n  // when we try to consume some more bytes, simply unpause the\n  // underlying stream.\n  self._read = function(n) {\n    debug('wrapped _read', n);\n    if (paused) {\n      paused = false;\n      stream.resume();\n    }\n  };\n\n  return self;\n};\n\n\n\n// exposed for testing purposes only.\nReadable._fromList = fromList;\n\n// Pluck off n bytes from an array of buffers.\n// Length is the combined lengths of all the buffers in the list.\nfunction fromList(n, state) {\n  var list = state.buffer;\n  var length = state.length;\n  var stringMode = !!state.decoder;\n  var objectMode = !!state.objectMode;\n  var ret;\n\n  // nothing in the list, definitely empty.\n  if (list.length === 0)\n    return null;\n\n  if (length === 0)\n    ret = null;\n  else if (objectMode)\n    ret = list.shift();\n  else if (!n || n >= length) {\n    // read it all, truncate the array.\n    if (stringMode)\n      ret = list.join('');\n    else\n      ret = Buffer.concat(list, length);\n    list.length = 0;\n  } else {\n    // read just some of it.\n    if (n < list[0].length) {\n      // just take a part of the first list item.\n      // slice is the same for buffers and strings.\n      var buf = list[0];\n      ret = buf.slice(0, n);\n      list[0] = buf.slice(n);\n    } else if (n === list[0].length) {\n      // first list is a perfect match\n      ret = list.shift();\n    } else {\n      // complex case.\n      // we have enough to cover it, but it spans past the first buffer.\n      if (stringMode)\n        ret = '';\n      else\n        ret = new Buffer(n);\n\n      var c = 0;\n      for (var i = 0, l = list.length; i < l && c < n; i++) {\n        var buf = list[0];\n        var cpy = Math.min(n - c, buf.length);\n\n        if (stringMode)\n          ret += buf.slice(0, cpy);\n        else\n          buf.copy(ret, c, 0, cpy);\n\n        if (cpy < buf.length)\n          list[0] = buf.slice(cpy);\n        else\n          list.shift();\n\n        c += cpy;\n      }\n    }\n  }\n\n  return ret;\n}\n\nfunction endReadable(stream) {\n  var state = stream._readableState;\n\n  // If we get here before consuming all the bytes, then that is a\n  // bug in node.  Should never happen.\n  if (state.length > 0)\n    throw new Error('endReadable called on non-empty stream');\n\n  if (!state.endEmitted) {\n    state.ended = true;\n    process.nextTick(function() {\n      // Check that we didn't get one last unshift.\n      if (!state.endEmitted && state.length === 0) {\n        state.endEmitted = true;\n        stream.readable = false;\n        stream.emit('end');\n      }\n    });\n  }\n}\n\nfunction forEach (xs, f) {\n  for (var i = 0, l = xs.length; i < l; i++) {\n    f(xs[i], i);\n  }\n}\n\nfunction indexOf (xs, x) {\n  for (var i = 0, l = xs.length; i < l; i++) {\n    if (xs[i] === x) return i;\n  }\n  return -1;\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n\n// a transform stream is a readable/writable stream where you do\n// something with the data.  Sometimes it's called a \"filter\",\n// but that's not a great name for it, since that implies a thing where\n// some bits pass through, and others are simply ignored.  (That would\n// be a valid example of a transform, of course.)\n//\n// While the output is causally related to the input, it's not a\n// necessarily symmetric or synchronous transformation.  For example,\n// a zlib stream might take multiple plain-text writes(), and then\n// emit a single compressed chunk some time in the future.\n//\n// Here's how this works:\n//\n// The Transform stream has all the aspects of the readable and writable\n// stream classes.  When you write(chunk), that calls _write(chunk,cb)\n// internally, and returns false if there's a lot of pending writes\n// buffered up.  When you call read(), that calls _read(n) until\n// there's enough pending readable data buffered up.\n//\n// In a transform stream, the written data is placed in a buffer.  When\n// _read(n) is called, it transforms the queued up data, calling the\n// buffered _write cb's as it consumes chunks.  If consuming a single\n// written chunk would result in multiple output chunks, then the first\n// outputted bit calls the readcb, and subsequent chunks just go into\n// the read buffer, and will cause it to emit 'readable' if necessary.\n//\n// This way, back-pressure is actually determined by the reading side,\n// since _read has to be called to start processing a new chunk.  However,\n// a pathological inflate type of transform can cause excessive buffering\n// here.  For example, imagine a stream where every byte of input is\n// interpreted as an integer from 0-255, and then results in that many\n// bytes of output.  Writing the 4 bytes {ff,ff,ff,ff} would result in\n// 1kb of data being output.  In this case, you could write a very small\n// amount of input, and end up with a very large amount of output.  In\n// such a pathological inflating mechanism, there'd be no way to tell\n// the system to stop doing the transform.  A single 4MB write could\n// cause the system to run out of memory.\n//\n// However, even in such a pathological case, only a single written chunk\n// would be consumed, and then the rest would wait (un-transformed) until\n// the results of the previous transformed chunk were consumed.\n\nmodule.exports = Transform;\n\nvar Duplex = require('./_stream_duplex');\n\n/*<replacement>*/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/*</replacement>*/\n\nutil.inherits(Transform, Duplex);\n\n\nfunction TransformState(options, stream) {\n  this.afterTransform = function(er, data) {\n    return afterTransform(stream, er, data);\n  };\n\n  this.needTransform = false;\n  this.transforming = false;\n  this.writecb = null;\n  this.writechunk = null;\n}\n\nfunction afterTransform(stream, er, data) {\n  var ts = stream._transformState;\n  ts.transforming = false;\n\n  var cb = ts.writecb;\n\n  if (!cb)\n    return stream.emit('error', new Error('no writecb in Transform class'));\n\n  ts.writechunk = null;\n  ts.writecb = null;\n\n  if (!util.isNullOrUndefined(data))\n    stream.push(data);\n\n  if (cb)\n    cb(er);\n\n  var rs = stream._readableState;\n  rs.reading = false;\n  if (rs.needReadable || rs.length < rs.highWaterMark) {\n    stream._read(rs.highWaterMark);\n  }\n}\n\n\nfunction Transform(options) {\n  if (!(this instanceof Transform))\n    return new Transform(options);\n\n  Duplex.call(this, options);\n\n  this._transformState = new TransformState(options, this);\n\n  // when the writable side finishes, then flush out anything remaining.\n  var stream = this;\n\n  // start out asking for a readable event once data is transformed.\n  this._readableState.needReadable = true;\n\n  // we have implemented the _read method, and done the other things\n  // that Readable wants before the first _read call, so unset the\n  // sync guard flag.\n  this._readableState.sync = false;\n\n  this.once('prefinish', function() {\n    if (util.isFunction(this._flush))\n      this._flush(function(er) {\n        done(stream, er);\n      });\n    else\n      done(stream);\n  });\n}\n\nTransform.prototype.push = function(chunk, encoding) {\n  this._transformState.needTransform = false;\n  return Duplex.prototype.push.call(this, chunk, encoding);\n};\n\n// This is the part where you do stuff!\n// override this function in implementation classes.\n// 'chunk' is an input chunk.\n//\n// Call `push(newChunk)` to pass along transformed output\n// to the readable side.  You may call 'push' zero or more times.\n//\n// Call `cb(err)` when you are done with this chunk.  If you pass\n// an error, then that'll put the hurt on the whole operation.  If you\n// never call cb(), then you'll never get another chunk.\nTransform.prototype._transform = function(chunk, encoding, cb) {\n  throw new Error('not implemented');\n};\n\nTransform.prototype._write = function(chunk, encoding, cb) {\n  var ts = this._transformState;\n  ts.writecb = cb;\n  ts.writechunk = chunk;\n  ts.writeencoding = encoding;\n  if (!ts.transforming) {\n    var rs = this._readableState;\n    if (ts.needTransform ||\n        rs.needReadable ||\n        rs.length < rs.highWaterMark)\n      this._read(rs.highWaterMark);\n  }\n};\n\n// Doesn't matter what the args are here.\n// _transform does all the work.\n// That we got here means that the readable side wants more data.\nTransform.prototype._read = function(n) {\n  var ts = this._transformState;\n\n  if (!util.isNull(ts.writechunk) && ts.writecb && !ts.transforming) {\n    ts.transforming = true;\n    this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);\n  } else {\n    // mark that we need a transform, so that any data that comes in\n    // will get processed, now that we've asked for it.\n    ts.needTransform = true;\n  }\n};\n\n\nfunction done(stream, er) {\n  if (er)\n    return stream.emit('error', er);\n\n  // if there's nothing in the write buffer, then that means\n  // that nothing more will ever be provided\n  var ws = stream._writableState;\n  var ts = stream._transformState;\n\n  if (ws.length)\n    throw new Error('calling transform done when ws.length != 0');\n\n  if (ts.transforming)\n    throw new Error('calling transform done when still transforming');\n\n  return stream.push(null);\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// A bit simpler than readable streams.\n// Implement an async ._write(chunk, cb), and it'll handle all\n// the drain event emission and buffering.\n\nmodule.exports = Writable;\n\n/*<replacement>*/\nvar Buffer = require('buffer').Buffer;\n/*</replacement>*/\n\nWritable.WritableState = WritableState;\n\n\n/*<replacement>*/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/*</replacement>*/\n\nvar Stream = require('stream');\n\nutil.inherits(Writable, Stream);\n\nfunction WriteReq(chunk, encoding, cb) {\n  this.chunk = chunk;\n  this.encoding = encoding;\n  this.callback = cb;\n}\n\nfunction WritableState(options, stream) {\n  var Duplex = require('./_stream_duplex');\n\n  options = options || {};\n\n  // the point at which write() starts returning false\n  // Note: 0 is a valid value, means that we always return false if\n  // the entire buffer is not flushed immediately on write()\n  var hwm = options.highWaterMark;\n  var defaultHwm = options.objectMode ? 16 : 16 * 1024;\n  this.highWaterMark = (hwm || hwm === 0) ? hwm : defaultHwm;\n\n  // object stream flag to indicate whether or not this stream\n  // contains buffers or objects.\n  this.objectMode = !!options.objectMode;\n\n  if (stream instanceof Duplex)\n    this.objectMode = this.objectMode || !!options.writableObjectMode;\n\n  // cast to ints.\n  this.highWaterMark = ~~this.highWaterMark;\n\n  this.needDrain = false;\n  // at the start of calling end()\n  this.ending = false;\n  // when end() has been called, and returned\n  this.ended = false;\n  // when 'finish' is emitted\n  this.finished = false;\n\n  // should we decode strings into buffers before passing to _write?\n  // this is here so that some node-core streams can optimize string\n  // handling at a lower level.\n  var noDecode = options.decodeStrings === false;\n  this.decodeStrings = !noDecode;\n\n  // Crypto is kind of old and crusty.  Historically, its default string\n  // encoding is 'binary' so we have to make this configurable.\n  // Everything else in the universe uses 'utf8', though.\n  this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n  // not an actual buffer we keep track of, but a measurement\n  // of how much we're waiting to get pushed to some underlying\n  // socket or file.\n  this.length = 0;\n\n  // a flag to see when we're in the middle of a write.\n  this.writing = false;\n\n  // when true all writes will be buffered until .uncork() call\n  this.corked = 0;\n\n  // a flag to be able to tell if the onwrite cb is called immediately,\n  // or on a later tick.  We set this to true at first, because any\n  // actions that shouldn't happen until \"later\" should generally also\n  // not happen before the first write call.\n  this.sync = true;\n\n  // a flag to know if we're processing previously buffered items, which\n  // may call the _write() callback in the same tick, so that we don't\n  // end up in an overlapped onwrite situation.\n  this.bufferProcessing = false;\n\n  // the callback that's passed to _write(chunk,cb)\n  this.onwrite = function(er) {\n    onwrite(stream, er);\n  };\n\n  // the callback that the user supplies to write(chunk,encoding,cb)\n  this.writecb = null;\n\n  // the amount that is being written when _write is called.\n  this.writelen = 0;\n\n  this.buffer = [];\n\n  // number of pending user-supplied write callbacks\n  // this must be 0 before 'finish' can be emitted\n  this.pendingcb = 0;\n\n  // emit prefinish if the only thing we're waiting for is _write cbs\n  // This is relevant for synchronous Transform streams\n  this.prefinished = false;\n\n  // True if the error was already emitted and should not be thrown again\n  this.errorEmitted = false;\n}\n\nfunction Writable(options) {\n  var Duplex = require('./_stream_duplex');\n\n  // Writable ctor is applied to Duplexes, though they're not\n  // instanceof Writable, they're instanceof Readable.\n  if (!(this instanceof Writable) && !(this instanceof Duplex))\n    return new Writable(options);\n\n  this._writableState = new WritableState(options, this);\n\n  // legacy.\n  this.writable = true;\n\n  Stream.call(this);\n}\n\n// Otherwise people can pipe Writable streams, which is just wrong.\nWritable.prototype.pipe = function() {\n  this.emit('error', new Error('Cannot pipe. Not readable.'));\n};\n\n\nfunction writeAfterEnd(stream, state, cb) {\n  var er = new Error('write after end');\n  // TODO: defer error events consistently everywhere, not just the cb\n  stream.emit('error', er);\n  process.nextTick(function() {\n    cb(er);\n  });\n}\n\n// If we get something that is not a buffer, string, null, or undefined,\n// and we're not in objectMode, then that's an error.\n// Otherwise stream chunks are all considered to be of length=1, and the\n// watermarks determine how many objects to keep in the buffer, rather than\n// how many bytes or characters.\nfunction validChunk(stream, state, chunk, cb) {\n  var valid = true;\n  if (!util.isBuffer(chunk) &&\n      !util.isString(chunk) &&\n      !util.isNullOrUndefined(chunk) &&\n      !state.objectMode) {\n    var er = new TypeError('Invalid non-string/buffer chunk');\n    stream.emit('error', er);\n    process.nextTick(function() {\n      cb(er);\n    });\n    valid = false;\n  }\n  return valid;\n}\n\nWritable.prototype.write = function(chunk, encoding, cb) {\n  var state = this._writableState;\n  var ret = false;\n\n  if (util.isFunction(encoding)) {\n    cb = encoding;\n    encoding = null;\n  }\n\n  if (util.isBuffer(chunk))\n    encoding = 'buffer';\n  else if (!encoding)\n    encoding = state.defaultEncoding;\n\n  if (!util.isFunction(cb))\n    cb = function() {};\n\n  if (state.ended)\n    writeAfterEnd(this, state, cb);\n  else if (validChunk(this, state, chunk, cb)) {\n    state.pendingcb++;\n    ret = writeOrBuffer(this, state, chunk, encoding, cb);\n  }\n\n  return ret;\n};\n\nWritable.prototype.cork = function() {\n  var state = this._writableState;\n\n  state.corked++;\n};\n\nWritable.prototype.uncork = function() {\n  var state = this._writableState;\n\n  if (state.corked) {\n    state.corked--;\n\n    if (!state.writing &&\n        !state.corked &&\n        !state.finished &&\n        !state.bufferProcessing &&\n        state.buffer.length)\n      clearBuffer(this, state);\n  }\n};\n\nfunction decodeChunk(state, chunk, encoding) {\n  if (!state.objectMode &&\n      state.decodeStrings !== false &&\n      util.isString(chunk)) {\n    chunk = new Buffer(chunk, encoding);\n  }\n  return chunk;\n}\n\n// if we're already writing something, then just put this\n// in the queue, and wait our turn.  Otherwise, call _write\n// If we return false, then we need a drain event, so set that flag.\nfunction writeOrBuffer(stream, state, chunk, encoding, cb) {\n  chunk = decodeChunk(state, chunk, encoding);\n  if (util.isBuffer(chunk))\n    encoding = 'buffer';\n  var len = state.objectMode ? 1 : chunk.length;\n\n  state.length += len;\n\n  var ret = state.length < state.highWaterMark;\n  // we must ensure that previous needDrain will not be reset to false.\n  if (!ret)\n    state.needDrain = true;\n\n  if (state.writing || state.corked)\n    state.buffer.push(new WriteReq(chunk, encoding, cb));\n  else\n    doWrite(stream, state, false, len, chunk, encoding, cb);\n\n  return ret;\n}\n\nfunction doWrite(stream, state, writev, len, chunk, encoding, cb) {\n  state.writelen = len;\n  state.writecb = cb;\n  state.writing = true;\n  state.sync = true;\n  if (writev)\n    stream._writev(chunk, state.onwrite);\n  else\n    stream._write(chunk, encoding, state.onwrite);\n  state.sync = false;\n}\n\nfunction onwriteError(stream, state, sync, er, cb) {\n  if (sync)\n    process.nextTick(function() {\n      state.pendingcb--;\n      cb(er);\n    });\n  else {\n    state.pendingcb--;\n    cb(er);\n  }\n\n  stream._writableState.errorEmitted = true;\n  stream.emit('error', er);\n}\n\nfunction onwriteStateUpdate(state) {\n  state.writing = false;\n  state.writecb = null;\n  state.length -= state.writelen;\n  state.writelen = 0;\n}\n\nfunction onwrite(stream, er) {\n  var state = stream._writableState;\n  var sync = state.sync;\n  var cb = state.writecb;\n\n  onwriteStateUpdate(state);\n\n  if (er)\n    onwriteError(stream, state, sync, er, cb);\n  else {\n    // Check if we're actually ready to finish, but don't emit yet\n    var finished = needFinish(stream, state);\n\n    if (!finished &&\n        !state.corked &&\n        !state.bufferProcessing &&\n        state.buffer.length) {\n      clearBuffer(stream, state);\n    }\n\n    if (sync) {\n      process.nextTick(function() {\n        afterWrite(stream, state, finished, cb);\n      });\n    } else {\n      afterWrite(stream, state, finished, cb);\n    }\n  }\n}\n\nfunction afterWrite(stream, state, finished, cb) {\n  if (!finished)\n    onwriteDrain(stream, state);\n  state.pendingcb--;\n  cb();\n  finishMaybe(stream, state);\n}\n\n// Must force callback to be called on nextTick, so that we don't\n// emit 'drain' before the write() consumer gets the 'false' return\n// value, and has a chance to attach a 'drain' listener.\nfunction onwriteDrain(stream, state) {\n  if (state.length === 0 && state.needDrain) {\n    state.needDrain = false;\n    stream.emit('drain');\n  }\n}\n\n\n// if there's something in the buffer waiting, then process it\nfunction clearBuffer(stream, state) {\n  state.bufferProcessing = true;\n\n  if (stream._writev && state.buffer.length > 1) {\n    // Fast case, write everything using _writev()\n    var cbs = [];\n    for (var c = 0; c < state.buffer.length; c++)\n      cbs.push(state.buffer[c].callback);\n\n    // count the one we are adding, as well.\n    // TODO(isaacs) clean this up\n    state.pendingcb++;\n    doWrite(stream, state, true, state.length, state.buffer, '', function(err) {\n      for (var i = 0; i < cbs.length; i++) {\n        state.pendingcb--;\n        cbs[i](err);\n      }\n    });\n\n    // Clear buffer\n    state.buffer = [];\n  } else {\n    // Slow case, write chunks one-by-one\n    for (var c = 0; c < state.buffer.length; c++) {\n      var entry = state.buffer[c];\n      var chunk = entry.chunk;\n      var encoding = entry.encoding;\n      var cb = entry.callback;\n      var len = state.objectMode ? 1 : chunk.length;\n\n      doWrite(stream, state, false, len, chunk, encoding, cb);\n\n      // if we didn't call the onwrite immediately, then\n      // it means that we need to wait until it does.\n      // also, that means that the chunk and cb are currently\n      // being processed, so move the buffer counter past them.\n      if (state.writing) {\n        c++;\n        break;\n      }\n    }\n\n    if (c < state.buffer.length)\n      state.buffer = state.buffer.slice(c);\n    else\n      state.buffer.length = 0;\n  }\n\n  state.bufferProcessing = false;\n}\n\nWritable.prototype._write = function(chunk, encoding, cb) {\n  cb(new Error('not implemented'));\n\n};\n\nWritable.prototype._writev = null;\n\nWritable.prototype.end = function(chunk, encoding, cb) {\n  var state = this._writableState;\n\n  if (util.isFunction(chunk)) {\n    cb = chunk;\n    chunk = null;\n    encoding = null;\n  } else if (util.isFunction(encoding)) {\n    cb = encoding;\n    encoding = null;\n  }\n\n  if (!util.isNullOrUndefined(chunk))\n    this.write(chunk, encoding);\n\n  // .end() fully uncorks\n  if (state.corked) {\n    state.corked = 1;\n    this.uncork();\n  }\n\n  // ignore unnecessary end() calls.\n  if (!state.ending && !state.finished)\n    endWritable(this, state, cb);\n};\n\n\nfunction needFinish(stream, state) {\n  return (state.ending &&\n          state.length === 0 &&\n          !state.finished &&\n          !state.writing);\n}\n\nfunction prefinish(stream, state) {\n  if (!state.prefinished) {\n    state.prefinished = true;\n    stream.emit('prefinish');\n  }\n}\n\nfunction finishMaybe(stream, state) {\n  var need = needFinish(stream, state);\n  if (need) {\n    if (state.pendingcb === 0) {\n      prefinish(stream, state);\n      state.finished = true;\n      stream.emit('finish');\n    } else\n      prefinish(stream, state);\n  }\n  return need;\n}\n\nfunction endWritable(stream, state, cb) {\n  state.ending = true;\n  finishMaybe(stream, state);\n  if (cb) {\n    if (state.finished)\n      process.nextTick(cb);\n    else\n      stream.once('finish', cb);\n  }\n  state.ended = true;\n}\n","exports = module.exports = require('./lib/_stream_readable.js');\nexports.Stream = require('stream');\nexports.Readable = exports;\nexports.Writable = require('./lib/_stream_writable.js');\nexports.Duplex = require('./lib/_stream_duplex.js');\nexports.Transform = require('./lib/_stream_transform.js');\nexports.PassThrough = require('./lib/_stream_passthrough.js');\nif (!process.browser && process.env.READABLE_STREAM === 'disable') {\n  module.exports = require('stream');\n}\n","/**\n * @author Titus Wormer\n * @copyright 2015 Titus Wormer\n * @license MIT\n * @module remark:html\n * @fileoverview Compile Markdown to HTML with remark.\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\n/*\n * Dependencies.\n */\n\nvar compilers = require('./lib/compilers');\nvar transformer = require('./lib/transformer');\n\n/**\n * Attach an HTML compiler.\n *\n * @param {Remark} remark - Instance.\n * @param {Object?} [options] - Configuration.\n */\nfunction plugin(remark, options) {\n    var MarkdownCompiler = remark.Compiler;\n    var ancestor = MarkdownCompiler.prototype;\n    var proto;\n    var key;\n\n    /**\n     * Extensible prototype.\n     */\n    function HTMLCompilerPrototype() {}\n\n    HTMLCompilerPrototype.prototype = ancestor;\n\n    proto = new HTMLCompilerPrototype();\n\n    proto.options.xhtml = false;\n    proto.options.sanitize = false;\n    proto.options.entities = 'true';\n\n    /**\n     * Extensible constructor.\n     *\n     * @param {VFile} file - Virtual file.\n     */\n    function HTMLCompiler(file) {\n        if (file.extension) {\n            file.move({\n                'extension': 'html'\n            });\n        }\n\n        MarkdownCompiler.apply(this, [file, options]);\n    }\n\n    HTMLCompiler.prototype = proto;\n\n    /*\n     * Expose compilers.\n     */\n\n    for (key in compilers) {\n        proto[key] = compilers[key];\n    }\n\n    remark.Compiler = HTMLCompiler;\n\n    return transformer;\n}\n\n/*\n * Expose `plugin`.\n */\n\nmodule.exports = plugin;\n","/**\n * @author Titus Wormer\n * @copyright 2015 Titus Wormer\n * @license MIT\n * @module remark:html:compilers\n * @fileoverview Compilers to transform mdast nodes to HTML.\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\n/*\n * Dependencies.\n */\n\nvar trim = require('trim');\nvar detab = require('detab');\nvar collapse = require('collapse-white-space');\nvar normalizeURI = require('normalize-uri');\nvar trimLines = require('trim-lines');\nvar visit = require('unist-util-visit');\nvar h = require('./h.js');\n\n/*\n * Compilers.\n */\n\nvar visitors = {};\n\n/**\n * Return the content of a reference without definition\n * as markdown.\n *\n * @example\n *   failsafe({\n *     identifier: 'foo',\n *     referenceType: 'shortcut',\n *     children: [\n *       {\n *         type: 'text',\n *         value: 'foo'\n *       }\n *     ]\n *   }, {}); // '[foo]'\n *\n * @param {Node} node - Node to compile.\n * @param {Node?} definition - Definition node, when\n *   existing.\n * @param {HTMLCompiler} context - Instance.\n * @return {string?} - If without definition, returns a\n *   string, returns nothing otherwise.\n */\nfunction failsafe(node, definition, context) {\n    var result;\n\n    if (node.referenceType === 'shortcut' && !definition.link) {\n        result = node.children ? context.all(node).join('') : node.alt;\n\n        return (node.type === 'imageReference' ? '!' : '') +\n            '[' + result + ']';\n    }\n\n    return '';\n}\n\n/**\n * Stringify all footnote definitions, if any.\n *\n * @example\n *   generateFootnotes(); // '<div class=\"footnotes\">\\n<hr>\\n...'\n *\n * @return {string} - Compiled footnotes, if any.\n * @this {HTMLCompiler}\n */\nfunction generateFootnotes() {\n    var self = this;\n    var definitions = self.footnotes;\n    var length = definitions.length;\n    var index = -1;\n    var results = [];\n    var def;\n\n    if (!length) {\n        return '';\n    }\n\n    while (++index < length) {\n        def = definitions[index];\n\n        results[index] = self.listItem({\n            'type': 'listItem',\n            'data': {\n                'htmlAttributes': {\n                    'id': 'fn-' + def.identifier\n                }\n            },\n            'children': def.children.concat({\n                'type': 'link',\n                'href': '#fnref-' + def.identifier,\n                'data': {\n                    'htmlAttributes': {\n                        'class': 'footnote-backref'\n                    }\n                },\n                'children': [{\n                    'type': 'text',\n                    'value': '↩'\n                }]\n            }),\n            'position': def.position\n        }, {});\n    }\n\n    return h(self, null, {\n        'name': 'div',\n        'attributes': {\n            'class': 'footnotes'\n        },\n        'content': h(self, null, {\n                'name': 'hr'\n            }) +\n            '\\n' +\n            h(self, null, {\n                'name': 'ol',\n                'content': results.join('\\n')\n            }, null, true)\n    }, null, true) + '\\n';\n}\n\n/**\n * Stringify an unknown node.\n *\n * @example\n *   unknown({\n *     data: {\n *       htmlName: 'section'\n *     },\n *     children: [\n *       {\n *         type: 'text',\n *         value: 'foo'\n *       }\n *     ]\n *   }); // '<section>foo</section>'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction unknown(node) {\n    var content = 'children' in node ? this.all(node).join('') : node.value;\n\n    return h(this, node, {\n        'name': 'div',\n        'content': content || ''\n    }, node.data);\n}\n\n/**\n * Visit a node.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.visit({\n *     type: 'strong',\n *     children: [{\n *       type: 'text',\n *       value: 'Foo'\n *     }]\n *   });\n *   // '**Foo**'\n *\n * @param {Object} node - Node.\n * @param {Object?} [parent] - `node`s parent.\n * @return {string} - Compiled `node`.\n */\nfunction one(node, parent) {\n    var self = this;\n    var type = node && node.type;\n    var fn = typeof self[type] === 'function' ? type : 'unknown';\n\n    if (!type) {\n        self.file.fail('Expected node `' + node + '`');\n    }\n\n    return self[fn](node, parent);\n}\n\n/**\n * Stringify the children of `node`.\n *\n * @example\n *   all({\n *     children: [\n *       {\n *         type: 'text',\n *         value: 'foo'\n *       }\n *     ]\n *   }); // 'foo'\n *\n * @param {Node} parent - Parent to visit.\n * @return {Array.<string>} - List of compiled nodes.\n * @this {HTMLCompiler}\n */\nfunction all(parent) {\n    var self = this;\n    var nodes = parent.children;\n    var values = [];\n    var index = -1;\n    var length = nodes.length;\n    var value;\n    var prev;\n\n    while (++index < length) {\n        value = self.visit(nodes[index], parent);\n\n        if (value) {\n            if (prev && prev.type === 'break') {\n                value = trim.left(value);\n            }\n\n            values.push(value);\n        }\n\n        prev = nodes[index];\n    }\n\n    return values;\n}\n\n/**\n * Stringify a root object.\n *\n * @example\n *   // This will additionally include defined footnotes,\n *   // when applicable.\n *   root({\n *     children: [\n *       {\n *         type: 'paragraph',\n *         children: [\n *           {\n *             type: 'text',\n *             value: 'foo'\n *           }\n *         ]\n *       }\n *     ]\n *   }); // '<p>foo</p>\\n'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction root(node) {\n    var self = this;\n    var definitions = {};\n    var footnotes = [];\n    var result;\n\n    self.definitions = definitions;\n    self.footnotes = footnotes;\n\n    visit(node, 'definition', function (definition) {\n        definitions[definition.identifier.toUpperCase()] = definition;\n    });\n\n    visit(node, 'footnoteDefinition', function (definition) {\n        footnotes.push(definition);\n    });\n\n    result = self.all(node).join('\\n');\n\n    return (result ? result + '\\n' : '') + self.generateFootnotes();\n}\n\n/**\n * Stringify a block quote.\n *\n * @example\n *   blockquote({\n *     children: [\n *       {\n *         type: 'paragraph',\n *         children: [\n *           {\n *             type: 'text',\n *             value: 'foo'\n *           }\n *         ]\n *       }\n *     ]\n *   }); // '<blockquote>\\n<p>foo</p>\\n</blockquote>'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction blockquote(node) {\n    return h(this, node, {\n        'name': 'blockquote',\n        'content': this.all(node).join('\\n')\n    }, node.data, true);\n}\n\n/**\n * Stringify an inline footnote.\n *\n * @example\n *   // This additionally adds a definition at the bottem\n *   // of the document.\n *   footnote({\n *     children: [\n *       {\n *         type: 'text',\n *         value: 'foo'\n *       }\n *     ]\n *   }); // '<sup id=\"fnref-1\"><a href=\"#fn-1\">1</a></sup>'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction footnote(node) {\n    var self = this;\n    var definitions = self.footnotes;\n    var index = -1;\n    var length = definitions.length;\n    var identifiers = [];\n    var identifier;\n\n    while (++index < length) {\n        identifiers[index] = definitions[index].identifier;\n    }\n\n    index = -1;\n    identifier = 1;\n\n    while (identifiers.indexOf(String(identifier)) !== -1) {\n        identifier++;\n    }\n\n    identifier = String(identifier);\n\n    self.footnotes.push({\n        'type': 'footnoteDefinition',\n        'identifier': identifier,\n        'children': node.children,\n        'position': node.position\n    });\n\n    return self.footnoteReference({\n        'type': 'footnoteReference',\n        'identifier': identifier,\n        'position': node.position\n    });\n}\n\n/**\n * Stringify a list.\n *\n * @example\n *   list({\n *     ordered: true\n *     loose: false\n *     children: [\n *       {\n *         type: 'listItem',\n *         children: [\n *           {\n *             type: 'paragraph',\n *             children: [\n *               {\n *                 type: 'text',\n *                 value: 'foo'\n *               }\n *             ]\n *           }\n *         ]\n *       }\n *     ]\n *   }); // '<ol>\\n<li>foo</li>\\n</ol>'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction list(node) {\n    return h(this, node, {\n        'name': node.ordered ? 'ol' : 'ul',\n        'attributes': {\n            'start': node.start !== 1 ? node.start : null\n        },\n        'content': this.all(node).join('\\n')\n    }, node.data, true);\n}\n\n/**\n * Stringify a list-item.\n *\n * @example\n *   listItem({\n *     children: [\n *       {\n *         type: 'paragraph',\n *         children: [\n *           {\n *             type: 'text',\n *             value: 'foo'\n *           }\n *         ]\n *       }\n *     ]\n *   }, {\n *     loose: false\n *   }); // '<li>foo</li>'\n *\n * @param {Node} node - Node to compile.\n * @param {Node} parent - Parent of `node`.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction listItem(node, parent) {\n    var single;\n    var result;\n\n    single = !parent.loose &&\n        node.children.length === 1 &&\n        node.children[0].children;\n\n    result = this.all(single ? node.children[0] : node)\n        .join(single ? '' : '\\n');\n\n    return h(this, node, {\n        'name': 'li',\n        'content': result\n    }, node.data, !single);\n}\n\n/**\n * Stringify a heading.\n *\n * @example\n *   heading({\n *     depth: 3,\n *     children: [\n *       {\n *         type: 'text',\n *         value: 'foo'\n *       }\n *     ]\n *   }); // '<h3>foo</h3>'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction heading(node) {\n    return h(this, node, {\n        'name': 'h' + node.depth,\n        'content': this.all(node).join('')\n    }, node.data);\n}\n\n/**\n * Stringify a paragraph.\n *\n * @example\n *   paragraph({\n *     children: [\n *       {\n *         type: 'text',\n *         value: 'foo'\n *       }\n *     ]\n *   }); // 'foo'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction paragraph(node) {\n    return h(this, node, {\n        'name': 'p',\n        'content': trim(detab(this.all(node).join('')))\n    }, node.data);\n}\n\n/**\n * Stringify a code block.\n *\n * @example\n *   code({\n *     value: 'foo &amp; bar;'\n *   }); // '<pre><code>foo &amp;amp; bar\\n</code></pre>'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction code(node) {\n    var self = this;\n    var value = node.value ? detab(node.value + '\\n') : '';\n\n    return h(self, node, {\n        'name': 'pre',\n        'content': h(self, node, {\n            'name': 'code',\n            'content': self.encode(value)\n        }, node.data)\n    });\n}\n\n/**\n * Stringify a table.\n *\n * @example\n *   table({\n *     children: [\n *       {\n *         type: 'tableRow',\n *         ...\n *       }\n *     ]\n *   }); // '<table><thead>...'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction table(node) {\n    var self = this;\n    var rows = node.children;\n    var index = rows.length;\n    var align = node.align;\n    var alignLength = align.length;\n    var pos;\n    var result = [];\n    var row;\n    var out;\n    var name;\n    var cell;\n\n    while (index--) {\n        pos = alignLength;\n        row = rows[index].children;\n        out = [];\n        name = index === 0 ? 'th' : 'td';\n\n        while (pos--) {\n            cell = row[pos];\n            out[pos] = h(self, cell, {\n                'name': name,\n                'attributes': {\n                    'align': align[pos]\n                },\n                'content': cell ? self.all(cell).join('\\n') : ''\n            }, cell && cell.data);\n        }\n\n        result[index] = h(self, rows[index], {\n            'name': 'tr',\n            'content': out.join('\\n')\n        }, rows[index], true);\n    }\n\n    return h(self, node, {\n        'name': 'table',\n        'content': h(self, node, {\n                'name': 'thead',\n                'content': result[0]\n            }, null, true) +\n            '\\n' +\n            h(self, node, {\n                'name': 'tbody',\n                'content': result.slice(1).join('\\n')\n            }, null, true)\n    }, node.data, true);\n}\n\n/**\n * Stringify a literal HTML.\n *\n * @example\n *   html({\n *     value: '<i>italic</i>'\n *   }); // '<i>italic</i>'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction html(node) {\n    return this.options.sanitize ? this.encode(node.value) : node.value;\n}\n\n/**\n * Stringify a horizontal rule.\n *\n * @example\n *   rule(); // '<hr>'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction rule(node) {\n    return h(this, node, {\n        'name': 'hr'\n    }, node.data);\n}\n\n/**\n * Stringify inline code.\n *\n * @example\n *   inlineCode({\n *     value: 'foo &amp; bar;'\n *   }); // '<code>foo &amp;amp; bar;</code>'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction inlineCode(node) {\n    return h(this, node, {\n        'name': 'code',\n        'content': collapse(this.encode(node.value))\n    }, node.data);\n}\n\n/**\n * Stringify strongly emphasised content.\n *\n * @example\n *   strong({\n *     children: [\n *       {\n *         type: 'text',\n *         value: 'foo'\n *       }\n *     ]\n *   }); // '<strong>foo</strong>'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction strong(node) {\n    return h(this, node, {\n        'name': 'strong',\n        'content': this.all(node).join('')\n    }, node.data);\n}\n\n/**\n * Stringify emphasised content.\n *\n * @example\n *   emphasis({\n *     children: [\n *       {\n *         type: 'text',\n *         value: 'foo'\n *       }\n *     ]\n *   }); // '<em>foo</em>'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction emphasis(node) {\n    return h(this, node, {\n        'name': 'em',\n        'content': this.all(node).join('')\n    }, node.data);\n}\n\n/**\n * Stringify an inline break.\n *\n * @example\n *   hardBreak(); // '<br>\\n'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction hardBreak(node) {\n    return h(this, node, {\n        'name': 'br'\n    }, node.data) + '\\n';\n}\n\n/**\n * Stringify a link.\n *\n * @example\n *   link({\n *     href: 'http://example.com',\n *     children: [\n *       {\n *         type: 'text',\n *         value: 'foo'\n *       }\n *     ]\n *   }); // '<a href=\"http://example.com\">foo</a>'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction link(node) {\n    return h(this, node, {\n        'name': 'a',\n        'attributes': {\n            'href': normalizeURI(node.href),\n            'title': node.title\n        },\n        'content': this.all(node).join('')\n    }, node.data);\n}\n\n/**\n * Stringify a reference to a footnote.\n *\n * @example\n *   // If a definition was added previously:\n *   footnoteReference({\n *     identifier: 'foo'\n *   });\n *   // <sup id=\"fnref-foo\">\n *   //   <a class=\"footnote-ref\" href=\"#fn-foo\">foo</a>\n *   // </sup>\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction footnoteReference(node) {\n    var identifier = node.identifier;\n\n    return h(this, node, {\n        'name': 'sup',\n        'attributes': {\n            'id': 'fnref-' + identifier\n        },\n        'content': h(this, node, {\n            'name': 'a',\n            'attributes': {\n                'href': '#fn-' + identifier,\n                'class': 'footnote-ref'\n            },\n            'content': identifier\n        })\n    }, node.data);\n}\n\n/**\n * Stringify a reference to a link.\n *\n * @example\n *   // If a definition was added previously:\n *   linkReference({\n *     identifier: 'foo'\n *   }); // '<a href=\"http://example.com/fav.ico\"></a>'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction linkReference(node) {\n    var self = this;\n    var def = self.definitions[node.identifier.toUpperCase()] || {};\n\n    return failsafe(node, def, self) || h(self, node, {\n        'name': 'a',\n        'attributes': {\n            'href': normalizeURI(def.link || ''),\n            'title': def.title\n        },\n        'content': self.all(node).join('')\n    }, node.data);\n}\n\n/**\n * Stringify a reference to an image.\n *\n * @example\n *   // If a definition was added previously:\n *   imageReference({\n *     identifier: 'foo'\n *   }); // '<img src=\"http://example.com/fav.ico\" alt=\"\">'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction imageReference(node) {\n    var self = this;\n    var def = self.definitions[node.identifier.toUpperCase()] || {};\n\n    return failsafe(node, def, self) || h(self, node, {\n        'name': 'img',\n        'attributes': {\n            'src': normalizeURI(def.link || ''),\n            'alt': node.alt || '',\n            'title': def.title\n        }\n    }, node.data);\n}\n\n/**\n * Stringify an image.\n *\n * @example\n *   image({\n *     src: 'http://example.com/fav.ico'\n *   }); // '<img src=\"http://example.com/fav.ico\" alt=\"\">'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction image(node) {\n    return h(this, node, {\n        'name': 'img',\n        'attributes': {\n            'src': normalizeURI(node.src),\n            'alt': node.alt || '',\n            'title': node.title\n        }\n    }, node.data);\n}\n\n/**\n * Stringify a deletion.\n *\n * @example\n *   strikethrough({\n *     children: [\n *       {\n *         type: 'text',\n *         value: 'foo'\n *       }\n *     ]\n *   }); // '<del>foo</del>'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction strikethrough(node) {\n    return h(this, node, {\n        'name': 'del',\n        'content': this.all(node).join('')\n    }, node.data);\n}\n\n/**\n * Stringify text.\n *\n * @example\n *   text({value: '&'}); // '&amp;'\n *\n *   text({value: 'foo'}); // 'foo'\n *\n * @param {Node} node - Node to compile.\n * @return {string} - Compiled node.\n * @this {HTMLCompiler}\n */\nfunction text(node) {\n    return trimLines(this.encode(node.value));\n}\n\n/**\n * Return an empty string for nodes which are ignored.\n *\n * @example\n *   ignore(); // ''\n *\n * @return {string} - Empty string.\n * @this {HTMLCompiler}\n */\nfunction ignore() {\n    return '';\n}\n\n/*\n * Helpers.\n */\n\nvisitors.visit = one;\nvisitors.all = all;\nvisitors.unknown = unknown;\nvisitors.generateFootnotes = generateFootnotes;\n\n/*\n * Ignored nodes.\n */\n\nvisitors.yaml = ignore;\nvisitors.definition = ignore;\nvisitors.footnoteDefinition = ignore;\n\n/*\n * Compilers.\n */\n\nvisitors.footnote = footnote;\nvisitors.root = root;\nvisitors.blockquote = blockquote;\nvisitors.list = list;\nvisitors.listItem = listItem;\nvisitors.paragraph = paragraph;\nvisitors.heading = heading;\nvisitors.table = table;\nvisitors.code = code;\nvisitors.html = html;\nvisitors.horizontalRule = rule;\nvisitors.inlineCode = inlineCode;\nvisitors.strong = strong;\nvisitors.emphasis = emphasis;\nvisitors.break = hardBreak;\nvisitors.link = link;\nvisitors.image = image;\nvisitors.footnoteReference = footnoteReference;\nvisitors.linkReference = linkReference;\nvisitors.imageReference = imageReference;\nvisitors.delete = strikethrough;\nvisitors.text = text;\nvisitors.escape = escape;\n\n/*\n * Expose.\n */\n\nmodule.exports = visitors;\n","/**\n * @author Titus Wormer\n * @copyright 2015 Titus Wormer\n * @license MIT\n * @module remark:html:h\n * @fileoverview\n *   Create HTML nodes. Loosely inspired by\n *   https://github.com/Matt-Esch/virtual-dom/blob/master/\n *   virtual-hyperscript/index.js\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\n/*\n * Dependencies.\n */\n\nvar assign = require('object-assign');\n\n/*\n * Constants.\n */\n\nvar LINE = '\\n';\nvar EMPTY = '';\nvar SPACE = ' ';\nvar GT = '>';\nvar LT = '<';\nvar SLASH = '/';\nvar QUOTE = '\"';\nvar EQUALS = '=';\n\n/*\n * List of self-closing tags.\n */\n\nvar CLOSING = ['hr', 'img', 'br'];\n\n/**\n * Compile attributes.\n *\n * @param {Object?} attributes - Map of attributes.\n * @param {function(string): string} encode - Strategy\n *   to use.\n * @param {Node} node - mdast node currently being\n *   compiled.\n * @return {string} - HTML attributes.\n */\nfunction toAttributes(attributes, encode, node) {\n    var parameters = [];\n    var key;\n    var value;\n\n    for (key in attributes) {\n        value = attributes[key];\n\n        if (value !== null && value !== undefined) {\n            value = encode(String(value || EMPTY), node);\n            parameters.push(key + EQUALS + QUOTE + value + QUOTE);\n        }\n    }\n\n    return parameters.length ? parameters.join(SPACE) : EMPTY;\n}\n\n/**\n * Compile a `node`, in `context`, into HTML.\n *\n * @example\n *   h(compiler, {\n *     'type': 'break'\n *     'attributes': {\n *       'id': 'foo'\n *     }\n *   }, 'br') // '<br id=\"foo\">'\n *\n *   h(compiler, {\n *     'type': 'break'\n *   }, 'br', {\n *     'id': 'foo'\n *   }) // '<br id=\"foo\">'\n *\n * @param {HTMLCompiler} context - Context compiler.\n * @param {Node} node - mdast node. Used for positions\n *   on errors.\n * @param {Object?} [defaults] - Default HTML configuration.\n * @param {Object?} [defaults.attributes] - Default Attributes.\n * @param {Object?} [defaults.content] - Default content.\n * @param {Object?} [defaults.name] - Default tag-name.\n * @param {Object?} [data] - Node configuration.\n * @param {Object?} [data.htmlAttributes] - HTML Attributes.\n * @param {Object?} [data.htmlContent] - Content of element.\n * @param {Object?} [data.htmlName] - Tag-name.\n * @param {boolean} [loose] - Whether to add an initial and\n *   a trailing newline character inside the opening and\n *   closing tags.\n * @return {string} - HTML representation of `node`, based\n *   on the given options.\n */\nfunction h(context, node, defaults, data, loose) {\n    var name;\n    var value;\n    var parameters;\n    var content;\n\n    if (!data) {\n        data = {};\n    }\n\n    name = context.encode(data.htmlName || defaults.name);\n\n    if (data.htmlContent && !context.options.sanitize) {\n        content = data.htmlContent;\n    } else {\n        content = defaults.content || EMPTY;\n    }\n\n    parameters = toAttributes(\n        assign({}, defaults.attributes, data.htmlAttributes\n    ), context.encode, node);\n\n    value = LT + name + (parameters ? SPACE + parameters : EMPTY);\n\n    if (CLOSING.indexOf(name) !== -1) {\n        return value + (context.options.xhtml ? SPACE + SLASH : EMPTY) + GT;\n    }\n\n    return value + GT +\n        (loose ? LINE : EMPTY) +\n        content +\n        (loose && content ? LINE : EMPTY) +\n        LT + SLASH + name + GT;\n}\n\n/*\n * Expose.\n */\n\nmodule.exports = h;\n","/**\n * @author Titus Wormer\n * @copyright 2015 Titus Wormer\n * @license MIT\n * @module remark:html:compilers\n * @fileoverview AST transformer for HTML.\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\n/*\n * Dependencies.\n */\n\nvar visit = require('unist-util-visit');\n\n/*\n * Constants.\n */\n\nvar FIRST_WORD = /^[^\\ \\t]+(?=[\\ \\t]|$)/;\n\n/**\n * Helper to get/set `htmlAttributes`.\n *\n * @param {Node} node - Node to get data from.\n * @return {Object} - Attributes.\n */\nfunction getAttributes(node) {\n    var data = node.data || (node.data = {});\n    return data.htmlAttributes || (data.htmlAttributes = {});\n}\n\n/**\n * Augment a code node.\n *\n * @param {Node} node - Code node.\n */\nfunction code(node) {\n    var lang = node.lang && node.lang.match(FIRST_WORD);\n    var attrs;\n\n    if (!lang) {\n        return;\n    }\n\n    attrs = getAttributes(node);\n    attrs.class = (attrs.class ? attrs.class + ' ' : '') + 'language-' + lang;\n}\n\n/*\n * Map of node-type handlers.\n */\n\nvar handlers = {};\n\nhandlers.code = code;\n\n/**\n * Transform `ast`.\n *\n * @param {Node} ast - Tree.\n */\nfunction transformer(ast) {\n    visit(ast, function (node) {\n        if (node.type in handlers) {\n            handlers[node.type](node);\n        }\n    });\n}\n\n/*\n * Expose.\n */\n\nmodule.exports = transformer;\n","/**\n * @author Titus Wormer\n * @copyright 2015-2016 Titus Wormer\n * @license MIT\n * @module remark\n * @version 3.2.2\n * @fileoverview Markdown processor powered by plugins.\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\n/*\n * Dependencies.\n */\n\nvar unified = require('unified');\nvar Parser = require('./lib/parse.js');\nvar Compiler = require('./lib/stringify.js');\nvar escape = require('./lib/escape.json');\n\n/*\n * Exports.\n */\n\nmodule.exports = unified({\n    'name': 'mdast',\n    'Parser': Parser,\n    'Compiler': Compiler,\n    'data': {\n        'escape': escape\n    }\n});\n","module.exports=[\n    \"article\",\n    \"header\",\n    \"aside\",\n    \"hgroup\",\n    \"blockquote\",\n    \"hr\",\n    \"iframe\",\n    \"body\",\n    \"li\",\n    \"map\",\n    \"button\",\n    \"object\",\n    \"canvas\",\n    \"ol\",\n    \"caption\",\n    \"output\",\n    \"col\",\n    \"p\",\n    \"colgroup\",\n    \"pre\",\n    \"dd\",\n    \"progress\",\n    \"div\",\n    \"section\",\n    \"dl\",\n    \"table\",\n    \"td\",\n    \"dt\",\n    \"tbody\",\n    \"embed\",\n    \"textarea\",\n    \"fieldset\",\n    \"tfoot\",\n    \"figcaption\",\n    \"th\",\n    \"figure\",\n    \"thead\",\n    \"footer\",\n    \"tr\",\n    \"form\",\n    \"ul\",\n    \"h1\",\n    \"h2\",\n    \"h3\",\n    \"h4\",\n    \"h5\",\n    \"h6\",\n    \"video\",\n    \"script\",\n    \"style\"\n]\n","/**\n * @author Titus Wormer\n * @copyright 2015-2016 Titus Wormer\n * @license MIT\n * @module remark:defaults\n * @version 3.2.2\n * @fileoverview Default values for parse and\n *  stringification settings.\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\n/*\n * Note that `stringify.entities` is a string.\n */\n\nmodule.exports = {\n    'parse': {\n        'position': true,\n        'gfm': true,\n        'yaml': true,\n        'commonmark': false,\n        'footnotes': false,\n        'pedantic': false,\n        'breaks': false\n    },\n    'stringify': {\n        'gfm': true,\n        'commonmark': false,\n        'entities': 'false',\n        'setext': false,\n        'closeAtx': false,\n        'looseTable': false,\n        'spacedTable': true,\n        'incrementListMarker': true,\n        'fences': false,\n        'fence': '`',\n        'bullet': '-',\n        'listItemIndent': 'tab',\n        'rule': '*',\n        'ruleSpaces': true,\n        'ruleRepetition': 3,\n        'strong': '*',\n        'emphasis': '_'\n    }\n};\n","module.exports={\n  \"default\": [\n    \"\\\\\",\n    \"`\",\n    \"*\",\n    \"{\",\n    \"}\",\n    \"[\",\n    \"]\",\n    \"(\",\n    \")\",\n    \"#\",\n    \"+\",\n    \"-\",\n    \".\",\n    \"!\",\n    \"_\",\n    \">\"\n  ],\n  \"gfm\": [\n    \"\\\\\",\n    \"`\",\n    \"*\",\n    \"{\",\n    \"}\",\n    \"[\",\n    \"]\",\n    \"(\",\n    \")\",\n    \"#\",\n    \"+\",\n    \"-\",\n    \".\",\n    \"!\",\n    \"_\",\n    \">\",\n    \"~\",\n    \"|\"\n  ],\n  \"commonmark\": [\n    \"\\\\\",\n    \"`\",\n    \"*\",\n    \"{\",\n    \"}\",\n    \"[\",\n    \"]\",\n    \"(\",\n    \")\",\n    \"#\",\n    \"+\",\n    \"-\",\n    \".\",\n    \"!\",\n    \"_\",\n    \">\",\n    \"~\",\n    \"|\",\n    \"\\n\",\n    \"\\\"\",\n    \"$\",\n    \"%\",\n    \"&\",\n    \"'\",\n    \",\",\n    \"/\",\n    \":\",\n    \";\",\n    \"<\",\n    \"=\",\n    \"?\",\n    \"@\",\n    \"^\"\n  ]\n}\n","/**\n * @author Titus Wormer\n * @copyright 2015-2016 Titus Wormer\n * @license MIT\n * @module remark:parse\n * @version 3.2.2\n * @fileoverview Parse a markdown document into an\n *   abstract syntax tree.\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\n/*\n * Dependencies.\n */\n\nvar decode = require('parse-entities');\nvar repeat = require('repeat-string');\nvar trim = require('trim');\nvar trimTrailingLines = require('trim-trailing-lines');\nvar extend = require('extend.js');\nvar utilities = require('./utilities.js');\nvar defaultOptions = require('./defaults.js').parse;\nvar blockElements = require('./block-elements.json');\n\n/*\n * Methods.\n */\n\nvar raise = utilities.raise;\nvar clean = utilities.clean;\nvar validate = utilities.validate;\nvar normalize = utilities.normalizeIdentifier;\nvar stateToggler = utilities.stateToggler;\nvar mergeable = utilities.mergeable;\nvar MERGEABLE_NODES = utilities.MERGEABLE_NODES;\nvar has = {}.hasOwnProperty;\n\n/*\n * Numeric constants.\n */\n\nvar SPACE_SIZE = 1;\nvar TAB_SIZE = 4;\nvar CODE_INDENT_LENGTH = 4;\nvar MIN_FENCE_COUNT = 3;\nvar MAX_ATX_COUNT = 6;\nvar MAX_LINE_HEADING_INDENT = 3;\nvar HORIZONTAL_RULE_MARKER_COUNT = 3;\nvar MIN_CLOSING_HTML_NEWLINE_COUNT = 2;\nvar MIN_BREAK_LENGTH = 2;\nvar MIN_TABLE_COLUMNS = 2;\nvar MIN_TABLE_ROWS = 2;\n\n/*\n * Error messages.\n */\n\nvar ERR_INFINITE_LOOP = 'Infinite loop';\nvar ERR_MISSING_LOCATOR = 'Missing locator: ';\nvar ERR_INCORRECTLY_EATEN = 'Incorrectly eaten value: please report this ' +\n    'warning on http://git.io/vUYWz';\n\n/*\n * Expressions.\n */\n\nvar EXPRESSION_BULLET = /^([ \\t]*)([*+-]|\\d+[.)])( {1,4}(?! )| |\\t|$|(?=\\n))([^\\n]*)/;\nvar EXPRESSION_PEDANTIC_BULLET = /^([ \\t]*)([*+-]|\\d+[.)])([ \\t]+)/;\nvar EXPRESSION_INITIAL_INDENT = /^( {1,4}|\\t)?/gm;\nvar EXPRESSION_INITIAL_TAB = /^( {4}|\\t)?/gm;\nvar EXPRESSION_HTML_LINK_OPEN = /^<a /i;\nvar EXPRESSION_HTML_LINK_CLOSE = /^<\\/a>/i;\nvar EXPRESSION_LOOSE_LIST_ITEM = /\\n\\n(?!\\s*$)/;\nvar EXPRESSION_TASK_ITEM = /^\\[([\\ \\t]|x|X)\\][\\ \\t]/;\n\n/*\n * Characters.\n */\n\nvar C_BACKSLASH = '\\\\';\nvar C_UNDERSCORE = '_';\nvar C_ASTERISK = '*';\nvar C_TICK = '`';\nvar C_AT_SIGN = '@';\nvar C_HASH = '#';\nvar C_PLUS = '+';\nvar C_DASH = '-';\nvar C_DOT = '.';\nvar C_PIPE = '|';\nvar C_DOUBLE_QUOTE = '\"';\nvar C_SINGLE_QUOTE = '\\'';\nvar C_COMMA = ',';\nvar C_SLASH = '/';\nvar C_COLON = ':';\nvar C_SEMI_COLON = ';';\nvar C_QUESTION_MARK = '?';\nvar C_CARET = '^';\nvar C_EQUALS = '=';\nvar C_EXCLAMATION_MARK = '!';\nvar C_TILDE = '~';\nvar C_LT = '<';\nvar C_GT = '>';\nvar C_BRACKET_OPEN = '[';\nvar C_BRACKET_CLOSE = ']';\nvar C_PAREN_OPEN = '(';\nvar C_PAREN_CLOSE = ')';\nvar C_SPACE = ' ';\nvar C_FORM_FEED = '\\f';\nvar C_NEWLINE = '\\n';\nvar C_CARRIAGE_RETURN = '\\r';\nvar C_TAB = '\\t';\nvar C_VERTICAL_TAB = '\\v';\nvar C_NO_BREAK_SPACE = '\\u00a0';\nvar C_OGHAM_SPACE = '\\u1680';\nvar C_MONGOLIAN_VOWEL_SEPARATOR = '\\u180e';\nvar C_EN_QUAD = '\\u2000';\nvar C_EM_QUAD = '\\u2001';\nvar C_EN_SPACE = '\\u2002';\nvar C_EM_SPACE = '\\u2003';\nvar C_THREE_PER_EM_SPACE = '\\u2004';\nvar C_FOUR_PER_EM_SPACE = '\\u2005';\nvar C_SIX_PER_EM_SPACE = '\\u2006';\nvar C_FIGURE_SPACE = '\\u2007';\nvar C_PUNCTUATION_SPACE = '\\u2008';\nvar C_THIN_SPACE = '\\u2009';\nvar C_HAIR_SPACE = '\\u200a';\nvar C_LINE_SEPARATOR = '​\\u2028';\nvar C_PARAGRAPH_SEPARATOR = '​\\u2029';\nvar C_NARROW_NO_BREAK_SPACE = '\\u202f';\nvar C_IDEOGRAPHIC_SPACE = '\\u3000';\nvar C_ZERO_WIDTH_NO_BREAK_SPACE = '\\ufeff';\nvar C_X_LOWER = 'x';\n\n/*\n * Character codes.\n */\n\nvar CC_A_LOWER = 'a'.charCodeAt(0);\nvar CC_A_UPPER = 'A'.charCodeAt(0);\nvar CC_Z_LOWER = 'z'.charCodeAt(0);\nvar CC_Z_UPPER = 'Z'.charCodeAt(0);\nvar CC_0 = '0'.charCodeAt(0);\nvar CC_9 = '9'.charCodeAt(0);\n\n/*\n * Protocols.\n */\n\nvar HTTP_PROTOCOL = 'http://';\nvar HTTPS_PROTOCOL = 'https://';\nvar MAILTO_PROTOCOL = 'mailto:';\n\nvar PROTOCOLS = [\n    HTTP_PROTOCOL,\n    HTTPS_PROTOCOL,\n    MAILTO_PROTOCOL\n];\n\nvar PROTOCOLS_LENGTH = PROTOCOLS.length;\n\n/*\n * Textual constants.\n */\n\nvar YAML_FENCE = repeat(C_DASH, 3);\nvar CODE_INDENT = repeat(C_SPACE, CODE_INDENT_LENGTH);\nvar EMPTY = '';\nvar BLOCK = 'block';\nvar INLINE = 'inline';\nvar COMMENT_START = '<!--';\nvar COMMENT_END = '-->';\nvar CDATA_START = '<![CDATA[';\nvar CDATA_END = ']]>';\nvar COMMENT_END_CHAR = COMMENT_END.charAt(0);\nvar CDATA_END_CHAR = CDATA_END.charAt(0);\nvar COMMENT_START_LENGTH = COMMENT_START.length;\nvar COMMENT_END_LENGTH = COMMENT_END.length;\nvar CDATA_START_LENGTH = CDATA_START.length;\nvar CDATA_END_LENGTH = CDATA_END.length;\n\n/*\n * Node types.\n */\n\nvar T_HORIZONTAL_RULE = 'horizontalRule';\nvar T_HTML = 'html';\nvar T_YAML = 'yaml';\nvar T_TABLE = 'table';\nvar T_TABLE_CELL = 'tableCell';\nvar T_TABLE_HEADER = 'tableHeader';\nvar T_TABLE_ROW = 'tableRow';\nvar T_PARAGRAPH = 'paragraph';\nvar T_TEXT = 'text';\nvar T_CODE = 'code';\nvar T_LIST = 'list';\nvar T_LIST_ITEM = 'listItem';\nvar T_DEFINITION = 'definition';\nvar T_FOOTNOTE_DEFINITION = 'footnoteDefinition';\nvar T_HEADING = 'heading';\nvar T_BLOCKQUOTE = 'blockquote';\nvar T_LINK = 'link';\nvar T_IMAGE = 'image';\nvar T_FOOTNOTE = 'footnote';\nvar T_STRONG = 'strong';\nvar T_EMPHASIS = 'emphasis';\nvar T_DELETE = 'delete';\nvar T_INLINE_CODE = 'inlineCode';\nvar T_BREAK = 'break';\nvar T_ROOT = 'root';\n\n/*\n * Available table alignments.\n */\n\nvar TABLE_ALIGN_LEFT = 'left';\nvar TABLE_ALIGN_CENTER = 'center';\nvar TABLE_ALIGN_RIGHT = 'right';\nvar TABLE_ALIGN_NONE = null;\n\n/*\n * Available reference types.\n */\n\nvar REFERENCE_TYPE_SHORTCUT = 'shortcut';\nvar REFERENCE_TYPE_COLLAPSED = 'collapsed';\nvar REFERENCE_TYPE_FULL = 'full';\n\n/*\n * A map of characters, and their column length,\n * which can be used as indentation.\n */\n\nvar INDENTATION_CHARACTERS = {};\n\nINDENTATION_CHARACTERS[C_SPACE] = SPACE_SIZE;\nINDENTATION_CHARACTERS[C_TAB] = TAB_SIZE;\n\n/*\n * A map of characters, which can be used to mark emphasis.\n */\n\nvar EMPHASIS_MARKERS = {};\n\nEMPHASIS_MARKERS[C_ASTERISK] = true;\nEMPHASIS_MARKERS[C_UNDERSCORE] = true;\n\n/*\n * A map of characters, which can be used to mark rules.\n */\n\nvar RULE_MARKERS = {};\n\nRULE_MARKERS[C_ASTERISK] = true;\nRULE_MARKERS[C_UNDERSCORE] = true;\nRULE_MARKERS[C_DASH] = true;\n\n/*\n * A map of characters which can be used to mark\n * list-items.\n */\n\nvar LIST_UNORDERED_MARKERS = {};\n\nLIST_UNORDERED_MARKERS[C_ASTERISK] = true;\nLIST_UNORDERED_MARKERS[C_PLUS] = true;\nLIST_UNORDERED_MARKERS[C_DASH] = true;\n\n/*\n * A map of characters which can be used to mark\n * list-items after a digit.\n */\n\nvar LIST_ORDERED_MARKERS = {};\n\nLIST_ORDERED_MARKERS[C_DOT] = true;\n\n/*\n * A map of characters which can be used to mark\n * list-items after a digit.\n */\n\nvar LIST_ORDERED_COMMONMARK_MARKERS = {};\n\nLIST_ORDERED_COMMONMARK_MARKERS[C_DOT] = true;\nLIST_ORDERED_COMMONMARK_MARKERS[C_PAREN_CLOSE] = true;\n\n/*\n * A map of characters, which can be used to mark link\n * and image titles.\n */\n\nvar LINK_TITLE_MARKERS = {};\n\nLINK_TITLE_MARKERS[C_DOUBLE_QUOTE] = C_DOUBLE_QUOTE;\nLINK_TITLE_MARKERS[C_SINGLE_QUOTE] = C_SINGLE_QUOTE;\n\n/*\n * A map of characters, which can be used to mark link\n * and image titles in commonmark-mode.\n */\n\nvar COMMONMARK_LINK_TITLE_MARKERS = {};\n\nCOMMONMARK_LINK_TITLE_MARKERS[C_DOUBLE_QUOTE] = C_DOUBLE_QUOTE;\nCOMMONMARK_LINK_TITLE_MARKERS[C_SINGLE_QUOTE] = C_SINGLE_QUOTE;\nCOMMONMARK_LINK_TITLE_MARKERS[C_PAREN_OPEN] = C_PAREN_CLOSE;\n\n/*\n * A map of characters which can be used to mark setext\n * headers, mapping to their corresponding depth.\n */\n\nvar SETEXT_MARKERS = {};\n\nSETEXT_MARKERS[C_EQUALS] = 1;\nSETEXT_MARKERS[C_DASH] = 2;\n\n/*\n * A map of two functions which can create list items.\n */\n\nvar LIST_ITEM_MAP = {};\n\nLIST_ITEM_MAP.true = renderPedanticListItem;\nLIST_ITEM_MAP.false = renderNormalListItem;\n\n/**\n * Check whether `character` is alphabetic.\n *\n * @param {string} character - Single character to check.\n * @return {boolean} - Whether or not `character` is\n *   alphabetic.\n */\nfunction isAlphabetic(character) {\n    var code = character.charCodeAt(0);\n\n    return (code >= CC_A_LOWER && code <= CC_Z_LOWER) ||\n        (code >= CC_A_UPPER && code <= CC_Z_UPPER);\n}\n\n/**\n * Check whether `character` is numeric.\n *\n * @param {string} character - Single character to check.\n * @return {boolean} - Whether or not `character` is\n *   numeric.\n */\nfunction isNumeric(character) {\n    var code = character.charCodeAt(0);\n\n    return code >= CC_0 && code <= CC_9;\n}\n\n/**\n * Check whether `character` is a word character.\n *\n * @param {string} character - Single character to check.\n * @return {boolean} - Whether or not `character` is a\n *   word character.\n */\nfunction isWordCharacter(character) {\n    return character === C_UNDERSCORE ||\n        isAlphabetic(character) ||\n        isNumeric(character);\n}\n\n/**\n * Check whether `character` is white-space.\n *\n * @param {string} character - Single character to check.\n * @return {boolean} - Whether or not `character` is\n *   white-space.\n */\nfunction isWhiteSpace(character) {\n    return character === C_SPACE ||\n        character === C_FORM_FEED ||\n        character === C_NEWLINE ||\n        character === C_CARRIAGE_RETURN ||\n        character === C_TAB ||\n        character === C_VERTICAL_TAB ||\n        character === C_NO_BREAK_SPACE ||\n        character === C_OGHAM_SPACE ||\n        character === C_MONGOLIAN_VOWEL_SEPARATOR ||\n        character === C_EN_QUAD ||\n        character === C_EM_QUAD ||\n        character === C_EN_SPACE ||\n        character === C_EM_SPACE ||\n        character === C_THREE_PER_EM_SPACE ||\n        character === C_FOUR_PER_EM_SPACE ||\n        character === C_SIX_PER_EM_SPACE ||\n        character === C_FIGURE_SPACE ||\n        character === C_PUNCTUATION_SPACE ||\n        character === C_THIN_SPACE ||\n        character === C_HAIR_SPACE ||\n        character === C_LINE_SEPARATOR ||\n        character === C_PARAGRAPH_SEPARATOR ||\n        character === C_NARROW_NO_BREAK_SPACE ||\n        character === C_IDEOGRAPHIC_SPACE ||\n        character === C_ZERO_WIDTH_NO_BREAK_SPACE;\n}\n\n/**\n * Check whether `character` can be inside an unquoted\n * attribute value.\n *\n * @param {string} character - Single character to check.\n * @return {boolean} - Whether or not `character` can be\n *   inside an unquoted attribute value.\n */\nfunction isUnquotedAttributeCharacter(character) {\n    return character !== C_DOUBLE_QUOTE &&\n        character !== C_SINGLE_QUOTE &&\n        character !== C_EQUALS &&\n        character !== C_LT &&\n        character !== C_GT &&\n        character !== C_TICK;\n}\n\n/**\n * Check whether `character` can be inside a double-quoted\n * attribute value.\n *\n * @property {string} delimiter - Closing delimiter.\n * @param {string} character - Single character to check.\n * @return {boolean} - Whether or not `character` can be\n *   inside a double-quoted attribute value.\n */\nfunction isDoubleQuotedAttributeCharacter(character) {\n    return character !== C_DOUBLE_QUOTE;\n}\n\nisDoubleQuotedAttributeCharacter.delimiter = C_DOUBLE_QUOTE;\n\n/**\n * Check whether `character` can be inside a single-quoted\n * attribute value.\n *\n * @property {string} delimiter - Closing delimiter.\n * @param {string} character - Single character to check.\n * @return {boolean} - Whether or not `character` can be\n *   inside a single-quoted attribute value.\n */\nfunction isSingleQuotedAttributeCharacter(character) {\n    return character !== C_SINGLE_QUOTE;\n}\n\nisSingleQuotedAttributeCharacter.delimiter = C_SINGLE_QUOTE;\n\n/**\n * Check whether `character` can be inside an enclosed\n * URI.\n *\n * @property {string} delimiter - Closing delimiter.\n * @param {string} character - Character to test.\n * @return {boolean} - Whether or not `character` can be\n *   inside an enclosed URI.\n */\nfunction isEnclosedURLCharacter(character) {\n    return character !== C_GT &&\n        character !== C_BRACKET_OPEN &&\n        character !== C_BRACKET_CLOSE;\n}\n\nisEnclosedURLCharacter.delimiter = C_GT;\n\n/**\n * Check whether `character` can be inside an unclosed\n * URI.\n *\n * @param {string} character - Character to test.\n * @return {boolean} - Whether or not `character` can be\n *   inside an unclosed URI.\n */\nfunction isUnclosedURLCharacter(character) {\n    return character !== C_BRACKET_OPEN &&\n        character !== C_BRACKET_CLOSE &&\n        !isWhiteSpace(character);\n}\n\n/**\n * Factory to create an entity decoder.\n *\n * @param {Object} context - Context to attach to, e.g.,\n *   a parser.\n * @return {Function} - See `decode`.\n */\nfunction decodeFactory(context) {\n    /**\n     * Normalize `position` to add an `indent`.\n     *\n     * @param {Position} position - Reference\n     * @return {Position} - Augmented with `indent`.\n     */\n    function normalize(position) {\n        return {\n            'start': position,\n            'indent': context.getIndent(position.line)\n        };\n    }\n\n    /**\n     * Handle a warning.\n     *\n     * @this {VFile} - Virtual file.\n     * @param {string} reason - Reason for warning.\n     * @param {Position} position - Place of warning.\n     * @param {number} code - Code for warning.\n     */\n    function handleWarning(reason, position, code) {\n        if (code === 3) {\n            return;\n        }\n\n        context.file.warn(reason, position);\n    }\n\n    /**\n     * Decode `value` (at `position`) into text-nodes.\n     *\n     * @param {string} value - Value to parse.\n     * @param {Position} position - Position to start parsing at.\n     * @param {Function} handler - Node handler.\n     */\n    function decoder(value, position, handler) {\n        var hasPosition = context.options.position;\n\n        decode(value, {\n            'position': position && normalize(position),\n            'warning': hasPosition && handleWarning,\n            'text': handler,\n            'reference': handler,\n            'textContext': context,\n            'referenceContext': context\n        });\n    }\n\n    /**\n     * Decode `value` (at `position`) into a string.\n     *\n     * @param {string} value - Value to parse.\n     * @param {Position} position - Position to start\n     *   parsing at.\n     * @return {string} - Plain-text.\n     */\n    function decodeRaw(value, position) {\n        return decode(value, {\n            'position': position && normalize(position),\n            'warning': context.options.position && handleWarning\n        });\n    }\n\n    decoder.raw = decodeRaw;\n\n    return decoder;\n}\n\n/**\n * Factory to de-escape a value, based on a list at `key`\n * in `scope`.\n *\n * @example\n *   var scope = {escape: ['a']}\n *   var descape = descapeFactory(scope, 'escape');\n *\n * @param {Object} scope - List of escapable characters.\n * @param {string} key - Key in `map` at which the list\n *   exists.\n * @return {function(string): string} - Function which\n *   takes a value and returns its unescaped version.\n */\nfunction descapeFactory(scope, key) {\n    /**\n     * De-escape a string using the expression at `key`\n     * in `scope`.\n     *\n     * @example\n     *   var scope = {escape: ['a']}\n     *   var descape = descapeFactory(scope, 'escape');\n     *   descape('\\a \\b'); // 'a \\b'\n     *\n     * @param {string} value - Escaped string.\n     * @return {string} - Unescaped string.\n     */\n    function descape(value) {\n        var prev = 0;\n        var index = value.indexOf(C_BACKSLASH);\n        var escape = scope[key];\n        var queue = [];\n        var character;\n\n        while (index !== -1) {\n            queue.push(value.slice(prev, index));\n            prev = index + 1;\n            character = value.charAt(prev);\n\n            /*\n             * If the following character is not a valid escape,\n             * add the slash.\n             */\n\n            if (!character || escape.indexOf(character) === -1) {\n                queue.push(C_BACKSLASH);\n            }\n\n            index = value.indexOf(C_BACKSLASH, prev);\n        }\n\n        queue.push(value.slice(prev));\n\n        return queue.join(EMPTY);\n    }\n\n    return descape;\n}\n\n/**\n * Gets indentation information for a line.\n *\n * @example\n *   getIndent('  foo');\n *   // {indent: 2, stops: {1: 0, 2: 1}}\n *\n *   getIndent('\\tfoo');\n *   // {indent: 4, stops: {4: 0}}\n *\n *   getIndent('  \\tfoo');\n *   // {indent: 4, stops: {1: 0, 2: 1, 4: 2}}\n *\n *   getIndent('\\t  foo')\n *   // {indent: 6, stops: {4: 0, 5: 1, 6: 2}}\n *\n * @param {string} value - Indented line.\n * @return {Object} - Indetation information.\n */\nfunction getIndent(value) {\n    var index = 0;\n    var indent = 0;\n    var character = value.charAt(index);\n    var stops = {};\n    var size;\n\n    while (character in INDENTATION_CHARACTERS) {\n        size = INDENTATION_CHARACTERS[character];\n\n        indent += size;\n\n        if (size > 1) {\n            indent = Math.floor(indent / size) * size;\n        }\n\n        stops[indent] = index;\n\n        character = value.charAt(++index);\n    }\n\n    return {\n        'indent': indent,\n        'stops': stops\n    };\n}\n\n/**\n * Remove the minimum indent from every line in `value`.\n * Supports both tab, spaced, and mixed indentation (as\n * well as possible).\n *\n * @example\n *   removeIndentation('  foo'); // 'foo'\n *   removeIndentation('    foo', 2); // '  foo'\n *   removeIndentation('\\tfoo', 2); // '  foo'\n *   removeIndentation('  foo\\n bar'); // ' foo\\n bar'\n *\n * @param {string} value - Value to trim.\n * @param {number?} [maximum] - Maximum indentation\n *   to remove.\n * @return {string} - Unindented `value`.\n */\nfunction removeIndentation(value, maximum) {\n    var values = value.split(C_NEWLINE);\n    var position = values.length + 1;\n    var minIndent = Infinity;\n    var matrix = [];\n    var index;\n    var indentation;\n    var stops;\n    var padding;\n\n    values.unshift(repeat(C_SPACE, maximum) + C_EXCLAMATION_MARK);\n\n    while (position--) {\n        indentation = getIndent(values[position]);\n\n        matrix[position] = indentation.stops;\n\n        if (trim(values[position]).length === 0) {\n            continue;\n        }\n\n        if (indentation.indent) {\n            if (indentation.indent > 0 && indentation.indent < minIndent) {\n                minIndent = indentation.indent;\n            }\n        } else {\n            minIndent = Infinity;\n\n            break;\n        }\n    }\n\n    if (minIndent !== Infinity) {\n        position = values.length;\n\n        while (position--) {\n            stops = matrix[position];\n            index = minIndent;\n\n            while (index && !(index in stops)) {\n                index--;\n            }\n\n            if (\n                trim(values[position]).length !== 0 &&\n                minIndent &&\n                index !== minIndent\n            ) {\n                padding = C_TAB;\n            } else {\n                padding = EMPTY;\n            }\n\n            values[position] = padding + values[position].slice(\n                index in stops ? stops[index] + 1 : 0\n            );\n        }\n    }\n\n    values.shift();\n\n    return values.join(C_NEWLINE);\n}\n\n/**\n * Tokenise a line.\n *\n * @example\n *   tokenizeNewline(eat, '\\n\\n');\n *\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {boolean?} - `true` when matching.\n */\nfunction tokenizeNewline(eat, value, silent) {\n    var character = value.charAt(0);\n    var length;\n    var subvalue;\n    var queue;\n    var index;\n\n    if (character !== C_NEWLINE) {\n        return;\n    }\n\n    /* istanbul ignore if - never used (yet) */\n    if (silent) {\n        return true;\n    }\n\n    index = 1;\n    length = value.length;\n    subvalue = C_NEWLINE;\n    queue = EMPTY;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (!isWhiteSpace(character)) {\n            break;\n        }\n\n        queue += character;\n\n        if (character === C_NEWLINE) {\n            subvalue += queue;\n            queue = EMPTY;\n        }\n\n        index++;\n    }\n\n    eat(subvalue);\n}\n\n/**\n * Tokenise an indented code block.\n *\n * @example\n *   tokenizeCode(eat, '\\tfoo');\n *\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `code` node.\n */\nfunction tokenizeCode(eat, value, silent) {\n    var self = this;\n    var index = -1;\n    var length = value.length;\n    var character;\n    var subvalue = EMPTY;\n    var content = EMPTY;\n    var subvalueQueue = EMPTY;\n    var contentQueue = EMPTY;\n    var blankQueue;\n    var indent;\n\n    while (++index < length) {\n        character = value.charAt(index);\n\n        if (indent) {\n            indent = false;\n\n            subvalue += subvalueQueue;\n            content += contentQueue;\n            subvalueQueue = contentQueue = EMPTY;\n\n            if (character === C_NEWLINE) {\n                subvalueQueue = contentQueue = character;\n            } else {\n                subvalue += character;\n                content += character;\n\n                while (++index < length) {\n                    character = value.charAt(index);\n\n                    if (!character || character === C_NEWLINE) {\n                        contentQueue = subvalueQueue = character;\n                        break;\n                    }\n\n                    subvalue += character;\n                    content += character;\n                }\n            }\n        } else if (\n            character === C_SPACE &&\n            value.charAt(index + 1) === C_SPACE &&\n            value.charAt(index + 2) === C_SPACE &&\n            value.charAt(index + 3) === C_SPACE\n        ) {\n            subvalueQueue += CODE_INDENT;\n            index += 3;\n            indent = true;\n        } else if (character === C_TAB) {\n            subvalueQueue += character;\n            indent = true;\n        } else {\n            blankQueue = EMPTY;\n\n            while (character === C_TAB || character === C_SPACE) {\n                blankQueue += character;\n                character = value.charAt(++index);\n            }\n\n            if (character !== C_NEWLINE) {\n                break;\n            }\n\n            subvalueQueue += blankQueue + character;\n            contentQueue += character;\n        }\n    }\n\n    if (content) {\n        if (silent) {\n            return true;\n        }\n\n        return eat(subvalue)(self.renderCodeBlock(content));\n    }\n}\n\n/**\n * Tokenise a fenced code block.\n *\n * @example\n *   tokenizeFences(eat, '```js\\nfoo()\\n```');\n *\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `code` node.\n */\nfunction tokenizeFences(eat, value, silent) {\n    var self = this;\n    var settings = self.options;\n    var length = value.length + 1;\n    var index = 0;\n    var subvalue = EMPTY;\n    var fenceCount;\n    var marker;\n    var character;\n    var flag;\n    var queue;\n    var content;\n    var exdentedContent;\n    var closing;\n    var exdentedClosing;\n    var indent;\n    var now;\n\n    if (!settings.gfm) {\n        return;\n    }\n\n    /*\n     * Eat initial spacing.\n     */\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (character !== C_SPACE && character !== C_TAB) {\n            break;\n        }\n\n        subvalue += character;\n        index++;\n    }\n\n    indent = index; // TODO: CHECK.\n\n    /*\n     * Eat the fence.\n     */\n\n    character = value.charAt(index);\n\n    if (character !== C_TILDE && character !== C_TICK) {\n        return;\n    }\n\n    index++;\n    marker = character;\n    fenceCount = 1;\n    subvalue += character;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (character !== marker) {\n            break;\n        }\n\n        subvalue += character;\n        fenceCount++;\n        index++;\n    }\n\n    if (fenceCount < MIN_FENCE_COUNT) {\n        return;\n    }\n\n    /*\n     * Eat spacing before flag.\n     */\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (character !== C_SPACE && character !== C_TAB) {\n            break;\n        }\n\n        subvalue += character;\n        index++;\n    }\n\n    /*\n     * Eat flag.\n     */\n\n    flag = queue = EMPTY;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (\n            character === C_NEWLINE ||\n            character === C_TILDE ||\n            character === C_TICK\n        ) {\n            break;\n        }\n\n        if (character === C_SPACE || character === C_TAB) {\n            queue += character;\n        } else {\n            flag += queue + character;\n            queue = EMPTY;\n        }\n\n        index++;\n    }\n\n    character = value.charAt(index);\n\n    if (character && character !== C_NEWLINE) {\n        return;\n    }\n\n    if (silent) {\n        return true;\n    }\n\n    now = eat.now();\n    now.column += subvalue.length;\n\n    subvalue += flag;\n    flag = self.decode.raw(self.descape(flag), now);\n\n    if (queue) {\n        subvalue += queue;\n    }\n\n    queue = closing = exdentedClosing = content = exdentedContent = EMPTY;\n\n    /*\n     * Eat content.\n     */\n\n    while (index < length) {\n        character = value.charAt(index);\n        content += closing;\n        exdentedContent += exdentedClosing;\n        closing = exdentedClosing = EMPTY;\n\n        if (character !== C_NEWLINE) {\n            content += character;\n            exdentedClosing += character;\n            index++;\n            continue;\n        }\n\n        /*\n         * Add the newline to `subvalue` if its the first\n         * character. Otherwise, add it to the `closing`\n         * queue.\n         */\n\n        if (!content) {\n            subvalue += character;\n        } else {\n            closing += character;\n            exdentedClosing += character;\n        }\n\n        queue = EMPTY;\n        index++;\n\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (character !== C_SPACE) {\n                break;\n            }\n\n            queue += character;\n            index++;\n        }\n\n        closing += queue;\n        exdentedClosing += queue.slice(indent);\n\n        if (queue.length >= CODE_INDENT_LENGTH) {\n            continue;\n        }\n\n        queue = EMPTY;\n\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (character !== marker) {\n                break;\n            }\n\n            queue += character;\n            index++;\n        }\n\n        closing += queue;\n        exdentedClosing += queue;\n\n        if (queue.length < fenceCount) {\n            continue;\n        }\n\n        queue = EMPTY;\n\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (character !== C_SPACE && character !== C_TAB) {\n                break;\n            }\n\n            closing += character;\n            exdentedClosing += character;\n            index++;\n        }\n\n        if (!character || character === C_NEWLINE) {\n            break;\n        }\n    }\n\n    subvalue += content + closing;\n\n    return eat(subvalue)(self.renderCodeBlock(exdentedContent, flag));\n}\n\n/**\n * Tokenise an ATX-style heading.\n *\n * @example\n *   tokenizeHeading(eat, ' # foo');\n *\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `heading` node.\n */\nfunction tokenizeHeading(eat, value, silent) {\n    var self = this;\n    var settings = self.options;\n    var length = value.length + 1;\n    var index = -1;\n    var now = eat.now();\n    var subvalue = EMPTY;\n    var content = EMPTY;\n    var character;\n    var queue;\n    var depth;\n\n    /*\n     * Eat initial spacing.\n     */\n\n    while (++index < length) {\n        character = value.charAt(index);\n\n        if (character !== C_SPACE && character !== C_TAB) {\n            index--;\n            break;\n        }\n\n        subvalue += character;\n    }\n\n    /*\n     * Eat hashes.\n     */\n\n    depth = 0;\n    length = index + MAX_ATX_COUNT + 1;\n\n    while (++index <= length) {\n        character = value.charAt(index);\n\n        if (character !== C_HASH) {\n            index--;\n            break;\n        }\n\n        subvalue += character;\n        depth++;\n    }\n\n    if (\n        !depth ||\n        (!settings.pedantic && value.charAt(index + 1) === C_HASH)\n    ) {\n        return;\n    }\n\n    length = value.length + 1;\n\n    /*\n     * Eat intermediate white-space.\n     */\n\n    queue = EMPTY;\n\n    while (++index < length) {\n        character = value.charAt(index);\n\n        if (character !== C_SPACE && character !== C_TAB) {\n            index--;\n            break;\n        }\n\n        queue += character;\n    }\n\n    /*\n     * Exit when not in pedantic mode without spacing.\n     */\n\n    if (\n        !settings.pedantic &&\n        !queue.length &&\n        character &&\n        character !== C_NEWLINE\n    ) {\n        return;\n    }\n\n    if (silent) {\n        return true;\n    }\n\n    /*\n     * Eat content.\n     */\n\n    subvalue += queue;\n    queue = content = EMPTY;\n\n    while (++index < length) {\n        character = value.charAt(index);\n\n        if (!character || character === C_NEWLINE) {\n            break;\n        }\n\n        if (\n            character !== C_SPACE &&\n            character !== C_TAB &&\n            character !== C_HASH\n        ) {\n            content += queue + character;\n            queue = EMPTY;\n            continue;\n        }\n\n        while (character === C_SPACE || character === C_TAB) {\n            queue += character;\n            character = value.charAt(++index);\n        }\n\n        while (character === C_HASH) {\n            queue += character;\n            character = value.charAt(++index);\n        }\n\n        while (character === C_SPACE || character === C_TAB) {\n            queue += character;\n            character = value.charAt(++index);\n        }\n\n        index--;\n    }\n\n    now.column += subvalue.length;\n    subvalue += content + queue;\n\n    return eat(subvalue)(self.renderHeading(content, depth, now));\n}\n\n/**\n * Tokenise a Setext-style heading.\n *\n * @example\n *   tokenizeLineHeading(eat, 'foo\\n===');\n *\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `heading` node.\n */\nfunction tokenizeLineHeading(eat, value, silent) {\n    var self = this;\n    var now = eat.now();\n    var length = value.length;\n    var index = -1;\n    var subvalue = EMPTY;\n    var content;\n    var queue;\n    var character;\n    var marker;\n    var depth;\n\n    /*\n     * Eat initial indentation.\n     */\n\n    while (++index < length) {\n        character = value.charAt(index);\n\n        if (character !== C_SPACE || index >= MAX_LINE_HEADING_INDENT) {\n            index--;\n            break;\n        }\n\n        subvalue += character;\n    }\n\n    /*\n     * Eat content.\n     */\n\n    content = queue = EMPTY;\n\n    while (++index < length) {\n        character = value.charAt(index);\n\n        if (character === C_NEWLINE) {\n            index--;\n            break;\n        }\n\n        if (character === C_SPACE || character === C_TAB) {\n            queue += character;\n        } else {\n            content += queue + character;\n            queue = EMPTY;\n        }\n    }\n\n    now.column += subvalue.length;\n    subvalue += content + queue;\n\n    /*\n     * Ensure the content is followed by a newline and a\n     * valid marker.\n     */\n\n    character = value.charAt(++index);\n    marker = value.charAt(++index);\n\n    if (\n        character !== C_NEWLINE ||\n        !SETEXT_MARKERS[marker]\n    ) {\n        return;\n    }\n\n    if (silent) {\n        return true;\n    }\n\n    subvalue += character;\n\n    /*\n     * Eat Setext-line.\n     */\n\n    queue = marker;\n    depth = SETEXT_MARKERS[marker];\n\n    while (++index < length) {\n        character = value.charAt(index);\n\n        if (character !== marker) {\n            if (character !== C_NEWLINE) {\n                return;\n            }\n\n            index--;\n            break;\n        }\n\n        queue += character;\n    }\n\n    return eat(subvalue + queue)(self.renderHeading(content, depth, now));\n}\n\n/**\n * Tokenise a horizontal rule.\n *\n * @example\n *   tokenizeHorizontalRule(eat, '***');\n *\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `horizontalRule` node.\n */\nfunction tokenizeHorizontalRule(eat, value, silent) {\n    var self = this;\n    var index = -1;\n    var length = value.length + 1;\n    var subvalue = EMPTY;\n    var character;\n    var marker;\n    var markerCount;\n    var queue;\n\n    while (++index < length) {\n        character = value.charAt(index);\n\n        if (character !== C_TAB && character !== C_SPACE) {\n            break;\n        }\n\n        subvalue += character;\n    }\n\n    if (RULE_MARKERS[character] !== true) {\n        return;\n    }\n\n    marker = character;\n    subvalue += character;\n    markerCount = 1;\n    queue = EMPTY;\n\n    while (++index < length) {\n        character = value.charAt(index);\n\n        if (character === marker) {\n            markerCount++;\n            subvalue += queue + marker;\n            queue = EMPTY;\n        } else if (character === C_SPACE) {\n            queue += character;\n        } else if (\n            markerCount >= HORIZONTAL_RULE_MARKER_COUNT &&\n            (!character || character === C_NEWLINE)\n        ) {\n            subvalue += queue;\n\n            if (silent) {\n                return true;\n            }\n\n            return eat(subvalue)(self.renderVoid(T_HORIZONTAL_RULE));\n        } else {\n            return;\n        }\n    }\n}\n\n/**\n * Tokenise a blockquote.\n *\n * @example\n *   tokenizeBlockquote(eat, '> Foo');\n *\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `blockquote` node.\n */\nfunction tokenizeBlockquote(eat, value, silent) {\n    var self = this;\n    var commonmark = self.options.commonmark;\n    var now = eat.now();\n    var indent = self.indent(now.line);\n    var length = value.length;\n    var values = [];\n    var contents = [];\n    var indents = [];\n    var add;\n    var tokenizers;\n    var index = 0;\n    var character;\n    var rest;\n    var nextIndex;\n    var content;\n    var line;\n    var startIndex;\n    var prefixed;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (character !== C_SPACE && character !== C_TAB) {\n            break;\n        }\n\n        index++;\n    }\n\n    if (value.charAt(index) !== C_GT) {\n        return;\n    }\n\n    if (silent) {\n        return true;\n    }\n\n    tokenizers = self.blockTokenizers;\n    index = 0;\n\n    while (index < length) {\n        nextIndex = value.indexOf(C_NEWLINE, index);\n        startIndex = index;\n        prefixed = false;\n\n        if (nextIndex === -1) {\n            nextIndex = length;\n        }\n\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (character !== C_SPACE && character !== C_TAB) {\n                break;\n            }\n\n            index++;\n        }\n\n        if (value.charAt(index) === C_GT) {\n            index++;\n            prefixed = true;\n\n            if (value.charAt(index) === C_SPACE) {\n                index++;\n            }\n        } else {\n            index = startIndex;\n        }\n\n        content = value.slice(index, nextIndex);\n\n        if (!prefixed && !trim(content)) {\n            index = startIndex;\n            break;\n        }\n\n        if (!prefixed) {\n            rest = value.slice(index);\n\n            if (\n                commonmark &&\n                (\n                    tokenizers.code.call(self, eat, rest, true) ||\n                    tokenizers.fences.call(self, eat, rest, true) ||\n                    tokenizers.heading.call(self, eat, rest, true) ||\n                    tokenizers.lineHeading.call(self, eat, rest, true) ||\n                    tokenizers.horizontalRule.call(self, eat, rest, true) ||\n                    tokenizers.html.call(self, eat, rest, true) ||\n                    tokenizers.list.call(self, eat, rest, true)\n                )\n            ) {\n                break;\n            }\n\n            if (\n                !commonmark &&\n                (\n                    tokenizers.definition.call(self, eat, rest, true) ||\n                    tokenizers.footnoteDefinition.call(self, eat, rest, true)\n                )\n            ) {\n                break;\n            }\n        }\n\n        line = startIndex === index ?\n            content :\n            value.slice(startIndex, nextIndex);\n\n        indents.push(index - startIndex);\n        values.push(line);\n        contents.push(content);\n\n        index = nextIndex + 1;\n    }\n\n    index = -1;\n    length = indents.length;\n    add = eat(values.join(C_NEWLINE));\n\n    while (++index < length) {\n        indent(indents[index]);\n    }\n\n    return add(self.renderBlockquote(contents.join(C_NEWLINE), now));\n}\n\n/**\n * Tokenise a list.\n *\n * @example\n *   tokenizeList(eat, '- Foo');\n *\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `list` node.\n */\nfunction tokenizeList(eat, value, silent) {\n    var self = this;\n    var commonmark = self.options.commonmark;\n    var pedantic = self.options.pedantic;\n    var tokenizers = self.blockTokenizers;\n    var markers;\n    var index = 0;\n    var length = value.length;\n    var start = null;\n    var queue;\n    var ordered;\n    var character;\n    var marker;\n    var nextIndex;\n    var startIndex;\n    var prefixed;\n    var currentMarker;\n    var content;\n    var line;\n    var prevEmpty;\n    var empty;\n    var items;\n    var allLines;\n    var emptyLines;\n    var item;\n    var enterTop;\n    var exitBlockquote;\n    var isLoose;\n    var node;\n    var now;\n    var end;\n    var indented;\n    var size;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (character !== C_SPACE && character !== C_TAB) {\n            break;\n        }\n\n        index++;\n    }\n\n    character = value.charAt(index);\n\n    markers = commonmark ?\n        LIST_ORDERED_COMMONMARK_MARKERS :\n        LIST_ORDERED_MARKERS;\n\n    if (LIST_UNORDERED_MARKERS[character] === true) {\n        marker = character;\n        ordered = false;\n    } else {\n        ordered = true;\n        queue = EMPTY;\n\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (!isNumeric(character)) {\n                break;\n            }\n\n            queue += character;\n            index++;\n        }\n\n        character = value.charAt(index);\n\n        if (!queue || markers[character] !== true) {\n            return;\n        }\n\n        start = parseInt(queue, 10);\n        marker = character;\n    }\n\n    character = value.charAt(++index);\n\n    if (character !== C_SPACE && character !== C_TAB) {\n        return;\n    }\n\n    if (silent) {\n        return true;\n    }\n\n    index = 0;\n    items = [];\n    allLines = [];\n    emptyLines = [];\n\n    while (index < length) {\n        nextIndex = value.indexOf(C_NEWLINE, index);\n        startIndex = index;\n        prefixed = false;\n        indented = false;\n\n        if (nextIndex === -1) {\n            nextIndex = length;\n        }\n\n        end = index + TAB_SIZE;\n        size = 0;\n\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (character === C_TAB) {\n                size += TAB_SIZE - size % TAB_SIZE;\n            } else if (character === C_SPACE) {\n                size++;\n            } else {\n                break;\n            }\n\n            index++;\n        }\n\n        if (size >= TAB_SIZE) {\n            indented = true;\n        }\n\n        if (item && size >= item.indent) {\n            indented = true;\n        }\n\n        character = value.charAt(index);\n        currentMarker = null;\n\n        if (!indented) {\n            if (LIST_UNORDERED_MARKERS[character] === true) {\n                currentMarker = character;\n                index++;\n                size++;\n            } else {\n                queue = EMPTY;\n\n                while (index < length) {\n                    character = value.charAt(index);\n\n                    if (!isNumeric(character)) {\n                        break;\n                    }\n\n                    queue += character;\n                    index++;\n                }\n\n                character = value.charAt(index);\n                index++;\n\n                if (queue && markers[character] === true) {\n                    currentMarker = character;\n                    size += queue.length + 1;\n                }\n            }\n\n            if (currentMarker) {\n                character = value.charAt(index);\n\n                if (character === C_TAB) {\n                    size += TAB_SIZE - size % TAB_SIZE;\n                    index++;\n                } else if (character === C_SPACE) {\n                    end = index + TAB_SIZE;\n\n                    while (index < end) {\n                        if (value.charAt(index) !== C_SPACE) {\n                            break;\n                        }\n\n                        index++;\n                        size++;\n                    }\n\n                    if (index === end && value.charAt(index) === C_SPACE) {\n                        index -= TAB_SIZE - 1;\n                        size -= TAB_SIZE - 1;\n                    }\n                } else if (\n                    character !== C_NEWLINE &&\n                    character !== EMPTY\n                ) {\n                    currentMarker = null;\n                }\n            }\n        }\n\n        if (currentMarker) {\n            if (commonmark && marker !== currentMarker) {\n                break;\n            }\n\n            prefixed = true;\n        } else {\n            if (\n                !commonmark &&\n                !indented &&\n                value.charAt(startIndex) === C_SPACE\n            ) {\n                indented = true;\n            } else if (\n                commonmark &&\n                item\n            ) {\n                indented = size >= item.indent || size > TAB_SIZE;\n            }\n\n            prefixed = false;\n            index = startIndex;\n        }\n\n        line = value.slice(startIndex, nextIndex);\n        content = startIndex === index ? line : value.slice(index, nextIndex);\n\n        if (currentMarker && RULE_MARKERS[currentMarker] === true) {\n            if (\n                tokenizers.horizontalRule.call(self, eat, line, true)\n            ) {\n                break;\n            }\n        }\n\n        prevEmpty = empty;\n        empty = !trim(content).length;\n\n        if (indented && item) {\n            item.value = item.value.concat(emptyLines, line);\n            allLines = allLines.concat(emptyLines, line);\n            emptyLines = [];\n        } else if (prefixed) {\n            if (emptyLines.length) {\n                item.value.push(EMPTY);\n                item.trail = emptyLines.concat();\n            }\n\n            item = {\n                // 'bullet': value.slice(startIndex, index),\n                'value': [line],\n                'indent': size,\n                'trail': []\n            };\n\n            items.push(item);\n            allLines = allLines.concat(emptyLines, line);\n            emptyLines = [];\n        } else if (empty) {\n            // TODO: disable when in pedantic-mode.\n            if (prevEmpty) {\n                break;\n            }\n\n            emptyLines.push(line);\n        } else {\n            if (prevEmpty) {\n                break;\n            }\n\n            if (\n                !pedantic &&\n                tokenizers.horizontalRule.call(self, eat, line, true)\n            ) {\n                break;\n            }\n\n            if (!commonmark) {\n                if (\n                    tokenizers.definition.call(self, eat, line, true) ||\n                    tokenizers.footnoteDefinition.call(self, eat, line, true)\n                ) {\n                    break;\n                }\n            }\n\n            item.value = item.value.concat(emptyLines, line);\n            allLines = allLines.concat(emptyLines, line);\n            emptyLines = [];\n        }\n\n        index = nextIndex + 1;\n    }\n\n    node = eat(allLines.join(C_NEWLINE)).reset({\n        'type': T_LIST,\n        'ordered': ordered,\n        'start': start,\n        'loose': null,\n        'children': []\n    });\n\n    enterTop = self.exitTop();\n    exitBlockquote = self.enterBlockquote();\n    isLoose = false;\n    index = -1;\n    length = items.length;\n\n    while (++index < length) {\n        item = items[index].value.join(C_NEWLINE);\n        now = eat.now();\n\n        item = eat(item)(self.renderListItem(item, now), node);\n\n        if (item.loose) {\n            isLoose = true;\n        }\n\n        item = items[index].trail.join(C_NEWLINE);\n\n        if (index !== length - 1) {\n            item += C_NEWLINE;\n        }\n\n        eat(item);\n    }\n\n    enterTop();\n    exitBlockquote();\n\n    node.loose = isLoose;\n\n    return node;\n}\n\n/**\n * Try to match comment.\n *\n * @param {string} value - Value to parse.\n * @param {Object} settings - Configuration as available on\n *   a parser.\n * @return {string?} - When applicable, the comment at the\n *   start of `value`.\n */\nfunction eatHTMLComment(value, settings) {\n    var index = COMMENT_START_LENGTH;\n    var queue = COMMENT_START;\n    var length = value.length;\n    var commonmark = settings.commonmark;\n    var character;\n    var hasNonDash;\n\n    if (value.slice(0, index) === queue) {\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (\n                character === COMMENT_END_CHAR &&\n                value.slice(index, index + COMMENT_END_LENGTH) === COMMENT_END\n            ) {\n                return queue + COMMENT_END;\n            }\n\n            if (commonmark) {\n                if (character === C_GT && !hasNonDash) {\n                    return;\n                }\n\n                if (character === C_DASH) {\n                    if (value.charAt(index + 1) === C_DASH) {\n                        return;\n                    }\n                } else {\n                    hasNonDash = true;\n                }\n            }\n\n            queue += character;\n            index++;\n        }\n    }\n}\n\n/**\n * Try to match CDATA.\n *\n * @param {string} value - Value to parse.\n * @return {string?} - When applicable, the CDATA at the\n *   start of `value`.\n */\nfunction eatHTMLCDATA(value) {\n    var index = CDATA_START_LENGTH;\n    var queue = value.slice(0, index);\n    var length = value.length;\n    var character;\n\n    if (queue.toUpperCase() === CDATA_START) {\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (\n                character === CDATA_END_CHAR &&\n                value.slice(index, index + CDATA_END_LENGTH) === CDATA_END\n            ) {\n                return queue + CDATA_END;\n            }\n\n            queue += character;\n            index++;\n        }\n    }\n}\n\n/**\n * Try to match a processing instruction.\n *\n * @param {string} value - Value to parse.\n * @return {string?} - When applicable, the processing\n *   instruction at the start of `value`.\n */\nfunction eatHTMLProcessingInstruction(value) {\n    var index = 0;\n    var queue = EMPTY;\n    var length = value.length;\n    var character;\n\n    if (\n        value.charAt(index) === C_LT &&\n        value.charAt(++index) === C_QUESTION_MARK\n    ) {\n        queue = C_LT + C_QUESTION_MARK;\n        index++;\n\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (\n                character === C_QUESTION_MARK &&\n                value.charAt(index + 1) === C_GT\n            ) {\n                return queue + character + C_GT;\n            }\n\n            queue += character;\n            index++;\n        }\n    }\n}\n\n/**\n * Try to match a declaration.\n *\n * @param {string} value - Value to parse.\n * @return {string?} - When applicable, the declaration at\n *   the start of `value`.\n */\nfunction eatHTMLDeclaration(value) {\n    var index = 0;\n    var length = value.length;\n    var queue = EMPTY;\n    var subqueue = EMPTY;\n    var character;\n\n    if (\n        value.charAt(index) === C_LT &&\n        value.charAt(++index) === C_EXCLAMATION_MARK\n    ) {\n        queue = C_LT + C_EXCLAMATION_MARK;\n        index++;\n\n        /*\n         * Eat as many alphabetic characters as\n         * possible.\n         */\n\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (!isAlphabetic(character)) {\n                break;\n            }\n\n            subqueue += character;\n            index++;\n        }\n\n        character = value.charAt(index);\n\n        if (!subqueue || !isWhiteSpace(character)) {\n            return;\n        }\n\n        queue += subqueue + character;\n        index++;\n\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (character === C_GT) {\n                return queue;\n            }\n\n            queue += character;\n            index++;\n        }\n    }\n}\n\n/**\n * Try to match a closing tag.\n *\n * @param {string} value - Value to parse.\n * @param {boolean?} [isBlock] - Whether the tag-name\n *   must be a known block-level node to match.\n * @return {string?} - When applicable, the closing tag at\n *   the start of `value`.\n */\nfunction eatHTMLClosingTag(value, isBlock) {\n    var index = 0;\n    var length = value.length;\n    var queue = EMPTY;\n    var subqueue = EMPTY;\n    var character;\n\n    if (\n        value.charAt(index) === C_LT &&\n        value.charAt(++index) === C_SLASH\n    ) {\n        queue = C_LT + C_SLASH;\n        subqueue = character = value.charAt(++index);\n\n        if (!isAlphabetic(character)) {\n            return;\n        }\n\n        index++;\n\n        /*\n         * Eat as many alphabetic characters as\n         * possible.\n         */\n\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (!isAlphabetic(character) && !isNumeric(character)) {\n                break;\n            }\n\n            subqueue += character;\n            index++;\n        }\n\n        if (isBlock && blockElements.indexOf(subqueue.toLowerCase()) === -1) {\n            return;\n        }\n\n        queue += subqueue;\n\n        /*\n         * Eat white-space.\n         */\n\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (!isWhiteSpace(character)) {\n                break;\n            }\n\n            queue += character;\n            index++;\n        }\n\n        if (value.charAt(index) === C_GT) {\n            return queue + C_GT;\n        }\n    }\n}\n\n/**\n * Try to match an opening tag.\n *\n * @param {string} value - Value to parse.\n * @param {boolean?} [isBlock] - Whether the tag-name\n *   must be a known block-level node to match.\n * @return {string?} - When applicable, the opening tag at\n *   the start of `value`.\n */\nfunction eatHTMLOpeningTag(value, isBlock) {\n    var index = 0;\n    var length = value.length;\n    var queue = EMPTY;\n    var subqueue = EMPTY;\n    var character = value.charAt(index);\n    var hasEquals;\n    var test;\n\n    if (character === C_LT) {\n        queue = character;\n        subqueue = character = value.charAt(++index);\n\n        if (!isAlphabetic(character)) {\n            return;\n        }\n\n        index++;\n\n        /*\n         * Eat as many alphabetic characters as\n         * possible.\n         */\n\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (!isAlphabetic(character) && !isNumeric(character)) {\n                break;\n            }\n\n            subqueue += character;\n            index++;\n        }\n\n        if (isBlock && blockElements.indexOf(subqueue.toLowerCase()) === -1) {\n            return;\n        }\n\n        queue += subqueue;\n        subqueue = EMPTY;\n\n        /*\n         * Find attributes.\n         */\n\n        while (index < length) {\n            /*\n             * Eat white-space.\n             */\n\n            while (index < length) {\n                character = value.charAt(index);\n\n                if (!isWhiteSpace(character)) {\n                    break;\n                }\n\n                subqueue += character;\n                index++;\n            }\n\n            if (!subqueue) {\n                break;\n            }\n\n            /*\n             * Eat an attribute name.\n             */\n\n            queue += subqueue;\n            subqueue = EMPTY;\n            character = value.charAt(index);\n\n            if (\n                isAlphabetic(character) ||\n                character === C_UNDERSCORE ||\n                character === C_COLON\n            ) {\n                subqueue = character;\n                index++;\n\n                while (index < length) {\n                    character = value.charAt(index);\n\n                    if (\n                        !isAlphabetic(character) &&\n                        !isNumeric(character) &&\n                        character !== C_UNDERSCORE &&\n                        character !== C_COLON &&\n                        character !== C_DOT &&\n                        character !== C_DASH\n                    ) {\n                        break;\n                    }\n\n                    subqueue += character;\n                    index++;\n                }\n            }\n\n            if (!subqueue) {\n                break;\n            }\n\n            queue += subqueue;\n            subqueue = EMPTY;\n            hasEquals = false;\n\n            /*\n             * Eat zero or more white-space and one\n             * equals sign.\n             */\n\n            while (index < length) {\n                character = value.charAt(index);\n\n                if (!isWhiteSpace(character)) {\n                    if (!hasEquals && character === C_EQUALS) {\n                        hasEquals = true;\n                    } else {\n                        break;\n                    }\n                }\n\n                subqueue += character;\n                index++;\n            }\n\n            queue += subqueue;\n            subqueue = EMPTY;\n\n            if (!hasEquals) {\n                queue += subqueue;\n            } else {\n                character = value.charAt(index);\n                queue += subqueue;\n\n                if (character === C_DOUBLE_QUOTE) {\n                    test = isDoubleQuotedAttributeCharacter;\n                    subqueue = character;\n                    index++;\n                } else if (character === C_SINGLE_QUOTE) {\n                    test = isSingleQuotedAttributeCharacter;\n                    subqueue = character;\n                    index++;\n                } else {\n                    test = isUnquotedAttributeCharacter;\n                    subqueue = EMPTY;\n                }\n\n                while (index < length) {\n                    character = value.charAt(index);\n\n                    if (!test(character)) {\n                        break;\n                    }\n\n                    subqueue += character;\n                    index++;\n                }\n\n                character = value.charAt(index);\n                index++;\n\n                if (!test.delimiter) {\n                    if (!subqueue.length) {\n                        return;\n                    }\n\n                    index--;\n                } else if (character === test.delimiter) {\n                    subqueue += character;\n                } else {\n                    return;\n                }\n\n                queue += subqueue;\n                subqueue = EMPTY;\n            }\n        }\n\n        /*\n         * More white-space is already eaten by the\n         * attributes subroutine.\n         */\n\n        character = value.charAt(index);\n\n        /*\n         * Eat an optional backslash (for self-closing\n         * tags).\n         */\n\n        if (character === C_SLASH) {\n            queue += character;\n            character = value.charAt(++index);\n        }\n\n        return character === C_GT ? queue + character : null;\n    }\n}\n\n/**\n * Tokenise HTML.\n *\n * @example\n *   tokenizeHTML(eat, '<span>foo</span>');\n *\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `html` node.\n */\nfunction tokenizeHTML(eat, value, silent) {\n    var self = this;\n    var index = 0;\n    var length = value.length;\n    var subvalue = EMPTY;\n    var offset;\n    var lineCount;\n    var character;\n    var queue;\n\n    /*\n     * Eat initial spacing.\n     */\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (character !== C_TAB && character !== C_SPACE) {\n            break;\n        }\n\n        subvalue += character;\n        index++;\n    }\n\n    offset = index;\n    value = value.slice(offset);\n\n    /*\n     * Try to eat an HTML thing.\n     */\n\n    queue = eatHTMLComment(value, self.options) ||\n        eatHTMLCDATA(value) ||\n        eatHTMLProcessingInstruction(value) ||\n        eatHTMLDeclaration(value) ||\n        eatHTMLClosingTag(value, true) ||\n        eatHTMLOpeningTag(value, true);\n\n    if (!queue) {\n        return;\n    }\n\n    if (silent) {\n        return true;\n    }\n\n    subvalue += queue;\n    index = subvalue.length - offset;\n    queue = EMPTY;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (character === C_NEWLINE) {\n            queue += character;\n            lineCount++;\n        } else if (queue.length < MIN_CLOSING_HTML_NEWLINE_COUNT) {\n            subvalue += queue + character;\n            queue = EMPTY;\n        } else {\n            break;\n        }\n\n        index++;\n    }\n\n    return eat(subvalue)(self.renderRaw(T_HTML, subvalue));\n}\n\n/**\n * Tokenise a definition.\n *\n * @example\n *   var value = '[foo]: http://example.com \"Example Domain\"';\n *   tokenizeDefinition(eat, value);\n *\n * @property {boolean} onlyAtTop\n * @property {boolean} notInBlockquote\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `definition` node.\n */\nfunction tokenizeDefinition(eat, value, silent) {\n    var self = this;\n    var commonmark = self.options.commonmark;\n    var index = 0;\n    var length = value.length;\n    var subvalue = EMPTY;\n    var beforeURL;\n    var beforeTitle;\n    var queue;\n    var character;\n    var test;\n    var identifier;\n    var url;\n    var title;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (character !== C_SPACE && character !== C_TAB) {\n            break;\n        }\n\n        subvalue += character;\n        index++;\n    }\n\n    character = value.charAt(index);\n\n    if (character !== C_BRACKET_OPEN) {\n        return;\n    }\n\n    index++;\n    subvalue += character;\n    queue = EMPTY;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (character === C_BRACKET_CLOSE) {\n            break;\n        } else if (character === C_BACKSLASH) {\n            queue += character;\n            index++;\n            character = value.charAt(index);\n        }\n\n        queue += character;\n        index++;\n    }\n\n    if (\n        !queue ||\n        value.charAt(index) !== C_BRACKET_CLOSE ||\n        value.charAt(index + 1) !== C_COLON\n    ) {\n        return;\n    }\n\n    identifier = queue;\n    subvalue += queue + C_BRACKET_CLOSE + C_COLON;\n    index = subvalue.length;\n    queue = EMPTY;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (\n            character !== C_TAB &&\n            character !== C_SPACE &&\n            character !== C_NEWLINE\n        ) {\n            break;\n        }\n\n        subvalue += character;\n        index++;\n    }\n\n    character = value.charAt(index);\n    queue = EMPTY;\n    beforeURL = subvalue;\n\n    if (character === C_LT) {\n        index++;\n\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (!isEnclosedURLCharacter(character)) {\n                break;\n            }\n\n            queue += character;\n            index++;\n        }\n\n        character = value.charAt(index);\n\n        if (character !== isEnclosedURLCharacter.delimiter) {\n            if (commonmark) {\n                return;\n            }\n\n            index -= queue.length + 1;\n            queue = EMPTY;\n        } else {\n            subvalue += C_LT + queue + character;\n            index++;\n        }\n    }\n\n    if (!queue) {\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (!isUnclosedURLCharacter(character)) {\n                break;\n            }\n\n            queue += character;\n            index++;\n        }\n\n        subvalue += queue;\n    }\n\n    if (!queue) {\n        return;\n    }\n\n    url = queue;\n    queue = EMPTY;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (\n            character !== C_TAB &&\n            character !== C_SPACE &&\n            character !== C_NEWLINE\n        ) {\n            break;\n        }\n\n        queue += character;\n        index++;\n    }\n\n    character = value.charAt(index);\n    test = null;\n\n    if (character === C_DOUBLE_QUOTE) {\n        test = C_DOUBLE_QUOTE;\n    } else if (character === C_SINGLE_QUOTE) {\n        test = C_SINGLE_QUOTE;\n    } else if (character === C_PAREN_OPEN) {\n        test = C_PAREN_CLOSE;\n    }\n\n    if (!test) {\n        queue = EMPTY;\n        index = subvalue.length;\n    } else if (!queue) {\n        return;\n    } else {\n        subvalue += queue + character;\n        index = subvalue.length;\n        queue = EMPTY;\n\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (character === test) {\n                break;\n            }\n\n            if (character === C_NEWLINE) {\n                index++;\n                character = value.charAt(index);\n\n                if (character === C_NEWLINE || character === test) {\n                    return;\n                }\n\n                queue += C_NEWLINE;\n            }\n\n            queue += character;\n            index++;\n        }\n\n        character = value.charAt(index);\n\n        if (character !== test) {\n            return;\n        }\n\n        beforeTitle = subvalue;\n        subvalue += queue + character;\n        index++;\n        title = queue;\n        queue = EMPTY;\n    }\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (character !== C_TAB && character !== C_SPACE) {\n            break;\n        }\n\n        subvalue += character;\n        index++;\n    }\n\n    character = value.charAt(index);\n\n    if (!character || character === C_NEWLINE) {\n        if (silent) {\n            return true;\n        }\n\n        beforeURL = eat(beforeURL).test().end;\n        url = self.decode.raw(self.descape(url), beforeURL);\n\n        if (title) {\n            beforeTitle = eat(beforeTitle).test().end;\n            title = self.decode.raw(self.descape(title), beforeTitle);\n        }\n\n        return eat(subvalue)({\n            'type': T_DEFINITION,\n            'identifier': normalize(identifier),\n            'title': title || null,\n            'link': url\n        });\n    }\n}\n\ntokenizeDefinition.onlyAtTop = true;\ntokenizeDefinition.notInBlockquote = true;\n\n/**\n * Tokenise YAML front matter.\n *\n * @example\n *   tokenizeYAMLFrontMatter(eat, '---\\nfoo: bar\\n---');\n *\n * @property {boolean} onlyAtStart\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `yaml` node.\n */\nfunction tokenizeYAMLFrontMatter(eat, value, silent) {\n    var self = this;\n    var subvalue;\n    var content;\n    var index;\n    var length;\n    var character;\n    var queue;\n\n    if (\n        !self.options.yaml ||\n        value.charAt(0) !== C_DASH ||\n        value.charAt(1) !== C_DASH ||\n        value.charAt(2) !== C_DASH ||\n        value.charAt(3) !== C_NEWLINE\n    ) {\n        return;\n    }\n\n    subvalue = YAML_FENCE + C_NEWLINE;\n    content = queue = EMPTY;\n    index = 3;\n    length = value.length;\n\n    while (++index < length) {\n        character = value.charAt(index);\n\n        if (\n            character === C_DASH &&\n            (queue || !content) &&\n            value.charAt(index + 1) === C_DASH &&\n            value.charAt(index + 2) === C_DASH\n        ) {\n            /* istanbul ignore if - never used (yet) */\n            if (silent) {\n                return true;\n            }\n\n            subvalue += queue + YAML_FENCE;\n\n            return eat(subvalue)(self.renderRaw(T_YAML, content));\n        }\n\n        if (character === C_NEWLINE) {\n            queue += character;\n        } else {\n            subvalue += queue + character;\n            content += queue + character;\n            queue = EMPTY;\n        }\n    }\n}\n\ntokenizeYAMLFrontMatter.onlyAtStart = true;\n\n/**\n * Tokenise a footnote definition.\n *\n * @example\n *   tokenizeFootnoteDefinition(eat, '[^foo]: Bar.');\n *\n * @property {boolean} onlyAtTop\n * @property {boolean} notInBlockquote\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `footnoteDefinition` node.\n */\nfunction tokenizeFootnoteDefinition(eat, value, silent) {\n    var self = this;\n    var index;\n    var length;\n    var subvalue;\n    var now;\n    var indent;\n    var content;\n    var queue;\n    var subqueue;\n    var character;\n    var identifier;\n\n    if (!self.options.footnotes) {\n        return;\n    }\n\n    index = 0;\n    length = value.length;\n    subvalue = EMPTY;\n    now = eat.now();\n    indent = self.indent(now.line);\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (!isWhiteSpace(character)) {\n            break;\n        }\n\n        subvalue += character;\n        index++;\n    }\n\n    if (\n        value.charAt(index) !== C_BRACKET_OPEN ||\n        value.charAt(index + 1) !== C_CARET\n    ) {\n        return;\n    }\n\n    subvalue += C_BRACKET_OPEN + C_CARET;\n    index = subvalue.length;\n    queue = EMPTY;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (character === C_BRACKET_CLOSE) {\n            break;\n        } else if (character === C_BACKSLASH) {\n            queue += character;\n            index++;\n            character = value.charAt(index);\n        }\n\n        queue += character;\n        index++;\n    }\n\n    if (\n        !queue ||\n        value.charAt(index) !== C_BRACKET_CLOSE ||\n        value.charAt(index + 1) !== C_COLON\n    ) {\n        return;\n    }\n\n    if (silent) {\n        return true;\n    }\n\n    identifier = normalize(queue);\n    subvalue += queue + C_BRACKET_CLOSE + C_COLON;\n    index = subvalue.length;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (\n            character !== C_TAB &&\n            character !== C_SPACE\n        ) {\n            break;\n        }\n\n        subvalue += character;\n        index++;\n    }\n\n    now.column += subvalue.length;\n    queue = content = subqueue = EMPTY;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (character === C_NEWLINE) {\n            subqueue = character;\n            index++;\n\n            while (index < length) {\n                character = value.charAt(index);\n\n                if (character !== C_NEWLINE) {\n                    break;\n                }\n\n                subqueue += character;\n                index++;\n            }\n\n            queue += subqueue;\n            subqueue = EMPTY;\n\n            while (index < length) {\n                character = value.charAt(index);\n\n                if (character !== C_SPACE) {\n                    break;\n                }\n\n                subqueue += character;\n                index++;\n            }\n\n            if (!subqueue.length) {\n                break;\n            }\n\n            queue += subqueue;\n        }\n\n        if (queue) {\n            content += queue;\n            queue = EMPTY;\n        }\n\n        content += character;\n        index++;\n    }\n\n    subvalue += content;\n\n    content = content.replace(EXPRESSION_INITIAL_TAB, function (line) {\n        indent(line.length);\n\n        return EMPTY;\n    });\n\n    return eat(subvalue)(\n        self.renderFootnoteDefinition(identifier, content, now)\n    );\n}\n\ntokenizeFootnoteDefinition.onlyAtTop = true;\ntokenizeFootnoteDefinition.notInBlockquote = true;\n\n/**\n * Tokenise a table.\n *\n * @example\n *   tokenizeTable(eat, ' | foo |\\n | --- |\\n | bar |');\n *\n * @property {boolean} onlyAtTop\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `table` node.\n */\nfunction tokenizeTable(eat, value, silent) {\n    var self = this;\n    var index;\n    var alignments;\n    var alignment;\n    var subvalue;\n    var row;\n    var length;\n    var lines;\n    var queue;\n    var character;\n    var hasDash;\n    var align;\n    var cell;\n    var preamble;\n    var count;\n    var opening;\n    var now;\n    var position;\n    var lineCount;\n    var line;\n    var rows;\n    var table;\n    var lineIndex;\n    var pipeIndex;\n    var first;\n\n    /*\n     * Exit when not in gfm-mode.\n     */\n\n    if (!self.options.gfm) {\n        return;\n    }\n\n    /*\n     * Get the rows.\n     * Detecting tables soon is hard, so there are some\n     * checks for performance here, such as the minimum\n     * number of rows, and allowed characters in the\n     * alignment row.\n     */\n\n    index = lineCount = 0;\n    length = value.length + 1;\n    lines = [];\n\n    while (index < length) {\n        lineIndex = value.indexOf(C_NEWLINE, index);\n        pipeIndex = value.indexOf(C_PIPE, index + 1);\n\n        if (lineIndex === -1) {\n            lineIndex = value.length;\n        }\n\n        if (\n            pipeIndex === -1 ||\n            pipeIndex > lineIndex\n        ) {\n            if (lineCount < MIN_TABLE_ROWS) {\n                return;\n            }\n\n            break;\n        }\n\n        lines.push(value.slice(index, lineIndex));\n        lineCount++;\n        index = lineIndex + 1;\n    }\n\n    /*\n     * Parse the alignment row.\n     */\n\n    subvalue = lines.join(C_NEWLINE);\n    alignments = lines.splice(1, 1)[0];\n    index = 0;\n    length = alignments.length;\n    lineCount--;\n    alignment = false;\n    align = [];\n\n    while (index < length) {\n        character = alignments.charAt(index);\n\n        if (character === C_PIPE) {\n            hasDash = null;\n\n            if (alignment === false) {\n                if (first === false) {\n                    return;\n                }\n            } else {\n                align.push(alignment);\n                alignment = false;\n            }\n\n            first = false;\n        } else if (character === C_DASH) {\n            hasDash = true;\n            alignment = alignment || TABLE_ALIGN_NONE;\n        } else if (character === C_COLON) {\n            if (alignment === TABLE_ALIGN_LEFT) {\n                alignment = TABLE_ALIGN_CENTER;\n            } else if (hasDash && alignment === TABLE_ALIGN_NONE) {\n                alignment = TABLE_ALIGN_RIGHT;\n            } else {\n                alignment = TABLE_ALIGN_LEFT;\n            }\n        } else if (!isWhiteSpace(character)) {\n            return;\n        }\n\n        index++;\n    }\n\n    if (alignment !== false) {\n        align.push(alignment);\n    }\n\n    /*\n     * Exit when without enough columns.\n     */\n\n    if (align.length < MIN_TABLE_COLUMNS) {\n        return;\n    }\n\n    /* istanbul ignore if - never used (yet) */\n    if (silent) {\n        return true;\n    }\n\n    /*\n     * Parse the rows.\n     */\n\n    position = -1;\n    rows = [];\n\n    table = eat(subvalue).reset({\n        'type': T_TABLE,\n        'align': align,\n        'children': rows\n    });\n\n    while (++position < lineCount) {\n        line = lines[position];\n        row = self.renderParent(position ? T_TABLE_ROW : T_TABLE_HEADER, []);\n\n        /*\n         * Eat a newline character when this is not the\n         * first row.\n         */\n\n        if (position) {\n            eat(C_NEWLINE);\n        }\n\n        /*\n         * Eat the row.\n         */\n\n        eat(line).reset(row, table);\n\n        length = line.length + 1;\n        index = 0;\n        queue = EMPTY;\n        cell = EMPTY;\n        preamble = true;\n        count = opening = null;\n\n        while (index < length) {\n            character = line.charAt(index);\n\n            if (character === C_TAB || character === C_SPACE) {\n                if (cell) {\n                    queue += character;\n                } else {\n                    eat(character);\n                }\n\n                index++;\n                continue;\n            }\n\n            if (character === EMPTY || character === C_PIPE) {\n                if (preamble) {\n                    eat(character);\n                } else {\n                    if (character && opening) {\n                        queue += character;\n                        index++;\n                        continue;\n                    }\n\n                    if ((cell || character) && !preamble) {\n                        subvalue = cell;\n\n                        if (queue.length > 1) {\n                            if (character) {\n                                subvalue += queue.slice(0, queue.length - 1);\n                                queue = queue.charAt(queue.length - 1);\n                            } else {\n                                subvalue += queue;\n                                queue = EMPTY;\n                            }\n                        }\n\n                        now = eat.now();\n\n                        eat(subvalue)(\n                            self.renderInline(T_TABLE_CELL, cell, now), row\n                        );\n                    }\n\n                    eat(queue + character);\n\n                    queue = EMPTY;\n                    cell = EMPTY;\n                }\n            } else {\n                if (queue) {\n                    cell += queue;\n                    queue = EMPTY;\n                }\n\n                cell += character;\n\n                if (character === C_BACKSLASH && index !== length - 2) {\n                    cell += line.charAt(index + 1);\n                    index++;\n                }\n\n                if (character === C_TICK) {\n                    count = 1;\n\n                    while (line.charAt(index + 1) === character) {\n                        cell += character;\n                        index++;\n                        count++;\n                    }\n\n                    if (!opening) {\n                        opening = count;\n                    } else if (count >= opening) {\n                        opening = 0;\n                    }\n                }\n            }\n\n            preamble = false;\n            index++;\n        }\n\n        /*\n         * Eat the alignment row.\n         */\n\n        if (!position) {\n            eat(C_NEWLINE + alignments);\n        }\n    }\n\n    return table;\n}\n\ntokenizeTable.onlyAtTop = true;\n\n/**\n * Tokenise a paragraph node.\n *\n * @example\n *   tokenizeParagraph(eat, 'Foo.');\n *\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `paragraph` node.\n */\nfunction tokenizeParagraph(eat, value, silent) {\n    var self = this;\n    var settings = self.options;\n    var commonmark = settings.commonmark;\n    var gfm = settings.gfm;\n    var tokenizers = self.blockTokenizers;\n    var index = value.indexOf(C_NEWLINE);\n    var length = value.length;\n    var position;\n    var subvalue;\n    var character;\n    var size;\n    var now;\n\n    while (index < length) {\n        /*\n         * Eat everything if there’s no following newline.\n         */\n\n        if (index === -1) {\n            index = length;\n            break;\n        }\n\n        /*\n         * Stop if the next character is NEWLINE.\n         */\n\n        if (value.charAt(index + 1) === C_NEWLINE) {\n            break;\n        }\n\n        /*\n         * In commonmark-mode, following indented lines\n         * are part of the paragraph.\n         */\n\n        if (commonmark) {\n            size = 0;\n            position = index + 1;\n\n            while (position < length) {\n                character = value.charAt(position);\n\n                if (character === C_TAB) {\n                    size = TAB_SIZE;\n                    break;\n                } else if (character === C_SPACE) {\n                    size++;\n                } else {\n                    break;\n                }\n\n                position++;\n            }\n\n            if (size >= TAB_SIZE) {\n                index = value.indexOf(C_NEWLINE, index + 1);\n                continue;\n            }\n        }\n\n        /*\n         * Check if the following code contains a possible\n         * block.\n         */\n\n        subvalue = value.slice(index + 1);\n\n        if (\n            tokenizers.horizontalRule.call(self, eat, subvalue, true) ||\n            tokenizers.heading.call(self, eat, subvalue, true) ||\n            tokenizers.fences.call(self, eat, subvalue, true) ||\n            tokenizers.blockquote.call(self, eat, subvalue, true) ||\n            tokenizers.html.call(self, eat, subvalue, true)\n        ) {\n            break;\n        }\n\n        if (gfm && tokenizers.list.call(self, eat, subvalue, true)) {\n            break;\n        }\n\n        if (\n            !commonmark &&\n            (\n                tokenizers.lineHeading.call(self, eat, subvalue, true) ||\n                tokenizers.definition.call(self, eat, subvalue, true) ||\n                tokenizers.footnoteDefinition.call(self, eat, subvalue, true)\n            )\n        ) {\n            break;\n        }\n\n        index = value.indexOf(C_NEWLINE, index + 1);\n    }\n\n    subvalue = value.slice(0, index);\n\n    if (trim(subvalue) === EMPTY) {\n        eat(subvalue);\n\n        return null;\n    }\n\n    /* istanbul ignore if - never used (yet) */\n    if (silent) {\n        return true;\n    }\n\n    now = eat.now();\n    subvalue = trimTrailingLines(subvalue);\n\n    return eat(subvalue)(self.renderInline(T_PARAGRAPH, subvalue, now));\n}\n\n/**\n * Tokenise a text node.\n *\n * @example\n *   tokenizeText(eat, 'foo');\n *\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `text` node.\n */\nfunction tokenizeText(eat, value, silent) {\n    var self = this;\n    var methods;\n    var tokenizers;\n    var index;\n    var length;\n    var subvalue;\n    var position;\n    var tokenizer;\n    var name;\n    var min;\n    var now;\n\n    /* istanbul ignore if - never used (yet) */\n    if (silent) {\n        return true;\n    }\n\n    methods = self.inlineMethods;\n    length = methods.length;\n    tokenizers = self.inlineTokenizers;\n    index = -1;\n    min = value.length;\n\n    while (++index < length) {\n        name = methods[index];\n\n        if (name === 'inlineText' || !tokenizers[name]) {\n            continue;\n        }\n\n        tokenizer = tokenizers[name].locator;\n\n        if (!tokenizer) {\n            eat.file.fail(ERR_MISSING_LOCATOR + C_TICK + name + C_TICK);\n            continue;\n        }\n\n        position = tokenizer.call(self, value, 1);\n\n        if (position !== -1 && position < min) {\n            min = position;\n        }\n    }\n\n    subvalue = value.slice(0, min);\n    now = eat.now();\n\n    self.decode(subvalue, now, function (content, position, source) {\n        eat(source || content)(self.renderRaw(T_TEXT, content));\n    });\n}\n\n/**\n * Create a code-block node.\n *\n * @example\n *   renderCodeBlock('foo()', 'js', now());\n *\n * @param {string?} [value] - Code.\n * @param {string?} [language] - Optional language flag.\n * @param {Function} eat - Eater.\n * @return {Object} - `code` node.\n */\nfunction renderCodeBlock(value, language) {\n    return {\n        'type': T_CODE,\n        'lang': language || null,\n        'value': trimTrailingLines(value || EMPTY)\n    };\n}\n\n/**\n * Create a list-item using overly simple mechanics.\n *\n * @example\n *   renderPedanticListItem('- _foo_', now());\n *\n * @param {string} value - List-item.\n * @param {Object} position - List-item location.\n * @return {string} - Cleaned `value`.\n */\nfunction renderPedanticListItem(value, position) {\n    var self = this;\n    var indent = self.indent(position.line);\n\n    /**\n     * A simple replacer which removed all matches,\n     * and adds their length to `offset`.\n     *\n     * @param {string} $0 - Indentation to subtract.\n     * @return {string} - An empty string.\n     */\n    function replacer($0) {\n        indent($0.length);\n\n        return EMPTY;\n    }\n\n    /*\n     * Remove the list-item’s bullet.\n     */\n\n    value = value.replace(EXPRESSION_PEDANTIC_BULLET, replacer);\n\n    /*\n     * The initial line was also matched by the below, so\n     * we reset the `line`.\n     */\n\n    indent = self.indent(position.line);\n\n    return value.replace(EXPRESSION_INITIAL_INDENT, replacer);\n}\n\n/**\n * Create a list-item using sane mechanics.\n *\n * @example\n *   renderNormalListItem('- _foo_', now());\n *\n * @param {string} value - List-item.\n * @param {Object} position - List-item location.\n * @return {string} - Cleaned `value`.\n */\nfunction renderNormalListItem(value, position) {\n    var self = this;\n    var indent = self.indent(position.line);\n    var max;\n    var bullet;\n    var rest;\n    var lines;\n    var trimmedLines;\n    var index;\n    var length;\n\n    /*\n     * Remove the list-item’s bullet.\n     */\n\n    value = value.replace(EXPRESSION_BULLET, function ($0, $1, $2, $3, $4) {\n        bullet = $1 + $2 + $3;\n        rest = $4;\n\n        /*\n         * Make sure that the first nine numbered list items\n         * can indent with an extra space.  That is, when\n         * the bullet did not receive an extra final space.\n         */\n\n        if (Number($2) < 10 && bullet.length % 2 === 1) {\n            $2 = C_SPACE + $2;\n        }\n\n        max = $1 + repeat(C_SPACE, $2.length) + $3;\n\n        return max + rest;\n    });\n\n    lines = value.split(C_NEWLINE);\n\n    trimmedLines = removeIndentation(\n        value, getIndent(max).indent\n    ).split(C_NEWLINE);\n\n    /*\n     * We replaced the initial bullet with something\n     * else above, which was used to trick\n     * `removeIndentation` into removing some more\n     * characters when possible. However, that could\n     * result in the initial line to be stripped more\n     * than it should be.\n     */\n\n    trimmedLines[0] = rest;\n\n    indent(bullet.length);\n\n    index = 0;\n    length = lines.length;\n\n    while (++index < length) {\n        indent(lines[index].length - trimmedLines[index].length);\n    }\n\n    return trimmedLines.join(C_NEWLINE);\n}\n\n/**\n * Create a list-item node.\n *\n * @example\n *   renderListItem('- _foo_', now());\n *\n * @param {Object} value - List-item.\n * @param {Object} position - List-item location.\n * @return {Object} - `listItem` node.\n */\nfunction renderListItem(value, position) {\n    var self = this;\n    var checked = null;\n    var node;\n    var task;\n    var indent;\n\n    value = LIST_ITEM_MAP[self.options.pedantic].apply(self, arguments);\n\n    if (self.options.gfm) {\n        task = value.match(EXPRESSION_TASK_ITEM);\n\n        if (task) {\n            indent = task[0].length;\n            checked = task[1].toLowerCase() === C_X_LOWER;\n\n            self.indent(position.line)(indent);\n            value = value.slice(indent);\n        }\n    }\n\n    node = {\n        'type': T_LIST_ITEM,\n        'loose': EXPRESSION_LOOSE_LIST_ITEM.test(value) ||\n            value.charAt(value.length - 1) === C_NEWLINE\n    };\n\n    if (self.options.gfm) {\n        node.checked = checked;\n    }\n\n    node.children = self.tokenizeBlock(value, position);\n\n    return node;\n}\n\n/**\n * Create a footnote-definition node.\n *\n * @example\n *   renderFootnoteDefinition('1', '_foo_', now());\n *\n * @param {string} identifier - Unique reference.\n * @param {string} value - Contents\n * @param {Object} position - Definition location.\n * @return {Object} - `footnoteDefinition` node.\n */\nfunction renderFootnoteDefinition(identifier, value, position) {\n    var self = this;\n    var exitBlockquote = self.enterBlockquote();\n    var node;\n\n    node = {\n        'type': T_FOOTNOTE_DEFINITION,\n        'identifier': identifier,\n        'children': self.tokenizeBlock(value, position)\n    };\n\n    exitBlockquote();\n\n    return node;\n}\n\n/**\n * Create a heading node.\n *\n * @example\n *   renderHeading('_foo_', 1, now());\n *\n * @param {string} value - Content.\n * @param {number} depth - Heading depth.\n * @param {Object} position - Heading content location.\n * @return {Object} - `heading` node\n */\nfunction renderHeading(value, depth, position) {\n    return {\n        'type': T_HEADING,\n        'depth': depth,\n        'children': this.tokenizeInline(value, position)\n    };\n}\n\n/**\n * Create a blockquote node.\n *\n * @example\n *   renderBlockquote('_foo_', eat);\n *\n * @param {string} value - Content.\n * @param {Object} now - Position.\n * @return {Object} - `blockquote` node.\n */\nfunction renderBlockquote(value, now) {\n    var self = this;\n    var exitBlockquote = self.enterBlockquote();\n    var node = {\n        'type': T_BLOCKQUOTE,\n        'children': self.tokenizeBlock(value, now)\n    };\n\n    exitBlockquote();\n\n    return node;\n}\n\n/**\n * Create a void node.\n *\n * @example\n *   renderVoid('horizontalRule');\n *\n * @param {string} type - Node type.\n * @return {Object} - Node of type `type`.\n */\nfunction renderVoid(type) {\n    return {\n        'type': type\n    };\n}\n\n/**\n * Create a parent.\n *\n * @example\n *   renderParent('paragraph', '_foo_');\n *\n * @param {string} type - Node type.\n * @param {Array.<Object>} children - Child nodes.\n * @return {Object} - Node of type `type`.\n */\nfunction renderParent(type, children) {\n    return {\n        'type': type,\n        'children': children\n    };\n}\n\n/**\n * Create a raw node.\n *\n * @example\n *   renderRaw('inlineCode', 'foo()');\n *\n * @param {string} type - Node type.\n * @param {string} value - Contents.\n * @return {Object} - Node of type `type`.\n */\nfunction renderRaw(type, value) {\n    return {\n        'type': type,\n        'value': value\n    };\n}\n\n/**\n * Create a link node.\n *\n * @example\n *   renderLink(true, 'example.com', 'example', 'Example Domain', now(), eat);\n *   renderLink(false, 'fav.ico', 'example', 'Example Domain', now(), eat);\n *\n * @param {boolean} isLink - Whether linking to a document\n *   or an image.\n * @param {string} href - URI reference.\n * @param {string} text - Content.\n * @param {string?} title - Title.\n * @param {Object} position - Location of link.\n * @return {Object} - `link` or `image` node.\n */\nfunction renderLink(isLink, href, text, title, position) {\n    var self = this;\n    var exitLink = self.enterLink();\n    var node;\n\n    node = {\n        'type': isLink ? T_LINK : T_IMAGE,\n        'title': title || null\n    };\n\n    if (isLink) {\n        node.href = href;\n        node.children = self.tokenizeInline(text, position);\n    } else {\n        node.src = href;\n        node.alt = text ?\n            self.decode.raw(self.descape(text), position) :\n            null;\n    }\n\n    exitLink();\n\n    return node;\n}\n\n/**\n * Create a footnote node.\n *\n * @example\n *   renderFootnote('_foo_', now());\n *\n * @param {string} value - Contents.\n * @param {Object} position - Location of footnote.\n * @return {Object} - `footnote` node.\n */\nfunction renderFootnote(value, position) {\n    return this.renderInline(T_FOOTNOTE, value, position);\n}\n\n/**\n * Add a node with inline content.\n *\n * @example\n *   renderInline('strong', '_foo_', now());\n *\n * @param {string} type - Node type.\n * @param {string} value - Contents.\n * @param {Object} position - Location of node.\n * @return {Object} - Node of type `type`.\n */\nfunction renderInline(type, value, position) {\n    return this.renderParent(type, this.tokenizeInline(value, position));\n}\n\n/**\n * Add a node with block content.\n *\n * @example\n *   renderBlock('blockquote', 'Foo.', now());\n *\n * @param {string} type - Node type.\n * @param {string} value - Contents.\n * @param {Object} position - Location of node.\n * @return {Object} - Node of type `type`.\n */\nfunction renderBlock(type, value, position) {\n    return this.renderParent(type, this.tokenizeBlock(value, position));\n}\n\n/**\n * Find a possible escape sequence.\n *\n * @example\n *   locateEscape('foo \\- bar'); // 4\n *\n * @param {string} value - Value to search.\n * @param {number} fromIndex - Index to start searching at.\n * @return {number} - Location of possible escape sequence.\n */\nfunction locateEscape(value, fromIndex) {\n    return value.indexOf(C_BACKSLASH, fromIndex);\n}\n\n/**\n * Tokenise an escape sequence.\n *\n * @example\n *   tokenizeEscape(eat, '\\\\a');\n *\n * @property {Function} locator - Escape locator.\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `text` or `break` node.\n */\nfunction tokenizeEscape(eat, value, silent) {\n    var self = this;\n    var character;\n\n    if (value.charAt(0) === C_BACKSLASH) {\n        character = value.charAt(1);\n\n        if (self.escape.indexOf(character) !== -1) {\n            /* istanbul ignore if - never used (yet) */\n            if (silent) {\n                return true;\n            }\n\n            return eat(C_BACKSLASH + character)(\n                character === C_NEWLINE ?\n                    self.renderVoid(T_BREAK) :\n                    self.renderRaw(T_TEXT, character)\n            );\n        }\n    }\n}\n\ntokenizeEscape.locator = locateEscape;\n\n/**\n * Find a possible auto-link.\n *\n * @example\n *   locateAutoLink('foo <bar'); // 4\n *\n * @param {string} value - Value to search.\n * @param {number} fromIndex - Index to start searching at.\n * @return {number} - Location of possible auto-link.\n */\nfunction locateAutoLink(value, fromIndex) {\n    return value.indexOf(C_LT, fromIndex);\n}\n\n/**\n * Tokenise a URL in carets.\n *\n * @example\n *   tokenizeAutoLink(eat, '<http://foo.bar>');\n *\n * @property {boolean} notInLink\n * @property {Function} locator - Auto-link locator.\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `link` node.\n */\nfunction tokenizeAutoLink(eat, value, silent) {\n    var self;\n    var subvalue;\n    var length;\n    var index;\n    var queue;\n    var character;\n    var hasAtCharacter;\n    var link;\n    var now;\n    var content;\n    var tokenize;\n    var node;\n\n    if (value.charAt(0) !== C_LT) {\n        return;\n    }\n\n    self = this;\n    subvalue = EMPTY;\n    length = value.length;\n    index = 0;\n    queue = EMPTY;\n    hasAtCharacter = false;\n    link = EMPTY;\n\n    index++;\n    subvalue = C_LT;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (\n            character === C_SPACE ||\n            character === C_GT ||\n            character === C_AT_SIGN ||\n            (character === C_COLON && value.charAt(index + 1) === C_SLASH)\n        ) {\n            break;\n        }\n\n        queue += character;\n        index++;\n    }\n\n    if (!queue) {\n        return;\n    }\n\n    link += queue;\n    queue = EMPTY;\n\n    character = value.charAt(index);\n    link += character;\n    index++;\n\n    if (character === C_AT_SIGN) {\n        hasAtCharacter = true;\n    } else {\n        if (\n            character !== C_COLON ||\n            value.charAt(index + 1) !== C_SLASH\n        ) {\n            return;\n        }\n\n        link += C_SLASH;\n        index++;\n    }\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (character === C_SPACE || character === C_GT) {\n            break;\n        }\n\n        queue += character;\n        index++;\n    }\n\n    character = value.charAt(index);\n\n    if (!queue || character !== C_GT) {\n        return;\n    }\n\n    /* istanbul ignore if - never used (yet) */\n    if (silent) {\n        return true;\n    }\n\n    link += queue;\n    content = link;\n    subvalue += link + character;\n    now = eat.now();\n    now.column++;\n\n    if (hasAtCharacter) {\n        if (\n            link.substr(0, MAILTO_PROTOCOL.length).toLowerCase() !==\n            MAILTO_PROTOCOL\n        ) {\n            link = MAILTO_PROTOCOL + link;\n        } else {\n            content = content.substr(MAILTO_PROTOCOL.length);\n            now.column += MAILTO_PROTOCOL.length;\n        }\n    }\n\n    /*\n     * Temporarily remove support for escapes in autolinks.\n     */\n\n    tokenize = self.inlineTokenizers.escape;\n    self.inlineTokenizers.escape = null;\n\n    node = eat(subvalue)(\n        self.renderLink(true, decode(link), content, null, now, eat)\n    );\n\n    self.inlineTokenizers.escape = tokenize;\n\n    return node;\n}\n\ntokenizeAutoLink.notInLink = true;\ntokenizeAutoLink.locator = locateAutoLink;\n\n/**\n * Find a possible URL.\n *\n * @example\n *   locateURL('foo http://bar'); // 4\n *\n * @param {string} value - Value to search.\n * @param {number} fromIndex - Index to start searching at.\n * @return {number} - Location of possible URL.\n */\nfunction locateURL(value, fromIndex) {\n    var index = -1;\n    var min = -1;\n    var position;\n\n    if (!this.options.gfm) {\n        return -1;\n    }\n\n    while (++index < PROTOCOLS_LENGTH) {\n        position = value.indexOf(PROTOCOLS[index], fromIndex);\n\n        if (position !== -1 && (position < min || min === -1)) {\n            min = position;\n        }\n    }\n\n    return min;\n}\n\n/**\n * Tokenise a URL in text.\n *\n * @example\n *   tokenizeURL(eat, 'http://foo.bar');\n *\n * @property {boolean} notInLink\n * @property {Function} locator - URL locator.\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `link` node.\n */\nfunction tokenizeURL(eat, value, silent) {\n    var self = this;\n    var subvalue;\n    var content;\n    var character;\n    var index;\n    var position;\n    var protocol;\n    var match;\n    var length;\n    var queue;\n    var parenCount;\n    var nextCharacter;\n    var now;\n\n    if (!self.options.gfm) {\n        return;\n    }\n\n    subvalue = EMPTY;\n    index = -1;\n    length = PROTOCOLS_LENGTH;\n\n    while (++index < length) {\n        protocol = PROTOCOLS[index];\n        match = value.slice(0, protocol.length);\n\n        if (match.toLowerCase() === protocol) {\n            subvalue = match;\n            break;\n        }\n    }\n\n    if (!subvalue) {\n        return;\n    }\n\n    index = subvalue.length;\n    length = value.length;\n    queue = EMPTY;\n    parenCount = 0;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (isWhiteSpace(character) || character === C_LT) {\n            break;\n        }\n\n        if (\n            character === C_DOT ||\n            character === C_COMMA ||\n            character === C_COLON ||\n            character === C_SEMI_COLON ||\n            character === C_DOUBLE_QUOTE ||\n            character === C_SINGLE_QUOTE ||\n            character === C_PAREN_CLOSE ||\n            character === C_BRACKET_CLOSE\n        ) {\n            nextCharacter = value.charAt(index + 1);\n\n            if (\n                !nextCharacter ||\n                isWhiteSpace(nextCharacter)\n            ) {\n                break;\n            }\n        }\n\n        if (\n            character === C_PAREN_OPEN ||\n            character === C_BRACKET_OPEN\n        ) {\n            parenCount++;\n        }\n\n        if (\n            character === C_PAREN_CLOSE ||\n            character === C_BRACKET_CLOSE\n        ) {\n            parenCount--;\n\n            if (parenCount < 0) {\n                break;\n            }\n        }\n\n        queue += character;\n        index++;\n    }\n\n    if (!queue) {\n        return;\n    }\n\n    subvalue += queue;\n    content = subvalue;\n\n    if (protocol === MAILTO_PROTOCOL) {\n        position = queue.indexOf(C_AT_SIGN);\n\n        if (position === -1 || position === length - 1) {\n            return;\n        }\n\n        content = content.substr(MAILTO_PROTOCOL.length);\n    }\n\n    /* istanbul ignore if - never used (yet) */\n    if (silent) {\n        return true;\n    }\n\n    now = eat.now();\n\n    return eat(subvalue)(\n        self.renderLink(true, decode(subvalue), content, null, now, eat)\n    );\n}\n\ntokenizeURL.notInLink = true;\ntokenizeURL.locator = locateURL;\n\n/**\n * Find a possible tag.\n *\n * @example\n *   locateTag('foo <bar'); // 4\n *\n * @param {string} value - Value to search.\n * @param {number} fromIndex - Index to start searching at.\n * @return {number} - Location of possible tag.\n */\nfunction locateTag(value, fromIndex) {\n    return value.indexOf(C_LT, fromIndex);\n}\n\n/**\n * Tokenise an HTML tag.\n *\n * @example\n *   tokenizeTag(eat, '<span foo=\"bar\">');\n *\n * @property {Function} locator - Tag locator.\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `html` node.\n */\nfunction tokenizeTag(eat, value, silent) {\n    var self = this;\n    var subvalue = eatHTMLComment(value, self.options) ||\n        eatHTMLCDATA(value) ||\n        eatHTMLProcessingInstruction(value) ||\n        eatHTMLDeclaration(value) ||\n        eatHTMLClosingTag(value) ||\n        eatHTMLOpeningTag(value);\n\n    if (!subvalue) {\n        return;\n    }\n\n    /* istanbul ignore if - never used (yet) */\n    if (silent) {\n        return true;\n    }\n\n    if (!self.inLink && EXPRESSION_HTML_LINK_OPEN.test(subvalue)) {\n        self.inLink = true;\n    } else if (self.inLink && EXPRESSION_HTML_LINK_CLOSE.test(subvalue)) {\n        self.inLink = false;\n    }\n\n    return eat(subvalue)(self.renderRaw(T_HTML, subvalue));\n}\n\ntokenizeTag.locator = locateTag;\n\n/**\n * Find a possible link.\n *\n * @example\n *   locateLink('foo ![bar'); // 4\n *\n * @param {string} value - Value to search.\n * @param {number} fromIndex - Index to start searching at.\n * @return {number} - Location of possible link.\n */\nfunction locateLink(value, fromIndex) {\n    var link = value.indexOf(C_BRACKET_OPEN, fromIndex);\n    var image = value.indexOf(C_EXCLAMATION_MARK + C_BRACKET_OPEN, fromIndex);\n\n    if (image === -1) {\n        return link;\n    }\n\n    /*\n     * Link can never be `-1` if an image is found, so we don’t need to\n     * check for that :)\n     */\n\n    return link < image ? link : image;\n}\n\n/**\n * Tokenise a link.\n *\n * @example\n *   tokenizeLink(eat, '![foo](fav.ico \"Favicon\"));\n *\n * @property {Function} locator - Link locator.\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `link` or `image` node.\n */\nfunction tokenizeLink(eat, value, silent) {\n    var self = this;\n    var subvalue = EMPTY;\n    var index = 0;\n    var character = value.charAt(0);\n    var beforeURL;\n    var beforeTitle;\n    var whiteSpaceQueue;\n    var commonmark;\n    var openCount;\n    var hasMarker;\n    var markers;\n    var isImage;\n    var content;\n    var marker;\n    var length;\n    var title;\n    var depth;\n    var queue;\n    var url;\n    var now;\n\n    /*\n     * Detect whether this is an image.\n     */\n\n    if (character === C_EXCLAMATION_MARK) {\n        isImage = true;\n        subvalue = character;\n        character = value.charAt(++index);\n    }\n\n    /*\n     * Eat the opening.\n     */\n\n    if (character !== C_BRACKET_OPEN) {\n        return;\n    }\n\n    /*\n     * Exit when this is a link and we’re already inside\n     * a link.\n     */\n\n    if (!isImage && self.inLink) {\n        return;\n    }\n\n    subvalue += character;\n    queue = EMPTY;\n    index++;\n\n    /*\n     * Eat the content.\n     */\n\n    commonmark = self.options.commonmark;\n    length = value.length;\n    now = eat.now();\n    depth = 0;\n\n    now.column += index;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (character === C_BRACKET_OPEN) {\n            depth++;\n        } else if (character === C_BRACKET_CLOSE) {\n            /*\n             * Allow a single closing bracket when not in\n             * commonmark-mode.\n             */\n\n            if (!commonmark && !depth) {\n                if (value.charAt(index + 1) === C_PAREN_OPEN) {\n                    break;\n                }\n\n                depth++;\n            }\n\n            if (depth === 0) {\n                break;\n            }\n\n            depth--;\n        }\n\n        queue += character;\n        index++;\n    }\n\n    /*\n     * Eat the content closing.\n     */\n\n    if (\n        value.charAt(index) !== C_BRACKET_CLOSE ||\n        value.charAt(++index) !== C_PAREN_OPEN\n    ) {\n        return;\n    }\n\n    subvalue += queue + C_BRACKET_CLOSE + C_PAREN_OPEN;\n    index++;\n    content = queue;\n\n    /*\n     * Eat white-space.\n     */\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (!isWhiteSpace(character)) {\n            break;\n        }\n\n        subvalue += character;\n        index++;\n    }\n\n    /*\n     * Eat the URL.\n     */\n\n    character = value.charAt(index);\n    markers = commonmark ? COMMONMARK_LINK_TITLE_MARKERS : LINK_TITLE_MARKERS;\n    openCount = 0;\n    queue = EMPTY;\n    beforeURL = subvalue;\n\n    if (character === C_LT) {\n        index++;\n        beforeURL += C_LT;\n\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (character === C_GT) {\n                break;\n            }\n\n            if (commonmark && character === C_NEWLINE) {\n                return;\n            }\n\n            queue += character;\n            index++;\n        }\n\n        if (value.charAt(index) !== C_GT) {\n            return;\n        }\n\n        subvalue += C_LT + queue + C_GT;\n        url = queue;\n        index++;\n    } else {\n        character = null;\n        whiteSpaceQueue = EMPTY;\n\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (whiteSpaceQueue && has.call(markers, character)) {\n                break;\n            }\n\n            if (isWhiteSpace(character)) {\n                if (commonmark) {\n                    break;\n                }\n\n                whiteSpaceQueue += character;\n            } else {\n                if (character === C_PAREN_OPEN) {\n                    depth++;\n                    openCount++;\n                } else if (character === C_PAREN_CLOSE) {\n                    if (depth === 0) {\n                        break;\n                    }\n\n                    depth--;\n                }\n\n                queue += whiteSpaceQueue;\n                whiteSpaceQueue = EMPTY;\n\n                if (character === C_BACKSLASH) {\n                    queue += C_BACKSLASH;\n                    character = value.charAt(++index);\n                }\n\n                queue += character;\n            }\n\n            index++;\n        }\n\n        queue = queue;\n        subvalue += queue;\n        url = queue;\n        index = subvalue.length;\n    }\n\n    /*\n     * Eat white-space.\n     */\n\n    queue = EMPTY;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (!isWhiteSpace(character)) {\n            break;\n        }\n\n        queue += character;\n        index++;\n    }\n\n    character = value.charAt(index);\n    subvalue += queue;\n\n    /*\n     * Eat the title.\n     */\n\n    if (queue && has.call(markers, character)) {\n        index++;\n        subvalue += character;\n        queue = EMPTY;\n        marker = markers[character];\n        beforeTitle = subvalue;\n\n        /*\n         * In commonmark-mode, things are pretty easy: the\n         * marker cannot occur inside the title.\n         *\n         * Non-commonmark does, however, support nested\n         * delimiters.\n         */\n\n        if (commonmark) {\n            while (index < length) {\n                character = value.charAt(index);\n\n                if (character === marker) {\n                    break;\n                }\n\n                if (character === C_BACKSLASH) {\n                    queue += C_BACKSLASH;\n                    character = value.charAt(++index);\n                }\n\n                index++;\n                queue += character;\n            }\n\n            character = value.charAt(index);\n\n            if (character !== marker) {\n                return;\n            }\n\n            title = queue;\n            subvalue += queue + character;\n            index++;\n\n            while (index < length) {\n                character = value.charAt(index);\n\n                if (!isWhiteSpace(character)) {\n                    break;\n                }\n\n                subvalue += character;\n                index++;\n            }\n        } else {\n            whiteSpaceQueue = EMPTY;\n\n            while (index < length) {\n                character = value.charAt(index);\n\n                if (character === marker) {\n                    if (hasMarker) {\n                        queue += marker + whiteSpaceQueue;\n                        whiteSpaceQueue = EMPTY;\n                    }\n\n                    hasMarker = true;\n                } else if (!hasMarker) {\n                    queue += character;\n                } else if (character === C_PAREN_CLOSE) {\n                    subvalue += queue + marker + whiteSpaceQueue;\n                    title = queue;\n                    break;\n                } else if (isWhiteSpace(character)) {\n                    whiteSpaceQueue += character;\n                } else {\n                    queue += marker + whiteSpaceQueue + character;\n                    whiteSpaceQueue = EMPTY;\n                    hasMarker = false;\n                }\n\n                index++;\n            }\n        }\n    }\n\n    if (value.charAt(index) !== C_PAREN_CLOSE) {\n        return;\n    }\n\n    /* istanbul ignore if - never used (yet) */\n    if (silent) {\n        return true;\n    }\n\n    subvalue += C_PAREN_CLOSE;\n\n    url = self.decode.raw(self.descape(url), eat(beforeURL).test().end);\n\n    if (title) {\n        beforeTitle = eat(beforeTitle).test().end;\n        title = self.decode.raw(self.descape(title), beforeTitle);\n    }\n\n    return eat(subvalue)(\n        self.renderLink(!isImage, url, content, title, now, eat)\n    );\n}\n\ntokenizeLink.locator = locateLink;\n\n/**\n * Tokenise a reference link, image, or footnote;\n * shortcut reference link, or footnote.\n *\n * @example\n *   tokenizeReference(eat, '[foo]');\n *   tokenizeReference(eat, '[foo][]');\n *   tokenizeReference(eat, '[foo][bar]');\n *\n * @property {Function} locator - Reference locator.\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - Reference node.\n */\nfunction tokenizeReference(eat, value, silent) {\n    var self = this;\n    var character = value.charAt(0);\n    var index = 0;\n    var length = value.length;\n    var subvalue = EMPTY;\n    var intro = EMPTY;\n    var type = T_LINK;\n    var referenceType = REFERENCE_TYPE_SHORTCUT;\n    var text;\n    var identifier;\n    var now;\n    var node;\n    var exitLink;\n    var queue;\n    var bracketed;\n    var depth;\n\n    /*\n     * Check whether we’re eating an image.\n     */\n\n    if (character === C_EXCLAMATION_MARK) {\n        type = T_IMAGE;\n        intro = character;\n        character = value.charAt(++index);\n    }\n\n    if (character !== C_BRACKET_OPEN) {\n        return;\n    }\n\n    index++;\n    intro += character;\n    queue = EMPTY;\n\n    /*\n     * Check whether we’re eating a footnote.\n     */\n\n    if (\n        self.options.footnotes &&\n        type === T_LINK &&\n        value.charAt(index) === C_CARET\n    ) {\n        intro += C_CARET;\n        index++;\n        type = T_FOOTNOTE;\n    }\n\n    /*\n     * Eat the text.\n     */\n\n    depth = 0;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (character === C_BRACKET_OPEN) {\n            bracketed = true;\n            depth++;\n        } else if (character === C_BRACKET_CLOSE) {\n            if (!depth) {\n                break;\n            }\n\n            depth--;\n        }\n\n        if (character === C_BACKSLASH) {\n            queue += C_BACKSLASH;\n            character = value.charAt(++index);\n        }\n\n        queue += character;\n        index++;\n    }\n\n    subvalue = text = queue;\n    character = value.charAt(index);\n\n    if (character !== C_BRACKET_CLOSE) {\n        return;\n    }\n\n    index++;\n    subvalue += character;\n    queue = EMPTY;\n\n    while (index < length) {\n        character = value.charAt(index);\n\n        if (!isWhiteSpace(character)) {\n            break;\n        }\n\n        queue += character;\n        index++;\n    }\n\n    character = value.charAt(index);\n\n    if (character !== C_BRACKET_OPEN) {\n        if (!text) {\n            return;\n        }\n\n        identifier = text;\n    } else {\n        identifier = EMPTY;\n        queue += character;\n        index++;\n\n        while (index < length) {\n            character = value.charAt(index);\n\n            if (\n                character === C_BRACKET_OPEN ||\n                character === C_BRACKET_CLOSE\n            ) {\n                break;\n            }\n\n            if (character === C_BACKSLASH) {\n                identifier += C_BACKSLASH;\n                character = value.charAt(++index);\n            }\n\n            identifier += character;\n            index++;\n        }\n\n        character = value.charAt(index);\n\n        if (character === C_BRACKET_CLOSE) {\n            queue += identifier + character;\n            index++;\n\n            referenceType = identifier ?\n                REFERENCE_TYPE_FULL :\n                REFERENCE_TYPE_COLLAPSED;\n        } else {\n            identifier = EMPTY;\n        }\n\n        subvalue += queue;\n        queue = EMPTY;\n    }\n\n    /*\n     * Brackets cannot be inside the identifier.\n     */\n\n    if (referenceType !== REFERENCE_TYPE_FULL && bracketed) {\n        return;\n    }\n\n    /*\n     * Inline footnotes cannot have an identifier.\n     */\n\n    if (type === T_FOOTNOTE && referenceType !== REFERENCE_TYPE_SHORTCUT) {\n        type = T_LINK;\n        intro = C_BRACKET_OPEN + C_CARET;\n        text = C_CARET + text;\n    }\n\n    subvalue = intro + subvalue;\n\n    if (type === T_LINK && self.inLink) {\n        return null;\n    }\n\n    /* istanbul ignore if - never used (yet) */\n    if (silent) {\n        return true;\n    }\n\n    if (type === T_FOOTNOTE && text.indexOf(C_SPACE) !== -1) {\n        return eat(subvalue)(self.renderFootnote(text, eat.now()));\n    }\n\n    now = eat.now();\n    now.column += intro.length;\n    identifier = referenceType === REFERENCE_TYPE_FULL ? identifier : text;\n\n    node = {\n        'type': type + 'Reference',\n        'identifier': normalize(identifier)\n    };\n\n    if (type === T_LINK || type === T_IMAGE) {\n        node.referenceType = referenceType;\n    }\n\n    if (type === T_LINK) {\n        exitLink = self.enterLink();\n        node.children = self.tokenizeInline(text, now);\n        exitLink();\n    } else if (type === T_IMAGE) {\n        node.alt = self.decode.raw(self.descape(text), now) || null;\n    }\n\n    return eat(subvalue)(node);\n}\n\ntokenizeReference.locator = locateLink;\n\n/**\n * Find a possible strong emphasis.\n *\n * @example\n *   locateStrong('foo **bar'); // 4\n *\n * @param {string} value - Value to search.\n * @param {number} fromIndex - Index to start searching at.\n * @return {number} - Location of possible strong emphasis.\n */\nfunction locateStrong(value, fromIndex) {\n    var asterisk = value.indexOf(C_ASTERISK + C_ASTERISK, fromIndex);\n    var underscore = value.indexOf(C_UNDERSCORE + C_UNDERSCORE, fromIndex);\n\n    if (underscore === -1) {\n        return asterisk;\n    }\n\n    if (asterisk === -1) {\n        return underscore;\n    }\n\n    return underscore < asterisk ? underscore : asterisk;\n}\n\n/**\n * Tokenise strong emphasis.\n *\n * @example\n *   tokenizeStrong(eat, '**foo**');\n *   tokenizeStrong(eat, '__foo__');\n *\n * @property {Function} locator - Strong emphasis locator.\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `strong` node.\n */\nfunction tokenizeStrong(eat, value, silent) {\n    var self = this;\n    var index = 0;\n    var character = value.charAt(index);\n    var now;\n    var pedantic;\n    var marker;\n    var queue;\n    var subvalue;\n    var length;\n    var prev;\n\n    if (\n        EMPHASIS_MARKERS[character] !== true ||\n        value.charAt(++index) !== character\n    ) {\n        return;\n    }\n\n    pedantic = self.options.pedantic;\n    marker = character;\n    subvalue = marker + marker;\n    length = value.length;\n    index++;\n    queue = character = EMPTY;\n\n    if (pedantic && isWhiteSpace(value.charAt(index))) {\n        return;\n    }\n\n    while (index < length) {\n        prev = character;\n        character = value.charAt(index);\n\n        if (\n            character === marker &&\n            value.charAt(index + 1) === marker &&\n            (!pedantic || !isWhiteSpace(prev))\n        ) {\n            character = value.charAt(index + 2);\n\n            if (character !== marker) {\n                if (!trim(queue)) {\n                    return;\n                }\n\n                /* istanbul ignore if - never used (yet) */\n                if (silent) {\n                    return true;\n                }\n\n                now = eat.now();\n                now.column += 2;\n\n                return eat(subvalue + queue + subvalue)(\n                    self.renderInline(T_STRONG, queue, now)\n                );\n            }\n        }\n\n        if (!pedantic && character === C_BACKSLASH) {\n            queue += character;\n            character = value.charAt(++index);\n        }\n\n        queue += character;\n        index++;\n    }\n}\n\ntokenizeStrong.locator = locateStrong;\n\n/**\n * Find possible slight emphasis.\n *\n * @example\n *   locateEmphasis('foo *bar'); // 4\n *\n * @param {string} value - Value to search.\n * @param {number} fromIndex - Index to start searching at.\n * @return {number} - Location of possible slight emphasis.\n */\nfunction locateEmphasis(value, fromIndex) {\n    var asterisk = value.indexOf(C_ASTERISK, fromIndex);\n    var underscore = value.indexOf(C_UNDERSCORE, fromIndex);\n\n    if (underscore === -1) {\n        return asterisk;\n    }\n\n    if (asterisk === -1) {\n        return underscore;\n    }\n\n    return underscore < asterisk ? underscore : asterisk;\n}\n\n/**\n * Tokenise slight emphasis.\n *\n * @example\n *   tokenizeEmphasis(eat, '*foo*');\n *   tokenizeEmphasis(eat, '_foo_');\n *\n * @property {Function} locator - Slight emphasis locator.\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `emphasis` node.\n */\nfunction tokenizeEmphasis(eat, value, silent) {\n    var self = this;\n    var index = 0;\n    var character = value.charAt(index);\n    var now;\n    var pedantic;\n    var marker;\n    var queue;\n    var subvalue;\n    var length;\n    var prev;\n\n    if (EMPHASIS_MARKERS[character] !== true) {\n        return;\n    }\n\n    pedantic = self.options.pedantic;\n    subvalue = marker = character;\n    length = value.length;\n    index++;\n    queue = character = EMPTY;\n\n    if (pedantic && isWhiteSpace(value.charAt(index))) {\n        return;\n    }\n\n    while (index < length) {\n        prev = character;\n        character = value.charAt(index);\n\n        if (\n            character === marker &&\n            (!pedantic || !isWhiteSpace(prev))\n        ) {\n            character = value.charAt(++index);\n\n            if (character !== marker) {\n                if (!trim(queue) || prev === marker) {\n                    return;\n                }\n\n                if (\n                    pedantic ||\n                    marker !== C_UNDERSCORE ||\n                    !isWordCharacter(character)\n                ) {\n                    /* istanbul ignore if - never used (yet) */\n                    if (silent) {\n                        return true;\n                    }\n\n                    now = eat.now();\n                    now.column++;\n\n                    return eat(subvalue + queue + marker)(\n                        self.renderInline(T_EMPHASIS, queue, now)\n                    );\n                }\n            }\n\n            queue += marker;\n        }\n\n        if (!pedantic && character === C_BACKSLASH) {\n            queue += character;\n            character = value.charAt(++index);\n        }\n\n        queue += character;\n        index++;\n    }\n}\n\ntokenizeEmphasis.locator = locateEmphasis;\n\n/**\n * Find a possible deletion.\n *\n * @example\n *   locateDeletion('foo ~~bar'); // 4\n *\n * @param {string} value - Value to search.\n * @param {number} fromIndex - Index to start searching at.\n * @return {number} - Location of possible deletion.\n */\nfunction locateDeletion(value, fromIndex) {\n    return value.indexOf(C_TILDE + C_TILDE, fromIndex);\n}\n\n/**\n * Tokenise a deletion.\n *\n * @example\n *   tokenizeDeletion(eat, '~~foo~~');\n *\n * @property {Function} locator - Deletion locator.\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `delete` node.\n */\nfunction tokenizeDeletion(eat, value, silent) {\n    var self = this;\n    var character = EMPTY;\n    var previous = EMPTY;\n    var preceding = EMPTY;\n    var subvalue = EMPTY;\n    var index;\n    var length;\n    var now;\n\n    if (\n        !self.options.gfm ||\n        value.charAt(0) !== C_TILDE ||\n        value.charAt(1) !== C_TILDE ||\n        isWhiteSpace(value.charAt(2))\n    ) {\n        return;\n    }\n\n    index = 1;\n    length = value.length;\n    now = eat.now();\n    now.column += 2;\n\n    while (++index < length) {\n        character = value.charAt(index);\n\n        if (\n            character === C_TILDE &&\n            previous === C_TILDE &&\n            (!preceding || !isWhiteSpace(preceding))\n        ) {\n            /* istanbul ignore if - never used (yet) */\n            if (silent) {\n                return true;\n            }\n\n            return eat(C_TILDE + C_TILDE + subvalue + C_TILDE + C_TILDE)(\n                self.renderInline(T_DELETE, subvalue, now)\n            );\n        }\n\n        subvalue += previous;\n        preceding = previous;\n        previous = character;\n    }\n}\n\ntokenizeDeletion.locator = locateDeletion;\n\n/**\n * Find possible inline code.\n *\n * @example\n *   locateInlineCode('foo `bar'); // 4\n *\n * @param {string} value - Value to search.\n * @param {number} fromIndex - Index to start searching at.\n * @return {number} - Location of possible inline code.\n */\nfunction locateInlineCode(value, fromIndex) {\n    return value.indexOf(C_TICK, fromIndex);\n}\n\n/**\n * Tokenise inline code.\n *\n * @example\n *   tokenizeInlineCode(eat, '`foo()`');\n *\n * @property {Function} locator - Inline code locator.\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `inlineCode` node.\n */\nfunction tokenizeInlineCode(eat, value, silent) {\n    var self = this;\n    var length = value.length;\n    var index = 0;\n    var queue = EMPTY;\n    var tickQueue = EMPTY;\n    var contentQueue;\n    var whiteSpaceQueue;\n    var count;\n    var openingCount;\n    var subvalue;\n    var character;\n    var found;\n    var next;\n\n    while (index < length) {\n        if (value.charAt(index) !== C_TICK) {\n            break;\n        }\n\n        queue += C_TICK;\n        index++;\n    }\n\n    if (!queue) {\n        return;\n    }\n\n    subvalue = queue;\n    openingCount = index;\n    queue = EMPTY;\n    next = value.charAt(index);\n    count = 0;\n\n    while (index < length) {\n        character = next;\n        next = value.charAt(index + 1);\n\n        if (character === C_TICK) {\n            count++;\n            tickQueue += character;\n        } else {\n            count = 0;\n            queue += character;\n        }\n\n        if (count && next !== C_TICK) {\n            if (count === openingCount) {\n                subvalue += queue + tickQueue;\n                found = true;\n                break;\n            }\n\n            queue += tickQueue;\n            tickQueue = EMPTY;\n        }\n\n        index++;\n    }\n\n    if (!found) {\n        if (openingCount % 2 !== 0) {\n            return;\n        }\n\n        queue = EMPTY;\n    }\n\n    /* istanbul ignore if - never used (yet) */\n    if (silent) {\n        return true;\n    }\n\n    contentQueue = whiteSpaceQueue = EMPTY;\n    length = queue.length;\n    index = -1;\n\n    while (++index < length) {\n        character = queue.charAt(index);\n\n        if (isWhiteSpace(character)) {\n            whiteSpaceQueue += character;\n            continue;\n        }\n\n        if (whiteSpaceQueue) {\n            if (contentQueue) {\n                contentQueue += whiteSpaceQueue;\n            }\n\n            whiteSpaceQueue = EMPTY;\n        }\n\n        contentQueue += character;\n    }\n\n    return eat(subvalue)(self.renderRaw(T_INLINE_CODE, contentQueue));\n}\n\ntokenizeInlineCode.locator = locateInlineCode;\n\n/**\n * Find a possible break.\n *\n * @example\n *   locateBreak('foo   \\nbar'); // 3\n *\n * @param {string} value - Value to search.\n * @param {number} fromIndex - Index to start searching at.\n * @return {number} - Location of possible break.\n */\nfunction locateBreak(value, fromIndex) {\n    var index = value.indexOf(C_NEWLINE, fromIndex);\n\n    while (index > fromIndex) {\n        if (value.charAt(index - 1) !== C_SPACE) {\n            break;\n        }\n\n        index--;\n    }\n\n    return index;\n}\n\n/**\n * Tokenise a break.\n *\n * @example\n *   tokenizeBreak(eat, '  \\n');\n *\n * @property {Function} locator - Break locator.\n * @param {function(string)} eat - Eater.\n * @param {string} value - Rest of content.\n * @param {boolean?} [silent] - Whether this is a dry run.\n * @return {Node?|boolean} - `break` node.\n */\nfunction tokenizeBreak(eat, value, silent) {\n    var self = this;\n    var breaks = self.options.breaks;\n    var length = value.length;\n    var index = -1;\n    var queue = EMPTY;\n    var character;\n\n    while (++index < length) {\n        character = value.charAt(index);\n\n        if (character === C_NEWLINE) {\n            if (!breaks && index < MIN_BREAK_LENGTH) {\n                return;\n            }\n\n            /* istanbul ignore if - never used (yet) */\n            if (silent) {\n                return true;\n            }\n\n            queue += character;\n            return eat(queue)(self.renderVoid(T_BREAK));\n        }\n\n        if (character !== C_SPACE) {\n            return;\n        }\n\n        queue += character;\n    }\n}\n\ntokenizeBreak.locator = locateBreak;\n\n/**\n * Construct a new parser.\n *\n * @example\n *   var parser = new Parser(new VFile('Foo'));\n *\n * @constructor\n * @class {Parser}\n * @param {VFile} file - File to parse.\n * @param {Object?} [options] - Passed to\n *   `Parser#setOptions()`.\n */\nfunction Parser(file, options, processor) {\n    var self = this;\n\n    self.file = file;\n    self.inLink = false;\n    self.atTop = true;\n    self.atStart = true;\n    self.inBlockquote = false;\n    self.data = processor.data;\n\n    self.descape = descapeFactory(self, 'escape');\n    self.decode = decodeFactory(self);\n\n    self.options = extend({}, self.options);\n\n    self.setOptions(options);\n}\n\n/**\n * Set options.  Does not overwrite previously set\n * options.\n *\n * @example\n *   var parser = new Parser();\n *   parser.setOptions({gfm: true});\n *\n * @this {Parser}\n * @throws {Error} - When an option is invalid.\n * @param {Object?} [options] - Parse settings.\n * @return {Parser} - `self`.\n */\nParser.prototype.setOptions = function (options) {\n    var self = this;\n    var escape = self.data.escape;\n    var current = self.options;\n    var key;\n\n    if (options === null || options === undefined) {\n        options = {};\n    } else if (typeof options === 'object') {\n        options = extend({}, options);\n    } else {\n        raise(options, 'options');\n    }\n\n    for (key in defaultOptions) {\n        validate.boolean(options, key, current[key]);\n    }\n\n    self.options = options;\n\n    if (options.commonmark) {\n        self.escape = escape.commonmark;\n    } else if (options.gfm) {\n        self.escape = escape.gfm;\n    } else {\n        self.escape = escape.default;\n    }\n\n    return self;\n};\n\n/*\n * Expose `defaults`.\n */\n\nParser.prototype.options = defaultOptions;\n\n/**\n * Factory to track indentation for each line corresponding\n * to the given `start` and the number of invocations.\n *\n * @param {number} start - Starting line.\n * @return {function(offset)} - Indenter.\n */\nParser.prototype.indent = function (start) {\n    var self = this;\n    var line = start;\n\n    /**\n     * Intender which increments the global offset,\n     * starting at the bound line, and further incrementing\n     * each line for each invocation.\n     *\n     * @example\n     *   indenter(2);\n     *\n     * @param {number} offset - Number to increment the\n     *   offset.\n     */\n    function indenter(offset) {\n        self.offset[line] = (self.offset[line] || 0) + offset;\n\n        line++;\n    }\n\n    return indenter;\n};\n\n/**\n * Get found offsets starting at `start`.\n *\n * @param {number} start - Starting line.\n * @return {Array.<number>} - Offsets starting at `start`.\n */\nParser.prototype.getIndent = function (start) {\n    var offset = this.offset;\n    var result = [];\n\n    while (++start) {\n        if (!(start in offset)) {\n            break;\n        }\n\n        result.push((offset[start] || 0) + 1);\n    }\n\n    return result;\n};\n\n/**\n * Parse the bound file.\n *\n * @example\n *   new Parser(new File('_Foo_.')).parse();\n *\n * @this {Parser}\n * @return {Object} - `root` node.\n */\nParser.prototype.parse = function () {\n    var self = this;\n    var value = clean(String(self.file));\n    var node;\n\n    /*\n     * Add an `offset` matrix, used to keep track of\n     * syntax and white space indentation per line.\n     */\n\n    self.offset = {};\n\n    node = self.renderBlock(T_ROOT, value);\n\n    if (self.options.position) {\n        node.position = {\n            'start': {\n                'line': 1,\n                'column': 1\n            }\n        };\n\n        node.position.end = self.eof || node.position.start;\n    }\n\n    return node;\n};\n\n/*\n * Enter and exit helpers.\n */\n\nParser.prototype.enterLink = stateToggler('inLink', false);\nParser.prototype.exitTop = stateToggler('atTop', true);\nParser.prototype.exitStart = stateToggler('atStart', true);\nParser.prototype.enterBlockquote = stateToggler('inBlockquote', false);\n\n/*\n * Expose helpers\n */\n\nParser.prototype.renderRaw = renderRaw;\nParser.prototype.renderVoid = renderVoid;\nParser.prototype.renderParent = renderParent;\nParser.prototype.renderInline = renderInline;\nParser.prototype.renderBlock = renderBlock;\n\nParser.prototype.renderLink = renderLink;\nParser.prototype.renderCodeBlock = renderCodeBlock;\nParser.prototype.renderBlockquote = renderBlockquote;\nParser.prototype.renderListItem = renderListItem;\nParser.prototype.renderFootnoteDefinition = renderFootnoteDefinition;\nParser.prototype.renderHeading = renderHeading;\nParser.prototype.renderFootnote = renderFootnote;\n\n/**\n * Construct a tokenizer.  This creates both\n * `tokenizeInline` and `tokenizeBlock`.\n *\n * @example\n *   Parser.prototype.tokenizeInline = tokenizeFactory('inline');\n *\n * @param {string} type - Name of parser, used to find\n *   its expressions (`%sMethods`) and tokenizers\n *   (`%Tokenizers`).\n * @return {Function} - Tokenizer.\n */\nfunction tokenizeFactory(type) {\n    /**\n     * Tokenizer for a bound `type`\n     *\n     * @example\n     *   parser = new Parser();\n     *   parser.tokenizeInline('_foo_');\n     *\n     * @param {string} value - Content.\n     * @param {Object?} [location] - Offset at which `value`\n     *   starts.\n     * @return {Array.<Object>} - Nodes.\n     */\n    function tokenize(value, location) {\n        var self = this;\n        var offset = self.offset;\n        var tokens = [];\n        var methods = self[type + 'Methods'];\n        var tokenizers = self[type + 'Tokenizers'];\n        var line = location ? location.line : 1;\n        var column = location ? location.column : 1;\n        var patchPosition = self.options.position;\n        var add;\n        var index;\n        var length;\n        var method;\n        var name;\n        var matched;\n        var valueLength;\n        var eater;\n\n        /*\n         * Trim white space only lines.\n         */\n\n        if (!value) {\n            return tokens;\n        }\n\n        /**\n         * Update line and column based on `value`.\n         *\n         * @example\n         *   updatePosition('foo');\n         *\n         * @param {string} subvalue - Subvalue to eat.\n         */\n        function updatePosition(subvalue) {\n            var lastIndex = -1;\n            var index = subvalue.indexOf(C_NEWLINE);\n\n            while (index !== -1) {\n                line++;\n                lastIndex = index;\n                index = subvalue.indexOf(C_NEWLINE, index + 1);\n            }\n\n            if (lastIndex === -1) {\n                column = column + subvalue.length;\n            } else {\n                column = subvalue.length - lastIndex;\n            }\n\n            if (line in offset) {\n                if (lastIndex !== -1) {\n                    column += offset[line];\n                } else if (column <= offset[line]) {\n                    column = offset[line] + 1;\n                }\n            }\n        }\n\n        /**\n         * Get offset. Called before the first character is\n         * eaten to retrieve the range's offsets.\n         *\n         * @return {Function} - `done`, to be called when\n         *   the last character is eaten.\n         */\n        function getOffset() {\n            var indentation = [];\n            var pos = line + 1;\n\n            /**\n             * Done. Called when the last character is\n             * eaten to retrieve the range’s offsets.\n             *\n             * @return {Array.<number>} - Offset.\n             */\n            function done() {\n                var last = line + 1;\n\n                while (pos < last) {\n                    indentation.push((offset[pos] || 0) + 1);\n\n                    pos++;\n                }\n\n                return indentation;\n            }\n\n            return done;\n        }\n\n        /**\n         * Get the current position.\n         *\n         * @example\n         *   position = now(); // {line: 1, column: 1}\n         *\n         * @return {Object} - Current Position.\n         */\n        function now() {\n            return {\n                'line': line,\n                'column': column\n            };\n        }\n\n        /**\n         * Store position information for a node.\n         *\n         * @example\n         *   start = now();\n         *   updatePosition('foo');\n         *   location = new Position(start);\n         *   // {start: {line: 1, column: 1}, end: {line: 1, column: 3}}\n         *\n         * @param {Object} start - Starting position.\n         */\n        function Position(start) {\n            this.start = start;\n            this.end = now();\n        }\n\n        /**\n         * Throw when a value is incorrectly eaten.\n         * This shouldn’t happen but will throw on new,\n         * incorrect rules.\n         *\n         * @example\n         *   // When the current value is set to `foo bar`.\n         *   validateEat('foo');\n         *   eat('foo');\n         *\n         *   validateEat('bar');\n         *   // throws, because the space is not eaten.\n         *\n         * @param {string} subvalue - Value to be eaten.\n         * @throws {Error} - When `subvalue` cannot be eaten.\n         */\n        function validateEat(subvalue) {\n            /* istanbul ignore if */\n            if (value.substring(0, subvalue.length) !== subvalue) {\n                self.file.fail(ERR_INCORRECTLY_EATEN, now());\n            }\n        }\n\n        /**\n         * Mark position and patch `node.position`.\n         *\n         * @example\n         *   var update = position();\n         *   updatePosition('foo');\n         *   update({});\n         *   // {\n         *   //   position: {\n         *   //     start: {line: 1, column: 1}\n         *   //     end: {line: 1, column: 3}\n         *   //   }\n         *   // }\n         *\n         * @returns {Function} - Updater.\n         */\n        function position() {\n            var before = now();\n\n            /**\n             * Add the position to a node.\n             *\n             * @example\n             *   update({type: 'text', value: 'foo'});\n             *\n             * @param {Node} node - Node to attach position\n             *   on.\n             * @param {Array} [indent] - Indentation for\n             *   `node`.\n             * @return {Node} - `node`.\n             */\n            function update(node, indent) {\n                var prev = node.position;\n                var start = prev ? prev.start : before;\n                var combined = [];\n                var n = prev && prev.end.line;\n                var l = before.line;\n\n                node.position = new Position(start);\n\n                /*\n                 * If there was already a `position`, this\n                 * node was merged.  Fixing `start` wasn’t\n                 * hard, but the indent is different.\n                 * Especially because some information, the\n                 * indent between `n` and `l` wasn’t\n                 * tracked.  Luckily, that space is\n                 * (should be?) empty, so we can safely\n                 * check for it now.\n                 */\n\n                if (prev && indent && prev.indent) {\n                    combined = prev.indent;\n\n                    if (n < l) {\n                        while (++n < l) {\n                            combined.push((offset[n] || 0) + 1);\n                        }\n\n                        combined.push(before.column);\n                    }\n\n                    indent = combined.concat(indent);\n                }\n\n                node.position.indent = indent || [];\n\n                return node;\n            }\n\n            return update;\n        }\n\n        /**\n         * Add `node` to `parent`s children or to `tokens`.\n         * Performs merges where possible.\n         *\n         * @example\n         *   add({});\n         *\n         *   add({}, {children: []});\n         *\n         * @param {Object} node - Node to add.\n         * @param {Object} [parent] - Parent to insert into.\n         * @return {Object} - Added or merged into node.\n         */\n        add = function (node, parent) {\n            var prev;\n            var children;\n\n            if (!parent) {\n                children = tokens;\n            } else {\n                children = parent.children;\n            }\n\n            prev = children[children.length - 1];\n\n            if (\n                prev &&\n                node.type === prev.type &&\n                node.type in MERGEABLE_NODES &&\n                mergeable(prev) &&\n                mergeable(node)\n            ) {\n                node = MERGEABLE_NODES[node.type].call(\n                    self, prev, node\n                );\n            }\n\n            if (node !== prev) {\n                children.push(node);\n            }\n\n            if (self.atStart && tokens.length) {\n                self.exitStart();\n            }\n\n            return node;\n        };\n\n        /**\n         * Remove `subvalue` from `value`.\n         * Expects `subvalue` to be at the start from\n         * `value`, and applies no validation.\n         *\n         * @example\n         *   eat('foo')({type: 'text', value: 'foo'});\n         *\n         * @param {string} subvalue - Removed from `value`,\n         *   and passed to `updatePosition`.\n         * @return {Function} - Wrapper around `add`, which\n         *   also adds `position` to node.\n         */\n        function eat(subvalue) {\n            var indent = getOffset();\n            var pos = position();\n            var current = now();\n\n            validateEat(subvalue);\n\n            /**\n             * Add the given arguments, add `position` to\n             * the returned node, and return the node.\n             *\n             * @param {Object} node - Node to add.\n             * @param {Object} [parent] - Node to insert into.\n             * @return {Node} - Added node.\n             */\n            function apply(node, parent) {\n                return pos(add(pos(node), parent), indent);\n            }\n\n            /**\n             * Functions just like apply, but resets the\n             * content:  the line and column are reversed,\n             * and the eaten value is re-added.\n             *\n             * This is useful for nodes with a single\n             * type of content, such as lists and tables.\n             *\n             * See `apply` above for what parameters are\n             * expected.\n             *\n             * @return {Node} - Added node.\n             */\n            function reset() {\n                var node = apply.apply(null, arguments);\n\n                line = current.line;\n                column = current.column;\n                value = subvalue + value;\n\n                return node;\n            }\n\n            /**\n             * Test the position, after eating, and reverse\n             * to a not-eaten state.\n             *\n             * @return {Position} - Position after eating `subvalue`.\n             */\n            function test() {\n                var result = pos({});\n\n                line = current.line;\n                column = current.column;\n                value = subvalue + value;\n\n                return result.position;\n            }\n\n            apply.reset = reset;\n            apply.test = reset.test = test;\n\n            value = value.substring(subvalue.length);\n\n            updatePosition(subvalue);\n\n            indent = indent();\n\n            return apply;\n        }\n\n        /**\n         * Same as `eat` above, but will not add positional\n         * information to nodes.\n         *\n         * @example\n         *   noEat('foo')({type: 'text', value: 'foo'});\n         *\n         * @param {string} subvalue - Removed from `value`.\n         * @return {Function} - Wrapper around `add`.\n         */\n        function noEat(subvalue) {\n            validateEat(subvalue);\n\n            /**\n             * Add the given arguments, and return the\n             * node.\n             *\n             * @return {Node} - Added node.\n             */\n            function apply() {\n                return add.apply(null, arguments);\n            }\n\n            /**\n             * Functions just like apply, but resets the\n             * content: the eaten value is re-added.\n             *\n             * @return {Node} - Added node.\n             */\n            function reset() {\n                var node = apply.apply(null, arguments);\n\n                value = subvalue + value;\n\n                return node;\n            }\n\n            /**\n             * Test the position, which in this mode is an\n             * empty object.\n             *\n             * @return {Object} - Empty position object.\n             */\n            function test() {\n                value = subvalue + value;\n\n                return {};\n            }\n\n            apply.reset = reset;\n            apply.test = reset.test = test;\n\n            value = value.substring(subvalue.length);\n\n            return apply;\n        }\n\n        /*\n         * Expose the eater, depending on if `position`s\n         * should be patched on nodes.\n         */\n\n        eater = patchPosition ? eat : noEat;\n\n        /*\n         * Expose `now` on `eater`.\n         */\n\n        eater.now = now;\n\n        /*\n         * Expose `file` on `eater`.\n         */\n\n        eater.file = self.file;\n\n        /*\n         * Sync initial offset.\n         */\n\n        updatePosition(EMPTY);\n\n        /*\n         * Iterate over `value`, and iterate over all\n         * tokenizers.  When one eats something, re-iterate\n         * with the remaining value.  If no tokenizer eats,\n         * something failed (should not happen) and an\n         * exception is thrown.\n         */\n\n        while (value) {\n            index = -1;\n            length = methods.length;\n            matched = false;\n\n            while (++index < length) {\n                name = methods[index];\n                method = tokenizers[name];\n\n                if (\n                    method &&\n                    (!method.onlyAtStart || self.atStart) &&\n                    (!method.onlyAtTop || self.atTop) &&\n                    (!method.notInBlockquote || !self.inBlockquote) &&\n                    (!method.notInLink || !self.inLink)\n                ) {\n                    valueLength = value.length;\n\n                    method.apply(self, [eater, value]);\n\n                    matched = valueLength !== value.length;\n\n                    if (matched) {\n                        break;\n                    }\n                }\n            }\n\n            /* istanbul ignore if */\n            if (!matched) {\n                self.file.fail(ERR_INFINITE_LOOP, eater.now());\n\n                /*\n                 * Errors are not thrown on `File#fail`\n                 * when `quiet: true`.\n                 */\n\n                break;\n            }\n        }\n\n        self.eof = now();\n\n        return tokens;\n    }\n\n    return tokenize;\n}\n\n/*\n * Expose tokenizers for block-level nodes.\n */\n\nParser.prototype.blockTokenizers = {\n    'yamlFrontMatter': tokenizeYAMLFrontMatter,\n    'newline': tokenizeNewline,\n    'code': tokenizeCode,\n    'fences': tokenizeFences,\n    'heading': tokenizeHeading,\n    'lineHeading': tokenizeLineHeading,\n    'horizontalRule': tokenizeHorizontalRule,\n    'blockquote': tokenizeBlockquote,\n    'list': tokenizeList,\n    'html': tokenizeHTML,\n    'definition': tokenizeDefinition,\n    'footnoteDefinition': tokenizeFootnoteDefinition,\n    'table': tokenizeTable,\n    'paragraph': tokenizeParagraph\n};\n\n/*\n * Expose order in which to parse block-level nodes.\n */\n\nParser.prototype.blockMethods = [\n    'yamlFrontMatter',\n    'newline',\n    'code',\n    'fences',\n    'blockquote',\n    'heading',\n    'horizontalRule',\n    'list',\n    'lineHeading',\n    'html',\n    'footnoteDefinition',\n    'definition',\n    'looseTable',\n    'table',\n    'paragraph'\n];\n\n/**\n * Block tokenizer.\n *\n * @example\n *   var parser = new Parser();\n *   parser.tokenizeBlock('> foo.');\n *\n * @param {string} value - Content.\n * @return {Array.<Object>} - Nodes.\n */\n\nParser.prototype.tokenizeBlock = tokenizeFactory(BLOCK);\n\n/*\n * Expose tokenizers for inline-level nodes.\n */\n\nParser.prototype.inlineTokenizers = {\n    'escape': tokenizeEscape,\n    'autoLink': tokenizeAutoLink,\n    'url': tokenizeURL,\n    'tag': tokenizeTag,\n    'link': tokenizeLink,\n    'reference': tokenizeReference,\n    'strong': tokenizeStrong,\n    'emphasis': tokenizeEmphasis,\n    'deletion': tokenizeDeletion,\n    'inlineCode': tokenizeInlineCode,\n    'break': tokenizeBreak,\n    'inlineText': tokenizeText\n};\n\n/*\n * Expose order in which to parse inline-level nodes.\n */\n\nParser.prototype.inlineMethods = [\n    'escape',\n    'autoLink',\n    'url',\n    'tag',\n    'link',\n    'reference',\n    'shortcutReference',\n    'strong',\n    'emphasis',\n    'deletion',\n    'inlineCode',\n    'break',\n    'inlineText'\n];\n\n/**\n * Inline tokenizer.\n *\n * @example\n *   var parser = new Parser();\n *   parser.tokenizeInline('_foo_');\n *\n * @param {string} value - Content.\n * @return {Array.<Object>} - Nodes.\n */\n\nParser.prototype.tokenizeInline = tokenizeFactory(INLINE);\n\n/*\n * Expose `tokenizeFactory` so dependencies could create\n * their own tokenizers.\n */\n\nParser.prototype.tokenizeFactory = tokenizeFactory;\n\n/*\n * Expose `parse` on `module.exports`.\n */\n\nmodule.exports = Parser;\n","/**\n * @author Titus Wormer\n * @copyright 2015-2016 Titus Wormer\n * @license MIT\n * @module remark:stringify\n * @version 3.2.2\n * @fileoverview Compile an abstract syntax tree into\n *   a markdown document.\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\n/*\n * Dependencies.\n */\n\nvar decode = require('parse-entities');\nvar encode = require('stringify-entities');\nvar table = require('markdown-table');\nvar repeat = require('repeat-string');\nvar extend = require('extend.js');\nvar ccount = require('ccount');\nvar longestStreak = require('longest-streak');\nvar utilities = require('./utilities.js');\nvar defaultOptions = require('./defaults.js').stringify;\n\n/*\n * Methods.\n */\n\nvar raise = utilities.raise;\nvar validate = utilities.validate;\nvar stateToggler = utilities.stateToggler;\nvar mergeable = utilities.mergeable;\nvar MERGEABLE_NODES = utilities.MERGEABLE_NODES;\n\n/*\n * Constants.\n */\n\nvar INDENT = 4;\nvar MINIMUM_CODE_FENCE_LENGTH = 3;\nvar YAML_FENCE_LENGTH = 3;\nvar MINIMUM_RULE_LENGTH = 3;\nvar MAILTO = 'mailto:';\nvar ERROR_LIST_ITEM_INDENT = 'Cannot indent code properly. See ' +\n    'http://git.io/mdast-lii';\n\n/*\n * Expressions.\n */\n\nvar EXPRESSIONS_WHITE_SPACE = /\\s/;\n\n/*\n * Naive fence expression.\n */\n\nvar FENCE = /([`~])\\1{2}/;\n\n/*\n * Expression for a protocol.\n *\n * @see http://en.wikipedia.org/wiki/URI_scheme#Generic_syntax\n */\n\nvar PROTOCOL = /^[a-z][a-z+.-]+:\\/?/i;\n\n/*\n * Punctuation characters.\n */\n\nvar PUNCTUATION = /[-!\"#$%&'()*+,.\\/:;<=>?@\\[\\\\\\]^`{|}~_]/;\n\n/*\n * Characters.\n */\n\nvar ANGLE_BRACKET_CLOSE = '>';\nvar ANGLE_BRACKET_OPEN = '<';\nvar ASTERISK = '*';\nvar BACKSLASH = '\\\\';\nvar CARET = '^';\nvar COLON = ':';\nvar SEMICOLON = ';';\nvar DASH = '-';\nvar DOT = '.';\nvar EMPTY = '';\nvar EQUALS = '=';\nvar EXCLAMATION_MARK = '!';\nvar HASH = '#';\nvar AMPERSAND = '&';\nvar LINE = '\\n';\nvar CARRIAGE = '\\r';\nvar FORM_FEED = '\\f';\nvar PARENTHESIS_OPEN = '(';\nvar PARENTHESIS_CLOSE = ')';\nvar PIPE = '|';\nvar PLUS = '+';\nvar QUOTE_DOUBLE = '\"';\nvar QUOTE_SINGLE = '\\'';\nvar SPACE = ' ';\nvar TAB = '\\t';\nvar VERTICAL_TAB = '\\u000B';\nvar SQUARE_BRACKET_OPEN = '[';\nvar SQUARE_BRACKET_CLOSE = ']';\nvar TICK = '`';\nvar TILDE = '~';\nvar UNDERSCORE = '_';\n\n/*\n * Entities.\n */\n\nvar ENTITY_AMPERSAND = AMPERSAND + 'amp' + SEMICOLON;\nvar ENTITY_ANGLE_BRACKET_OPEN = AMPERSAND + 'lt' + SEMICOLON;\nvar ENTITY_COLON = AMPERSAND + '#x3A' + SEMICOLON;\n\n/*\n * Character combinations.\n */\n\nvar BREAK = LINE + LINE;\nvar GAP = BREAK + LINE;\nvar DOUBLE_TILDE = TILDE + TILDE;\n\n/*\n * Allowed entity options.\n */\n\nvar ENTITY_OPTIONS = {};\n\nENTITY_OPTIONS.true = true;\nENTITY_OPTIONS.false = true;\nENTITY_OPTIONS.numbers = true;\nENTITY_OPTIONS.escape = true;\n\n/*\n * Allowed list-bullet characters.\n */\n\nvar LIST_BULLETS = {};\n\nLIST_BULLETS[ASTERISK] = true;\nLIST_BULLETS[DASH] = true;\nLIST_BULLETS[PLUS] = true;\n\n/*\n * Allowed horizontal-rule bullet characters.\n */\n\nvar HORIZONTAL_RULE_BULLETS = {};\n\nHORIZONTAL_RULE_BULLETS[ASTERISK] = true;\nHORIZONTAL_RULE_BULLETS[DASH] = true;\nHORIZONTAL_RULE_BULLETS[UNDERSCORE] = true;\n\n/*\n * Allowed emphasis characters.\n */\n\nvar EMPHASIS_MARKERS = {};\n\nEMPHASIS_MARKERS[UNDERSCORE] = true;\nEMPHASIS_MARKERS[ASTERISK] = true;\n\n/*\n * Allowed fence markers.\n */\n\nvar FENCE_MARKERS = {};\n\nFENCE_MARKERS[TICK] = true;\nFENCE_MARKERS[TILDE] = true;\n\n/*\n * Which method to use based on `list.ordered`.\n */\n\nvar ORDERED_MAP = {};\n\nORDERED_MAP.true = 'visitOrderedItems';\nORDERED_MAP.false = 'visitUnorderedItems';\n\n/*\n * Allowed list-item-indent's.\n */\n\nvar LIST_ITEM_INDENTS = {};\n\nvar LIST_ITEM_TAB = 'tab';\nvar LIST_ITEM_ONE = '1';\nvar LIST_ITEM_MIXED = 'mixed';\n\nLIST_ITEM_INDENTS[LIST_ITEM_ONE] = true;\nLIST_ITEM_INDENTS[LIST_ITEM_TAB] = true;\nLIST_ITEM_INDENTS[LIST_ITEM_MIXED] = true;\n\n/*\n * Which checkbox to use.\n */\n\nvar CHECKBOX_MAP = {};\n\nCHECKBOX_MAP.null = EMPTY;\nCHECKBOX_MAP.undefined = EMPTY;\nCHECKBOX_MAP.true = SQUARE_BRACKET_OPEN + 'x' + SQUARE_BRACKET_CLOSE + SPACE;\nCHECKBOX_MAP.false = SQUARE_BRACKET_OPEN + SPACE + SQUARE_BRACKET_CLOSE +\n    SPACE;\n\n/**\n * Encode noop.\n * Simply returns the given value.\n *\n * @example\n *   var encode = encodeNoop();\n *   encode('AT&T') // 'AT&T'\n *\n * @param {string} value - Content.\n * @return {string} - Content, without any modifications.\n */\nfunction encodeNoop(value) {\n    return value;\n}\n\n/**\n * Factory to encode HTML entities.\n * Creates a no-operation function when `type` is\n * `'false'`, a function which encodes using named\n * references when `type` is `'true'`, and a function\n * which encodes using numbered references when `type` is\n * `'numbers'`.\n *\n * @example\n *   encodeFactory('false')('AT&T') // 'AT&T'\n *   encodeFactory('true')('AT&T') // 'AT&amp;T'\n *   encodeFactory('numbers')('AT&T') // 'ATT&#x26;T'\n *\n * @param {string} type - Either `'true'`, `'false'`, or\n *   `'numbers'`.\n * @return {function(string): string} - Function which\n *   takes a value and returns its encoded version.\n */\nfunction encodeFactory(type) {\n    var options = {};\n\n    if (type === 'false') {\n        return encodeNoop;\n    }\n\n    if (type === 'true') {\n        options.useNamedReferences = true;\n    }\n\n    if (type === 'escape') {\n        options.escapeOnly = options.useNamedReferences = true;\n    }\n\n    /**\n     * Encode HTML entities using `he` using bound options.\n     *\n     * @see https://github.com/mathiasbynens/he#strict\n     *\n     * @example\n     *   // When `type` is `'true'`.\n     *   encode('AT&T'); // 'AT&amp;T'\n     *\n     *   // When `type` is `'numbers'`.\n     *   encode('AT&T'); // 'ATT&#x26;T'\n     *\n     * @param {string} value - Content.\n     * @param {Object} [node] - Node which is compiled.\n     * @return {string} - Encoded content.\n     * @throws {Error} - When `file.quiet` is not `true`.\n     *   However, by default `he` does not throw on\n     *   parse errors, but when\n     *   `he.encode.options.strict: true`, they occur on\n     *   invalid HTML.\n     */\n    function encoder(value) {\n        return encode(value, options);\n    }\n\n    return encoder;\n}\n\n/**\n * Returns the length of HTML entity that is a prefix of\n * the given string (excluding the ampersand), 0 if it\n * does not start with an entity.\n *\n * @example\n *   entityPrefixLength('&copycat') // 4\n *   entityPrefixLength('&foo &amp &bar') // 0\n *\n * @param {string} value - Input string.\n * @return {number} - Length of an entity.\n */\nfunction entityPrefixLength(value) {\n    var prefix;\n\n    /* istanbul ignore if - Currently also tested for at\n     * implemention, but we keep it here because that’s\n     * proper. */\n    if (value.charAt(0) !== AMPERSAND) {\n        return 0;\n    }\n\n    prefix = value.split(AMPERSAND, 2).join(AMPERSAND);\n\n    return prefix.length - decode(prefix).length;\n}\n\n/**\n * Checks if a string starts with HTML entity.\n *\n * @example\n *   startsWithEntity('&copycat') // true\n *   startsWithEntity('&foo &amp &bar') // false\n *\n * @param {string} value - Value to check.\n * @return {number} - Whether `value` starts an entity.\n */\nfunction startsWithEntity(value) {\n    return entityPrefixLength(value) > 0;\n}\n\n/**\n * Check if `character` is a valid alignment row character.\n *\n * @example\n *   isAlignmentRowCharacter(':') // true\n *   isAlignmentRowCharacter('=') // false\n *\n * @param {string} character - Character to check.\n * @return {boolean} - Whether `character` is a valid\n *   alignment row character.\n */\nfunction isAlignmentRowCharacter(character) {\n    return character === COLON ||\n        character === DASH ||\n        character === SPACE ||\n        character === PIPE;\n}\n\n/**\n * Check if `index` in `value` is inside an alignment row.\n *\n * @example\n *   isInAlignmentRow(':--:', 2) // true\n *   isInAlignmentRow(':--:\\n:-*-:', 9) // false\n *\n * @param {string} value - Value to check.\n * @param {number} index - Position in `value` to check.\n * @return {boolean} - Whether `index` in `value` is in\n *   an alignment row.\n */\nfunction isInAlignmentRow(value, index) {\n    var length = value.length;\n    var start = index;\n    var character;\n\n    while (++index < length) {\n        character = value.charAt(index);\n\n        if (character === LINE) {\n            break;\n        }\n\n        if (!isAlignmentRowCharacter(character)) {\n            return false;\n        }\n    }\n\n    index = start;\n\n    while (--index > -1) {\n        character = value.charAt(index);\n\n        if (character === LINE) {\n            break;\n        }\n\n        if (!isAlignmentRowCharacter(character)) {\n            return false;\n        }\n    }\n\n    return true;\n}\n\n/**\n * Factory to escape characters.\n *\n * @example\n *   var escape = escapeFactory({ commonmark: true });\n *   escape('x*x', { type: 'text', value: 'x*x' }) // 'x\\\\*x'\n *\n * @param {Object} options - Compiler options.\n * @return {function(value, node, parent): string} - Function which\n *   takes a value and a node and (optionally) its parent and returns\n *   its escaped value.\n */\nfunction escapeFactory(options) {\n    /**\n     * Escape punctuation characters in a node's value.\n     *\n     * @param {string} value - Value to escape.\n     * @param {Object} node - Node in which `value` exists.\n     * @param {Object} [parent] - Parent of `node`.\n     * @return {string} - Escaped `value`.\n     */\n    return function escape(value, node, parent) {\n        var self = this;\n        var gfm = options.gfm;\n        var commonmark = options.commonmark;\n        var siblings = parent && parent.children;\n        var index = siblings && siblings.indexOf(node);\n        var prev = siblings && siblings[index - 1];\n        var next = siblings && siblings[index + 1];\n        var length = value.length;\n        var position = -1;\n        var queue = [];\n        var escaped = queue;\n        var afterNewLine;\n        var character;\n\n        if (prev) {\n            afterNewLine = prev.type === 'text' && /\\n\\s*$/.test(prev.value);\n        } else if (parent) {\n            afterNewLine = parent.type === 'paragraph';\n        }\n\n        while (++position < length) {\n            character = value.charAt(position);\n\n            if (\n                character === BACKSLASH ||\n                character === TICK ||\n                character === ASTERISK ||\n                character === SQUARE_BRACKET_OPEN ||\n                character === UNDERSCORE ||\n                (self.inLink && character === SQUARE_BRACKET_CLOSE) ||\n                (\n                    gfm &&\n                    character === PIPE &&\n                    (\n                        self.inTable ||\n                        isInAlignmentRow(value, position)\n                    )\n                )\n            ) {\n                afterNewLine = false;\n                queue.push(BACKSLASH);\n            } else if (character === ANGLE_BRACKET_OPEN) {\n                afterNewLine = false;\n\n                if (commonmark) {\n                    queue.push(BACKSLASH);\n                } else {\n                    queue.push(ENTITY_ANGLE_BRACKET_OPEN);\n                    continue;\n                }\n            } else if (\n                gfm &&\n                !self.inLink &&\n                character === COLON &&\n                (\n                    queue.slice(-6).join(EMPTY) === 'mailto' ||\n                    queue.slice(-5).join(EMPTY) === 'https' ||\n                    queue.slice(-4).join(EMPTY) === 'http'\n                )\n            ) {\n                afterNewLine = false;\n\n                if (commonmark) {\n                    queue.push(BACKSLASH);\n                } else {\n                    queue.push(ENTITY_COLON);\n                    continue;\n                }\n            /* istanbul ignore if - Impossible to test with\n             * the current set-up.  We need tests which try\n             * to force markdown content into the tree. */\n            } else if (\n                character === AMPERSAND &&\n                startsWithEntity(value.slice(position))\n            ) {\n                afterNewLine = false;\n\n                if (commonmark) {\n                    queue.push(BACKSLASH);\n                } else {\n                    queue.push(ENTITY_AMPERSAND);\n                    continue;\n                }\n            } else if (\n                gfm &&\n                character === TILDE &&\n                value.charAt(position + 1) === TILDE\n            ) {\n                queue.push(BACKSLASH, TILDE);\n                afterNewLine = false;\n                position += 1;\n            } else if (character === LINE) {\n                afterNewLine = true;\n            } else if (afterNewLine) {\n                if (\n                    character === ANGLE_BRACKET_CLOSE ||\n                    character === HASH ||\n                    LIST_BULLETS[character]\n                ) {\n                    queue.push(BACKSLASH);\n                    afterNewLine = false;\n                } else if (\n                    character !== SPACE &&\n                    character !== TAB &&\n                    character !== CARRIAGE &&\n                    character !== VERTICAL_TAB &&\n                    character !== FORM_FEED\n                ) {\n                    afterNewLine = false;\n                }\n            }\n\n            queue.push(character);\n        }\n\n        /*\n         * Multi-node versions.\n         */\n\n        if (siblings && node.type === 'text') {\n            /*\n             * Check for an opening parentheses after a\n             * link-reference (which can be joined by\n             * white-space).\n             */\n\n            if (\n                prev &&\n                prev.referenceType === 'shortcut'\n            ) {\n                position = -1;\n                length = escaped.length;\n\n                while (++position < length) {\n                    character = escaped[position];\n\n                    if (character === SPACE || character === TAB) {\n                        continue;\n                    }\n\n                    if (character === PARENTHESIS_OPEN) {\n                        escaped[position] = BACKSLASH + character;\n                    }\n\n                    if (character === COLON) {\n                        if (commonmark) {\n                            escaped[position] = BACKSLASH + character;\n                        } else {\n                            escaped[position] = ENTITY_COLON;\n                        }\n                    }\n\n                    break;\n                }\n            }\n\n            /*\n             * Ensure non-auto-links are not seen as links.\n             * This pattern needs to check the preceding\n             * nodes too.\n             */\n\n            if (\n                gfm &&\n                !self.inLink &&\n                prev &&\n                prev.type === 'text' &&\n                value.charAt(0) === COLON\n            ) {\n                queue = prev.value.slice(-6);\n\n                if (\n                    queue === 'mailto' ||\n                    queue.slice(-5) === 'https' ||\n                    queue.slice(-4) === 'http'\n                ) {\n                    if (commonmark) {\n                        escaped.unshift(BACKSLASH);\n                    } else {\n                        escaped.splice(0, 1, ENTITY_COLON);\n                    }\n                }\n            }\n\n            /*\n             * Escape ampersand if it would otherwise\n             * start an entity.\n             */\n\n            if (\n                next &&\n                next.type === 'text' &&\n                value.slice(-1) === AMPERSAND &&\n                startsWithEntity(AMPERSAND + next.value)\n            ) {\n                if (commonmark) {\n                    escaped.splice(escaped.length - 1, 0, BACKSLASH);\n                } else {\n                    escaped.push('amp', SEMICOLON);\n                }\n            }\n\n            /*\n             * Escape double tildes in GFM.\n             */\n\n            if (\n                gfm &&\n                next &&\n                next.type === 'text' &&\n                value.slice(-1) === TILDE &&\n                next.value.charAt(0) === TILDE\n            ) {\n                escaped.splice(escaped.length - 1, 0, BACKSLASH);\n            }\n        }\n\n        return escaped.join(EMPTY);\n    };\n}\n\n/**\n * Wrap `url` in angle brackets when needed, or when\n * forced.\n *\n * In links, images, and definitions, the URL part needs\n * to be enclosed when it:\n *\n * - has a length of `0`;\n * - contains white-space;\n * - has more or less opening than closing parentheses.\n *\n * @example\n *   encloseURI('foo bar') // '<foo bar>'\n *   encloseURI('foo(bar(baz)') // '<foo(bar(baz)>'\n *   encloseURI('') // '<>'\n *   encloseURI('example.com') // 'example.com'\n *   encloseURI('example.com', true) // '<example.com>'\n *\n * @param {string} uri - URI to enclose.\n * @param {boolean?} [always] - Force enclosing.\n * @return {boolean} - Properly enclosed `uri`.\n */\nfunction encloseURI(uri, always) {\n    if (\n        always ||\n        !uri.length ||\n        EXPRESSIONS_WHITE_SPACE.test(uri) ||\n        ccount(uri, PARENTHESIS_OPEN) !== ccount(uri, PARENTHESIS_CLOSE)\n    ) {\n        return ANGLE_BRACKET_OPEN + uri + ANGLE_BRACKET_CLOSE;\n    }\n\n    return uri;\n}\n\n/**\n * There is currently no way to support nested delimiters\n * across Markdown.pl, CommonMark, and GitHub (RedCarpet).\n * The following code supports Markdown.pl and GitHub.\n * CommonMark is not supported when mixing double- and\n * single quotes inside a title.\n *\n * @see https://github.com/vmg/redcarpet/issues/473\n * @see https://github.com/jgm/CommonMark/issues/308\n *\n * @example\n *   encloseTitle('foo') // '\"foo\"'\n *   encloseTitle('foo \\'bar\\' baz') // '\"foo \\'bar\\' baz\"'\n *   encloseTitle('foo \"bar\" baz') // '\\'foo \"bar\" baz\\''\n *   encloseTitle('foo \"bar\" \\'baz\\'') // '\"foo \"bar\" \\'baz\\'\"'\n *\n * @param {string} title - Content.\n * @return {string} - Properly enclosed title.\n */\nfunction encloseTitle(title) {\n    var delimiter = QUOTE_DOUBLE;\n\n    if (title.indexOf(delimiter) !== -1) {\n        delimiter = QUOTE_SINGLE;\n    }\n\n    return delimiter + title + delimiter;\n}\n\n/**\n * Pad `value` with `level * INDENT` spaces.  Respects\n * lines. Ignores empty lines.\n *\n * @example\n *   pad('foo', 1) // '    foo'\n *\n * @param {string} value - Content.\n * @param {number} level - Indentation level.\n * @return {string} - Padded `value`.\n */\nfunction pad(value, level) {\n    var index;\n    var padding;\n\n    value = value.split(LINE);\n\n    index = value.length;\n    padding = repeat(SPACE, level * INDENT);\n\n    while (index--) {\n        if (value[index].length !== 0) {\n            value[index] = padding + value[index];\n        }\n    }\n\n    return value.join(LINE);\n}\n\n/**\n * Construct a new compiler.\n *\n * @example\n *   var compiler = new Compiler(new File('> foo.'));\n *\n * @constructor\n * @class {Compiler}\n * @param {File} file - Virtual file.\n * @param {Object?} [options] - Passed to\n *   `Compiler#setOptions()`.\n */\nfunction Compiler(file, options) {\n    var self = this;\n\n    self.file = file;\n\n    self.options = extend({}, self.options);\n\n    self.setOptions(options);\n}\n\n/*\n * Cache prototype.\n */\n\nvar compilerPrototype = Compiler.prototype;\n\n/*\n * Expose defaults.\n */\n\ncompilerPrototype.options = defaultOptions;\n\n/*\n * Map of applicable enum's.\n */\n\nvar maps = {\n    'entities': ENTITY_OPTIONS,\n    'bullet': LIST_BULLETS,\n    'rule': HORIZONTAL_RULE_BULLETS,\n    'listItemIndent': LIST_ITEM_INDENTS,\n    'emphasis': EMPHASIS_MARKERS,\n    'strong': EMPHASIS_MARKERS,\n    'fence': FENCE_MARKERS\n};\n\n/**\n * Set options.  Does not overwrite previously set\n * options.\n *\n * @example\n *   var compiler = new Compiler();\n *   compiler.setOptions({bullet: '*'});\n *\n * @this {Compiler}\n * @throws {Error} - When an option is invalid.\n * @param {Object?} [options] - Stringify settings.\n * @return {Compiler} - `self`.\n */\ncompilerPrototype.setOptions = function (options) {\n    var self = this;\n    var current = self.options;\n    var ruleRepetition;\n    var key;\n\n    if (options === null || options === undefined) {\n        options = {};\n    } else if (typeof options === 'object') {\n        options = extend({}, options);\n    } else {\n        raise(options, 'options');\n    }\n\n    for (key in defaultOptions) {\n        validate[typeof current[key]](\n            options, key, current[key], maps[key]\n        );\n    }\n\n    ruleRepetition = options.ruleRepetition;\n\n    if (ruleRepetition && ruleRepetition < MINIMUM_RULE_LENGTH) {\n        raise(ruleRepetition, 'options.ruleRepetition');\n    }\n\n    self.encode = encodeFactory(String(options.entities));\n    self.escape = escapeFactory(options);\n\n    self.options = options;\n\n    return self;\n};\n\n/*\n * Enter and exit helpers.\n */\n\ncompilerPrototype.enterLink = stateToggler('inLink', false);\ncompilerPrototype.enterTable = stateToggler('inTable', false);\n\n/**\n * Shortcut and collapsed link references need no escaping\n * and encoding during the processing of child nodes (it\n * must be implied from identifier).\n *\n * This toggler turns encoding and escaping off for shortcut\n * and collapsed references.\n *\n * Implies `enterLink`.\n *\n * @param {Compiler} compiler - Compiler instance.\n * @param {LinkReference} node - LinkReference node.\n * @return {Function} - Exit state.\n */\ncompilerPrototype.enterLinkReference = function (compiler, node) {\n    var encode = compiler.encode;\n    var escape = compiler.escape;\n    var exitLink = compiler.enterLink();\n\n    if (\n        node.referenceType === 'shortcut' ||\n        node.referenceType === 'collapsed'\n    ) {\n        compiler.encode = compiler.escape = encodeNoop;\n        return function () {\n            compiler.encode = encode;\n            compiler.escape = escape;\n            exitLink();\n        };\n    } else {\n        return exitLink;\n    }\n};\n\n/**\n * Visit a node.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.visit({\n *     type: 'strong',\n *     children: [{\n *       type: 'text',\n *       value: 'Foo'\n *     }]\n *   });\n *   // '**Foo**'\n *\n * @param {Object} node - Node.\n * @param {Object?} [parent] - `node`s parent.\n * @return {string} - Compiled `node`.\n */\ncompilerPrototype.visit = function (node, parent) {\n    var self = this;\n\n    /*\n     * Fail on unknown nodes.\n     */\n\n    if (typeof self[node.type] !== 'function') {\n        self.file.fail(\n            'Missing compiler for node of type `' +\n            node.type + '`: `' + node + '`',\n            node\n        );\n    }\n\n    return self[node.type](node, parent);\n};\n\n/**\n * Visit all children of `parent`.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.all({\n *     type: 'strong',\n *     children: [{\n *       type: 'text',\n *       value: 'Foo'\n *     },\n *     {\n *       type: 'text',\n *       value: 'Bar'\n *     }]\n *   });\n *   // ['Foo', 'Bar']\n *\n * @param {Object} parent - Parent node of children.\n * @return {Array.<string>} - List of compiled children.\n */\ncompilerPrototype.all = function (parent) {\n    var self = this;\n    var children = parent.children;\n    var values = [];\n    var index = 0;\n    var length = children.length;\n    var node = children[0];\n    var next;\n\n    if (length === 0) {\n        return values;\n    }\n\n    while (++index < length) {\n        next = children[index];\n\n        if (\n            node.type === next.type &&\n            node.type in MERGEABLE_NODES &&\n            mergeable(node) &&\n            mergeable(next)\n        ) {\n            node = MERGEABLE_NODES[node.type].call(self, node, next);\n        } else {\n            values.push(self.visit(node, parent));\n            node = next;\n        }\n    }\n\n    values.push(self.visit(node, parent));\n\n    return values;\n};\n\n/**\n * Visit ordered list items.\n *\n * Starts the list with\n * `node.start` and increments each following list item\n * bullet by one:\n *\n *     2. foo\n *     3. bar\n *\n * In `incrementListMarker: false` mode, does not increment\n * each marker and stays on `node.start`:\n *\n *     1. foo\n *     1. bar\n *\n * Adds an extra line after an item if it has\n * `loose: true`.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.visitOrderedItems({\n *     type: 'list',\n *     ordered: true,\n *     children: [{\n *       type: 'listItem',\n *       children: [{\n *         type: 'text',\n *         value: 'bar'\n *       }]\n *     }]\n *   });\n *   // '1.  bar'\n *\n * @param {Object} node - `list` node with\n *   `ordered: true`.\n * @return {string} - Markdown list.\n */\ncompilerPrototype.visitOrderedItems = function (node) {\n    var self = this;\n    var increment = self.options.incrementListMarker;\n    var values = [];\n    var start = node.start;\n    var children = node.children;\n    var length = children.length;\n    var index = -1;\n    var bullet;\n\n    while (++index < length) {\n        bullet = (increment ? start + index : start) + DOT;\n        values[index] = self.listItem(children[index], node, index, bullet);\n    }\n\n    return values.join(LINE);\n};\n\n/**\n * Visit unordered list items.\n *\n * Uses `options.bullet` as each item's bullet.\n *\n * Adds an extra line after an item if it has\n * `loose: true`.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.visitUnorderedItems({\n *     type: 'list',\n *     ordered: false,\n *     children: [{\n *       type: 'listItem',\n *       children: [{\n *         type: 'text',\n *         value: 'bar'\n *       }]\n *     }]\n *   });\n *   // '-   bar'\n *\n * @param {Object} node - `list` node with\n *   `ordered: false`.\n * @return {string} - Markdown list.\n */\ncompilerPrototype.visitUnorderedItems = function (node) {\n    var self = this;\n    var values = [];\n    var children = node.children;\n    var length = children.length;\n    var index = -1;\n    var bullet = self.options.bullet;\n\n    while (++index < length) {\n        values[index] = self.listItem(children[index], node, index, bullet);\n    }\n\n    return values.join(LINE);\n};\n\n/**\n * Stringify a block node with block children (e.g., `root`\n * or `blockquote`).\n *\n * Knows about code following a list, or adjacent lists\n * with similar bullets, and places an extra newline\n * between them.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.block({\n *     type: 'root',\n *     children: [{\n *       type: 'paragraph',\n *       children: [{\n *         type: 'text',\n *         value: 'bar'\n *       }]\n *     }]\n *   });\n *   // 'bar'\n *\n * @param {Object} node - `root` node.\n * @return {string} - Markdown block content.\n */\ncompilerPrototype.block = function (node) {\n    var self = this;\n    var values = [];\n    var children = node.children;\n    var length = children.length;\n    var index = -1;\n    var child;\n    var prev;\n\n    while (++index < length) {\n        child = children[index];\n\n        if (prev) {\n            /*\n             * Duplicate nodes, such as a list\n             * directly following another list,\n             * often need multiple new lines.\n             *\n             * Additionally, code blocks following a list\n             * might easily be mistaken for a paragraph\n             * in the list itself.\n             */\n\n            if (child.type === prev.type && prev.type === 'list') {\n                values.push(prev.ordered === child.ordered ? GAP : BREAK);\n            } else if (\n                prev.type === 'list' &&\n                child.type === 'code' &&\n                !child.lang\n            ) {\n                values.push(GAP);\n            } else {\n                values.push(BREAK);\n            }\n        }\n\n        values.push(self.visit(child, node));\n\n        prev = child;\n    }\n\n    return values.join(EMPTY);\n};\n\n/**\n * Stringify a root.\n *\n * Adds a final newline to ensure valid POSIX files.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.root({\n *     type: 'root',\n *     children: [{\n *       type: 'paragraph',\n *       children: [{\n *         type: 'text',\n *         value: 'bar'\n *       }]\n *     }]\n *   });\n *   // 'bar'\n *\n * @param {Object} node - `root` node.\n * @return {string} - Markdown document.\n */\ncompilerPrototype.root = function (node) {\n    return this.block(node) + LINE;\n};\n\n/**\n * Stringify a heading.\n *\n * In `setext: true` mode and when `depth` is smaller than\n * three, creates a setext header:\n *\n *     Foo\n *     ===\n *\n * Otherwise, an ATX header is generated:\n *\n *     ### Foo\n *\n * In `closeAtx: true` mode, the header is closed with\n * hashes:\n *\n *     ### Foo ###\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.heading({\n *     type: 'heading',\n *     depth: 2,\n *     children: [{\n *       type: 'strong',\n *       children: [{\n *         type: 'text',\n *         value: 'bar'\n *       }]\n *     }]\n *   });\n *   // '## **bar**'\n *\n * @param {Object} node - `heading` node.\n * @return {string} - Markdown heading.\n */\ncompilerPrototype.heading = function (node) {\n    var self = this;\n    var setext = self.options.setext;\n    var closeAtx = self.options.closeAtx;\n    var depth = node.depth;\n    var content = self.all(node).join(EMPTY);\n    var prefix;\n\n    if (setext && depth < 3) {\n        return content + LINE +\n            repeat(depth === 1 ? EQUALS : DASH, content.length);\n    }\n\n    prefix = repeat(HASH, node.depth);\n    content = prefix + SPACE + content;\n\n    if (closeAtx) {\n        content += SPACE + prefix;\n    }\n\n    return content;\n};\n\n/**\n * Stringify text.\n *\n * Supports named entities in `settings.encode: true` mode:\n *\n *     AT&amp;T\n *\n * Supports numbered entities in `settings.encode: numbers`\n * mode:\n *\n *     AT&#x26;T\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.text({\n *     type: 'text',\n *     value: 'foo'\n *   });\n *   // 'foo'\n *\n * @param {Object} node - `text` node.\n * @param {Object} parent - Parent of `node`.\n * @return {string} - Raw markdown text.\n */\ncompilerPrototype.text = function (node, parent) {\n    return this.encode(this.escape(node.value, node, parent), node);\n};\n\n/**\n * Stringify a paragraph.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.paragraph({\n *     type: 'paragraph',\n *     children: [{\n *       type: 'strong',\n *       children: [{\n *         type: 'text',\n *         value: 'bar'\n *       }]\n *     }]\n *   });\n *   // '**bar**'\n *\n * @param {Object} node - `paragraph` node.\n * @return {string} - Markdown paragraph.\n */\ncompilerPrototype.paragraph = function (node) {\n    return this.all(node).join(EMPTY);\n};\n\n/**\n * Stringify a block quote.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.paragraph({\n *     type: 'blockquote',\n *     children: [{\n *       type: 'paragraph',\n *       children: [{\n *         type: 'strong',\n *         children: [{\n *           type: 'text',\n *           value: 'bar'\n *         }]\n *       }]\n *     }]\n *   });\n *   // '> **bar**'\n *\n * @param {Object} node - `blockquote` node.\n * @return {string} - Markdown block quote.\n */\ncompilerPrototype.blockquote = function (node) {\n    var values = this.block(node).split(LINE);\n    var result = [];\n    var length = values.length;\n    var index = -1;\n    var value;\n\n    while (++index < length) {\n        value = values[index];\n        result[index] = (value ? SPACE : EMPTY) + value;\n    }\n\n    return ANGLE_BRACKET_CLOSE + result.join(LINE + ANGLE_BRACKET_CLOSE);\n};\n\n/**\n * Stringify a list. See `Compiler#visitOrderedList()` and\n * `Compiler#visitUnorderedList()` for internal working.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.visitUnorderedItems({\n *     type: 'list',\n *     ordered: false,\n *     children: [{\n *       type: 'listItem',\n *       children: [{\n *         type: 'text',\n *         value: 'bar'\n *       }]\n *     }]\n *   });\n *   // '-   bar'\n *\n * @param {Object} node - `list` node.\n * @return {string} - Markdown list.\n */\ncompilerPrototype.list = function (node) {\n    return this[ORDERED_MAP[node.ordered]](node);\n};\n\n/**\n * Stringify a list item.\n *\n * Prefixes the content with a checked checkbox when\n * `checked: true`:\n *\n *     [x] foo\n *\n * Prefixes the content with an unchecked checkbox when\n * `checked: false`:\n *\n *     [ ] foo\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.listItem({\n *     type: 'listItem',\n *     checked: true,\n *     children: [{\n *       type: 'text',\n *       value: 'bar'\n *     }]\n *   }, {\n *     type: 'list',\n *     ordered: false,\n *     children: [{\n *       type: 'listItem',\n *       checked: true,\n *       children: [{\n *         type: 'text',\n *         value: 'bar'\n *       }]\n *     }]\n *   }, 0, '*');\n *   '-   [x] bar'\n *\n * @param {Object} node - `listItem` node.\n * @param {Object} parent - `list` node.\n * @param {number} position - Index of `node` in `parent`.\n * @param {string} bullet - Bullet to use.  This, and the\n *   `listItemIndent` setting define the used indent.\n * @return {string} - Markdown list item.\n */\ncompilerPrototype.listItem = function (node, parent, position, bullet) {\n    var self = this;\n    var style = self.options.listItemIndent;\n    var children = node.children;\n    var values = [];\n    var index = -1;\n    var length = children.length;\n    var loose = node.loose;\n    var value;\n    var indent;\n    var spacing;\n\n    while (++index < length) {\n        values[index] = self.visit(children[index], node);\n    }\n\n    value = CHECKBOX_MAP[node.checked] + values.join(loose ? BREAK : LINE);\n\n    if (\n        style === LIST_ITEM_ONE ||\n        (style === LIST_ITEM_MIXED && value.indexOf(LINE) === -1)\n    ) {\n        indent = bullet.length + 1;\n        spacing = SPACE;\n    } else {\n        indent = Math.ceil((bullet.length + 1) / INDENT) * INDENT;\n        spacing = repeat(SPACE, indent - bullet.length);\n    }\n\n    value = bullet + spacing + pad(value, indent / INDENT).slice(indent);\n\n    if (loose && parent.children.length - 1 !== position) {\n        value += LINE;\n    }\n\n    return value;\n};\n\n/**\n * Stringify inline code.\n *\n * Knows about internal ticks (`\\``), and ensures one more\n * tick is used to enclose the inline code:\n *\n *     ```foo ``bar`` baz```\n *\n * Even knows about inital and final ticks:\n *\n *     `` `foo ``\n *     `` foo` ``\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.inlineCode({\n *     type: 'inlineCode',\n *     value: 'foo(); `bar`; baz()'\n *   });\n *   // '``foo(); `bar`; baz()``'\n *\n * @param {Object} node - `inlineCode` node.\n * @return {string} - Markdown inline code.\n */\ncompilerPrototype.inlineCode = function (node) {\n    var value = node.value;\n    var ticks = repeat(TICK, longestStreak(value, TICK) + 1);\n    var start = ticks;\n    var end = ticks;\n\n    if (value.charAt(0) === TICK) {\n        start += SPACE;\n    }\n\n    if (value.charAt(value.length - 1) === TICK) {\n        end = SPACE + end;\n    }\n\n    return start + node.value + end;\n};\n\n/**\n * Stringify YAML front matter.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.yaml({\n *     type: 'yaml',\n *     value: 'foo: bar'\n *   });\n *   // '---\\nfoo: bar\\n---'\n *\n * @param {Object} node - `yaml` node.\n * @return {string} - Markdown YAML document.\n */\ncompilerPrototype.yaml = function (node) {\n    var delimiter = repeat(DASH, YAML_FENCE_LENGTH);\n    var value = node.value ? LINE + node.value : EMPTY;\n\n    return delimiter + value + LINE + delimiter;\n};\n\n/**\n * Stringify a code block.\n *\n * Creates indented code when:\n *\n * - No language tag exists;\n * - Not in `fences: true` mode;\n * - A non-empty value exists.\n *\n * Otherwise, GFM fenced code is created:\n *\n *     ```js\n *     foo();\n *     ```\n *\n * When in ``fence: `~` `` mode, uses tildes as fences:\n *\n *     ~~~js\n *     foo();\n *     ~~~\n *\n * Knows about internal fences (Note: GitHub/Kramdown does\n * not support this):\n *\n *     ````javascript\n *     ```markdown\n *     foo\n *     ```\n *     ````\n *\n * Supports named entities in the language flag with\n * `settings.encode` mode.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.code({\n *     type: 'code',\n *     lang: 'js',\n *     value: 'fooo();'\n *   });\n *   // '```js\\nfooo();\\n```'\n *\n * @param {Object} node - `code` node.\n * @param {Object} parent - Parent of `node`.\n * @return {string} - Markdown code block.\n */\ncompilerPrototype.code = function (node, parent) {\n    var self = this;\n    var value = node.value;\n    var options = self.options;\n    var marker = options.fence;\n    var language = self.encode(node.lang || EMPTY, node);\n    var fence;\n\n    /*\n     * Without (needed) fences.\n     */\n\n    if (!language && !options.fences && value) {\n        /*\n         * Throw when pedantic, in a list item which\n         * isn’t compiled using a tab.\n         */\n\n        if (\n            parent &&\n            parent.type === 'listItem' &&\n            options.listItemIndent !== LIST_ITEM_TAB &&\n            options.pedantic\n        ) {\n            self.file.fail(ERROR_LIST_ITEM_INDENT, node.position);\n        }\n\n        return pad(value, 1);\n    }\n\n    fence = longestStreak(value, marker) + 1;\n\n    /*\n     * Fix GFM / RedCarpet bug, where fence-like characters\n     * inside fenced code can exit a code-block.\n     * Yes, even when the outer fence uses different\n     * characters, or is longer.\n     * Thus, we can only pad the code to make it work.\n     */\n\n    if (FENCE.test(value)) {\n        value = pad(value, 1);\n    }\n\n    fence = repeat(marker, Math.max(fence, MINIMUM_CODE_FENCE_LENGTH));\n\n    return fence + language + LINE + value + LINE + fence;\n};\n\n/**\n * Stringify HTML.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.html({\n *     type: 'html',\n *     value: '<div>bar</div>'\n *   });\n *   // '<div>bar</div>'\n *\n * @param {Object} node - `html` node.\n * @return {string} - Markdown HTML.\n */\ncompilerPrototype.html = function (node) {\n    return node.value;\n};\n\n/**\n * Stringify a horizontal rule.\n *\n * The character used is configurable by `rule`: (`'_'`)\n *\n *     ___\n *\n * The number of repititions is defined through\n * `ruleRepetition`: (`6`)\n *\n *     ******\n *\n * Whether spaces delimit each character, is configured\n * through `ruleSpaces`: (`true`)\n *\n *     * * *\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.horizontalRule({\n *     type: 'horizontalRule'\n *   });\n *   // '***'\n *\n * @return {string} - Markdown rule.\n */\ncompilerPrototype.horizontalRule = function () {\n    var options = this.options;\n    var rule = repeat(options.rule, options.ruleRepetition);\n\n    if (options.ruleSpaces) {\n        rule = rule.split(EMPTY).join(SPACE);\n    }\n\n    return rule;\n};\n\n/**\n * Stringify a strong.\n *\n * The marker used is configurable by `strong`, which\n * defaults to an asterisk (`'*'`) but also accepts an\n * underscore (`'_'`):\n *\n *     _foo_\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.strong({\n *     type: 'strong',\n *     children: [{\n *       type: 'text',\n *       value: 'Foo'\n *     }]\n *   });\n *   // '**Foo**'\n *\n * @param {Object} node - `strong` node.\n * @return {string} - Markdown strong-emphasised text.\n */\ncompilerPrototype.strong = function (node) {\n    var marker = this.options.strong;\n\n    marker = marker + marker;\n\n    return marker + this.all(node).join(EMPTY) + marker;\n};\n\n/**\n * Stringify an emphasis.\n *\n * The marker used is configurable by `emphasis`, which\n * defaults to an underscore (`'_'`) but also accepts an\n * asterisk (`'*'`):\n *\n *     *foo*\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.emphasis({\n *     type: 'emphasis',\n *     children: [{\n *       type: 'text',\n *       value: 'Foo'\n *     }]\n *   });\n *   // '_Foo_'\n *\n * @param {Object} node - `emphasis` node.\n * @return {string} - Markdown emphasised text.\n */\ncompilerPrototype.emphasis = function (node) {\n    var marker = this.options.emphasis;\n\n    return marker + this.all(node).join(EMPTY) + marker;\n};\n\n/**\n * Stringify a hard break.\n *\n * In Commonmark mode, trailing backslash form is used in order\n * to preserve trailing whitespace that the line may end with,\n * and also for better visibility.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.break({\n *     type: 'break'\n *   });\n *   // '  \\n'\n *\n * @return {string} - Hard markdown break.\n */\ncompilerPrototype.break = function () {\n    return this.options.commonmark ? BACKSLASH + LINE : SPACE + SPACE + LINE;\n};\n\n/**\n * Stringify a delete.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.delete({\n *     type: 'delete',\n *     children: [{\n *       type: 'text',\n *       value: 'Foo'\n *     }]\n *   });\n *   // '~~Foo~~'\n *\n * @param {Object} node - `delete` node.\n * @return {string} - Markdown strike-through.\n */\ncompilerPrototype.delete = function (node) {\n    return DOUBLE_TILDE + this.all(node).join(EMPTY) + DOUBLE_TILDE;\n};\n\n/**\n * Stringify a link.\n *\n * When no title exists, the compiled `children` equal\n * `href`, and `href` starts with a protocol, an auto\n * link is created:\n *\n *     <http://example.com>\n *\n * Otherwise, is smart about enclosing `href` (see\n * `encloseURI()`) and `title` (see `encloseTitle()`).\n *\n *    [foo](<foo at bar dot com> 'An \"example\" e-mail')\n *\n * Supports named entities in the `href` and `title` when\n * in `settings.encode` mode.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.link({\n *     type: 'link',\n *     href: 'http://example.com',\n *     title: 'Example Domain',\n *     children: [{\n *       type: 'text',\n *       value: 'Foo'\n *     }]\n *   });\n *   // '[Foo](http://example.com \"Example Domain\")'\n *\n * @param {Object} node - `link` node.\n * @return {string} - Markdown link.\n */\ncompilerPrototype.link = function (node) {\n    var self = this;\n    var url = self.encode(node.href, node);\n    var exit = self.enterLink();\n    var escapedURL = self.encode(self.escape(node.href, node));\n    var value = self.all(node).join(EMPTY);\n\n    exit();\n\n    if (\n        node.title === null &&\n        PROTOCOL.test(url) &&\n        (escapedURL === value || escapedURL === MAILTO + value)\n    ) {\n        /*\n         * Backslash escapes do not work in autolinks,\n         * so we do not escape.\n         */\n\n        return encloseURI(self.encode(node.href), true);\n    }\n\n    url = encloseURI(url);\n\n    if (node.title) {\n        url += SPACE + encloseTitle(self.encode(self.escape(\n            node.title, node\n        ), node));\n    }\n\n    value = SQUARE_BRACKET_OPEN + value + SQUARE_BRACKET_CLOSE;\n\n    value += PARENTHESIS_OPEN + url + PARENTHESIS_CLOSE;\n\n    return value;\n};\n\n/**\n * Stringify a link label.\n *\n * Because link references are easily, mistakingly,\n * created (for example, `[foo]`), reference nodes have\n * an extra property depicting how it looked in the\n * original document, so stringification can cause minimal\n * changes.\n *\n * @example\n *   label({\n *     type: 'referenceImage',\n *     referenceType: 'full',\n *     identifier: 'foo'\n *   });\n *   // '[foo]'\n *\n *   label({\n *     type: 'referenceImage',\n *     referenceType: 'collapsed',\n *     identifier: 'foo'\n *   });\n *   // '[]'\n *\n *   label({\n *     type: 'referenceImage',\n *     referenceType: 'shortcut',\n *     identifier: 'foo'\n *   });\n *   // ''\n *\n * @param {Object} node - `linkReference` or\n *   `imageReference` node.\n * @return {string} - Markdown label reference.\n */\nfunction label(node) {\n    var value = EMPTY;\n    var type = node.referenceType;\n\n    if (type === 'full') {\n        value = node.identifier;\n    }\n\n    if (type !== 'shortcut') {\n        value = SQUARE_BRACKET_OPEN + value + SQUARE_BRACKET_CLOSE;\n    }\n\n    return value;\n}\n\n/**\n * For shortcut and collapsed reference links, the contents\n * is also an identifier, so we need to restore the original\n * encoding and escaping that were present in the source\n * string.\n *\n * This function takes the unescaped & unencoded value from\n * shortcut's child nodes and the identifier and encodes\n * the former according to the latter.\n *\n * @example\n *   copyIdentifierEncoding('a*b', 'a\\\\*b*c')\n *   // 'a\\\\*b*c'\n *\n * @param {string} value - Unescaped and unencoded stringified\n *   link value.\n * @param {string} identifier - Link identifier.\n * @return {string} - Encoded link value.\n */\nfunction copyIdentifierEncoding(value, identifier) {\n    var index = 0;\n    var position = 0;\n    var length = value.length;\n    var count = identifier.length;\n    var result = [];\n    var start;\n\n    while (index < length) {\n        /*\n         * Take next non-punctuation characters from `value`.\n         */\n\n        start = index;\n\n        while (\n            index < length &&\n            !PUNCTUATION.test(value.charAt(index))\n        ) {\n            index += 1;\n        }\n\n        result.push(value.slice(start, index));\n\n        /*\n         * Advance `position` to the next punctuation character.\n         */\n        while (\n            position < count &&\n            !PUNCTUATION.test(identifier.charAt(position))\n        ) {\n            position += 1;\n        }\n\n        /*\n         * Take next punctuation characters from `identifier`.\n         */\n        start = position;\n\n        while (\n            position < count &&\n            PUNCTUATION.test(identifier.charAt(position))\n        ) {\n            if (identifier.charAt(position) === AMPERSAND) {\n                position += entityPrefixLength(identifier.slice(position));\n            }\n            position += 1;\n        }\n\n        result.push(identifier.slice(start, position));\n\n        /*\n         * Advance `index` to the next non-punctuation character.\n         */\n        while (index < length && PUNCTUATION.test(value.charAt(index))) {\n            index += 1;\n        }\n    }\n\n    return result.join(EMPTY);\n}\n\n/**\n * Stringify a link reference.\n *\n * See `label()` on how reference labels are created.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.linkReference({\n *     type: 'linkReference',\n *     referenceType: 'collapsed',\n *     identifier: 'foo',\n *     children: [{\n *       type: 'text',\n *       value: 'Foo'\n *     }]\n *   });\n *   // '[Foo][]'\n *\n * @param {Object} node - `linkReference` node.\n * @return {string} - Markdown link reference.\n */\ncompilerPrototype.linkReference = function (node) {\n    var self = this;\n    var exitLinkReference = self.enterLinkReference(self, node);\n    var value = self.all(node).join(EMPTY);\n\n    exitLinkReference();\n\n    if (\n        node.referenceType === 'shortcut' ||\n        node.referenceType === 'collapsed'\n    ) {\n        value = copyIdentifierEncoding(value, node.identifier);\n    }\n\n    return SQUARE_BRACKET_OPEN + value + SQUARE_BRACKET_CLOSE + label(node);\n};\n\n/**\n * Stringify an image reference.\n *\n * See `label()` on how reference labels are created.\n *\n * Supports named entities in the `alt` when\n * in `settings.encode` mode.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.imageReference({\n *     type: 'imageReference',\n *     referenceType: 'full',\n *     identifier: 'foo',\n *     alt: 'Foo'\n *   });\n *   // '![Foo][foo]'\n *\n * @param {Object} node - `imageReference` node.\n * @return {string} - Markdown image reference.\n */\ncompilerPrototype.imageReference = function (node) {\n    var alt = this.encode(node.alt, node) || EMPTY;\n\n    return EXCLAMATION_MARK +\n        SQUARE_BRACKET_OPEN + alt + SQUARE_BRACKET_CLOSE +\n        label(node);\n};\n\n/**\n * Stringify a footnote reference.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.footnoteReference({\n *     type: 'footnoteReference',\n *     identifier: 'foo'\n *   });\n *   // '[^foo]'\n *\n * @param {Object} node - `footnoteReference` node.\n * @return {string} - Markdown footnote reference.\n */\ncompilerPrototype.footnoteReference = function (node) {\n    return SQUARE_BRACKET_OPEN + CARET + node.identifier +\n        SQUARE_BRACKET_CLOSE;\n};\n\n/**\n * Stringify an link- or image definition.\n *\n * Is smart about enclosing `href` (see `encloseURI()`) and\n * `title` (see `encloseTitle()`).\n *\n *    [foo]: <foo at bar dot com> 'An \"example\" e-mail'\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.definition({\n *     type: 'definition',\n *     link: 'http://example.com',\n *     title: 'Example Domain',\n *     identifier: 'foo'\n *   });\n *   // '[foo]: http://example.com \"Example Domain\"'\n *\n * @param {Object} node - `definition` node.\n * @return {string} - Markdown link- or image definition.\n */\ncompilerPrototype.definition = function (node) {\n    var value = SQUARE_BRACKET_OPEN + node.identifier + SQUARE_BRACKET_CLOSE;\n    var url = encloseURI(node.link);\n\n    if (node.title) {\n        url += SPACE + encloseTitle(node.title);\n    }\n\n    return value + COLON + SPACE + url;\n};\n\n/**\n * Stringify an image.\n *\n * Is smart about enclosing `href` (see `encloseURI()`) and\n * `title` (see `encloseTitle()`).\n *\n *    ![foo](</fav icon.png> 'My \"favourite\" icon')\n *\n * Supports named entities in `src`, `alt`, and `title`\n * when in `settings.encode` mode.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.image({\n *     type: 'image',\n *     href: 'http://example.png/favicon.png',\n *     title: 'Example Icon',\n *     alt: 'Foo'\n *   });\n *   // '![Foo](http://example.png/favicon.png \"Example Icon\")'\n *\n * @param {Object} node - `image` node.\n * @return {string} - Markdown image.\n */\ncompilerPrototype.image = function (node) {\n    var url = encloseURI(this.encode(node.src, node));\n    var value;\n\n    if (node.title) {\n        url += SPACE + encloseTitle(this.encode(node.title, node));\n    }\n\n    value = EXCLAMATION_MARK +\n        SQUARE_BRACKET_OPEN + this.encode(node.alt || EMPTY, node) +\n        SQUARE_BRACKET_CLOSE;\n\n    value += PARENTHESIS_OPEN + url + PARENTHESIS_CLOSE;\n\n    return value;\n};\n\n/**\n * Stringify a footnote.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.footnote({\n *     type: 'footnote',\n *     children: [{\n *       type: 'text',\n *       value: 'Foo'\n *     }]\n *   });\n *   // '[^Foo]'\n *\n * @param {Object} node - `footnote` node.\n * @return {string} - Markdown footnote.\n */\ncompilerPrototype.footnote = function (node) {\n    return SQUARE_BRACKET_OPEN + CARET + this.all(node).join(EMPTY) +\n        SQUARE_BRACKET_CLOSE;\n};\n\n/**\n * Stringify a footnote definition.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.footnoteDefinition({\n *     type: 'footnoteDefinition',\n *     identifier: 'foo',\n *     children: [{\n *       type: 'paragraph',\n *       children: [{\n *         type: 'text',\n *         value: 'bar'\n *       }]\n *     }]\n *   });\n *   // '[^foo]: bar'\n *\n * @param {Object} node - `footnoteDefinition` node.\n * @return {string} - Markdown footnote definition.\n */\ncompilerPrototype.footnoteDefinition = function (node) {\n    var id = node.identifier.toLowerCase();\n\n    return SQUARE_BRACKET_OPEN + CARET + id +\n        SQUARE_BRACKET_CLOSE + COLON + SPACE +\n        this.all(node).join(BREAK + repeat(SPACE, INDENT));\n};\n\n/**\n * Stringify table.\n *\n * Creates a fenced table by default, but not in\n * `looseTable: true` mode:\n *\n *     Foo | Bar\n *     :-: | ---\n *     Baz | Qux\n *\n * NOTE: Be careful with `looseTable: true` mode, as a\n * loose table inside an indented code block on GitHub\n * renders as an actual table!\n *\n * Creates a spaces table by default, but not in\n * `spacedTable: false`:\n *\n *     |Foo|Bar|\n *     |:-:|---|\n *     |Baz|Qux|\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.table({\n *     type: 'table',\n *     align: ['center', null],\n *     children: [\n *       {\n *         type: 'tableHeader',\n *         children: [\n *           {\n *             type: 'tableCell'\n *             children: [{\n *               type: 'text'\n *               value: 'Foo'\n *             }]\n *           },\n *           {\n *             type: 'tableCell'\n *             children: [{\n *               type: 'text'\n *               value: 'Bar'\n *             }]\n *           }\n *         ]\n *       },\n *       {\n *         type: 'tableRow',\n *         children: [\n *           {\n *             type: 'tableCell'\n *             children: [{\n *               type: 'text'\n *               value: 'Baz'\n *             }]\n *           },\n *           {\n *             type: 'tableCell'\n *             children: [{\n *               type: 'text'\n *               value: 'Qux'\n *             }]\n *           }\n *         ]\n *       }\n *     ]\n *   });\n *   // '| Foo | Bar |\\n| :-: | --- |\\n| Baz | Qux |'\n *\n * @param {Object} node - `table` node.\n * @return {string} - Markdown table.\n */\ncompilerPrototype.table = function (node) {\n    var self = this;\n    var loose = self.options.looseTable;\n    var spaced = self.options.spacedTable;\n    var rows = node.children;\n    var index = rows.length;\n    var exit = self.enterTable();\n    var result = [];\n    var start;\n\n    while (index--) {\n        result[index] = self.all(rows[index]);\n    }\n\n    exit();\n\n    start = loose ? EMPTY : spaced ? PIPE + SPACE : PIPE;\n\n    return table(result, {\n        'align': node.align,\n        'start': start,\n        'end': start.split(EMPTY).reverse().join(EMPTY),\n        'delimiter': spaced ? SPACE + PIPE + SPACE : PIPE\n    });\n};\n\n/**\n * Stringify a table cell.\n *\n * @example\n *   var compiler = new Compiler();\n *\n *   compiler.tableCell({\n *     type: 'tableCell',\n *     children: [{\n *       type: 'text'\n *       value: 'Qux'\n *     }]\n *   });\n *   // 'Qux'\n *\n * @param {Object} node - `tableCell` node.\n * @return {string} - Markdown table cell.\n */\ncompilerPrototype.tableCell = function (node) {\n    return this.all(node).join(EMPTY);\n};\n\n/**\n * Stringify the bound file.\n *\n * @example\n *   var file = new VFile('__Foo__');\n *\n *   file.namespace('mdast').tree = {\n *     type: 'strong',\n *     children: [{\n *       type: 'text',\n *       value: 'Foo'\n *     }]\n *   });\n *\n *   new Compiler(file).compile();\n *   // '**Foo**'\n *\n * @this {Compiler}\n * @return {string} - Markdown document.\n */\ncompilerPrototype.compile = function () {\n    return this.visit(this.file.namespace('mdast').tree);\n};\n\n/*\n * Expose `stringify` on `module.exports`.\n */\n\nmodule.exports = Compiler;\n","/**\n * @author Titus Wormer\n * @copyright 2015-2016 Titus Wormer\n * @license MIT\n * @module remark:utilities\n * @version 3.2.2\n * @fileoverview Collection of tiny helpers useful for\n *   both parsing and compiling markdown.\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\n/*\n * Dependencies.\n */\n\nvar collapseWhiteSpace = require('collapse-white-space');\n\n/*\n * Expressions.\n */\n\nvar EXPRESSION_LINE_BREAKS = /\\r\\n|\\r/g;\nvar EXPRESSION_SYMBOL_FOR_NEW_LINE = /\\u2424/g;\nvar EXPRESSION_BOM = /^\\ufeff/;\n\n/**\n * Throw an exception with in its `message` `value`\n * and `name`.\n *\n * @param {*} value - Invalid value.\n * @param {string} name - Setting name.\n */\nfunction raise(value, name) {\n    throw new Error(\n        'Invalid value `' + value + '` ' +\n        'for setting `' + name + '`'\n    );\n}\n\n/**\n * Validate a value to be boolean. Defaults to `def`.\n * Raises an exception with `context[name]` when not\n * a boolean.\n *\n * @example\n *   validateBoolean({foo: null}, 'foo', true) // true\n *   validateBoolean({foo: false}, 'foo', true) // false\n *   validateBoolean({foo: 'bar'}, 'foo', true) // Throws\n *\n * @throws {Error} - When a setting is neither omitted nor\n *   a boolean.\n * @param {Object} context - Settings.\n * @param {string} name - Setting name.\n * @param {boolean} def - Default value.\n */\nfunction validateBoolean(context, name, def) {\n    var value = context[name];\n\n    if (value === null || value === undefined) {\n        value = def;\n    }\n\n    if (typeof value !== 'boolean') {\n        raise(value, 'options.' + name);\n    }\n\n    context[name] = value;\n}\n\n/**\n * Validate a value to be boolean. Defaults to `def`.\n * Raises an exception with `context[name]` when not\n * a boolean.\n *\n * @example\n *   validateNumber({foo: null}, 'foo', 1) // 1\n *   validateNumber({foo: 2}, 'foo', 1) // 2\n *   validateNumber({foo: 'bar'}, 'foo', 1) // Throws\n *\n * @throws {Error} - When a setting is neither omitted nor\n *   a number.\n * @param {Object} context - Settings.\n * @param {string} name - Setting name.\n * @param {number} def - Default value.\n */\nfunction validateNumber(context, name, def) {\n    var value = context[name];\n\n    if (value === null || value === undefined) {\n        value = def;\n    }\n\n    if (typeof value !== 'number' || value !== value) {\n        raise(value, 'options.' + name);\n    }\n\n    context[name] = value;\n}\n\n/**\n * Validate a value to be in `map`. Defaults to `def`.\n * Raises an exception with `context[name]` when not\n * not in `map`.\n *\n * @example\n *   var map = {bar: true, baz: true};\n *   validateString({foo: null}, 'foo', 'bar', map) // 'bar'\n *   validateString({foo: 'baz'}, 'foo', 'bar', map) // 'baz'\n *   validateString({foo: true}, 'foo', 'bar', map) // Throws\n *\n * @throws {Error} - When a setting is neither omitted nor\n *   in `map`.\n * @param {Object} context - Settings.\n * @param {string} name - Setting name.\n * @param {string} def - Default value.\n * @param {Object} map - Enum.\n */\nfunction validateString(context, name, def, map) {\n    var value = context[name];\n\n    if (value === null || value === undefined) {\n        value = def;\n    }\n\n    if (!(value in map)) {\n        raise(value, 'options.' + name);\n    }\n\n    context[name] = value;\n}\n\n/**\n * Clean a string in preperation of parsing.\n *\n * @example\n *   clean('\\ufefffoo'); // 'foo'\n *   clean('foo\\r\\nbar'); // 'foo\\nbar'\n *   clean('foo\\u2424bar'); // 'foo\\nbar'\n *\n * @param {string} value - Content to clean.\n * @return {string} - Cleaned content.\n */\nfunction clean(value) {\n    return String(value)\n        .replace(EXPRESSION_BOM, '')\n        .replace(EXPRESSION_LINE_BREAKS, '\\n')\n        .replace(EXPRESSION_SYMBOL_FOR_NEW_LINE, '\\n');\n}\n\n/**\n * Normalize an identifier.  Collapses multiple white space\n * characters into a single space, and removes casing.\n *\n * @example\n *   normalizeIdentifier('FOO\\t bar'); // 'foo bar'\n *\n * @param {string} value - Content to normalize.\n * @return {string} - Normalized content.\n */\nfunction normalizeIdentifier(value) {\n    return collapseWhiteSpace(value).toLowerCase();\n}\n\n/**\n * Construct a state `toggler`: a function which inverses\n * `property` in context based on its current value.\n * The by `toggler` returned function restores that value.\n *\n * @example\n *   var context = {};\n *   var key = 'foo';\n *   var val = true;\n *   context[key] = val;\n *   context.enter = stateToggler(key, val);\n *   context[key]; // true\n *   var exit = context.enter();\n *   context[key]; // false\n *   var nested = context.enter();\n *   context[key]; // false\n *   nested();\n *   context[key]; // false\n *   exit();\n *   context[key]; // true\n *\n * @param {string} key - Property to toggle.\n * @param {boolean} state - It's default state.\n * @return {function(): function()} - Enter.\n */\nfunction stateToggler(key, state) {\n    /**\n     * Construct a toggler for the bound `key`.\n     *\n     * @return {Function} - Exit state.\n     */\n    function enter() {\n        var self = this;\n        var current = self[key];\n\n        self[key] = !state;\n\n        /**\n         * State canceler, cancels the state, if allowed.\n         */\n        function exit() {\n            self[key] = current;\n        }\n\n        return exit;\n    }\n\n    return enter;\n}\n\n/*\n * Define nodes of a type which can be merged.\n */\n\nvar MERGEABLE_NODES = {};\n\n/**\n * Check whether a node is mergeable with adjacent nodes.\n *\n * @param {Object} node - Node to check.\n * @return {boolean} - Whether `node` is mergable.\n */\nfunction mergeable(node) {\n    var start;\n    var end;\n\n    if (node.type !== 'text' || !node.position) {\n        return true;\n    }\n\n    start = node.position.start;\n    end = node.position.end;\n\n    /*\n     * Only merge nodes which occupy the same size as their\n     * `value`.\n     */\n\n    return start.line !== end.line ||\n        end.column - start.column === node.value.length;\n}\n\n/**\n * Merge two text nodes: `node` into `prev`.\n *\n * @param {Object} prev - Preceding sibling.\n * @param {Object} node - Following sibling.\n * @return {Object} - `prev`.\n */\nMERGEABLE_NODES.text = function (prev, node) {\n    prev.value += node.value;\n\n    return prev;\n};\n\n/**\n * Merge two blockquotes: `node` into `prev`, unless in\n * CommonMark mode.\n *\n * @param {Object} prev - Preceding sibling.\n * @param {Object} node - Following sibling.\n * @return {Object} - `prev`, or `node` in CommonMark mode.\n */\nMERGEABLE_NODES.blockquote = function (prev, node) {\n    if (this.options.commonmark) {\n        return node;\n    }\n\n    prev.children = prev.children.concat(node.children);\n\n    return prev;\n};\n\n/*\n * Expose `validate`.\n */\n\nexports.validate = {\n    'boolean': validateBoolean,\n    'string': validateString,\n    'number': validateNumber\n};\n\n/*\n * Expose.\n */\n\nexports.normalizeIdentifier = normalizeIdentifier;\nexports.clean = clean;\nexports.raise = raise;\nexports.stateToggler = stateToggler;\nexports.mergeable = mergeable;\nexports.MERGEABLE_NODES = MERGEABLE_NODES;\n","/*!\n * repeat-string <https://github.com/jonschlinkert/repeat-string>\n *\n * Copyright (c) 2014-2015, Jon Schlinkert.\n * Licensed under the MIT License.\n */\n\n'use strict';\n\n/**\n * Results cache\n */\n\nvar res = '';\nvar cache;\n\n/**\n * Expose `repeat`\n */\n\nmodule.exports = repeat;\n\n/**\n * Repeat the given `string` the specified `number`\n * of times.\n *\n * **Example:**\n *\n * ```js\n * var repeat = require('repeat-string');\n * repeat('A', 5);\n * //=> AAAAA\n * ```\n *\n * @param {String} `string` The string to repeat\n * @param {Number} `number` The number of times to repeat the string\n * @return {String} Repeated string\n * @api public\n */\n\nfunction repeat(str, num) {\n  if (typeof str !== 'string') {\n    throw new TypeError('repeat-string expects a string.');\n  }\n\n  // cover common, quick use cases\n  if (num === 1) return str;\n  if (num === 2) return str + str;\n\n  var max = str.length * num;\n  if (cache !== str || typeof cache === 'undefined') {\n    cache = str;\n    res = '';\n  }\n\n  while (max > res.length && num > 0) {\n    if (num & 1) {\n      res += str;\n    }\n\n    num >>= 1;\n    if (!num) break;\n    str += str;\n  }\n\n  return res.substr(0, max);\n}\n\n","module.exports = rimraf\nrimraf.sync = rimrafSync\n\nvar assert = require(\"assert\")\nvar path = require(\"path\")\nvar fs = require(\"fs\")\nvar glob = require(\"glob\")\n\nvar globOpts = {\n  nosort: true,\n  nocomment: true,\n  nonegate: true,\n  silent: true\n}\n\n// for EMFILE handling\nvar timeout = 0\n\nvar isWindows = (process.platform === \"win32\")\n\nfunction defaults (options) {\n  var methods = [\n    'unlink',\n    'chmod',\n    'stat',\n    'lstat',\n    'rmdir',\n    'readdir'\n  ]\n  methods.forEach(function(m) {\n    options[m] = options[m] || fs[m]\n    m = m + 'Sync'\n    options[m] = options[m] || fs[m]\n  })\n\n  options.maxBusyTries = options.maxBusyTries || 3\n  options.emfileWait = options.emfileWait || 1000\n  options.disableGlob = options.disableGlob || false\n}\n\nfunction rimraf (p, options, cb) {\n  if (typeof options === 'function') {\n    cb = options\n    options = {}\n  }\n\n  assert(p, 'rimraf: missing path')\n  assert.equal(typeof p, 'string', 'rimraf: path should be a string')\n  assert(options, 'rimraf: missing options')\n  assert.equal(typeof options, 'object', 'rimraf: options should be object')\n  assert.equal(typeof cb, 'function', 'rimraf: callback function required')\n\n  defaults(options)\n\n  var busyTries = 0\n  var errState = null\n  var n = 0\n\n  if (options.disableGlob || !glob.hasMagic(p))\n    return afterGlob(null, [p])\n\n  fs.lstat(p, function (er, stat) {\n    if (!er)\n      return afterGlob(null, [p])\n\n    glob(p, globOpts, afterGlob)\n  })\n\n  function next (er) {\n    errState = errState || er\n    if (--n === 0)\n      cb(errState)\n  }\n\n  function afterGlob (er, results) {\n    if (er)\n      return cb(er)\n\n    n = results.length\n    if (n === 0)\n      return cb()\n\n    results.forEach(function (p) {\n      rimraf_(p, options, function CB (er) {\n        if (er) {\n          if (isWindows && (er.code === \"EBUSY\" || er.code === \"ENOTEMPTY\" || er.code === \"EPERM\") &&\n              busyTries < options.maxBusyTries) {\n            busyTries ++\n            var time = busyTries * 100\n            // try again, with the same exact callback as this one.\n            return setTimeout(function () {\n              rimraf_(p, options, CB)\n            }, time)\n          }\n\n          // this one won't happen if graceful-fs is used.\n          if (er.code === \"EMFILE\" && timeout < options.emfileWait) {\n            return setTimeout(function () {\n              rimraf_(p, options, CB)\n            }, timeout ++)\n          }\n\n          // already gone\n          if (er.code === \"ENOENT\") er = null\n        }\n\n        timeout = 0\n        next(er)\n      })\n    })\n  }\n}\n\n// Two possible strategies.\n// 1. Assume it's a file.  unlink it, then do the dir stuff on EPERM or EISDIR\n// 2. Assume it's a directory.  readdir, then do the file stuff on ENOTDIR\n//\n// Both result in an extra syscall when you guess wrong.  However, there\n// are likely far more normal files in the world than directories.  This\n// is based on the assumption that a the average number of files per\n// directory is >= 1.\n//\n// If anyone ever complains about this, then I guess the strategy could\n// be made configurable somehow.  But until then, YAGNI.\nfunction rimraf_ (p, options, cb) {\n  assert(p)\n  assert(options)\n  assert(typeof cb === 'function')\n\n  // sunos lets the root user unlink directories, which is... weird.\n  // so we have to lstat here and make sure it's not a dir.\n  options.lstat(p, function (er, st) {\n    if (er && er.code === \"ENOENT\")\n      return cb(null)\n\n    if (st && st.isDirectory())\n      return rmdir(p, options, er, cb)\n\n    options.unlink(p, function (er) {\n      if (er) {\n        if (er.code === \"ENOENT\")\n          return cb(null)\n        if (er.code === \"EPERM\")\n          return (isWindows)\n            ? fixWinEPERM(p, options, er, cb)\n            : rmdir(p, options, er, cb)\n        if (er.code === \"EISDIR\")\n          return rmdir(p, options, er, cb)\n      }\n      return cb(er)\n    })\n  })\n}\n\nfunction fixWinEPERM (p, options, er, cb) {\n  assert(p)\n  assert(options)\n  assert(typeof cb === 'function')\n  if (er)\n    assert(er instanceof Error)\n\n  options.chmod(p, 666, function (er2) {\n    if (er2)\n      cb(er2.code === \"ENOENT\" ? null : er)\n    else\n      options.stat(p, function(er3, stats) {\n        if (er3)\n          cb(er3.code === \"ENOENT\" ? null : er)\n        else if (stats.isDirectory())\n          rmdir(p, options, er, cb)\n        else\n          options.unlink(p, cb)\n      })\n  })\n}\n\nfunction fixWinEPERMSync (p, options, er) {\n  assert(p)\n  assert(options)\n  if (er)\n    assert(er instanceof Error)\n\n  try {\n    options.chmodSync(p, 666)\n  } catch (er2) {\n    if (er2.code === \"ENOENT\")\n      return\n    else\n      throw er\n  }\n\n  try {\n    var stats = options.statSync(p)\n  } catch (er3) {\n    if (er3.code === \"ENOENT\")\n      return\n    else\n      throw er\n  }\n\n  if (stats.isDirectory())\n    rmdirSync(p, options, er)\n  else\n    options.unlinkSync(p)\n}\n\nfunction rmdir (p, options, originalEr, cb) {\n  assert(p)\n  assert(options)\n  if (originalEr)\n    assert(originalEr instanceof Error)\n  assert(typeof cb === 'function')\n\n  // try to rmdir first, and only readdir on ENOTEMPTY or EEXIST (SunOS)\n  // if we guessed wrong, and it's not a directory, then\n  // raise the original error.\n  options.rmdir(p, function (er) {\n    if (er && (er.code === \"ENOTEMPTY\" || er.code === \"EEXIST\" || er.code === \"EPERM\"))\n      rmkids(p, options, cb)\n    else if (er && er.code === \"ENOTDIR\")\n      cb(originalEr)\n    else\n      cb(er)\n  })\n}\n\nfunction rmkids(p, options, cb) {\n  assert(p)\n  assert(options)\n  assert(typeof cb === 'function')\n\n  options.readdir(p, function (er, files) {\n    if (er)\n      return cb(er)\n    var n = files.length\n    if (n === 0)\n      return options.rmdir(p, cb)\n    var errState\n    files.forEach(function (f) {\n      rimraf(path.join(p, f), options, function (er) {\n        if (errState)\n          return\n        if (er)\n          return cb(errState = er)\n        if (--n === 0)\n          options.rmdir(p, cb)\n      })\n    })\n  })\n}\n\n// this looks simpler, and is strictly *faster*, but will\n// tie up the JavaScript thread and fail on excessively\n// deep directory trees.\nfunction rimrafSync (p, options) {\n  options = options || {}\n  defaults(options)\n\n  assert(p, 'rimraf: missing path')\n  assert.equal(typeof p, 'string', 'rimraf: path should be a string')\n  assert(options, 'rimraf: missing options')\n  assert.equal(typeof options, 'object', 'rimraf: options should be object')\n\n  var results\n\n  if (options.disableGlob || !glob.hasMagic(p)) {\n    results = [p]\n  } else {\n    try {\n      fs.lstatSync(p)\n      results = [p]\n    } catch (er) {\n      results = glob.sync(p, globOpts)\n    }\n  }\n\n  if (!results.length)\n    return\n\n  for (var i = 0; i < results.length; i++) {\n    var p = results[i]\n\n    try {\n      var st = options.lstatSync(p)\n    } catch (er) {\n      if (er.code === \"ENOENT\")\n        return\n    }\n\n    try {\n      // sunos lets the root user unlink directories, which is... weird.\n      if (st && st.isDirectory())\n        rmdirSync(p, options, null)\n      else\n        options.unlinkSync(p)\n    } catch (er) {\n      if (er.code === \"ENOENT\")\n        return\n      if (er.code === \"EPERM\")\n        return isWindows ? fixWinEPERMSync(p, options, er) : rmdirSync(p, options, er)\n      if (er.code !== \"EISDIR\")\n        throw er\n      rmdirSync(p, options, er)\n    }\n  }\n}\n\nfunction rmdirSync (p, options, originalEr) {\n  assert(p)\n  assert(options)\n  if (originalEr)\n    assert(originalEr instanceof Error)\n\n  try {\n    options.rmdirSync(p)\n  } catch (er) {\n    if (er.code === \"ENOENT\")\n      return\n    if (er.code === \"ENOTDIR\")\n      throw originalEr\n    if (er.code === \"ENOTEMPTY\" || er.code === \"EEXIST\" || er.code === \"EPERM\")\n      rmkidsSync(p, options)\n  }\n}\n\nfunction rmkidsSync (p, options) {\n  assert(p)\n  assert(options)\n  options.readdirSync(p).forEach(function (f) {\n    rimrafSync(path.join(p, f), options)\n  })\n  options.rmdirSync(p, options)\n}\n","/*\nCryptoJS v3.1.2\ncode.google.com/p/crypto-js\n(c) 2009-2013 by Jeff Mott. All rights reserved.\ncode.google.com/p/crypto-js/wiki/License\n*/\n/** @preserve\n(c) 2012 by Cédric Mesnil. All rights reserved.\n\nRedistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:\n\n    - Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.\n    - Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n*/\n\n// constants table\nvar zl = [\n  0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,\n  7, 4, 13, 1, 10, 6, 15, 3, 12, 0, 9, 5, 2, 14, 11, 8,\n  3, 10, 14, 4, 9, 15, 8, 1, 2, 7, 0, 6, 13, 11, 5, 12,\n  1, 9, 11, 10, 0, 8, 12, 4, 13, 3, 7, 15, 14, 5, 6, 2,\n  4, 0, 5, 9, 7, 12, 2, 10, 14, 1, 3, 8, 11, 6, 15, 13\n]\n\nvar zr = [\n  5, 14, 7, 0, 9, 2, 11, 4, 13, 6, 15, 8, 1, 10, 3, 12,\n  6, 11, 3, 7, 0, 13, 5, 10, 14, 15, 8, 12, 4, 9, 1, 2,\n  15, 5, 1, 3, 7, 14, 6, 9, 11, 8, 12, 2, 10, 0, 4, 13,\n  8, 6, 4, 1, 3, 11, 15, 0, 5, 12, 2, 13, 9, 7, 10, 14,\n  12, 15, 10, 4, 1, 5, 8, 7, 6, 2, 13, 14, 0, 3, 9, 11\n]\n\nvar sl = [\n  11, 14, 15, 12, 5, 8, 7, 9, 11, 13, 14, 15, 6, 7, 9, 8,\n  7, 6, 8, 13, 11, 9, 7, 15, 7, 12, 15, 9, 11, 7, 13, 12,\n  11, 13, 6, 7, 14, 9, 13, 15, 14, 8, 13, 6, 5, 12, 7, 5,\n  11, 12, 14, 15, 14, 15, 9, 8, 9, 14, 5, 6, 8, 6, 5, 12,\n  9, 15, 5, 11, 6, 8, 13, 12, 5, 12, 13, 14, 11, 8, 5, 6\n]\n\nvar sr = [\n  8, 9, 9, 11, 13, 15, 15, 5, 7, 7, 8, 11, 14, 14, 12, 6,\n  9, 13, 15, 7, 12, 8, 9, 11, 7, 7, 12, 7, 6, 15, 13, 11,\n  9, 7, 15, 11, 8, 6, 6, 14, 12, 13, 5, 14, 13, 13, 7, 5,\n  15, 5, 8, 11, 14, 14, 6, 14, 6, 9, 12, 9, 12, 5, 15, 8,\n  8, 5, 12, 9, 12, 5, 14, 6, 8, 13, 6, 5, 15, 13, 11, 11\n]\n\nvar hl = [0x00000000, 0x5A827999, 0x6ED9EBA1, 0x8F1BBCDC, 0xA953FD4E]\nvar hr = [0x50A28BE6, 0x5C4DD124, 0x6D703EF3, 0x7A6D76E9, 0x00000000]\n\nfunction bytesToWords (bytes) {\n  var words = []\n  for (var i = 0, b = 0; i < bytes.length; i++, b += 8) {\n    words[b >>> 5] |= bytes[i] << (24 - b % 32)\n  }\n  return words\n}\n\nfunction wordsToBytes (words) {\n  var bytes = []\n  for (var b = 0; b < words.length * 32; b += 8) {\n    bytes.push((words[b >>> 5] >>> (24 - b % 32)) & 0xFF)\n  }\n  return bytes\n}\n\nfunction processBlock (H, M, offset) {\n  // swap endian\n  for (var i = 0; i < 16; i++) {\n    var offset_i = offset + i\n    var M_offset_i = M[offset_i]\n\n    // Swap\n    M[offset_i] = (\n      (((M_offset_i << 8) | (M_offset_i >>> 24)) & 0x00ff00ff) |\n      (((M_offset_i << 24) | (M_offset_i >>> 8)) & 0xff00ff00)\n    )\n  }\n\n  // Working variables\n  var al, bl, cl, dl, el\n  var ar, br, cr, dr, er\n\n  ar = al = H[0]\n  br = bl = H[1]\n  cr = cl = H[2]\n  dr = dl = H[3]\n  er = el = H[4]\n\n  // computation\n  var t\n  for (i = 0; i < 80; i += 1) {\n    t = (al + M[offset + zl[i]]) | 0\n    if (i < 16) {\n      t += f1(bl, cl, dl) + hl[0]\n    } else if (i < 32) {\n      t += f2(bl, cl, dl) + hl[1]\n    } else if (i < 48) {\n      t += f3(bl, cl, dl) + hl[2]\n    } else if (i < 64) {\n      t += f4(bl, cl, dl) + hl[3]\n    } else {// if (i<80) {\n      t += f5(bl, cl, dl) + hl[4]\n    }\n    t = t | 0\n    t = rotl(t, sl[i])\n    t = (t + el) | 0\n    al = el\n    el = dl\n    dl = rotl(cl, 10)\n    cl = bl\n    bl = t\n\n    t = (ar + M[offset + zr[i]]) | 0\n    if (i < 16) {\n      t += f5(br, cr, dr) + hr[0]\n    } else if (i < 32) {\n      t += f4(br, cr, dr) + hr[1]\n    } else if (i < 48) {\n      t += f3(br, cr, dr) + hr[2]\n    } else if (i < 64) {\n      t += f2(br, cr, dr) + hr[3]\n    } else {// if (i<80) {\n      t += f1(br, cr, dr) + hr[4]\n    }\n\n    t = t | 0\n    t = rotl(t, sr[i])\n    t = (t + er) | 0\n    ar = er\n    er = dr\n    dr = rotl(cr, 10)\n    cr = br\n    br = t\n  }\n\n  // intermediate hash value\n  t = (H[1] + cl + dr) | 0\n  H[1] = (H[2] + dl + er) | 0\n  H[2] = (H[3] + el + ar) | 0\n  H[3] = (H[4] + al + br) | 0\n  H[4] = (H[0] + bl + cr) | 0\n  H[0] = t\n}\n\nfunction f1 (x, y, z) {\n  return ((x) ^ (y) ^ (z))\n}\n\nfunction f2 (x, y, z) {\n  return (((x) & (y)) | ((~x) & (z)))\n}\n\nfunction f3 (x, y, z) {\n  return (((x) | (~(y))) ^ (z))\n}\n\nfunction f4 (x, y, z) {\n  return (((x) & (z)) | ((y) & (~(z))))\n}\n\nfunction f5 (x, y, z) {\n  return ((x) ^ ((y) | (~(z))))\n}\n\nfunction rotl (x, n) {\n  return (x << n) | (x >>> (32 - n))\n}\n\nfunction ripemd160 (message) {\n  var H = [0x67452301, 0xEFCDAB89, 0x98BADCFE, 0x10325476, 0xC3D2E1F0]\n\n  if (typeof message === 'string') {\n    message = new Buffer(message, 'utf8')\n  }\n\n  var m = bytesToWords(message)\n\n  var nBitsLeft = message.length * 8\n  var nBitsTotal = message.length * 8\n\n  // Add padding\n  m[nBitsLeft >>> 5] |= 0x80 << (24 - nBitsLeft % 32)\n  m[(((nBitsLeft + 64) >>> 9) << 4) + 14] = (\n    (((nBitsTotal << 8) | (nBitsTotal >>> 24)) & 0x00ff00ff) |\n    (((nBitsTotal << 24) | (nBitsTotal >>> 8)) & 0xff00ff00)\n  )\n\n  for (var i = 0; i < m.length; i += 16) {\n    processBlock(H, m, i)\n  }\n\n  // swap endian\n  for (i = 0; i < 5; i++) {\n    // shortcut\n    var H_i = H[i]\n\n    // Swap\n    H[i] = (((H_i << 8) | (H_i >>> 24)) & 0x00ff00ff) |\n      (((H_i << 24) | (H_i >>> 8)) & 0xff00ff00)\n  }\n\n  var digestbytes = wordsToBytes(H)\n  return new Buffer(digestbytes)\n}\n\nmodule.exports = ripemd160\n","var SecretStack = require('secret-stack')\nvar create     = require('secure-scuttlebutt/create')\nvar ssbKeys    = require('ssb-keys')\nvar path       = require('path')\nvar osenv      = require('osenv')\nvar mkdirp     = require('mkdirp')\nvar rimraf     = require('rimraf')\nvar mdm        = require('mdmanifest')\nvar cmdAliases = require('./lib/cli-cmd-aliases')\nvar valid      = require('./lib/validators')\nvar apidocs    = require('./lib/apidocs.js')\n\nfunction isString(s) { return 'string' === typeof s }\n\n// create SecretStack definition\nvar manifest = mdm.manifest(apidocs._)\nmanifest.usage = 'sync'\nvar SSB = {\n  manifest: manifest,\n  permissions: {\n    master: {allow: null, deny: null},\n    anonymous: {allow: ['createHistoryStream'], deny: null}\n  },\n  init: function (api, opts) {\n\n    // .temp: use a /tmp data directory\n    // (useful for testing)\n    if(opts.temp) {\n      var name = isString(opts.temp) ? opts.temp : ''+Date.now()\n      opts.path = path.join(osenv.tmpdir(), name)\n      rimraf.sync(opts.path)\n    }\n\n    // load/create secure scuttlebutt data directory\n    var dbPath = path.join(opts.path, 'db')\n    mkdirp.sync(dbPath)\n\n    if(!opts.keys)\n      opts.keys = ssbKeys.generate('ed25519', opts.seed && new Buffer(opts.seed, 'base64'))\n\n    if(!opts.path)\n      throw new Error('opts.path *must* be provided, or use opts.temp=name to create a test instance')\n\n    // main interface\n    var ssb = create(path.join(opts.path, 'db'), null, opts.keys)\n    var feed = ssb.createFeed(opts.keys)\n    var _close = api.close\n    var close = function (cb) {\n      // override to close the SSB database\n      ssb.close(function (err) {\n        if (err) throw err\n        _close(cb)\n      })\n    }\n    return {\n      id                       : feed.id,\n      keys                     : opts.keys,\n\n      usage                    : valid.sync(usage, 'string?|boolean?'),\n      close                    : valid.async(close),\n\n      publish                  : valid.async(feed.add, 'string|msgContent'),\n      add                      : valid.async(ssb.add, 'msg'),\n      get                      : valid.async(ssb.get, 'msgId'),\n\n      pre                      : ssb.pre,\n      post                     : ssb.post,\n\n      getPublicKey             : ssb.getPublicKey,\n      latest                   : ssb.latest,\n      getLatest                : valid.async(ssb.getLatest, 'feedId'),\n      latestSequence           : valid.async(ssb.latestSequence, 'feedId'),\n      createFeed               : ssb.createFeed,\n      whoami                   : function () { return { id: feed.id } },\n      relatedMessages          : valid.async(ssb.relatedMessages, 'relatedMessagesOpts'),\n      query                    : ssb.query,\n      createFeedStream         : valid.source(ssb.createFeedStream, 'readStreamOpts?'),\n      createHistoryStream      : valid.source(ssb.createHistoryStream, ['createHistoryStreamOpts'], ['feedId', 'number?', 'boolean?']),\n      createLogStream          : valid.source(ssb.createLogStream, 'readStreamOpts?'),\n      createUserStream         : valid.source(ssb.createUserStream, 'createUserStreamOpts'),\n      links                    : valid.source(ssb.links, 'linksOpts'),\n      sublevel                 : ssb.sublevel,\n      messagesByType           : valid.source(ssb.messagesByType, 'string|messagesByTypeOpts'),\n      createWriteStream        : ssb.createWriteStream,\n//      createLatestLookupStream : ssb.createLatestLookupStream,\n    }\n  }\n}\n\n// live help RPC method\nfunction usage (cmd) {\n  var path = (cmd||'').split('.')\n  if ((path[0] && apidocs[path[0]]) || (cmd && apidocs[cmd])) {\n    // return usage for the plugin\n    cmd = path.slice(1).join('.')\n    return mdm.usage(apidocs[path[0]], cmd, { prefix: path[0] })\n  }\n  if (!cmd) {\n    // return usage for all docs\n    return Object.keys(apidocs).map(function (name) {\n      if (name == '_')\n        return mdm.usage(apidocs[name], null, { nameWidth: 20 })\n\n      var text = mdm.usage(apidocs[name], null, { prefix: name, nameWidth: 20 })\n      return text.slice(text.indexOf('Commands:') + 10) // skip past the toplevel summary, straight to the cmd list\n    }).join('\\n\\n')\n  }\n  // toplevel cmd usage\n  cmd = cmdAliases[cmd] || cmd\n  return mdm.usage(apidocs._, cmd)\n}\n\nmodule.exports = SecretStack({\n  appKey: require('./lib/ssb-cap')\n})\n.use(SSB)\n\n","var fs = require('fs')\nvar path = require('path')\nmodule.exports = {\n  _: fs.readFileSync(path.join(__dirname, '../api.md'), 'utf-8'),\n  blobs: fs.readFileSync(path.join(__dirname, '../plugins/blobs.md'), 'utf-8'),\n  block: fs.readFileSync(path.join(__dirname, '../plugins/block.md'), 'utf-8'),\n  friends: fs.readFileSync(path.join(__dirname, '../plugins/friends.md'), 'utf-8'),\n  gossip: fs.readFileSync(path.join(__dirname, '../plugins/gossip.md'), 'utf-8'),\n  invite: fs.readFileSync(path.join(__dirname, '../plugins/invite.md'), 'utf-8'),\n  plugins: fs.readFileSync(path.join(__dirname, '../plugins/plugins.md'), 'utf-8'),\n  'private': fs.readFileSync(path.join(__dirname, '../plugins/private.md'), 'utf-8'),\n  replicate: fs.readFileSync(path.join(__dirname, '../plugins/replicate.md'), 'utf-8')\n}","module.exports = {\n  feed: 'createFeedStream',\n  history: 'createHistoryStream',\n  hist: 'createHistoryStream',\n  public: 'getPublicKey',\n  pub: 'getPublicKey',\n  log: 'createLogStream',\n  logt: 'messagesByType',\n  conf: 'config'\n}","//this is the key for accessing the ssb protocol.\n//this will be updated whenever breaking changes are made.\n//(see secret-handshake paper for a full explaination)\nmodule.exports =\n  new Buffer('1KHLiKZvAvjbY1ziZEHMXawbCEIM6qwjCDm3VYRan/s=', 'base64')\n\n//there is nothing special about this value.\n//I generated it in the node repl with:\n//\n// > crypto.randomBytes(32).toString('base64')\n//\n//and copied it here.\n\n","var ref = require('ssb-ref')\n\nfunction isObject(o) {\n  return o && 'object' === typeof o\n}\nvar DEFAULT_PORT = 8008\n\nvar isArray = Array.isArray\n\nvar isInteger = Number.isInteger\n\nfunction isString (s) {\n  return 'string' === typeof s\n}\n\nvar find = exports.find = function find(ary, test) {\n  for(var i in ary)\n    if(test(ary[i], i, ary)) return ary[i]\n}\n\nvar clone = exports.clone = function clone (obj, mapper) {\n  function map(v, k) {\n    return isObject(v) ? clone(v, mapper) : mapper(v, k)\n  }\n  if(isArray(obj))\n    return obj.map(map)\n  else if(isObject(obj)) {\n    var o = {}\n    for(var k in obj)\n      o[k] = map(obj[k], k)\n    return o\n  }\n  else\n    return map(obj)\n}\n\nvar mergeKeys = exports.mergeKeys = function (a, b, iter) {\n  var o = {}\n  for(var k in a) {\n    if(!isUndefined(a[k]))\n      o[k] = iter(v[k], b[k], k)\n  }\n  for(var k in b) {\n    if(isUndefined(a[a]))\n      o[k] = iter(undefined, b[k], k)\n  }\n  return o\n}\n\nexports.merge = function (a, b) {\n\n  //merge a and b objects\n\n  if(isArray(a) != isArray(b))\n    throw new Error('cannot merge array with non-array')\n  if(isObject(a) != isObject(b))\n    throw new Error('cannot merge object with non-object')\n\n  a = clone(a)\n\n  var keys\n\n  if(isObject(b)) {\n    for(var k in b)\n      a[k] = b\n  }\n}\n\nexports.stringifyAddress = function (e) {\n  if(isString(e)) return e\n  return [e.host, e.port || DEFAULT_PORT, e.key].join(':')\n}\n\nexports.parseAddress = function (e) {\n  if(isString(e)) {\n    var parts = e.split(':')\n    var id = parts.pop(), port = parts.pop(), host = parts.join(':')\n    var e = {\n      host: host,\n      port: +(port || DEFAULT_PORT),\n      key: id\n    }\n    return e\n  }\n  return e\n}\n\nexports.isAddress = function (addr) {\n  return (\n    ref.isFeedId(addr.key || addr.link)\n    && isInteger(addr.port)\n    && typeof addr.host === 'string' && !!addr.host\n  )\n}\n\nexports.toAddress = function (e) {\n  e = exports.parseAddress(e)\n  e.port = e.port || DEFAULT_PORT\n  e.host = e.host || 'localhost'\n  return e\n}\n","var valid = require('muxrpc-validation')\nvar zerr  = require('zerr')\nvar ref   = require('ssb-ref')\n\n// errors\nvar MissingAttr = zerr('Usage', 'Param % must have a .% of type \"%\"')\nvar AttrType = zerr('Usage', '.% of param % must be of type \"%\"')\n\nfunction isFilter (v) {\n  return (v == '@' || v == '%' || v == '&')\n}\n\nmodule.exports = valid({\n  msgId: function (v) {\n    if (!ref.isMsg(v))\n      return 'type'\n  },\n  feedId: function (v) {\n    if (!ref.isFeed(v))\n      return 'type'\n  },\n  blobId: function (v) {\n    if (!ref.isBlob(v))\n      return 'type'\n  },\n\n  msgContent: function (v, n) {\n    var err = this.get('object')(v, n)\n    if (err) return err\n    if (!v.type || typeof v.type != 'string')\n      return MissingAttr(n, 'type', 'string')\n  },\n\n  msg: function (v, n) {\n    var err = this.get('object')(v, n)\n    if (err)\n      return err\n    \n    // .content\n    var err = this.get('object')(v.content, n)\n    if (err) \n      return MissingAttr(n, 'content', 'object')\n\n    // .content.type\n    if (!v.content.type || typeof v.content.type != 'string')\n      return MissingAttr(n, 'content.type', 'string')\n\n    // .author\n    if (!ref.isFeed(v.author))\n      return MissingAttr(n, 'author', 'feedId')\n\n    // .sequence\n    if (typeof v.sequence != 'number')\n      return MissingAttr(n, 'sequence', 'number')\n\n    // .previous\n    if (v.sequence > 1 && !ref.isMsg(v.previous))\n      return MissingAttr(n, 'previous', 'msgId')\n    else if(v.sequence == 1 && v.previous != null)\n      return MissingAttr(n, 'previous', 'null')\n\n    // .timestamp\n    if (typeof v.timestamp != 'number')\n      return MissingAttr(n, 'timestamp', 'number')\n\n    // .hash\n    if (v.hash != 'sha256')\n      return zerr('Usage', 'Param % must have .hash set to \"sha256\"')(n)\n\n    // .signature\n    if (typeof v.signature != 'string')\n      return MissingAttr(n, 'signature', 'string')\n  },\n\n  readStreamOpts: function (v, n) {\n    var err = this.get('object')(v, n)\n    if (err)\n      return err\n\n    // .live\n    if (v.live && typeof v.live != 'boolean' && typeof v.live != 'number')\n      return AttrType(n, 'live', 'boolean')\n\n    // .reverse\n    if (v.reverse && typeof v.reverse != 'boolean' && typeof v.reverse != 'number')\n      return AttrType(n, 'reverse', 'boolean')\n\n    // .keys\n    if (v.keys && typeof v.keys != 'boolean' && typeof v.keys != 'number')\n      return AttrType(n, 'keys', 'boolean')\n\n    // .values\n    if (v.values && typeof v.values != 'boolean' && typeof v.values != 'number')\n      return AttrType(n, 'values', 'boolean')\n\n    // .limit\n    if (v.limit && typeof v.limit != 'number')\n      return AttrType(n, 'limit', 'number')\n\n    // .fillCache\n    if (v.fillCache && typeof v.fillCache != 'boolean' && typeof v.fillCache != 'number')\n      return AttrType(n, 'fillCache', 'boolean')\n  },\n\n  createHistoryStreamOpts: function (v, n) {\n    // .id\n    if (!ref.isFeed(v.id))\n      return MissingAttr(n, 'id', 'feedId')\n\n    // .seq\n    if (v.seq && typeof v.seq != 'number')\n      return AttrType(n, 'seq', 'number')\n\n    // .live\n    if (v.live && typeof v.live != 'boolean' && typeof v.live != 'number')\n      return AttrType(n, 'live', 'boolean')\n  },\n\n  createUserStreamOpts: function (v, n) {\n    var err = this.get('readStreamOpts')(v, n)\n    if (err)\n      return err\n\n    // .id\n    if (!ref.isFeed(v.id))\n      return MissingAttr(n, 'id', 'feedId')\n  },\n\n  messagesByTypeOpts: function (v, n) {\n    var err = this.get('readStreamOpts')(v, n)\n    if (err)\n      return err\n\n    // .type\n    if (typeof v.type != 'string')\n      return MissingAttr(n, 'type', 'string')\n  },\n\n  linksOpts: function (v, n) {\n    var err = this.get('object')(v, n)\n    if (err)\n      return err\n\n    // .source\n    if (v.source && !ref.isLink(v.source) && !isFilter(v.source))\n      return AttrType(n, 'source', 'id|filter')\n\n    // .dest\n    if (v.dest && !ref.isLink(v.dest) && !isFilter(v.dest))\n      return AttrType(n, 'dest', 'id|filter')\n\n    // .rel\n    if (v.rel && typeof v.rel != 'string')\n      return AttrType(n, 'rel', 'string')\n\n    // .live\n    if (v.live && typeof v.live != 'boolean' && typeof v.live != 'number')\n      return AttrType(n, 'live', 'boolean')\n\n    // .reverse\n    if (v.reverse && typeof v.reverse != 'boolean' && typeof v.reverse != 'number')\n      return AttrType(n, 'reverse', 'boolean')\n\n    // .keys\n    if (v.keys && typeof v.keys != 'boolean' && typeof v.keys != 'number')\n      return AttrType(n, 'keys', 'boolean')\n\n    // .values\n    if (v.values && typeof v.values != 'boolean' && typeof v.values != 'number')\n      return AttrType(n, 'values', 'boolean')\n  },\n\n  relatedMessagesOpts: function (v, n) {\n    var err = this.get('object')(v, n)\n    if (err)\n      return err\n\n    // .id\n    if (!ref.isMsg(v.id))\n      return MissingAttr(n, 'id', 'msgId')\n\n    // .rel\n    if (v.rel && typeof v.rel != 'string')\n      return AttrType(n, 'rel', 'string')\n\n    // .count\n    if (v.count && typeof v.count != 'boolean' && typeof v.count != 'number')\n      return AttrType(n, 'count', 'boolean')\n\n    // .parent\n    if (v.parent && typeof v.parent != 'boolean' && typeof v.parent != 'number')\n      return AttrType(n, 'parent', 'boolean')\n  },\n\n  isBlockedOpts: function (v, n) {\n    var err = this.get('object')(v, n)\n    if (err)\n      return err\n\n    // .source\n    if (v.source && !ref.isFeed(v.source))\n      return AttrType(n, 'source', 'feedId')\n\n    // .dest\n    if (v.dest && !ref.isFeed(v.dest))\n      return AttrType(n, 'dest', 'feedId')\n  },\n\n  createFriendStreamOpts: function (v, n) {\n    var err = this.get('object')(v, n)\n    if (err)\n      return err\n\n    // .start\n    if (v.start && !ref.isFeed(v.start))\n      return AttrType(n, 'start', 'feedId')\n\n    // .graph\n    if (v.graph && typeof v.graph != 'string')\n      return AttrType(n, 'graph', 'string')\n\n    // .dunbar\n    if (v.dunbar && typeof v.dunbar != 'number')\n      return AttrType(n, 'dunbar', 'number')\n\n    // .hops\n    if (v.hops && typeof v.hops != 'number')\n      return AttrType(n, 'hops', 'number')\n  }\n})\n","var ref = require('ssb-ref')\n\nfunction isObject (o) { return o && 'object' === typeof o }\nfunction isBool (o) { return 'boolean' === typeof o }\nfunction isString (s) { return 'string' === typeof s }\n\nfunction traverse (obj, each) {\n  for (var k in obj) {\n    if (!obj[k])\n      continue\n    if (Array.isArray(obj[k])) {\n      obj[k].forEach(function (v) {\n        each(v, k)\n      })\n    } else\n      each(obj[k], k)\n  }\n}\n\nexports.indexLinks = function (message, opts, each) {\n  if (typeof opts == 'function') {\n    each = opts\n    opts = null\n  }\n  if (typeof opts == 'string')\n    opts = { rel: opts }\n  if (!opts)\n    opts = {}\n  var msg  = opts.msg\n  var feed = opts.feed\n  var blob = opts.blob\n  var any  = !(msg || feed || blob)\n\n  traverse(message, function (obj, rel) {\n    if (opts.rel && rel !== opts.rel) return\n\n    var r = (typeof obj == 'string') ? obj : obj.link\n    if (any) {\n      if (!ref.isLink(r)) return\n    } else {\n      if (msg) {\n        if (isBool(msg) && ref.type(r) != 'msg') return \n        if (!isBool(msg) && r != msg) return\n      }\n\n      if (feed) {\n        if (isBool(feed) && ref.type(r) != 'feed') return \n        if (!isBool(feed) && r != feed) return\n      }\n\n      if (blob) {\n        if (isBool(blob) && ref.type(r) != 'blob') return \n        if (!isBool(blob) && r != blob) return\n      }\n    }\n\n    each((typeof obj == 'string') ? { link: obj } : obj, rel)\n  })\n}\n\nexports.link =\nexports.asLink = function (obj, type) {\n  if (!obj)\n    return null\n  if (isString(obj))\n    obj = { link: obj }\n  return isLink(obj, type) ? obj : null\n}\n\nexports.links =\nexports.asLinks = function (obj, type) {\n  if (!obj)\n    return []\n  var arr = Array.isArray(obj) ? obj : [obj]\n  return arr\n    .filter(function (l) { return isLink(l, type) })\n    .map(function (o) { return (typeof o == 'string') ? { link: o } : o })\n}\n\nvar isLink =\nexports.isLink = function (obj, type) {\n  if (!obj)\n    return false\n  var r = (isString(obj)) ? obj : obj.link\n  return (type) ? (ref.type(r) == type) : ref.isLink(r)\n}\n","'use strict'\n\nvar Blobs  = require('multiblob')\nvar path   = require('path')\nvar pull   = require('pull-stream')\nvar isBlob = require('ssb-ref').isBlobId\nvar Quota  = require('./quota')\nvar Notify = require('pull-notify')\nvar mdm    = require('mdmanifest')\nvar valid  = require('../../lib/validators')\nvar apidoc = require('../../lib/apidocs').blobs\nvar Replicate = require('./replication')\n\n// blobs plugin\n// methods to read/write the blobstore\n// and automated blob-fetching from the network\n\nfunction isFunction (f) {\n  return 'function' === typeof f\n}\n\nfunction desigil (hash) {\n  return isBlob(hash) ? hash.substring(1) : hash\n}\n\nfunction resigil (hash) {\n  return isBlob(hash) ? hash : '&'+hash\n}\n\nfunction isString (s) {\n  return 'string' === typeof s\n}\n\nmodule.exports = {\n  name: 'blobs',\n  version: '0.0.0',\n  manifest: mdm.manifest(apidoc),\n  permissions: {\n    anonymous: {allow: ['has', 'get', 'changes']},\n  },\n  init: function (sbot, opts) {\n\n    var notify = Notify()\n    var config = opts\n\n    var blobs = sbot._blobs = Blobs({\n      dir: path.join(config.path, 'blobs'),\n      hash: 'sha256'\n    })\n\n    var userQuotas = {} // map of { feedId => quotaUsage }, for rate-limiting\n    var drain = Quota(sbot, blobs, userQuotas)\n    var wantList = Replicate(sbot, config, notify, userQuotas)\n\n    return {\n      get: valid.source(function (hash) {\n        return blobs.get(desigil(hash))\n      }, 'blobId'),\n\n      has: valid.async(function (hash, cb) {\n        //emit blobs:has event when this api is called remotely.\n        //needed to make tests pass. should probably remove this.\n        if(this.id) sbot.emit('blobs:has', hash)\n        blobs.has(desigil(hash), cb)\n      }, 'blobId|array'),\n\n      size: valid.async(function (hash, cb) {\n        //sbot.emit('blobs:size', hash)\n        blobs.size(desigil(hash), cb)\n      }, 'blobId|array'),\n\n      add: valid.sink(function (hash, cb) {\n        // cb once blob is successfully added.\n        // sink cbs are not exposed over rpc\n        // so this is only available when using this api \n        if(isFunction(hash)) cb = hash, hash = null\n\n        return blobs.add(desigil(hash), function (err, hash) {\n          if(!err) {\n            hash = resigil(hash)\n            sbot.emit('blobs:got', hash)\n            notify(hash)\n            //wait until quotas have been calculated\n            //befor returning (tests will fail without this)\n            if(cb) drain(function () {\n              cb(null, hash)\n            })\n          }\n          else {\n            if(cb) cb(err, hash)\n            else   console.error(err.stack)\n          }\n        })\n      }, 'string?'),\n\n      rm: valid.async(function (hash, cb) {\n        return blobs.rm(desigil(hash), cb)\n      }, 'string'),\n\n      ls: function (opts) {\n        return pull(blobs.ls(opts), pull.map(function (e) {\n          if(e.sync) return e\n          if(isString(e)) return resigil(e)\n          e.id = resigil(e.id)\n          return e\n        }))\n      },\n      // request to retrieve a blob,\n      // calls back when that file is available.\n      // - `opts.nowait`: call cb immediately if not found (dont register for callback)\n      want: valid.async(function (hash, opts, cb) {\n        if (isFunction(opts)) {\n          cb = opts\n          opts = null\n        }\n        var id = this.id\n        if(!isBlob(hash)) return cb(new Error('not a hash:' + hash))\n\n        sbot.emit('blobs:wants', hash)\n        blobs.has(desigil(hash), function (_, has) {\n          if (has) return cb(null, true)\n          // update queue\n          wantList.want(hash, id, cb)\n        })\n      }, 'blobId', 'object?'),\n\n      changes: function () {\n        return notify.listen()\n      },\n\n      quota: valid.sync(function (id) {\n        return wantList.quota(id)\n      }, 'feedId'),\n\n      // get current want list\n      wants: function () {\n        return wantList.jobs\n      }\n    }\n  }\n}\n","// Queue\n// returns a function which...\n// - only acts if not already acting\n// - automatically requeues if the task is not yet done\n// - `delay`: ms, amount of time to wait before calling again\n// - `n`: number, amount of simultaneous calls allowed\n// - `label`: string, name of the task (for logging)\n// - `fun`: function(cb(done?)), calls cb(true) when done, cb(false) when needs to requeue\n\nfunction isFunction (f) {\n  return 'function' === typeof f\n}\n\nfunction Work(avgWait, n, label, fun) {\n  n  = 1\n  var doing = 0, timeout\n\n  var timers = []\n\n  function clear (timer) {\n    var i = timers.indexOf(timer)\n    clearTimeout(timer[i])\n    times.splice(i, 1)\n  }\n\n  function delay (job, d) {\n    var i\n    var timer = setTimeout(function () {\n      timers.splice(timers.indexOf(timer), 1); job()\n    }, d)\n    timer.unref()\n    timers.push(timer)\n\n    return timer\n  }\n\n  function job () {\n    // abort if already doing too many\n\n    if(doing >= n) return\n    doing++\n\n    // run the behavior\n    fun(function (done) {\n      doing--\n      if(done) {\n        // we're done, dont requeue\n        return\n      }\n\n      // requeue after a delay\n      var wait = ~~(avgWait/2 + avgWait*Math.random())\n      delay(job, wait)\n    })\n  }\n\n  job.abort = function () {\n    timers.forEach(clear)\n  }\n\n  return job\n}\n\nfunction find (jobs, test) {\n  for(var k in jobs)\n    if(test(jobs[k])) return k\n  return -1\n}\n\nfunction max (jobs, test) {\n  var M = -Infinity, i = -1\n  for(var k in jobs) {\n    var m = test(jobs[k], k, jobs)\n    if(m > M) {\n      M = m\n      i = k\n    }\n  }\n  return k\n}\n\nmodule.exports = function (work) {\n\n  var jobs = []\n\n  var queue = {\n    push: function (job) {\n      jobs.push(job)\n    },\n\n    pull: function (id) {\n      var test = isFunction(id) ? id : function (e) { return e.id === id }\n      if(!this.length()) return\n      if(!id)\n        return jobs.shift()\n      else {\n        var index = find(jobs, test)\n        if(~index) return jobs.splice(index, 1)[0]\n      }\n    },\n\n    each: function (iter) {\n      jobs.forEach(iter)\n    },\n\n    length: function () {\n      return jobs.length\n    },\n\n    toJSON: function () {\n      return jobs.slice()\n    }\n  }\n\n  Work(100, 2, null, function (done) {\n    if(!queue.length()) return done()\n    work(queue, done)\n  }) ()\n\n  return queue\n}\n\n\n\n\n\n\n\n","var pull = require('pull-stream')\nvar paramap = require('pull-paramap')\n\nmodule.exports = function (sbot, blobs, userQuotas, cb) {\n  var listeners = []\n\n  //recalculate the quota, with live updates.\n\n  // share a file size between the feeds that link to it.\n  // At the time we download it.\n\n  // More feeds might link to it later, and these\n  // won't be included in the calculation.\n  // but it's simplest to do it this way.\n\n  // this is only in memory, so it will be recalculated\n  // when sbot is restarted.\n\n  var total = 0\n  var start = Date.now()\n  var inflight = 0\n\n  pull(\n    blobs.ls({long: true, live: true}),\n    paramap(function (data, cb) {\n      if(data.sync) return cb(null, data)\n\n      var acc = {}, count = 0\n      total += data.size\n\n      inflight ++\n      pull(\n        sbot.links({dest: '&'+data.id}),\n        pull.drain(function (link) {\n          if(!acc[link.source]) {\n            acc[link.source] = true\n            count ++\n          }\n          return acc\n        }, function (err) {\n          inflight --\n          if(err) return cb(err)\n          var size = data.size\n          for(var k in acc)\n            userQuotas[k] = (userQuotas[k] || 0) + size/count\n\n          if(inflight === 0)\n            while (listeners.length) listeners.shift()()\n\n         cb(null, data)\n        })\n      )\n    }),\n    pull.drain()\n  )\n\n  return function (listener) {\n    if(!inflight) listener()\n    else          listeners.push(listener)\n  }\n}\n","var pull = require('pull-stream')\nvar Queue = require('./queue')\n\nfunction each (obj, iter) {\n  for(var k in obj)\n    iter(obj[k], k, obj)\n}\n\nfunction first (obj, test) {\n  var v\n  for (var k in obj)\n    if(v = test(obj[k], k, obj))\n      return v\n}\n\nfunction union (a, b) {\n  b = toArray(b)\n  a = toArray(a)\n  if(!a.length) return b\n  if(a.length < b.length) {\n    var t = b; b = a; a = t\n  }\n  b.forEach(function (e) {\n    if(!~a.indexOf(e)) a.push(e)\n  })\n  return a\n}\n\nfunction toArray (s) {\n  return s != null ? (Array.isArray(s) ? s : [s]) : []\n}\n\nfunction isFunction (f) {\n  return 'function' === typeof f\n}\n\nvar MB = 1024*1024\n//default replication limits.\nvar defaults = {limit: [-1, 100*MB, 20*MB], minLimit: 5*MB}\nmodule.exports = function (sbot, opts, notify, userQuotas) {\n  var jobs = {}, hasQueue, getQueue\n  var conf = opts.blobs || defaults, wl\n\n  //keep track of who is over quota so that it doesn't get logged again and again.\n  var over = {}\n\n  // calculate quotas for each feed.\n  // start with size of each blob\n  // divided between the feeds that mention it.\n  // getting a use for each feed.\n\n  function createJob(id, owner, cb) {\n    toArray(owner).forEach(function (e) {\n      if(e[0] !== '@') throw new Error('not a owner:'+e)\n    })\n    if(jobs[id]) {\n      jobs[id].owner = union(jobs[id].owner, owner || [])\n      jobs[id].cbs.push(cb)\n      return\n    }\n    hasQueue.push(jobs[id] = {\n      id: id, has: {}, owner: toArray(owner),\n      cbs: cb ? [cb] : [], done: false\n    })\n  }\n\n  function finishJob(job) {\n    if(!job) return\n    delete jobs[job.id]\n    while(job.cbs && job.cbs.length) {\n      var cb = job.cbs.shift()\n      if(isFunction(cb)) cb(null, true)\n    }\n  }\n\n  //if want is called and then it's locally added,\n  //handle that by calling back want.\n  pull(notify.listen(), pull.drain(function (hash) {\n    finishJob(hasQueue.pull(hash) || getQueue.pull(hash))\n  }))\n\n  function hasPeers () {\n    return Object.keys(sbot.peers).length !== 0\n  }\n\n  function hops (id) {\n    var p = sbot.friends.path({\n      source: sbot.id, dest: id, hops: conf.limit.length\n    })\n    return p ? p.length - 1 : -1\n  }\n\n  function limitFor(id) {\n    if(opts.party) return -1\n    var h = hops(id)\n    if(hops === -1) return conf.minLimit\n    return conf.limit[h] || conf.minLimit\n  }\n\n  function filter (job) {\n    //set config.blobs.party = true\n    //to disable all quotas.\n    if(conf.party) return true\n    return job.owner.every(function (id) {\n      var l = limitFor(id)\n      if(l < 0) return true\n      else if ((userQuotas[id] || 0) < l)\n        return true\n      else if(!over[id]) {\n        over[id] = userQuotas[id]\n        console.log('Over Quota:', id, wl.quota(id))\n      }\n    })\n  }\n\n  hasQueue = Queue(function (_, done) {\n    //check if there is a something in the has queue.\n    //filter out cases where work is impossible...\n    //(empty queue, or no peers)\n    if(!hasPeers()) return done()\n\n    var job = hasQueue.pull(filter)\n\n    if(!job || job.done) return done()\n\n    var n = 0, found = false\n    each(sbot.peers, function (peers, id) {\n      if(('undefined' !== typeof job.has[id]) || !peers[0]) return\n      n++\n      peers[0].blobs.has(job.id, function (err, has) {\n        found = found || (job.has[id] = has)\n        if(--n) return\n        next()\n      })\n    })\n    if(!n) return hasQueue.push(job), done()\n\n    function next () {\n      (found ? getQueue : hasQueue).push(job)\n      done()\n    }\n  })\n\n  getQueue = Queue(function (_, done) {\n    if(!hasPeers()) return done()\n\n    //check if this file is over quota.\n    var job = getQueue.pull(filter)\n    if(!job) return done()\n    //this covers weird edgecase where a blob is added\n    //while something is looking for it. covered in\n    //test/blobs2.js\n    if(job.done) {\n      delete jobs[job.id]\n      return done()\n    }\n\n    var remote = first(job.has, function (has, id) {\n      if (has)\n        return getPeer(id)\n    })\n\n    if(!remote) {\n      hasQueue.push(job); return done()\n    }\n\n    pull(\n      remote.blobs.get(job.id),\n      //only accept blobs that have the correct size.\n      sbot.blobs.add(job.id, function (err) {\n        if(!err) {\n          finishJob(job)\n          return done() //success\n        }\n        // remove the remote, it may be misbehaving\n        delete job.has[remote.id]\n        // put it back on the get or has queue\n        if(Object.keys(job.has).length) getQueue.push(job)\n        else hasQueue.push(job)\n        done()\n      })\n    )\n  })\n\n  function getPeer(id) {\n    return sbot.peers[id] && sbot.peers[id][0]\n  }\n\n  // monitor the feed for new links to blobs\n  pull(\n    sbot.links({dest: '&', live: true}),\n    pull.drain(function (data) {\n      // do we have the referenced blob yet?\n      sbot.blobs.has(data.dest, function (_, has) {\n        if(!has) createJob(data.dest, data.source)\n      })\n    })\n  )\n\n  //handle weird edge case where something is added locally\n  //but we are already looking for it because we saw a link.\n  sbot.on('blobs:got', function (hash) {\n    if(jobs[hash]) jobs[hash].done = true\n  })\n\n  sbot.on('rpc:connect', function (rpc) {\n    for(id in jobs)\n      if(false === jobs[id].has[rpc.id])\n        delete jobs[id].has[rpc.id]\n  })\n\n  return wl = {\n    has: hasQueue,\n    get: getQueue,\n    want: function (id, owner, cb) {\n      createJob(id, owner || sbot.id, cb)\n    },\n    quota: function (id) {\n      var l = limitFor(id), q = userQuotas[id] || 0\n      return {\n        limit: l,\n        usage: q,\n        hops: hops(id),\n        percent: ((q/l)*100).toPrecision(4)+'%'\n      }\n    }\n  }\n}\n\n\n\n","var pull = require('pull-stream')\nvar valid = require('../lib/validators')\n\nexports.name = 'block'\nexports.version = '1.0.0'\nexports.manifest = {\n  isBlocked  : 'sync',\n}\n\nexports.init = function (sbot) {\n\n  //TODO: move other blocking code in here,\n  //      i think we'll need a hook system for this.\n\n  //if a currently connected peer is blocked, disconnect them immediately.\n  pull(\n    sbot.friends.createFriendStream({graph: 'flag', live: true}),\n    pull.drain(function (blocked) {\n      if(sbot.peers[blocked]) {\n        sbot.peers[blocked].forEach(function (b) {\n          b.close(true, function () {})\n        })\n      }\n    })\n  )\n\n  function isBlocked (_opts) {\n    var opts\n\n    if('string' === typeof _opts)\n      opts = {\n        source: sbot.id, dest: _opts, graph:'flag'\n      }\n    else opts = {\n      source: _opts.source, dest: _opts.dest, graph: 'flag'\n    }\n    return sbot.friends.get(opts)\n  }\n\n  sbot.createHistoryStream.hook(function (fn, args) {\n    var opts = args[0], id = this.id\n    if(opts.id !== this.id && isBlocked({source: opts.id, dest: this.id}))\n      return fn({id: null, sequence: 0})\n    else\n      return pull(\n        fn.apply(this, args),\n        //break off this feed if they suddenly block\n        //the recipient.\n        pull.take(function (msg) {\n          //handle when createHistoryStream is called with keys: true\n          if(!msg.content && msg.value.content)\n            msg = msg.value\n          if(msg.content.type !== 'contact') return true\n          return !(\n            msg.content.flagged &&\n            msg.content.contact === id\n          )\n        })\n      )\n  })\n\n  sbot.auth.hook(function (fn, args) {\n    if(isBlocked(args[0])) args[1](new Error('client is blocked'))\n    else return fn.apply(this, args)\n  })\n\n  return {isBlocked: valid.sync(isBlocked, 'feedId|isBlockedOpts') }\n\n}\n","var Graphmitter = require('graphmitter')\nvar pull        = require('pull-stream')\nvar mlib        = require('ssb-msgs')\nvar memview     = require('level-memview')\nvar pushable    = require('pull-pushable')\nvar mdm         = require('mdmanifest')\nvar valid       = require('../lib/validators')\nvar apidoc      = require('../lib/apidocs').friends\n\n// friends plugin\n// methods to analyze the social graph\n// maintains a 'follow' and 'flag' graph\n\nfunction isFunction (f) {\n  return 'function' === typeof f\n}\n\nfunction isString (s) {\n  return 'string' === typeof s\n}\n\nexports.name = 'friends'\nexports.version = '1.0.0'\nexports.manifest = mdm.manifest(apidoc)\n\nexports.init = function (sbot, config) {\n\n  var graphs = {\n    follow: new Graphmitter(),\n    flag: new Graphmitter()\n  }\n\n  // view processor\n  var syncCbs = []\n  function awaitSync (cb) {\n    if (syncCbs) syncCbs.push(cb)\n    else cb()\n  }\n\n  // read/watch the log for changes to the social graph\n  pull(sbot.createLogStream({ live: true }), pull.drain(function (msg) {\n\n    if (msg.sync) {\n      syncCbs.forEach(function (cb) { cb() })\n      syncCbs = null\n      return\n    }\n\n    var c = msg.value.content\n    if (c.type == 'contact') {\n      mlib.asLinks(c.contact).forEach(function (link) {\n        if ('following' in c) {\n          if (c.following)\n            graphs.follow.edge(msg.value.author, link.link, true)\n          else\n            graphs.follow.del(msg.value.author, link.link)\n\n        }\n        if ('flagged' in c) {\n          if (c.flagged)\n            graphs.flag.edge(msg.value.author, link.link, c.flagged)\n          else\n            graphs.flag.del(msg.value.author, link.link)\n        }\n      })\n    }\n  }))\n\n  return {\n\n    get: valid.sync(function (opts) {\n      var g = graphs[opts.graph || 'follow']\n      if(!g) throw new Error('opts.graph must be provided')\n      return g.get(opts.source, opts.dest)\n    }, 'object?'),\n\n    all: valid.async(function (graph, cb) {\n      if (typeof graph == 'function') {\n        cb = graph\n        graph = null\n      }\n      if (!graph)\n        graph = 'follow'\n      awaitSync(function () {\n        cb(null, graphs[graph] ? graphs[graph].toJSON() : null)\n      })\n    }, 'string?'),\n\n    path: valid.sync(function (opts) {\n      if(isString(opts))\n        opts = {source: sbot.id, dest: opts}\n      return graphs.follow.path(opts)\n\n    }, 'string|object'),\n    \n    createFriendStream: valid.source(function (opts) {\n      opts = opts || {}\n      var live = opts.live === true\n      var meta = opts.meta === true\n      var start = opts.start || sbot.id\n      var graph = graphs[opts.graph || 'follow']\n      if(!graph)\n        return pull.error(new Error('unknown graph:' + opts.graph))\n      var cancel, ps = pushable(function () {\n        cancel && cancel()\n      })\n\n      function push (to, hops) {\n        return ps.push(meta ? {id: to, hops: hops} : to)\n      }\n\n      //by default, also emit your own key.\n      if(opts.self !== false)\n        push(start, 0)\n\n      var conf = config.friends || {}\n      cancel = graph.traverse({\n        start: start,\n        hops: opts.hops || conf.hops || 3,\n        max: opts.dunbar || conf.dunbar || 150,\n        each: function (_, to, hops) {\n          if(to !== start) push(to, hops)\n        }\n      })\n\n      if(!live) { cancel(); ps.end() }\n\n      return ps\n    }, 'createFriendStreamOpts?'),\n\n    hops: valid.async(function (start, graph, opts, cb) {\n      if (typeof opts == 'function') { // (start|opts, graph, cb)\n        cb = opts\n        opts = null\n      } else if (typeof graph == 'function') { // (start|opts, cb)\n        cb = graph\n        opts = graph = null\n      }\n      opts = opts || {}\n      if(isString(start)) { // (start, ...)\n        // first arg is id string\n        opts.start = start\n      } else if (start && typeof start == 'object') { // (opts, ...)\n        // first arg is opts\n        for (var k in start)\n          opts[k] = start[k]\n      }\n\n      var conf = config.friends || {}\n      opts.start  = opts.start  || sbot.id\n      opts.dunbar = opts.dunbar || conf.dunbar || 150\n      opts.hops   = opts.hops   || conf.hops   || 3\n\n      var g = graphs[graph || 'follow']\n      if (!g)\n        return cb(new Error('Invalid graph type: '+graph))\n\n      awaitSync(function () {\n        cb(null, g.traverse(opts))\n      })\n    }, ['feedId', 'string?', 'object?'], ['createFriendStreamOpts'])\n  }\n}\n","'use strict'\nvar pull = require('pull-stream')\nvar Notify = require('pull-notify')\nvar toAddress = require('../../lib/util').toAddress\nvar mdm = require('mdmanifest')\nvar valid = require('../../lib/validators')\nvar apidoc = require('../../lib/apidocs').gossip\nvar u = require('../../lib/util')\nvar ping = require('pull-ping')\nvar Stats = require('statistics')\nvar isArray = Array.isArray\nvar Schedule = require('./schedule')\nvar Init = require('./init')\n\nfunction isFunction (f) {\n  return 'function' === typeof f\n}\n\n/*\nPeers : [{\n  key: id,\n  host: ip,\n  port: int,\n  //to be backwards compatible with patchwork...\n  announcers: {length: int}\n  source: 'pub'|'manual'|'local'\n}]\n*/\n\n\nmodule.exports = {\n  name: 'gossip',\n  version: '1.0.0',\n  manifest: mdm.manifest(apidoc),\n  permissions: {\n    anonymous: {allow: ['ping']}\n  },\n  init: function (server, config) {\n    var notify = Notify()\n    var conf = config.gossip || {}\n    var home = u.toAddress(server.getAddress())\n\n    //Known Peers\n    var peers = []\n\n    function getPeer(id) {\n      return u.find(peers, function (e) {\n        return e && e.key === id\n      })\n    }\n\n    var timer_ping = 5*6e4\n\n    var gossip = {\n      peers: function () {\n        return peers\n      },\n      get: function (addr) {\n        addr = u.toAddress(addr)\n        return u.find(peers, function (a) {\n          return (\n            addr.port === a.port\n            && addr.host === a.host\n            && addr.key === a.key\n          )\n        })\n      },\n      connect: valid.async(function (addr, cb) {\n        addr = u.toAddress(addr)\n        if (!addr || typeof addr != 'object')\n          return cb(new Error('first param must be an address'))\n\n        if(!addr.key) return cb(new Error('address must have ed25519 key'))\n        // add peer to the table, incase it isn't already.\n        gossip.add(addr, 'manual')\n        var p = gossip.get(addr)\n        if(!p) return cb()\n\n        p.stateChange = Date.now()\n        p.state = 'connecting'\n        server.connect(p, function (err, rpc) {\n          if (err) {\n            p.state = undefined\n            p.failure = (p.failure || 0) + 1\n            p.stateChange = Date.now()\n            notify({ type: 'connect-failure', peer: p })\n            server.emit('log:info', ['SBOT', p.host+':'+p.port+p.key, 'connection failed', err.message || err])\n            p.duration.value(0)\n            return (cb && cb(err))\n          }\n          else {\n            p.state = 'connected'\n            p.failure = 0\n          }\n          cb && cb(null, rpc)\n        })\n\n      }, 'string|object'),\n\n      disconnect: valid.async(function (addr, cb) {\n        var peer = this.get(addr)\n\n        peer.state = 'disconnecting'\n        peer.stateChange = Date.now()\n        if(!peer || !peer.disconnect) cb && cb()\n        else peer.disconnect(true, function (err) {\n          peer.stateChange = Date.now()\n        })\n\n      }, 'string|object'),\n\n      changes: function () {\n        return notify.listen()\n      },\n      //add an address to the peer table.\n      add: valid.sync(function (addr, source) {\n        addr = u.toAddress(addr)\n        if(!u.isAddress(addr))\n          throw new Error('not a valid address:' + JSON.stringify(addr))\n        // check that this is a valid address, and not pointing at self.\n\n        if(addr.key === home.key) return\n        if(addr.host === home.host && addr.port === home.port) return\n\n        var f = gossip.get(addr)\n\n        if(!f) {\n          // new peer\n          addr.source = source\n          addr.announcers = 1\n          addr.duration = Stats()\n          peers.push(addr)\n          notify({ type: 'discover', peer: addr, source: source || 'manual' })\n          return addr\n        }\n        //don't count local over and over\n        else if(f.source != 'local')\n          f.announcers ++\n\n        return f\n      }, 'string|object', 'string?'),\n      ping: function (opts) {\n        var timeout = config.timers && config.timers.ping || 5*60e3\n        //between 10 seconds and 30 minutes, default 5 min\n        timeout = Math.max(10e3, Math.min(timeout, 30*60e3))\n        return ping({timeout: timeout})\n      }\n    }\n\n    Schedule (gossip, config, server)\n    Init (gossip, config, server)\n    //get current state\n\n    server.on('rpc:connect', function (rpc, isClient) {\n      var peer = getPeer(rpc.id)\n      //don't track clients that connect, but arn't considered peers.\n      //maybe we should though?\n      if(!peer) return\n      console.log('+connected', u.stringifyAddress(peer))\n      //means that we have created this connection, not received it.\n      peer.client = !!isClient\n      peer.state = 'connected'\n      peer.stateChange = Date.now()\n      peer.disconnect = function (err, cb) {\n        if(isFunction(err)) cb = err, err = null\n        rpc.close(err, cb)\n      }\n\n      if(isClient) {\n        //default ping is 5 minutes...\n        var pp = ping({serve: true, timeout: timer_ping}, function (_) {})\n        peer.ping = {rtt: pp.rtt, skew: pp.skew}\n        pull(\n          pp,\n          rpc.gossip.ping({timeout: timer_ping}, function (err) {\n            if(err.name === 'TypeError') peer.ping.fail = true\n          }),\n          pp\n        )\n      }\n\n      rpc.on('closed', function () {\n        console.log('-disconnected', u.stringifyAddress(peer))\n        //track whether we have successfully connected.\n        //or how many failures there have been.\n        var since = peer.stateChange\n        peer.stateChange = Date.now()\n        if(peer.state === 'connected') //may be \"disconnecting\"\n          peer.duration.value(peer.stateChange - since)\n        peer.state = undefined\n        notify({ type: 'disconnect', peer: peer })\n        server.emit('log:info', ['SBOT', rpc.id, 'disconnect'])\n      })\n\n      notify({ type: 'connect', peer: peer })\n    })\n\n    return gossip\n  }\n}\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n","var isArray = Array.isArray\nvar pull = require('pull-stream')\n\nmodule.exports = function (gossip, config, server) {\n\n  // populate peertable with configured seeds (mainly used in testing)\n  var seeds = config.seeds\n\n  ;(isArray(seeds)  ? seeds : [seeds]).filter(Boolean)\n  .forEach(function (addr) { gossip.add(addr, 'seed') })\n\n  // populate peertable with pub announcements on the feed\n  pull(\n    server.messagesByType({\n      type: 'pub', live: true, keys: false\n    }),\n    pull.drain(function (msg) {\n      if(!msg.content.address) return\n      gossip.add(msg.content.address, 'pub')\n    })\n  )\n\n  // populate peertable with announcements on the LAN multicast\n  server.on('local', function (_peer) {\n    gossip.add(_peer, 'local')\n  })\n\n}\n\n\n\n","var nonPrivate = require('non-private-ip')\nvar ip = require('ip')\nvar onWakeup = require('on-wakeup')\nvar Stats = require('statistics')\nvar os = require('os')\nvar pull = require('pull-stream')\nvar u = require('../../lib/util')\n\nfunction rand(array) {\n  return array[~~(Math.random()*array.length)]\n}\n\nfunction not (fn) {\n  return function (e) { return !fn(e) }\n}\n\nfunction and () {\n  var args = [].slice.call(arguments)\n  return function (value) {\n    return args.every(function (fn) { return fn.call(null, value) })\n  }\n}\n\n//min delay (delay since last disconnect of most recent peer in unconnected set)\n//unconnected filter delay peer < min delay\nfunction delay (failures, factor, max) {\n  return Math.min(Math.pow(2, failures)*factor, max || Infinity)\n}\n\nfunction maxStateChange (M, e) {\n  return Math.max(M, e.stateChange || 0)\n}\n\nfunction peerNext(peer, opts) {\n  return (peer.stateChange|0) + delay(peer.failure|0, opts.factor, opts.max)\n}\n\n\n//detect if not connected to wifi or other network\n//(i.e. if there is only localhost)\n\nfunction isOffline () {\n  var lo = Object.keys(os.networkInterfaces())\n  return lo.length === 1 && lo[0] === 'lo'\n}\n\nvar isOnline = not(isOffline)\n\nfunction isLocal (e) {\n  return ip.isPrivate(e.host)\n}\n\nfunction isUnattempted (e) {\n  return !e.stateChange\n}\n\n//select peers which have never been successfully connected to yet,\n//but have been tried.\nfunction isInactive (e) {\n  return e.stateChange && e.duration.mean == 0\n}\n\nfunction isLongterm (e) {\n  return e.ping && e.ping.rtt.mean > 0\n}\n\n//peers which we can connect to, but are not upgraded.\n//select peers which we can connect to, but are not upgraded to LT.\n//assume any peer is legacy, until we know otherwise...\nfunction isLegacy (peer) {\n  return peer.duration.mean > 0 && !exports.isLongterm(peer)\n}\n\nfunction isConnect (e) {\n  return 'connected' === e.state || 'connecting' === e.state\n}\n\n//sort oldest to newest then take first n\nfunction earliest(peers, n) {\n  return peers.sort(function (a, b) {\n    return a.stateChange - b.stateChange\n  }).slice(0, Math.max(n, 0))\n}\n\nfunction select(peers, ts, filter, opts) {\n  if(opts.disable) return []\n  //opts: { quota, groupMin, min, factor, max }\n  var type = peers.filter(filter)\n  var unconnect = type.filter(not(isConnect))\n  var count = Math.max(opts.quota - type.filter(isConnect).length, 0)\n  var min = unconnect.reduce(maxStateChange, 0) + opts.groupMin\n  if(ts < min) return []\n\n  return earliest(unconnect.filter(function (peer) {\n    return peerNext(peer, opts) < ts\n  }), count)\n}\n\nvar schedule = exports = module.exports =\nfunction (gossip, config, server) { \n\n  var min = 60e3, hour = 60*60e3\n\n  function conf(name, def) {\n    if(!config.gossip) return def\n    var value = config.gossip[name]\n    return (value === undefined || value === '') ? def : value\n  }\n\n  function connect (peers, ts, name, filter, opts) {\n    var connected = peers.filter(isConnect).filter(filter)\n      .filter(function (peer) {\n        return peer.stateChange + 10e3 < ts\n      })\n\n    if(connected.length > opts.quota) {\n      return earliest(connected, connected.length - opts.quota)\n        .forEach(function (peer) {\n          console.log('Disconnect', name, u.stringifyAddress(peer))\n          gossip.disconnect(peer)\n        })\n    }\n\n    select(peers, ts, and(filter, isOnline), opts)\n      .forEach(function (peer) {\n        console.log('Connect', name, u.stringifyAddress(peer))\n        gossip.connect(peer)\n      })\n  }\n\n\n  function connections () {\n    var ts = Date.now()\n    var peers = gossip.peers()\n\n    connect(peers, ts, 'attempt', exports.isUnattempted, {\n        min: 0, quota: 10, factor: 0, max: 0, groupMin: 0,\n        disable: !conf('global', true)\n    })\n\n    //quota, groupMin, min, factor, max\n    connect(peers, ts, 'retry', exports.isInactive, {\n        min: 0,\n        quota: 3, factor: 5*60e3, max: 3*60*60e3, groupMin: 5*50e3\n      })\n\n    connect(peers, ts, 'legacy', exports.isLegacy, {\n        quota: 3, factor: 5*min, max: 3*hour, groupMin: 5*min,\n        disable: !conf('global', true)\n      })\n\n    connect(peers, ts, 'longterm', exports.isLongterm, {\n      quota: 3, factor: 10e3, max: 10*min, groupMin: 5e3,\n      disable: !conf('global', true)\n    })\n\n    connect(peers, ts, 'local', exports.isLocal, {\n      quota: 3, factor: 2e3, max: 10*min, groupMin: 1e3,\n      disable: !conf('local', true)\n    })\n\n  }\n\n    pull(\n      gossip.changes(),\n      pull.drain(function (ev) {\n        if(ev.type == 'disconnect')\n          connections()\n      })\n    )\n\n    setInterval(function () {\n      connections()\n    }, 2e3).unref()\n\n    connections()\n\n}\n\nexports.isUnattempted = isUnattempted\nexports.isInactive = isInactive\nexports.isLongterm = isLongterm\nexports.isLegacy = isLegacy\nexports.isLocal = isLocal\nexports.isConnectedOrConnecting = isConnect\nexports.select = select\n\n\n\n\n\n\n\n\n\n","var crypto = require('crypto')\nvar ssbKeys = require('ssb-keys')\nvar toAddress = require('../lib/util').toAddress\nvar cont = require('cont')\nvar explain = require('explain-error')\nvar ip = require('ip')\nvar mdm = require('mdmanifest')\nvar valid = require('../lib/validators')\nvar apidoc = require('../lib/apidocs').invite\n\n// invite plugin\n// adds methods for producing invite-codes,\n// which peers can use to command your server to follow them.\n\nfunction isFunction (f) {\n  return 'function' === typeof f\n}\n\nfunction isString (s) {\n  return 'string' === typeof s\n}\n\nmodule.exports = {\n  name: 'invite',\n  version: '1.0.0',\n  manifest: mdm.manifest(apidoc),\n  permissions: {\n    master: {allow: ['create']},\n    //temp: {allow: ['use']}\n  },\n  init: function (server, config) {\n    var codes = {}\n    var codesDB = server.sublevel('codes')\n\n    var createClient = this.createClient\n\n    //add an auth hook.\n    server.auth.hook(function (fn, args) {\n      var pubkey = args[0], cb = args[1]\n\n      // run normal authentication\n      fn(pubkey, function (err, auth) {\n        if(err || auth) return cb(err, auth)\n\n        // if no rights were already defined for this pubkey\n        // check if the pubkey is one of our invite codes\n        codesDB.get(pubkey, function (_, code) {\n          return cb(null, code && code.permissions)\n        })\n      })\n    })\n\n    return {\n      create: valid.async(function (n, cb) {\n        var addr = server.getAddress()\n        var host = toAddress(addr).host\n        if(!config.allowPrivate && (ip.isPrivate(host) || 'localhost' === host))\n          return cb(new Error('Server has no public ip address, '\n                            + 'cannot create useable invitation'))\n\n        //this stuff is SECURITY CRITICAL\n        //so it should be moved into the main app.\n        //there should be something that restricts what\n        //permissions the plugin can create also:\n        //it should be able to diminish it's own permissions.\n\n        // generate a key-seed and its key\n        var seed = crypto.randomBytes(32)\n        var keyCap = ssbKeys.generate('ed25519', seed)\n\n        // store metadata under the generated pubkey\n        var owner = server.id\n        codesDB.put(keyCap.id,  {\n          id: keyCap.id,\n          total: +n,\n          used: 0,\n          permissions: {allow: ['invite.use'], deny: null}\n        }, function (err) {\n          // emit the invite code: our server address, plus the key-seed\n          if(err) cb(err)\n          else cb(null, addr + '~' + seed.toString('base64'))\n        })\n      }, 'number'),\n      use: valid.async(function (req, cb) {\n        var rpc = this\n\n        // fetch the code\n        codesDB.get(rpc.id, function(err, invite) {\n          if(err) return cb(err)\n\n          // check if we're already following them\n          server.friends.all('follow', function(err, follows) {\n            if (follows && follows[server.id] && follows[server.id][req.feed])\n              return cb(new Error('already following'))\n\n            // although we already know the current feed\n            // it's included so that request cannot be replayed.\n            if(!req.feed)\n              return cb(new Error('feed to follow is missing'))\n\n            if(invite.used >= invite.total)\n              return cb(new Error('invite has expired'))\n\n            invite.used ++\n\n            //never allow this to be used again\n            if(invite.used >= invite.total)\n              invite.permissions = {allow: [], deny: null}\n\n            //TODO\n            //okay so there is a small race condition here\n            //if people use a code massively in parallel\n            //then it may not be counted correctly...\n            //this is not a big enough deal to fix though.\n            //-dominic\n\n            // update code metadata\n            codesDB.put(rpc.id, invite, function (err) {\n              server.emit('log:info', ['invite', rpc.id, 'use', req])\n\n              // follow the user\n              server.publish({\n                type: 'contact',\n                contact: req.feed,\n                following: true,\n                autofollow: true\n              }, cb)\n            })\n          })\n        })\n      }, 'object'),\n      accept: valid.async(function (invite, cb) {\n        // remove surrounding quotes, if found\n        if (invite.charAt(0) === '\"' && invite.charAt(invite.length - 1) === '\"')\n          invite = invite.slice(1, -1)\n\n        // connect to the address in the invite code\n        // using a keypair generated from the key-seed in the invite code\n\n        var parts = invite.split('~')\n        var addr = toAddress(parts[0])\n\n        createClient({ seed: parts[1] })\n        (addr, function (err, rpc) {\n          if(err) return cb(explain(err, 'could not connect to server'))\n\n          // command the peer to follow me\n          rpc.invite.use({ feed: server.id }, function (err, msg) {\n            if(err) return cb(explain(err, 'invite not accepted'))\n            \n            // follow and announce the pub\n            cont.para([\n              server.publish({\n                type: 'contact',\n                following: true,\n                autofollow: true,\n                contact: addr.link || addr.key\n              }),\n              server.publish({\n                type: 'pub',\n                address: addr,\n              })\n            ])(function (err, results) {\n              rpc.close()\n              cb(err, results)\n            })\n          })\n        })\n      }, 'string')\n    }\n  }\n}\n\n\n\n\n\n\n\n","var broadcast = require('broadcast-stream')\n\n// local plugin\n// broadcasts the address:port:pubkey triple of the sbot server\n// on the LAN, using multicast UDP\n\nfunction isFunction (f) {\n  return 'function' === typeof f\n}\n\nmodule.exports = {\n  name: 'local',\n  version: '2.0.0',\n  init: function (sbot, config) {\n\n    var local = broadcast(config.port)\n\n    local.on('data', function (buf) {\n      if(buf.loopback) return\n      var data = buf.toString()\n      sbot.gossip.add(data, 'local')\n    })\n\n    setInterval(function () {\n      // broadcast self\n      // TODO: sign beacons, so that receipient can be confidant\n      // that is really your id.\n      // (which means they can update their peer table)\n      // Oh if this includes your local address,\n      // then it becomes unforgeable.\n      local.write(sbot.getAddress())\n    }, 1000)\n  }\n}\n\n","var color = require('bash-color')\n\n// logging plugin\n// subscribes to 'log:*' events\n// and emits using lovely colors\n\nvar LOG_LEVELS = [\n  'error',\n  'warning',\n  'notice',\n  'info'\n]\nvar DEFAULT_LEVEL = LOG_LEVELS.indexOf('notice')\n\nfunction indent (o) {\n  return o.split('\\n').map(function (e) {\n    return '  ' + e\n  }).join('\\n')\n}\n\nfunction isString(s) {\n  return 'string' === s\n}\n\nfunction formatter(id, level) {\n  var b = id.substring(0, 4)\n  return function (ary) {\n    var plug = ary[0].substring(0, 4).toUpperCase()\n    var id = ary[1]\n    var verb = ary[2]\n    var data = ary.length > 4 ? ary.slice(3) : ary[3]\n    var _data = (isString(data) ? data : JSON.stringify(data)) || ''\n\n    var pre = [plug, id, color.cyan(verb)].join(' ')\n    var length = (5 + pre.length + 1 + _data.length)\n    var lines = isString(data) && data.split('\\n').length > 1\n\n    var c = process.stdout.columns\n    if((process.stdout.columns > length) && !lines)\n      console.log([level, b, pre, _data].join(' '))\n    else {\n      console.log([level, b, pre].join(' '))\n      if(lines)\n        console.log(indent(data))\n      else if(data && data.stack)\n        console.log(indent(data.stack))\n      else if(data) {\n        console.log(indent(JSON.stringify(data, null, 2)))\n      }\n    }\n  }\n}\n\nmodule.exports = function logging (server, conf) {\n  var level = conf.logging && conf.logging.level && LOG_LEVELS.indexOf(conf.logging.level) || DEFAULT_LEVEL\n  if (level === -1) {\n    console.log('Warning, logging.level configured to an invalid value:', conf.logging.level)\n    console.log('Should be one of:', LOG_LEVELS.join(', '))\n    level = DEFAULT_LEVEL\n  }\n  console.log('Log level:', LOG_LEVELS[level])\n\n  var id = server.id\n  if (level >= LOG_LEVELS.indexOf('info'))\n    server.on('log:info',    formatter(id, color.green('info')))\n  if (level >= LOG_LEVELS.indexOf('notice'))\n    server.on('log:notice',  formatter(id, color.blue('note')))\n  if (level >= LOG_LEVELS.indexOf('warning'))\n    server.on('log:warning', formatter(id, color.yellow('warn')))\n  if (level >= LOG_LEVELS.indexOf('error'))\n    server.on('log:error',   formatter(id, color.red('err!')))\n}\n\nmodule.exports.init = module.exports\n","// master plugin\n// allows you to define \"master\" IDs in the config\n// which are given the full rights of the local main ID\nmodule.exports = function (api, opts) {\n  var masters = [api.id].concat(opts.master).filter(Boolean)\n  api.auth.hook(function (fn, args) {\n    var id = args[0]\n    var cb = args[1]\n    cb(null, ~masters.indexOf(id) ? {allow: null, deny: null} : null)\n  })\n}\n","var ssbKeys = require('ssb-keys')\nvar explain = require('explain-error')\nvar mdm = require('mdmanifest')\nvar valid = require('../lib/validators')\nvar apidoc = require('../lib/apidocs').private\n\nmodule.exports = {\n  name: 'private',\n  version: '0.0.0',\n  manifest: mdm.manifest(apidoc),\n  permissions: {\n    anonymous: {},\n  },\n  init: function (sbot, opts) {\n    return {\n      publish: valid.async(function (data, recps, cb) {\n        var ciphertext\n        try { ciphertext = ssbKeys.box(data, recps) }\n        catch (e) { return cb(explain(e, 'failed to encrypt')) }\n\n        sbot.publish(ciphertext, cb)\n      }, 'string|object', 'array'),\n      unbox: valid.sync(function (ciphertext) {\n        var data\n        try { data = ssbKeys.unbox(ciphertext, sbot.keys.private) }\n        catch (e) { throw explain(e, 'failed to decrypt') }\n        return data\n      }, 'string')\n    }\n  }\n}","var pull = require('pull-stream')\nvar para = require('pull-paramap')\nvar Notify = require('pull-notify')\nvar many = require('pull-many')\nvar cat = require('pull-cat')\nvar Abort = require('pull-abortable')\nvar Debounce = require('observ-debounce')\nvar Observ = require('observ')\nvar mdm = require('mdmanifest')\nvar apidoc = require('../lib/apidocs').replicate\n\nvar DAY = 1000*60*60*24\nvar LIMIT = [-1, -1, 100] // default rate-limits, by hops out\n\nvar notify = Notify()\n\nfunction last (a) { return a[a.length - 1] }\n\n// main log-replication behavior\nfunction replicate(sbot, config, rpc, cb) {\n\n  // rate limiter:\n  // calculate how many messages we're willing to receive for a user\n  // - works by number of \"hops\" away from the local user, in the follow graph\n  function calcLimit (upto) {\n\n    var limit = config.replication && config.replication.limit\n    if(!Array.isArray(limit)) limit = LIMIT\n\n    var hopLimit = (upto.hops < limit.length) ? limit[upto.hops] : last(limit)\n    if(hopLimit <=0) return hopLimit\n\n    return (\n        !upto.ts\n      ? hopLimit\n      : Math.ceil((Date.now() - upto.ts)/DAY * hopLimit)\n    )\n  }\n\n  // TODO\n  // is `initial` and `to_recv` the same thing? do we need both?\n  // -prf\n  var aborter = Abort()\n  var sources = many()\n  var to_send = {} // { feedId => their latest seq } map for feeds requested by the peer\n  var to_recv = {} // { feedId => our latest seq } map for feeds we request\n  var initial = {} // { feedId => initial seq } map for feeds request, remembers what seq each feed was initially at\n  var replicated = {} // { feedId => final seq } map for feeds request, tracks the final seq for each received feed\n  var debounce = Debounce(100)\n\n  // track progress, and emit update events periodically\n  debounce(function () {\n    // HACK\n    // This uses the information produced by normal replication \n    // to get a rough approximation for a progress-bar.\n    // When the peer requests feeds, they'll tell us what sequence they have for each feed.\n    // We track that in `to_send`.\n    // We also track the sequence we have, for the feeds we're requesting, in `to_recv`.\n    // If it so happens they have a higher sequence for a feed than we do, then\n    // `to_send` will be higher than `to_recv`.\n    // This means they have to request a feed for us to track that feed's progress, which is\n    // often the case, but not always.\n    // Works for now.\n    // -prf (but code by dominic, blame him)\n    var total = 0, progress = 0, feeds = 0\n    for(var id in to_recv) {\n      var feed_to_send    = to_send[id]    || 0\n      var feed_to_recv    = to_recv[id]    || 0\n      var feed_replicated = replicated[id] || 0\n      if(to_send[id] != null && to_recv[id] != null) {\n        feeds++\n        if(feed_to_send > feed_to_recv) {\n          total    += (feed_to_send    - feed_to_recv)\n          progress += (feed_replicated - feed_to_recv)\n        }\n      }\n    }\n\n    // emit progress event\n    notify({\n      type: 'progress',\n      peerid: rpc.id,\n      total: total,\n      progress: progress,\n      feeds: feeds,\n      sync: !!(feeds && (progress >= total))\n    })\n  })\n\n  rpc.on('call:createHistoryStream', function (opts) {\n    // track what sequence the peer has for each feed\n    to_send[opts.id] = (opts.sequence || opts.seq) - 1\n    debounce.set()\n  })\n\n  // compatibility function for old implementations of `latestSequence`\n  function toSeq (s) {\n    return 'number' === typeof s ? s : s.sequence\n  }\n\n  // collect the IDs of feeds we want to request\n  var opts = config.replication || {}\n  opts.hops = opts.hops || 3\n  opts.dunbar = opts.dunbar || 150\n  opts.live = true\n  opts.meta = true\n  var userSources = [sbot.friends.createFriendStream(opts)]\n  if (sbot.gossip) {\n    // if we have the gossip plugin active, then include new local peers\n    // so that you can put a name to someone on your local network.\n    userSources.unshift(pull.values(\n      sbot.gossip.peers()\n        .filter(function (e) { return e.source === 'local' })\n        .map(function (e) { return {id: e.key, hops: 6} })\n    ))\n  }\n\n  // create read-streams for the desired feeds\n  pull(\n    cat(userSources),\n    aborter,\n    // filter out duplicates, and also keep track of what we expect to receive\n    pull.filter(function (s) {\n      var id = 'string' === typeof s ? s  : s.id\n      if(to_recv[id] == null) { to_recv[id] = 0; return true }\n    }),\n    // lookup the latest sequence from each user\n    para(function (data, cb) {\n      if(data.sync) return cb(null, data)\n      var id = data.id || data\n      sbot.latestSequence(id, function (err, seq) {\n        cb(null, {\n          id: id,\n          sequence: err ? 0 : toSeq(seq),\n          ts: err ? null : seq.ts,\n          hops: data.hops\n        })\n      })\n    }, 32),\n    pull.drain(function (upto) {\n      to_recv[upto.id] = upto.sequence\n      initial[upto.id] = replicated[upto.id] = upto.sequence\n\n      var limit = config.party ? null : calcLimit(upto)\n\n      sources.add(\n        pull(\n\n          // TODO\n          // how do `limit` and `live` interact, here?\n          // what if only the first 100 messages, of 200, were requested? \n          // would you start getting live updates, starting at sequence 201?\n          // -prf\n          rpc.createHistoryStream({\n            id: upto.id,\n            seq: upto.sequence + 1,\n            limit: limit,\n            live: true,\n            keys: false\n          }),\n          pull.through(function () {\n            if(limit === null || limit--) return\n            //REPLICATIOAN BACK PRESSURE\n            rpc.close(true)\n\n            // TODO\n            // do we want to close the entire RPC connection when the limit is hit?\n            // the limit is per feed ... it should just close the feed's history stream\n            // -prf\n          })\n        )\n      )\n\n      debounce.set()\n    }, function (err) {\n      if(err)\n        sbot.emit('log:error', ['replication', rep.id, 'error', err])\n      sources.cap()\n    })\n  )\n\n  // create the read -> write stream\n  pull(\n    sources,\n    pull.through(function (msg) {\n      // track progress\n      replicated[msg.author] = Math.max(\n        replicated[msg.author]||0,\n        msg.sequence\n      )\n      debounce.set()\n    }),\n    sbot.createWriteStream(function (err) {\n      aborter.abort()\n      debounce.immediate()\n\n      // done!\n      cb(err, replicated, initial)\n    })\n  )\n}\n\nmodule.exports = {\n  name: 'replicate',\n  version: '1.0.0',\n  manifest: mdm.manifest(apidoc),\n  replicate: replicate,\n  init: function (sbot, config) {\n    sbot.createHistoryStream.hook(function (fn, args) {\n      if(this._emit)\n        this._emit('call:createHistoryStream', args[0])\n      return fn.apply(this, args)\n    })\n\n    // watch for new connections and replicate on creation\n    sbot.on('rpc:connect', function(rpc) {\n      // this is the cli client, just ignore.\n      if(rpc.id === sbot.id) return\n\n      sbot.emit('log:info', ['replicate', rpc.id, 'start'])\n      sbot.emit('replicate:start', rpc)\n      replicate(sbot, config, rpc, function (err, final, initial) {\n        if(err) {\n          sbot.emit('replicate:fail', err)\n          sbot.emit('log:warning', ['replicate', rpc.id, 'error', err])\n        } else {\n          var progress = {}\n          // subtract `initial` from `final` so `progress` represents a delta\n          for (var author in final)\n            progress[author] = final[author] - (initial[author] || 0)\n\n          var progressSummary = summarizeProgress(progress)\n          if (progressSummary)\n            sbot.emit('log:notice', ['replicate', rpc.id, 'success', progressSummary])\n          sbot.emit('replicate:finish', final)\n        }\n      })\n    })\n\n    return {\n      changes: function () {\n        return notify.listen()\n      }\n    }\n  }\n}\n\nfunction summarizeProgress (progress) {\n  // count the number of feeds updated, and the number of new messages\n  var updatedFeeds = 0, newMessages = 0\n  for (var author in progress) {\n    if (progress[author] > 0) {\n      updatedFeeds++\n      newMessages += progress[author]\n    }\n  }\n  // no message if no updates\n  if (updatedFeeds === 0)\n    return false\n  return 'Feeds updated: '+updatedFeeds+', New messages: '+newMessages\n}\n\n\n\n\n\n\n","var pull = require('pull-stream')\n\nvar Handshake = require('pull-handshake')\nvar State = require('./state')\n\nvar challenge_length = 64\nvar client_auth_length = 16+32+64\nvar server_auth_length = 16+64\nvar mac_length = 16\n\n//client is Alice\n//create the client stream with the public key you expect to connect to.\nexports.client =\nexports.createClientStream = function (alice, app_key, timeout) {\n\n  return function (bob_pub, cb) {\n    var state = new State(app_key, alice, bob_pub)\n\n    var stream = Handshake({timeout: timeout}, cb)\n    var shake = stream.handshake\n    delete stream.handshake\n\n    function abort(err, reason) {\n      if(err && err !== true) shake.abort(err, cb)\n      else                    shake.abort(new Error(reason), cb)\n    }\n\n    shake.write(state.createChallenge())\n\n    shake.read(challenge_length, function (err, msg) {\n      if(err) return abort(err, 'challenge not accepted')\n      //create the challenge first, because we need to generate a local key\n      if(!state.verifyChallenge(msg))\n        return abort(null, 'wrong protocol (version?)')\n\n      shake.write(state.createClientAuth())\n\n      shake.read(server_auth_length, function (err, boxed_sig) {\n        if(err) return abort(err, 'hello not accepted')\n\n        if(!state.verifyServerAccept(boxed_sig))\n          return abort(null, 'server not authenticated')\n\n        cb(null, shake.rest(), state.cleanSecrets())\n      })\n    })\n\n    return stream\n  }\n}\n\n//server is Bob.\nexports.server =\nexports.createServerStream = function (bob, authorize, app_key, timeout) {\n\n  return function (cb) {\n    var state = new State(app_key, bob)\n    var stream = Handshake({timeout: timeout}, cb)\n\n    var shake = stream.handshake\n    delete stream.handshake\n\n    function abort (err, reason) {\n      if(err && err !== true) shake.abort(err, cb)\n      else                    shake.abort(new Error(reason), cb)\n    }\n\n    shake.read(challenge_length, function (err, challenge) {\n      if(err) return abort(err, 'expected challenge')\n      if(!state.verifyChallenge(challenge))\n        return shake.abort(new Error('wrong protocol/version'))\n\n      shake.write(state.createChallenge())\n      shake.read(client_auth_length, function (err, hello) {\n        if(err) return abort(err, 'expected hello')\n        if(!state.verifyClientAuth(hello)) {\n          //we know who the client was, but chose not to answer:\n          if(state.remote.public)\n            return abort(null, 'unauthenticated client:' + state.remote.public.toString('hex'), cb)\n          //client dialed wrong number... (we don't know who they where)\n          else\n            return abort(null, 'wrong number')\n        }\n        //check if the user wants to speak to alice.\n        authorize(state.remote.public, function (err, auth) {\n          if(auth == null && !err) err = new Error('client unauthorized')\n          if(!auth) return abort(err, 'client authentication rejected')\n          state.auth = auth\n          shake.write(state.createServerAccept())\n          cb(null, shake.rest(), state.cleanSecrets())\n        })\n      })\n    })\n    return stream\n  }\n}\n\n\n","var handshake = require('./handshake')\nvar secure = require('./secure')\n\nexports.client =\nexports.createClient = function (alice, app_key, timeout) {\n  var create = handshake.client(alice, app_key, timeout)\n\n  return function (bob, cb) {\n    if(!Buffer.isBuffer(bob) || bob.length != 32)\n      throw new Error('createClient *must* be passed a public key')\n    return create(bob, secure(cb))\n  }\n\n}\nexports.server =\nexports.createServer = function (bob, authorize, app_key, timeout) {\n  var create = handshake.server(bob, authorize, app_key, timeout)\n\n  return function (cb) {\n    return create(secure(cb))\n  }\n\n}\n\n\n","\nvar sodium = require('chloride')\nvar net = require('net')\nvar toPull = require('stream-to-pull-stream')\nvar shs = require('./')\nvar isBuffer = Buffer.isBuffer\nvar pull = require('pull-stream')\nvar Defer = require('pull-defer/duplex')\n\nfunction assertOpts (opts) {\n  if(!(opts && 'object' === typeof opts))\n    throw new Error('opts *must* be provided')\n}\nfunction assertKeys (opts) {\n  if(!(\n      opts.keys\n    && isBuffer(opts.keys.publicKey)\n    && isBuffer(opts.keys.secretKey)\n  ))\n    throw new Error('opts.keys = ed25519 key pair *must* be provided.')\n}\nfunction assertAppKey (opts) {\n  if(!isBuffer(opts.appKey))\n    throw new Error('appKey must be provided')\n}\n\nfunction assertAddr (addr) {\n  if(!isBuffer(addr.key))\n    throw new Error('opts.key *must* be an ed25519 public key')\n  if(!Number.isInteger(+addr.port))\n    throw new Error('opts.port *must* be provided')\n  if(!('string' === typeof addr.host || null == addr.host))\n    throw new Error('opts.host must be string or null')\n}\n\nmodule.exports = function createNode (opts) {\n  var keys =\n    isBuffer(opts.seed)\n    ? sodium.crypto_sign_seed_keypair(opts.seed)\n    : opts.keys\n\n  assertOpts(opts); assertKeys({keys: keys}); assertAppKey(opts)\n\n  var create = shs.createClient(keys, opts.appKey, opts.timeout)\n\n  return {\n    publicKey: keys.publicKey,\n    createServer: function (onConnect) {\n      if('function' !== typeof opts.authenticate)\n        throw new Error('function opts.authenticate(pub, cb)'\n          + '*must* be provided in order to receive connections')\n      var createServerStream =\n        shs.createServer(keys, opts.authenticate, opts.appKey, opts.timeout)\n      var server\n      return server = net.createServer(function (stream) {\n        stream = toPull.duplex(stream)\n        pull(\n          stream,\n          createServerStream(function (err, stream) {\n            if(err) return server.emit('unauthenticated', err)\n            onConnect(stream)\n          }),\n          stream\n        )\n      })\n    },\n    connect: function (addr, cb) {\n      assertAddr(addr)\n      var stream = toPull.duplex(net.connect(addr.port, addr.host))\n\n      if(cb) {\n        pull(\n          stream,\n          create(addr.key, cb),\n          stream\n        )\n      }\n      else {\n\n        var defer = Defer()\n\n        pull(\n          stream,\n          create(addr.key, function (err, stream) {\n            if(err)\n              defer.resolve({\n                source: function (abort, cb) { cb(err) },\n                sink: function (read) { read(err, function (){}) }\n              })\n            else defer.resolve(stream)\n          }),\n          stream\n        )\n\n        return defer\n\n      }\n    }\n  }\n}\n","var sodium = require('chloride')\nvar hash = sodium.crypto_hash_sha256\nvar pull = require('pull-stream')\nvar boxes = require('pull-box-stream')\n\nvar concat = Buffer.concat\n\nmodule.exports = function (cb) {\n\n  return function (err, stream, state) {\n    if(err) return cb(err)\n\n    var en_key = hash(concat([state.secret, state.remote.public]))\n    var de_key = hash(concat([state.secret, state.local.public]))\n\n    var en_nonce = state.remote.app_mac.slice(0, 24)\n    var de_nonce = state.local.app_mac.slice(0, 24)\n\n    cb(null, {\n      remote: state.remote.public,\n      //on the server, attach any metadata gathered\n      //during `authorize` call\n      auth: state.auth,\n      source: pull(\n        stream.source,\n        boxes.createUnboxStream(de_key, de_nonce)\n      ),\n      sink: pull(\n        boxes.createBoxStream(en_key, en_nonce),\n        stream.sink\n      )\n    })\n  }\n\n}\n\n\n","\nvar sodium      = require('chloride')\n\nvar keypair     = sodium.crypto_box_keypair\nvar shared      = sodium.crypto_scalarmult\nvar hash        = sodium.crypto_hash_sha256\nvar sign        = sodium.crypto_sign_detached\nvar verify      = sodium.crypto_sign_verify_detached\nvar auth        = sodium.crypto_auth\nvar verify_auth = sodium.crypto_auth_verify\nvar curvify_pk  = sodium.crypto_sign_ed25519_pk_to_curve25519\nvar curvify_sk  = sodium.crypto_sign_ed25519_sk_to_curve25519\nvar box         = sodium.crypto_secretbox_easy\nvar unbox       = sodium.crypto_secretbox_open_easy\n\nvar concat = Buffer.concat\n\nvar nonce = new Buffer(24); nonce.fill(0)\n\nvar challenge_length = 64\nvar client_auth_length = 16+32+64\nvar server_auth_length = 16+64\nvar mac_length = 16\n\n//this is a simple secure handshake,\n//the client public key is passed in plain text,\n\nmodule.exports = State\n\nfunction State (app_key, local, remote) {\n  if(!(this instanceof State)) return new State(app_key, local, remote)\n  this.app_key = app_key\n  var kx = keypair()\n  this.local = {\n    kx_pk: kx.publicKey,\n    kx_sk: kx.secretKey,\n    public: local.publicKey,\n    secret: local.secretKey\n  }\n  this.remote = {\n    public: remote || null\n  }\n\n}\n\nvar proto = State.prototype\n\nproto.createChallenge =\nfunction createChallenge () {\n  var state = this\n\n  state.local.app_mac = auth(state.local.kx_pk, state.app_key)\n  return concat([state.local.app_mac, state.local.kx_pk])\n}\n\nproto.verifyChallenge =\nfunction verifyChallenge (challenge) {\n  var state = this\n\n  var mac = challenge.slice(0, 32)\n  var remote_pk = challenge.slice(32, challenge.length)\n  if(0 !== verify_auth(mac, remote_pk, state.app_key))\n    return null\n\n  state.remote.kx_pk = remote_pk\n  state.remote.app_mac = mac\n  state.secret = shared(state.local.kx_sk, state.remote.kx_pk)\n  state.shash = hash(state.secret)\n\n  return true\n}\n\n\nproto.createClientAuth =\nfunction createClientAuth () {\n  var state = this\n  //now we have agreed on the secret.\n  //this can be an encryption secret,\n  //or a hmac secret.\n\n  // shared(local.kx, remote.public)\n  var a_bob = shared(state.local.kx_sk, curvify_pk(state.remote.public))\n  state.a_bob = a_bob\n  state.secret2 = hash(concat([state.app_key, state.secret, a_bob]))\n\n  var signed = concat([state.app_key, state.remote.public, state.shash])\n  var sig = sign(signed, state.local.secret)\n\n  state.local.hello = Buffer.concat([sig, state.local.public])\n  return box(state.local.hello, nonce, state.secret2)\n}\n\nproto.verifyClientAuth =\nfunction verifyClientAuth (data) {\n  var state = this\n\n  var a_bob = shared(curvify_sk(state.local.secret), state.remote.kx_pk)\n  state.a_bob = a_bob\n  state.secret2 = hash(concat([state.app_key, state.secret, a_bob]))\n\n  state.remote.hello = unbox(data, nonce, state.secret2)\n  if(!state.remote.hello)\n    return null\n\n  var sig = state.remote.hello.slice(0, 64)\n  var public = state.remote.hello.slice(64, client_auth_length)\n\n  var signed = concat([state.app_key, state.local.public, state.shash])\n  if(!verify(sig, signed, public))\n    return null\n\n  state.remote.public = public\n\n  return true\n}\n\nproto.createServerAccept =\nfunction createServerAccept () {\n  var state = this\n\n  //shared key between my local ephemeral key + remote public\n  var b_alice = shared(state.local.kx_sk, curvify_pk(state.remote.public))\n  state.b_alice = b_alice\n  state.secret3 = hash(concat([state.app_key, state.secret, state.a_bob, state.b_alice]))\n\n  var signed = concat([state.app_key, state.remote.hello, state.shash])\n  var okay = sign(signed, state.local.secret)\n  return box(okay, nonce, state.secret3)\n}\n\nproto.verifyServerAccept =\nfunction verifyServerAccept (boxed_okay) {\n  var state = this\n\n  var b_alice = shared(curvify_sk(state.local.secret), state.remote.kx_pk)\n  state.b_alice = b_alice\n//  state.secret3 = hash(concat([state.secret2, b_alice]))\n  state.secret3 = hash(concat([state.app_key, state.secret, state.a_bob, state.b_alice]))\n\n  var sig = unbox(boxed_okay, nonce, state.secret3)\n  if(!sig) return null\n  var signed = concat([state.app_key, state.local.hello, state.shash])\n  if(!verify(sig, signed, state.remote.public))\n      return null\n  return true\n}\n\nproto.cleanSecrets =\nfunction cleanSecrets () {\n  var state = this\n\n  // clean away all the secrets for forward security.\n  // use a different secret hash(secret3) in the rest of the session,\n  // and so that a sloppy application cannot compromise the handshake.\n\n  delete state.local.secret\n  state.shash.fill(0)\n  state.secret.fill(0)\n  state.a_bob.fill(0)\n  state.b_alice.fill(0)\n  state.secret = hash(state.secret3)\n  state.secret2.fill(0)\n  state.secret3.fill(0)\n  state.local.kx_sk.fill(0)\n\n  delete state.shash\n  delete state.secret2\n  delete state.secret3\n  delete state.a_bob\n  delete state.b_alice\n  delete state.local.kx_sk\n\n  return state\n}\n\n","var EventEmitter = require('events')\nvar u            = require('./util')\nvar Hookable     = require('hoox')\n\nfunction isFunction (f) {\n  return 'function' === typeof f\n}\n\nfunction merge (a, b, mapper) {\n\n  for(var k in b) {\n    if(b[k] && 'object' === typeof b[k] && !Buffer.isBuffer(b[k]))\n      merge(a[k] = {}, b[k], mapper)\n    else\n      a[k] = mapper(b[k], k)\n  }\n\n  return a\n}\n\nmodule.exports = function (plugins) {\n\n  function create (opts) {\n    //change event emitter to something with more rigorous security?\n    var api = new EventEmitter()\n    create.plugins.forEach(function (plug) {\n      var _api = plug.init.call({createClient: create.createClient}, api, opts)\n      if(plug.name) {\n        var o = {}; o[plug.name] = _api; _api = o\n      }\n      api = merge(api, _api, function (v, k) {\n        if ('function' === typeof v) {\n          v = Hookable(v)\n          if (plug.manifest && plug.manifest[k] === 'sync') {\n            u.hookOptionalCB(v)\n          }\n        }\n        return v\n      })\n    })\n\n    return api\n  }\n\n  create.plugins = []\n  create.manifest = {}\n  create.permissions = {}\n\n  create.use = function (plug) {\n    if(isFunction(plug))\n      return create.plugins.push({init: plug}), create\n\n    if(!plug.init)\n      throw new Error('plugins *must* have \"init\" method')\n\n    var name = plug.name\n    if(plug.manifest)\n      create.manifest =\n        u.merge.manifest(create.manifest, plug.manifest, name)\n    if(plug.permissions)\n      create.permissions =\n        u.merge.permissions(create.permissions, plug.permissions, name)\n    create.plugins.push(plug)\n\n    return create\n  }\n\n  ;[].concat(plugins).filter(Boolean).forEach(create.use)\n\n  return create\n}\n","var u          = require('./util')\nvar Api        = require('./api')\nvar Muxrpc     = require('muxrpc')\nvar pull       = require('pull-stream')\nvar createNode = require('secret-handshake/net')\nvar nonPrivate = require('non-private-ip')\nvar Inactive   = require('pull-inactivity')\n\nfunction isFunction (f) { return 'function' === typeof f }\n\nfunction isString (s) { return 'string' === typeof s }\n\nfunction each(obj, iter) {\n  if(Array.isArray(obj)) return obj.forEach(iter)\n  for(var k in obj) iter(obj[k], k, obj)\n}\n\nfunction toBuffer(base64) {\n  if(Buffer.isBuffer(base64)) return base64\n  var i = base64.indexOf('.')\n  return new Buffer(~i ? base64.substring(0, i) : base64, 'base64')\n}\n\nfunction toSodiumKeys (keys) {\n  if(!(isString(keys.public) && isString(keys.private)))\n    return keys\n  return {\n    publicKey: toBuffer(keys.public),\n    secretKey: toBuffer(keys.private)\n  }\n}\n\nfunction coearseAddress (address) {\n  if(isString(address)) address = u.parseAddress(address)\n  if(isString(address.key))\n    return {\n      host: address.host, port: address.port,\n      key: new Buffer(\n        address.key\n          .substring(1, address.key.indexOf('.')),\n        'base64'\n      )\n    }\n  return address\n}\n\n//opts must have appKey\nmodule.exports = function (opts) {\n\n  var appKey = opts.appKey\n  var defaultTimeout = (\n    opts.defaultTimeout || 5e3 // 5 seconds.\n  )\n  var timeout_handshake\n\n  if(opts.timers && !isNaN(opts.timers.inactivity))\n    defaultTimeout = opts.timers.inactivity\n  if(opts.timers && !isNaN(opts.timers.handshake))\n    timeout_handshake = opts.timers.handshake\n  timeout_handshake = timeout_handshake || 5e3\n\n  opts.permissions = opts.permissions || {}\n\n  var create = Api(opts.permissions ? [{\n    permissions: opts.permissions,\n    init: function () {}\n  }]: null)\n\n  create.createClient = function (opts) {\n    if(opts.keys) opts.keys = toSodiumKeys(opts.keys)\n    if(opts.seed) opts.seed = toBuffer(opts.seed)\n//    opts.appKey = toBuffer(opts.appKey || appKey)\n\n    var snet = createNode({\n      keys: opts.keys && toSodiumKeys(opts.keys),\n      seed: opts.seed && toBuffer(opts.seed),\n      appKey: toBuffer(opts.appKey || appKey),\n      timeout: opts.timeout || (opts.timers && opts.timers.handshake) || 5e3\n    })\n\n    return function (address, cb) {\n      address = coearseAddress(address)\n\n      snet.connect(address, function (err, stream) {\n        if(err) return cb(err)\n        var rpc = Muxrpc(opts.manifest || create.manifest, {})({})\n        pull(stream, rpc.createStream(), stream)\n        cb(null, rpc)\n      })\n    }\n  }\n\n  return create.use({\n    manifest: {\n      auth: 'async',\n      address: 'sync',\n      manifest: 'sync',\n    },\n    init: function (api, opts, permissions, manifest) {\n      var snet = createNode({\n        keys: opts.keys && toSodiumKeys(opts.keys),\n        seed: opts.seed,\n        appKey: toBuffer(opts.appKey || appKey),\n\n        //****************************************\n        timeout: timeout_handshake,\n\n        authenticate: function (pub, cb) {\n          var id = '@'+u.toId(pub)\n          api.auth(id, function (err, auth) {\n            if(err) cb(err)\n            else    cb(null, auth || create.permissions.anonymous)\n          })\n        }\n      })\n\n      //use configured port, or a random user port.\n      var port = opts.port || 1024+(~~(Math.random()*(65536-1024)))\n      var host = opts.host || nonPrivate.v4 || nonPrivate.private.v4 || '127.0.0.1'\n\n      var peers = api.peers = {}\n\n      var server = snet.createServer(setupRPC)\n      server.listen(port)\n\n      function setupRPC (stream, manf, isClient) {\n        var rpc = Muxrpc(create.manifest, manf || create.manifest)(api, stream.auth)\n        var timeout = opts.timeout == null ? defaultTimeout : opts.timeout\n        var rpcStream = rpc.createStream()\n        if(timeout > 0) rpcStream = Inactive(rpcStream, opts.timeout)\n\n        pull(stream, rpcStream, stream)\n\n        var id = rpc.id = '@'+u.toId(stream.remote)\n\n        //keep track of current connections.\n        if(!peers[id]) peers[id] = []\n        peers[id].push(rpc)\n        rpc.once('closed', function () {\n          peers[id].splice(peers[id].indexOf(rpc), 1)\n        })\n\n        api.emit('rpc:connect', rpc, !!isClient)\n\n        return rpc\n      }\n\n      return {\n        //can be called remotely.\n        publicKey: snet.publicKey,\n        auth: function (pub, cb) { cb() },\n        address: function () {\n          return this.getAddress()\n        },\n        getAddress: function () {\n          return [host, port, '@'+u.toId(snet.publicKey)].join(':')\n        },\n        manifest: function () {\n          return create.manifest\n        },\n        getManifest: function () {\n          return this.manifest()\n        },\n        //cannot be called remote.\n        connect: function (address, cb) {\n          address = coearseAddress(address)\n          address.appKey = opts.appKey || appKey\n          snet.connect(address, function (err, stream) {\n            return err ? cb(err) : cb(null, setupRPC(stream, null, true))\n          })\n        },\n\n        close: function (err, cb) {\n          if(isFunction(err)) cb = err, err = null\n          api.closed = true\n          server.close(function (err) {\n            api.emit('close', err)\n            cb && cb(err)\n          })\n\n          if(err) {\n            each(peers, function (connections, id) {\n              each(connections, function (rpc) {\n                rpc.close(err)\n              })\n            })\n          }\n        }\n      }\n    }\n  })\n}\n\n\n\n","var os = require('os')\nvar ip = require('ip')\n//pick the first reasonable looking host.\n//this should *just work* when running on a vps.\n\nvar isPrivate = ip.isPrivate\n\nfunction isNonPrivate (e) {\n  return !isPrivate(e)\n}\n\n\nvar address = module.exports = function (inter, filter) {\n  inter = inter || os.networkInterfaces()\n  filter = filter || isNonPrivate\n  for(var k in inter) {\n    for(var i in inter[k]) {\n      var e = inter[k][i]\n      // find a reasonable looking address\n      if(!e.internal && filter(e.address, e))\n          return e.address\n    }\n  }\n}\n\nfunction isV4 (e) {\n  return e.family === 'IPv4'\n}\n\nfunction isV6 (e) {\n  return e.family === 'IPv6'\n}\n\nvar private = module.exports.private = function (inter) {\n  return address(inter, isPrivate)\n}\n\nmodule.exports.v4 = address(null, function (addr, e) {\n  return isV4(e) && isNonPrivate(addr)\n})\n\nmodule.exports.v6 = address(null, function (addr, e) {\n  return isV6(e) && isNonPrivate(addr)\n})\n\nprivate.v4 = address(null, function (addr, e) {\n  return isV4(e) && isPrivate(addr)\n})\n\nprivate.v6 = address(null, function (addr, e) {\n  return isV6(e) && isPrivate(addr)\n})\n\nmodule.exports.all = {\n  public: {\n    v4: module.exports.v4, v6: module.exports.v6\n  },\n  private: {\n    v4: private.v4, v6: private.v6\n  }\n}\n\n\nif(!module.parent) {\n  console.log(module.exports.all)\n}\n","var u      = require('pull-core')\nvar sources = require('./sources')\nvar sinks = require('./sinks')\n\nvar prop   = u.prop\nvar id     = u.id\nvar tester = u.tester\n\nvar map = exports.map =\nfunction (read, map) {\n  map = prop(map) || id\n  return function (abort, cb) {\n    read(abort, function (end, data) {\n      try {\n      data = !end ? map(data) : null\n      } catch (err) {\n        return read(err, function () {\n          return cb(err)\n        })\n      }\n      cb(end, data)\n    })\n  }\n}\n\nvar asyncMap = exports.asyncMap =\nfunction (read, map) {\n  if(!map) return read\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    read(null, function (end, data) {\n      if(end) return cb(end, data)\n      map(data, cb)\n    })\n  }\n}\n\nvar paraMap = exports.paraMap =\nfunction (read, map, width) {\n  if(!map) return read\n  var ended = false, queue = [], _cb\n\n  function drain () {\n    if(!_cb) return\n    var cb = _cb\n    _cb = null\n    if(queue.length)\n      return cb(null, queue.shift())\n    else if(ended && !n)\n      return cb(ended)\n    _cb = cb\n  }\n\n  function pull () {\n    read(null, function (end, data) {\n      if(end) {\n        ended = end\n        return drain()\n      }\n      n++\n      map(data, function (err, data) {\n        n--\n\n        queue.push(data)\n        drain()\n      })\n\n      if(n < width && !ended)\n        pull()\n    })\n  }\n\n  var n = 0\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    //continue to read while there are less than 3 maps in flight\n    _cb = cb\n    if(queue.length || ended)\n      pull(), drain()\n    else pull()\n  }\n  return highWaterMark(asyncMap(read, map), width)\n}\n\nvar filter = exports.filter =\nfunction (read, test) {\n  //regexp\n  test = tester(test)\n  return function next (end, cb) {\n    var sync, loop = true\n    while(loop) {\n      loop = false\n      sync = true\n      read(end, function (end, data) {\n        if(!end && !test(data))\n          return sync ? loop = true : next(end, cb)\n        cb(end, data)\n      })\n      sync = false\n    }\n  }\n}\n\nvar filterNot = exports.filterNot =\nfunction (read, test) {\n  test = tester(test)\n  return filter(read, function (e) {\n    return !test(e)\n  })\n}\n\nvar through = exports.through =\nfunction (read, op, onEnd) {\n  var a = false\n  function once (abort) {\n    if(a || !onEnd) return\n    a = true\n    onEnd(abort === true ? null : abort)\n  }\n\n  return function (end, cb) {\n    if(end) once(end)\n    return read(end, function (end, data) {\n      if(!end) op && op(data)\n      else once(end)\n      cb(end, data)\n    })\n  }\n}\n\nvar take = exports.take =\nfunction (read, test) {\n  var ended = false\n  if('number' === typeof test) {\n    var n = test; test = function () {\n      return n --\n    }\n  }\n\n  return function (end, cb) {\n    if(ended) return cb(ended)\n    if(ended = end) return read(ended, cb)\n\n    read(null, function (end, data) {\n      if(ended = ended || end) return cb(ended)\n      if(!test(data)) {\n        ended = true\n        read(true, function (end, data) {\n          cb(ended, data)\n        })\n      }\n      else\n        cb(null, data)\n    })\n  }\n}\n\nvar unique = exports.unique = function (read, field, invert) {\n  field = prop(field) || id\n  var seen = {}\n  return filter(read, function (data) {\n    var key = field(data)\n    if(seen[key]) return !!invert //false, by default\n    else seen[key] = true\n    return !invert //true by default\n  })\n}\n\nvar nonUnique = exports.nonUnique = function (read, field) {\n  return unique(read, field, true)\n}\n\nvar group = exports.group =\nfunction (read, size) {\n  var ended; size = size || 5\n  var queue = []\n\n  return function (end, cb) {\n    //this means that the upstream is sending an error.\n    if(end) return read(ended = end, cb)\n    //this means that we read an end before.\n    if(ended) return cb(ended)\n\n    read(null, function next(end, data) {\n      if(ended = ended || end) {\n        if(!queue.length)\n          return cb(ended)\n\n        var _queue = queue; queue = []\n        return cb(null, _queue)\n      }\n      queue.push(data)\n      if(queue.length < size)\n        return read(null, next)\n\n      var _queue = queue; queue = []\n      cb(null, _queue)\n    })\n  }\n}\n\nvar flatten = exports.flatten = function (read) {\n  var _read\n  return function (abort, cb) {\n    if(_read) nextChunk()\n    else      nextStream()\n\n    function nextChunk () {\n      _read(null, function (end, data) {\n        if(end) nextStream()\n        else    cb(null, data)\n      })\n    }\n    function nextStream () {\n      read(null, function (end, stream) {\n        if(end)\n          return cb(end)\n        if(Array.isArray(stream) || stream && 'object' === typeof stream)\n          stream = sources.values(stream)\n        else if('function' != typeof stream)\n          throw new Error('expected stream of streams')\n        _read = stream\n        nextChunk()\n      })\n    }\n  }\n}\n\nvar prepend =\nexports.prepend =\nfunction (read, head) {\n\n  return function (abort, cb) {\n    if(head !== null) {\n      if(abort)\n        return read(abort, cb)\n      var _head = head\n      head = null\n      cb(null, _head)\n    } else {\n      read(abort, cb)\n    }\n  }\n\n}\n\n//var drainIf = exports.drainIf = function (op, done) {\n//  sinks.drain(\n//}\n\nvar _reduce = exports._reduce = function (read, reduce, initial) {\n  return function (close, cb) {\n    if(close) return read(close, cb)\n    if(ended) return cb(ended)\n\n    sinks.drain(function (item) {\n      initial = reduce(initial, item)\n    }, function (err, data) {\n      ended = err || true\n      if(!err) cb(null, initial)\n      else     cb(ended)\n    })\n    (read)\n  }\n}\n\nvar nextTick = process.nextTick\n\nvar highWaterMark = exports.highWaterMark =\nfunction (read, highWaterMark) {\n  var buffer = [], waiting = [], ended, ending, reading = false\n  highWaterMark = highWaterMark || 10\n\n  function readAhead () {\n    while(waiting.length && (buffer.length || ended))\n      waiting.shift()(ended, ended ? null : buffer.shift())\n\n    if (!buffer.length && ending) ended = ending;\n  }\n\n  function next () {\n    if(ended || ending || reading || buffer.length >= highWaterMark)\n      return\n    reading = true\n    return read(ended || ending, function (end, data) {\n      reading = false\n      ending = ending || end\n      if(data != null) buffer.push(data)\n\n      next(); readAhead()\n    })\n  }\n\n  process.nextTick(next)\n\n  return function (end, cb) {\n    ended = ended || end\n    waiting.push(cb)\n\n    next(); readAhead()\n  }\n}\n\nvar flatMap = exports.flatMap =\nfunction (read, mapper) {\n  mapper = mapper || id\n  var queue = [], ended\n\n  return function (abort, cb) {\n    if(queue.length) return cb(null, queue.shift())\n    else if(ended)   return cb(ended)\n\n    read(abort, function next (end, data) {\n      if(end) ended = end\n      else {\n        var add = mapper(data)\n        while(add && add.length)\n          queue.push(add.shift())\n      }\n\n      if(queue.length) cb(null, queue.shift())\n      else if(ended)   cb(ended)\n      else             read(null, next)\n    })\n  }\n}\n\n","var isArray = Array.isArray\nvar merge   = require('map-merge')\n\nfunction isObject (o) {\n  return o && 'object' === typeof o\n}\n\nfunction isString (s) {\n  return 'string' === typeof s\n}\n\nvar clone = exports.clone = function clone (obj, mapper) {\n  function map(v, k) {\n    return isObject(v) ? clone(v, mapper) : mapper(v, k)\n  }\n  if(isArray(obj))\n    return obj.map(map)\n  else if(isObject(obj)) {\n    var o = {}\n    for(var k in obj)\n      o[k] = map(obj[k], k)\n    return o\n  }\n  else\n    return map(obj)\n}\n\nexports.parseAddress = function (e) {\n  if(isString(e)) {\n    var parts = e.split(':')\n    var e = {\n      host: parts[0],\n      port: +parts[1],\n      key: fromId(parts[2])\n    }\n    return e\n  }\n  return e\n}\n\nvar fromId = exports.fromId = function (id) {\n  return new Buffer(id.substring(0, id.indexOf('.')), 'base64')\n}\n\nexports.toId = function (pub) {\n  return Buffer.isBuffer(pub) ? pub.toString('base64')+'.ed25519' : pub\n}\n\nexports.merge = {\n  permissions: function (perms, _perms, name) {\n    return merge(perms,\n      clone(_perms, function (v) {\n        return name ? name + '.' + v : v\n      })\n    )\n\n  },\n  manifest: function (manf, _manf, name) {\n    if(name) {\n      var o = {}; o[name] = _manf; _manf = o\n    }\n    return merge(manf, _manf)\n  }\n}\n\nexports.hookOptionalCB = function (syncFn) {\n  // syncFn is a function that's expected to return its result or throw an error\n  // we're going to hook it so you can optionally pass a callback\n  syncFn.hook(function(fn, args) {\n    // if a function is given as the last argument, treat it as a callback\n    var cb = args[args.length - 1]\n    if (typeof cb == 'function') {\n      var res\n      args.pop() // remove cb from the arguments\n      try { res = fn.apply(this, args) }\n      catch (e) { return cb(e) }\n      cb(null, res)\n    } else {\n      // no cb provided, regular usage\n      return fn.apply(this, args)\n    }\n  })\n}\n","module.exports = {\n  decode: function (string) {\n    return JSON.parse(string)\n  },\n  encode: function (obj) {\n    return JSON.stringify(obj, null, 2)\n  },\n  buffer: false\n}\n\n","\nvar level = require('level')\nvar sublevel = require('level-sublevel/bytewise')\nvar opts = require('./defaults')\nvar SSB = require('./')\n\nmodule.exports = function (path, opts, keys) {\n  opts = opts || require('./defaults')\n  return SSB(\n    sublevel(level(path, {\n      valueEncoding: opts.codec\n    })), opts, keys)\n}\n","\nmodule.exports = require('ssb-keys')\nmodule.exports.codec = require('./codec')\nmodule.exports.keys = module.exports\n\n","'use strict';\n\nvar contpara  = require('cont').para\nvar pull      = require('pull-stream')\nvar pl        = require('pull-level')\nvar paramap   = require('pull-paramap')\nvar timestamp = require('monotonic-timestamp')\nvar assert    = require('assert')\nvar ltgt      = require('ltgt')\nvar mlib      = require('ssb-msgs')\nvar explain   = require('explain-error')\nvar pdotjson  = require('./package.json')\nvar createFeed = require('ssb-feed')\nvar cat       = require('pull-cat')\nvar ssbref    = require('ssb-ref')\nvar ssbKeys   = require('ssb-keys')\n\nvar Validator = require('ssb-feed/validator')\n\nvar isFeedId = ssbref.isFeedId\nvar isMsgId  = ssbref.isMsgId\nvar isBlobId = ssbref.isBlobId\n\n//var u         = require('./util')\n\n//53 bit integer\nvar MAX_INT  = 0x1fffffffffffff\n\nfunction isNumber (n) {\n  return typeof n === 'number'\n}\n\nfunction isString (s) {\n  return 'string' === typeof s\n}\n\nfunction isObject (o) {\n  return o && 'object' === typeof o && !Array.isArray(o)\n}\n\nfunction all (stream) {\n  return function (cb) {\n    pull(stream, pull.collect(cb))\n  }\n}\n\nfunction compare(a, b) {\n  return a < b ? -1 : a > b ? 1 : 0\n}\n\nfunction getVMajor () {\n  var version = require('./package.json').version\n  return (version.split('.')[0])|0\n}\n\nmodule.exports = function (db, opts, keys) {\n  var sysDB   = db.sublevel('sys')\n  var logDB   = db.sublevel('log')\n  var feedDB  = db.sublevel('fd')\n  var clockDB = db.sublevel('clk')\n  var lastDB  = db.sublevel('lst')\n  var indexDB = db.sublevel('idx')\n  var appsDB  = db.sublevel('app')\n\n  function get (db, key) {\n    return function (cb) { db.get(key, cb) }\n  }\n\n  db.opts = opts\n\n  db.add = Validator(db)\n\n  db.pre(function (op, add, _batch) {\n    var msg = op.value\n    var id = op.key\n    // index by sequence number\n\n    add({\n      key: [msg.author, msg.sequence], value: id,\n      type: 'put', prefix: clockDB\n    })\n\n    // index my timestamp, used to generate feed.\n    add({\n      key: [msg.timestamp, msg.author], value: id,\n      type: 'put', prefix: feedDB\n    })\n\n    var localtime = op.timestamp = timestamp()\n\n    // index the latest message from each author\n    add({\n      key: msg.author, value: {sequence: msg.sequence, ts: localtime },\n      type: 'put', prefix: lastDB\n    })\n\n    // index messages in the order _received_\n    // this will be used to pass to plugins which\n    // must create their indexes asyncly.\n\n    add({\n      key: localtime, value: id,\n      type: 'put', prefix: logDB\n    })\n\n    indexMsg(add, localtime, id, msg)\n\n  })\n\n  function indexMsg (add, localtime, id, msg) {\n    //DECRYPT the message, if possible\n    //to enable indexing. If external apis\n    //are not provided that may access indexes\n    //then this will not leak information.\n    //otherwise, we may need to figure something out.\n\n    var content = (keys && isString(msg.content))\n      ? ssbKeys.unbox(msg.content, keys)\n      : msg.content\n\n    if(!content) return\n\n    if(isString(content.type))\n      add({\n        key: ['type', content.type.toString().substring(0, 32), localtime],\n        value: id, type: 'put', prefix: indexDB\n      })\n\n    mlib.indexLinks(content, function (obj, rel) {\n      add({\n        key: ['link', msg.author, rel, obj.link, msg.sequence, id],\n        value: obj,\n        type: 'put', prefix: indexDB\n      })\n      add({\n        key: ['_link', obj.link, rel, msg.author, msg.sequence, id],\n        value: obj,\n        type: 'put', prefix: indexDB\n      })\n    })\n  }\n\n  db.createFeed = function (keys) {\n    return createFeed(db, keys, opts)\n  }\n\n  db.needsRebuild = function (cb) {\n    sysDB.get('vmajor', function (err, dbvmajor) {\n      dbvmajor = (dbvmajor|0) || 0\n      cb(null, dbvmajor < getVMajor())\n    })\n  }\n\n  db.rebuildIndex = function (cb) {\n    // remove all entries from the index\n    pull(\n      pl.read(indexDB, { keys: true, values: false }),\n      paramap(function (key, cb) { indexDB.del(key, cb) }),\n      pull.drain(null, next)\n    )\n\n    function next (err) {\n      if (err)\n        return cb(err)\n\n      // replay the log\n      pull(\n        db.createLogStream({ keys: true, values: true }),\n        pull.map(function (msg) {\n          var ops = []\n          function add (item) { ops.push(item) }\n          indexMsg(add, msg.timestamp, msg.key, msg.value)\n          return ops\n        }),\n        pull.flatten(),\n        pl.write(indexDB, next2)\n      )\n      function next2 (err) {\n        if (err)\n          return cb(err)\n\n        sysDB.put('vmajor', getVMajor(), cb)\n      }\n    }\n  }\n\n  // opts standardized to work like levelup api\n  function stdopts (opts) {\n    opts = opts || {}\n    if (opts.keys !== false)\n      opts.keys = true\n    if (opts.values !== false)\n      opts.values = true\n    return opts\n  }\n  function msgFmt (keys, values, obj) {\n    if (keys && values)\n      return obj\n    if (keys)\n      return obj.key\n    if (values)\n      return obj.value\n    return null // i guess?\n  }\n\n  //TODO: eventually, this should filter out authors you do not follow.\n  db.createFeedStream = function (opts) {\n    opts = stdopts(opts)\n    ltgt.toLtgt(opts, opts, function (value) {\n      return [value, LO]\n    }, LO, HI)\n    var _keys = opts.keys\n    var _values = opts.values\n    opts.keys = false\n    opts.values = true\n\n    return pull(\n      pl.read(feedDB, opts),\n      lookup(_keys, _values)\n    )\n  }\n\n  //latest was stored as author: seq\n  //but for the purposes of replication back pressure\n  //we need to know when we last replicated with someone.\n  //instead store as: {sequence: seq, ts: localtime}\n  //then, peers can request a max number of posts per feed.\n\n  function toSeq (latest) {\n    return isNumber(latest) ? latest : latest.sequence\n  }\n\n  db.latest = function (opts) {\n    return pull(\n      pl.read(lastDB, opts),\n      pull.map(function (data) {\n        var d = {id: data.key, sequence: toSeq(data.value), ts: data.value.ts }\n        return d\n      })\n    )\n  }\n\n  function lookup(keys, values) {\n    return paramap(function (key, cb) {\n      if(key.sync) return cb(null, key)\n      if(!values) return cb(null, key)\n      db.get(key, function (err, msg) {\n        if (err) cb(err)\n        else cb(null, msgFmt(keys, values, { key: key, value: msg }))\n      })\n    })\n  }\n\n  db.createHistoryStream = function (id, seq, live) {\n    var _keys = true, _values = true, limit\n    if(!isFeedId(id)) {\n      var opts = stdopts(id)\n      id       = opts.id\n      seq      = opts.sequence || opts.seq || 0\n      live     = !!opts.live\n      limit    = opts.limit\n      _keys    = opts.keys !== false\n      _values  = opts.values !== false\n    }\n    return pull(\n      pl.read(clockDB, {\n        gte:  [id, seq],\n        lte:  [id, MAX_INT],\n        live: live,\n        keys: false,\n        sync: opts && opts.sync,\n        limit: limit,\n        onAbort: opts && opts.onAbort\n      }),\n      lookup(_keys, _values)\n    )\n  }\n\n\n  db.createUserStream = function (opts) {\n    opts = stdopts(opts)\n    ltgt.toLtgt(opts, opts, function (value) {\n      return [opts.id, value]\n    }, LO, HI)\n    var _keys = opts.keys\n    var _values = opts.values\n\n    opts.keys = false\n    opts.values = true\n    return pull(\n      pl.read(clockDB, opts),\n      lookup(_keys, _values)\n    )\n  }\n\n\n  //writeStream - used in replication.\n  db.createWriteStream = function (cb) {\n    return pull(\n      paramap(function (data, cb) {\n        db.add(data, function (err, msg) {\n          db.emit('invalid', err, msg)\n          cb()\n        })\n      }),\n      pull.drain(null, cb)\n    )\n  }\n\n  db.createFeed = function (keys) {\n    if(!keys)\n      keys = opts.keys.generate()\n    return createFeed(db, keys, opts)\n  }\n\n  db.latestSequence = function (id, cb) {\n    lastDB.get(id, cb)\n  }\n\n  db.getLatest = function (id, cb) {\n    lastDB.get(id, function (err, v) {\n      if(err) return cb(err)\n      clockDB.get([id, toSeq(v)], function (err, hash) {\n        if(err) return cb(err)\n        db.get(hash, function (err, msg) {\n          cb(err, {key: hash, value: msg})\n        })\n      })\n    })\n  }\n\n  db.createLogStream = function (opts) {\n    opts = stdopts(opts)\n    var live = opts.live || opts.tail; delete opts.live\n    var keys = opts.keys; delete opts.keys\n    var values = opts.values; delete opts.values\n\n    var old = pull(\n      pl.read(logDB, opts),\n      paramap(function (data, cb) {\n        if(data.sync) return cb(null, data)\n        var key = data.value\n        var seq = data.key\n        db.get(key, function (err, value) {\n          if (err) cb(err)\n          else cb(null, msgFmt(keys, values, {key: key, value: value, timestamp: seq}))\n        })\n      })\n    )\n    if(!live) return old\n\n    return cat([old, pull.values([{sync: true}]), pl.live(db)])\n\n  }\n\n  var HI = undefined, LO = null\n\n  db.messagesByType = function (opts) {\n    if(!opts)\n      throw new Error('must provide {type: string} to messagesByType')\n\n    if(isString(opts))\n      opts = {type: opts}\n\n    opts = stdopts(opts)\n    var _keys   = opts.keys\n    var _values = opts.values\n    opts.values = true\n\n    ltgt.toLtgt(opts, opts, function (value) {\n      return ['type', opts.type, value]\n    }, LO, HI)\n\n    return pull(\n      pl.read(indexDB, opts),\n      paramap(function (data, cb) {\n        var id = _keys ? data.value : data\n        db.get(id, function (err, msg) {\n          var ts = opts.keys ? data.key[2] : undefined\n          cb(null, msgFmt(_keys, _values, {key: id, ts: ts, value: msg}))\n        })\n      }),\n      pull.filter()\n    )\n  }\n\n  function format(opts, op, key, value) {\n    var meta = opts.meta !== false  //default: true\n    var keys = opts.keys !== false  //default: true\n    var vals = opts.values === true //default: false\n    if(!meta&&!keys&&!vals)\n      throw new Error('a stream without any values does not make sense')\n    if(!meta) return (\n          keys && vals  ? {key: op.key, value: value}\n        : keys          ? op.key\n                        : value\n      )\n    else {\n      if(vals)  op.value = value\n      if(!keys) delete op.key\n      return op\n    }\n  }\n\n  function type(t) { return {feed: '@', msg: '%', blob: '&'}[t] || t }\n\n  db.links = function (opts) {\n    if(!opts) throw new Error('opts *must* be provided')\n    opts.meta = opts.meta !== false //default: true\n    opts.keys = opts.keys !== false //default: true\n    if(!opts.values&&!opts.meta&&!opts.keys)\n      throw new Error('makes no sense to return stream without results'\n        + 'set at least one of {keys, values, meta} to true')\n\n    function tolink (v) {\n      return (ssbref.isLink(v)) ? v : null\n    }\n\n    var src = type(opts.source), dst = type(opts.dest), rel = opts.rel\n\n    var back = dst && !src\n    var from = back ? dst : src, to = back ? src : dst\n\n    function range(value, end, def) {\n      return !value ? def : /^[@%&]$/.test(value) ? value + end : value\n    }\n    function lo(value) { return range(value, \"!\", LO) }\n    function hi(value) { return range(value, \"~\", HI) }\n\n\n    var index = back ? '_link' : 'link'\n    var gte = [index, lo(from), rel || LO, lo(to), LO, LO]\n    var lte = [index, hi(from), rel || HI, hi(to), HI, HI]\n\n    function testLink (a, e) { //actual, expected\n      return e ? e.length === 1 ? a[0]==e[0] : a===e : true\n    }\n\n    return pull(\n      pl.read(indexDB, { gte: gte, lte: lte, live: opts.live, reverse: opts.reverse }),\n      pull.map(function (op) {\n        return {\n          source: op.key[back?3:1],\n          rel: op.key[2],\n          dest: op.key[back?1:3],\n          key: op.key[5]\n        }\n      }),\n      // in case source and dest are known but not rel,\n      // this will scan all links from the source\n      // and filter out those to the dest. not efficient\n      // but probably a rare query.\n      pull.filter(function (data) {\n        if(rel && rel !== data.rel) return false\n        if(!testLink(data.dest, dst)) return false\n        if(!testLink(data.source, src)) return false\n        return true\n      }),\n      ! opts.values\n      ? pull.map(function (op) {\n          return format(opts, op, op.key, null)\n        })\n      : paramap(function (op, cb) {\n          db.get(op.key, function (err, msg) {\n            if(err) return cb(err)\n            cb(null, format(opts, op, op.key, msg))\n          })\n      })\n    )\n  }\n\n  //get all messages that link to a given message.\n  db.relatedMessages = function (opts, cb) {\n    if(isString(opts)) opts = {key: opts}\n    if(!opts) throw new Error('opts *must* be object')\n    var key = opts.id || opts.key\n\n    var n = 1\n    var msgs = {key: key, value: null}\n    db.get(key, function (err, msg) {\n      msgs.value = msg\n      if (err && err.notFound)\n        err = null // ignore not found\n      done(err)\n    })\n\n    related(msgs)\n\n    function related (msg) {\n      if (n<0) return\n      n++\n      all(db.links({dest: msg.key, rel: opts.rel, keys: true, values:true, meta: false, type:'msg'}))\n      (function (err, ary) {\n        if(ary && ary.length) {\n          ary.sort(function (a, b) {\n            return compare(a.value.timestamp, b.value.timestamp) || compare(a.key, b.key)\n          })\n          msg.related = ary\n          ary.forEach(related)\n        }\n        done(err)\n      })\n    }\n\n    function count (msg) {\n      if(!msg.related)\n        return msg\n      var c = 0\n      msg.related.forEach(function (_msg) {\n        if(opts.parent) _msg.parent = msg.key\n        c += 1 + (count(_msg).count || 0)\n      })\n      if(opts.count) msg.count = c\n      return msg\n    }\n\n    function done (err) {\n      if(err && n > 0) {\n        n = -1\n        return cb(err)\n      }\n      if(--n) return\n      cb(null, count(msgs))\n    }\n  }\n\n  return db\n}\n\n\n\n\n","// require typewise first to extend with core typewise functionality\nrequire('typewise')\n\n// TODO: bytewise-binary encoding -- no hex parsing or toString hackery\nmodule.exports = require('bytewise-core')\n","// TODO: standard bytewise encoding constructor\n// TODO: enhance binary encoding with optional hex helpers\nmodule.exports = require('./binary')","// TODO: initialize and export a standard bytewise encoding, add hex and binary\nmodule.exports = require('./encoding/')\n","var nut     = require('./nut')\nvar shell   = require('./shell') //the shell surrounds the nut\nvar codec   = require('levelup/lib/codec')\nvar merge   = require('xtend')\nvar compare = require('typewiselite')\nvar ReadStream = require('levelup/lib/read-stream')\n\nvar precodec = require('./codec/bytewise')\n\nfunction id (e) {\n  return e\n}\n\nmodule.exports = function (db, opts) {\n\n  opts = merge(db.options, {\n    keyEncoding: {\n      encode: id,\n      decode: id,\n      buffer: true\n    }\n  }, opts)\n\n  return shell (\n    nut ( db, precodec, codec, compare ),\n    [], ReadStream, opts\n  )\n}\n\n\n","var bytewise = require('bytewise')\n\nmodule.exports = {\n  encode: bytewise.encode,\n  decode: bytewise.decode,\n  lowerBound: null,\n  upperBound: undefined,\n  buffer: true\n}\n","\nvar inRange = require('./range')\n\nmodule.exports = function (compare) {\n  var hooks = []\n\n  return {\n    add: function (range, hook) {\n      var m = {range: range, hook: hook}\n      hooks.push(m)\n      //call this to remove\n      return function () {\n        var i = hooks.indexOf(m)\n        if(~i) return hooks.splice(i, 1)\n      }\n\n    },\n\n    //remove all listeners within a range.\n    //this will be used to close a sublevel.\n    removeAll: function (range) {\n      throw new Error('not implemented')\n    },\n\n    trigger: function (key, args) {\n      for(var i = 0; i < hooks.length; i++) {\n        var test = hooks[i]\n        if(inRange(test.range, key, compare))\n          test.hook.apply(this, args)\n      }\n    }\n  }\n}\n","\nexports.compare = function (a, b) {\n\n  if(Buffer.isBuffer(a)) {\n    var l = Math.min(a.length, b.length)\n    for(var i = 0; i < l; i++) {\n      var cmp = a[i] - b[i]\n      if(cmp) return cmp\n    }\n    return a.length - b.length\n  }\n\n  return a < b ? -1 : a > b ? 1 : 0\n}\n\nfunction has(obj, key) {\n  return Object.hasOwnProperty.call(obj, key)\n}\n\n// to be compatible with the current abstract-leveldown tests\n// nullish or empty strings.\n// I could use !!val but I want to permit numbers and booleans,\n// if possible.\n\nfunction isDef (val) {\n  return val !== undefined && val !== ''\n}\n\nfunction has (range, name) {\n  return Object.hasOwnProperty.call(range, name)\n}\n\nfunction hasKey(range, name) {\n  return Object.hasOwnProperty.call(range, name) && name\n}\n\nvar lowerBoundKey = exports.lowerBoundKey = function (range) {\n    return (\n       hasKey(range, 'gt')\n    || hasKey(range, 'gte')\n    || hasKey(range, 'min')\n    || (range.reverse ? hasKey(range, 'end') : hasKey(range, 'start'))\n    || undefined\n    )\n}\n\nvar lowerBound = exports.lowerBound = function (range) {\n  var k = lowerBoundKey(range)\n  return k && range[k]\n}\n\nexports.lowerBoundInclusive = function (range) {\n  return has(range, 'gt') ? false : true\n}\n\nexports.upperBoundInclusive =\n  function (range) {\n    return has(range, 'lt') || !range.minEx ? false : true\n  }\n\nvar lowerBoundExclusive = exports.lowerBoundExclusive =\n  function (range) {\n    return has(range, 'gt') || range.minEx ? true : false\n  }\n\nvar upperBoundExclusive = exports.upperBoundExclusive =\n  function (range) {\n    return has(range, 'lt') ? true : false\n  }\n\nvar upperBoundKey = exports.upperBoundKey = function (range) {\n    return (\n       hasKey(range, 'lt')\n    || hasKey(range, 'lte')\n    || hasKey(range, 'max')\n    || (range.reverse ? hasKey(range, 'start') : hasKey(range, 'end'))\n    || undefined\n    )\n}\n\nvar upperBound = exports.upperBound = function (range) {\n  var k = upperBoundKey(range)\n  return k && range[k]\n}\n\nfunction id (e) { return e }\n\nexports.toLtgt = function (range, _range, map, lower, upper) {\n  _range = _range || {}\n  map = map || id\n  var defaults = arguments.length > 3\n  var lb = exports.lowerBoundKey(range)\n  var ub = exports.upperBoundKey(range)\n  if(lb) {\n    if(lb === 'gt') _range.gt = map(range.gt, false)\n    else            _range.gte = map(range[lb], false)\n  }\n  else if(defaults)\n    _range.gte = map(lower, false)\n\n  if(ub) {\n    if(ub === 'lt') _range.lt = map(range.lt, true)\n    else            _range.lte = map(range[ub], true)\n  }\n  else if(defaults)\n    _range.lte = map(upper, true)\n\n  if(range.reverse != null)\n    _range.reverse = !!range.reverse\n\n  //if range was used mutably\n  //(in level-sublevel it's part of an options object\n  //that has more properties on it.)\n  if(has(_range, 'max'))   delete _range.max\n  if(has(_range, 'min'))   delete _range.min\n  if(has(_range, 'start')) delete _range.start\n  if(has(_range, 'end'))   delete _range.end\n\n  return _range\n}\n\nexports.contains = function (range, key, compare) {\n  compare = compare || exports.compare\n\n  var lb = lowerBound(range)\n  if(isDef(lb)) {\n    var cmp = compare(key, lb)\n    if(cmp < 0 || (cmp === 0 && lowerBoundExclusive(range)))\n      return false\n  }\n\n  var ub = upperBound(range)\n  if(isDef(ub)) {\n    var cmp = compare(key, ub)\n    if(cmp > 0 || (cmp === 0) && upperBoundExclusive(range))\n      return false\n  }\n\n  return true\n}\n\nexports.filter = function (range, compare) {\n  return function (key) {\n    return exports.contains(range, key, compare)\n  }\n}\n","var hooks = require('./hooks')\nvar ltgt = require('ltgt')\n\nfunction isFunction (f) {\n  return 'function' === typeof f\n}\n\nfunction getPrefix (db) {\n  if(db == null) return db\n  if(isFunction(db.prefix)) return db.prefix()\n  return db\n}\n\nfunction has(obj, name) {\n  return Object.hasOwnProperty.call(obj, name)\n}\n\nfunction clone (_obj) {\n  var obj = {}\n  for(var k in _obj)\n    obj[k] = _obj[k]\n  return obj\n}\n\nmodule.exports = function (db, precodec, codec, compare) {\n  var prehooks = hooks(compare)\n  var posthooks = hooks(compare)\n  var waiting = [], ready = false\n\n  function encodePrefix(prefix, key, opts1, opts2) {\n    return precodec.encode([ prefix, codec.encodeKey(key, opts1, opts2 ) ])\n  }\n\n  function decodePrefix(data) {\n    return precodec.decode(data)\n  }\n\n  function addEncodings(op, prefix) {\n    if(prefix && prefix.options) {\n      op.keyEncoding =\n        op.keyEncoding || prefix.options.keyEncoding\n      op.valueEncoding =\n        op.valueEncoding || prefix.options.valueEncoding\n    }\n    return op\n  }\n\n  function start () {\n    ready = true\n    while(waiting.length)\n      waiting.shift()()\n  }\n\n  if(isFunction(db.isOpen)) {\n    if(db.isOpen())\n      ready = true\n    else\n      db.open(start)\n  } else {\n    db.open(start)\n  }\n\n  return {\n    apply: function (ops, opts, cb) {\n      //apply prehooks here.\n      for(var i = 0; i < ops.length; i++) {\n        var op = ops[i]\n\n        function add(op) {\n          if(op === false) return delete ops[i]\n          ops.push(op)\n        }\n\n        addEncodings(op, op.prefix)\n        op.prefix = getPrefix(op.prefix)\n        prehooks.trigger([op.prefix, op.key], [op, add, ops])\n      }\n\n      opts = opts || {}\n\n      if('object' !== typeof opts) throw new Error('opts must be object, was:'+ opts) \n\n      if('function' === typeof opts) cb = opts, opts = {}\n\n      if(ops.length)\n        (db.db || db).batch(\n          ops.map(function (op) {\n            return {\n              key: encodePrefix(op.prefix, op.key, opts, op),\n              value:\n                  op.type !== 'del'\n                ? codec.encodeValue(\n                    op.value,\n                    opts,\n                    op\n                  )\n                : undefined,\n              type:\n                op.type || (op.value === undefined ? 'del' : 'put')\n            }\n          }),\n          opts,\n          function (err) {\n              if(err) return cb(err)\n            ops.forEach(function (op) {\n              posthooks.trigger([op.prefix, op.key], [op])\n            })\n            cb()\n          }\n        )\n      else\n        cb()\n    },\n    get: function (key, prefix, opts, cb) {\n      opts.asBuffer = codec.isValueAsBuffer(opts)\n      return (db.db || db).get(\n        encodePrefix(prefix, key, opts),\n        opts,\n        function (err, value) {\n          if(err) cb(err)\n          else    cb(null, codec.decodeValue(value, opts))\n        }\n      )\n    },\n    pre: prehooks.add,\n    post: posthooks.add,\n    createDecoder: function (opts) {\n      if(opts.keys !== false && opts.values !== false)\n        return function (key, value) {\n          return {\n            key: codec.decodeKey(precodec.decode(key)[1], opts),\n            value: codec.decodeValue(value, opts)\n          }\n        }\n      if(opts.values !== false)\n        return function (_, value) {\n          return codec.decodeValue(value, opts)\n        }\n      if(opts.keys !== false)\n        return function (key) {\n          return codec.decodeKey(precodec.decode(key)[1], opts)\n        }\n      return function () {}\n    },\n    isOpen: function isOpen() {\n      if (db.db && isFunction(db.db.isOpen))\n        return db.db.isOpen()\n\n      return db.isOpen()\n    },\n    isClosed: function isClosed() {\n      if (db.db && isFunction(db.db.isClosed))\n        return db.db.isClosed()\n\n      return db.isClosed()\n    },\n    close: function close (cb) {\n      return db.close(cb)\n    },\n    iterator: function (_opts, cb) {\n      var opts = clone(_opts || {})\n      var prefix = _opts.prefix || []\n\n      function encodeKey(key) {\n        return encodePrefix(prefix, key, opts, {})\n      }\n\n      ltgt.toLtgt(_opts, opts, encodeKey, precodec.lowerBound, precodec.upperBound)\n\n      // if these legacy values are in the options, remove them\n\n      opts.prefix = null\n\n      //************************************************\n      //hard coded defaults, for now...\n      //TODO: pull defaults and encoding out of levelup.\n      opts.keyAsBuffer = opts.valueAsBuffer = false\n      //************************************************\n\n\n      //this is vital, otherwise limit: undefined will\n      //create an empty stream.\n      if ('number' !== typeof opts.limit)\n        opts.limit = -1\n\n      opts.keyAsBuffer = precodec.buffer\n      opts.valueAsBuffer = codec.isValueAsBuffer(opts)\n\n      function wrapIterator (iterator) {\n        return {\n          next: function (cb) {\n            return iterator.next(cb)\n          },\n          end: function (cb) {\n            iterator.end(cb)\n          }\n        }\n      }\n\n      if(ready)\n        return wrapIterator((db.db || db).iterator(opts))\n      else\n        waiting.push(function () {\n          cb(null, wrapIterator((db.db || db).iterator(opts)))\n        })\n\n    }\n  }\n\n}\n","module.exports={\n  \"_args\": [\n    [\n      \"level-sublevel@^6.5.2\",\n      \"/Users/joran/Documents/development/patchdeck/node_modules/secure-scuttlebutt\"\n    ]\n  ],\n  \"_from\": \"level-sublevel@>=6.5.2 <7.0.0\",\n  \"_id\": \"level-sublevel@6.5.4\",\n  \"_inCache\": true,\n  \"_installable\": true,\n  \"_location\": \"/secure-scuttlebutt/level-sublevel\",\n  \"_nodeVersion\": \"5.3.0\",\n  \"_npmUser\": {\n    \"email\": \"dominic.tarr@gmail.com\",\n    \"name\": \"dominictarr\"\n  },\n  \"_npmVersion\": \"3.3.12\",\n  \"_phantomChildren\": {\n    \"pull-core\": \"1.0.0\"\n  },\n  \"_requested\": {\n    \"name\": \"level-sublevel\",\n    \"raw\": \"level-sublevel@^6.5.2\",\n    \"rawSpec\": \"^6.5.2\",\n    \"scope\": null,\n    \"spec\": \">=6.5.2 <7.0.0\",\n    \"type\": \"range\"\n  },\n  \"_requiredBy\": [\n    \"/secure-scuttlebutt\"\n  ],\n  \"_resolved\": \"https://registry.npmjs.org/level-sublevel/-/level-sublevel-6.5.4.tgz\",\n  \"_shasum\": \"92e6534e7ac3fa35c8bdb121b8a8094a8d1c0826\",\n  \"_shrinkwrap\": null,\n  \"_spec\": \"level-sublevel@^6.5.2\",\n  \"_where\": \"/Users/joran/Documents/development/patchdeck/node_modules/secure-scuttlebutt\",\n  \"author\": {\n    \"email\": \"dominic.tarr@gmail.com\",\n    \"name\": \"Dominic Tarr\",\n    \"url\": \"http://dominictarr.com\"\n  },\n  \"bugs\": {\n    \"url\": \"https://github.com/dominictarr/level-sublevel/issues\"\n  },\n  \"dependencies\": {\n    \"bytewise\": \"~1.1.0\",\n    \"levelup\": \"~0.19.0\",\n    \"ltgt\": \"~2.1.1\",\n    \"pull-stream\": \"~2.21.0\",\n    \"typewiselite\": \"~1.0.0\",\n    \"xtend\": \"~4.0.0\"\n  },\n  \"description\": \"partition levelup databases\",\n  \"devDependencies\": {\n    \"level\": \"^1.4.0\",\n    \"level-test\": \"^2.0.1\",\n    \"monotonic-timestamp\": \"0.0.8\",\n    \"pull-level\": \"~1.1.1\",\n    \"rimraf\": \"~2.1.4\",\n    \"shasum\": \"0.0.2\",\n    \"stream-to-pull-stream\": \"~1.2.0\",\n    \"tape\": \"~2.14.0\",\n    \"through\": \"~2.3.4\"\n  },\n  \"directories\": {},\n  \"dist\": {\n    \"shasum\": \"92e6534e7ac3fa35c8bdb121b8a8094a8d1c0826\",\n    \"tarball\": \"http://registry.npmjs.org/level-sublevel/-/level-sublevel-6.5.4.tgz\"\n  },\n  \"gitHead\": \"fa1b7121f9632b637e650cc1ec9b1723b60df864\",\n  \"homepage\": \"https://github.com/dominictarr/level-sublevel\",\n  \"license\": \"MIT\",\n  \"maintainers\": [\n    {\n      \"name\": \"dominictarr\",\n      \"email\": \"dominic.tarr@gmail.com\"\n    }\n  ],\n  \"name\": \"level-sublevel\",\n  \"optionalDependencies\": {},\n  \"readme\": \"ERROR: No README data found!\",\n  \"repository\": {\n    \"type\": \"git\",\n    \"url\": \"git://github.com/dominictarr/level-sublevel.git\"\n  },\n  \"scripts\": {\n    \"test\": \"set -e; for t in test/*.js; do node $t; done\"\n  },\n  \"stability\": \"unstable\",\n  \"testling\": {\n    \"browsers\": [\n      \"android-browser/4.2..latest\",\n      \"chrome/22..latest\",\n      \"chrome/canary\",\n      \"firefox/17..latest\",\n      \"firefox/nightly\",\n      \"ie/8..latest\",\n      \"ipad/6.0..latest\",\n      \"iphone/6.0..latest\",\n      \"opera/12..latest\",\n      \"opera/next\",\n      \"safari/5.1..latest\"\n    ],\n    \"files\": \"test/*.js\"\n  },\n  \"version\": \"6.5.4\"\n}\n","var ltgt = require('ltgt')\n\n//compare two array items\nfunction isArrayLike (a) {\n  return Array.isArray(a) || Buffer.isBuffer(a)\n}\n\nfunction isPrimitive (a) {\n  return 'string' === typeof a || 'number' === typeof a\n}\n\nfunction has(o, k) {\n  return Object.hasOwnProperty.call(o, k)\n}\n\nfunction compare (a, b) {\n  if(isArrayLike(a) && isArrayLike(b)) {\n    var l = Math.min(a.length, b.length)\n    for(var i = 0; i < l; i++) {\n      var c = compare(a[i], b[i])\n      if(c) return c\n    }\n    return a.length - b.length\n  }\n  if(isPrimitive(a) && isPrimitive(b))\n    return a < b ? -1 : a > b ? 1 : 0\n\n  throw new Error('items not comparable:'\n    + JSON.stringify(a) + ' ' + JSON.stringify(b))\n}\n\n//this assumes that the prefix is of the form:\n// [Array, string]\n\nfunction prefix (a, b) {\n  if(a.length > b.length) return false\n  var l = a.length - 1\n  var lastA = a[l]\n  var lastB = b[l]\n\n  if(typeof lastA !== typeof lastB)\n    return false\n\n  if('string' == typeof lastA\n    && 0 != lastB.indexOf(lastA))\n      return false\n  \n  //handle cas where there is no key prefix\n  //(a hook on an entire sublevel)\n  if(a.length == 1 && isArrayLike(lastA)) l ++\n  \n  while(l--) {\n    if(compare(a[l], b[l])) return false\n  }\n  return true\n}\n\nexports = module.exports = function (range, key, _compare) {\n  _compare = _compare || compare\n  //handle prefix specially,\n  //check that everything up to the last item is equal\n  //then check the last item starts with\n  if(isArrayLike(range)) return prefix(range, key)\n\n  return ltgt.contains(range, key, _compare)\n}\n\nfunction addPrefix(prefix, range) {\n  var o = ltgt.toLtgt(range, null, function (key) {\n    return [prefix, key]\n  })\n\n  //if there where no ranges, then then just use a prefix.\n  if(!has(o, 'gte') && !has(o, 'lte')) return [prefix]\n\n  return o\n}\n\nexports.compare = compare\nexports.prefix = prefix\nexports.addPrefix = addPrefix\n","var EventEmitter = require('events').EventEmitter\nvar addpre = require('./range').addPrefix\n\nvar errors = require('levelup/lib/errors')\n\nfunction isFunction (f) {\n  return 'function' === typeof f\n}\n\nfunction isString (s) {\n  return 'string' === typeof s\n}\n\nfunction isObject (o) {\n  return o && 'object' === typeof o\n}\n\nvar version = require('./package.json').version\n\nvar sublevel = module.exports = function (nut, prefix, createStream, options) {\n  var emitter = new EventEmitter()\n  emitter.sublevels = {}\n  emitter.options = options\n\n  emitter.version = version\n\n  emitter.methods = {}\n  prefix = prefix || []\n\n  function errback (err) { if (err) emitter.emit('error', err) }\n\n  createStream = createStream || function (e) { return e }\n\n  function mergeOpts(opts) {\n    var o = {}\n    if(options)\n      for(var k in options)\n        if(options[k] != undefined)o[k] = options[k]\n    if(opts)\n      for(var k in opts)\n        if(opts[k] != undefined) o[k] = opts[k]\n    return o\n  }\n\n  emitter.put = function (key, value, opts, cb) {\n    if('function' === typeof opts) cb = opts, opts = {}\n    if(!cb) cb = errback\n\n    nut.apply([{\n      key: key, value: value,\n      prefix: prefix.slice(), type: 'put'\n    }], mergeOpts(opts), function (err) {\n      if(!err) { emitter.emit('put', key, value); cb(null) }\n      if(err) return cb(err)\n    })\n  }\n\n  emitter.prefix = function () {\n    return prefix.slice()\n  }\n\n  emitter.del = function (key, opts, cb) {\n    if('function' === typeof opts) cb = opts, opts = {}\n    if(!cb) cb = errback\n\n    nut.apply([{\n      key: key,\n      prefix: prefix.slice(), type: 'del'\n    }], mergeOpts(opts), function (err) {\n      if(!err) { emitter.emit('del', key); cb(null) }\n      if(err) return cb(err)\n    })\n  }\n\n  emitter.batch = function (ops, opts, cb) {\n    if('function' === typeof opts)\n      cb = opts, opts = {}\n    if(!cb) cb = errback\n\n    ops = ops.map(function (op) {\n      return {\n        key:           op.key,\n        value:         op.value,\n        prefix:        op.prefix || prefix,\n        keyEncoding:   op.keyEncoding,    // *\n        valueEncoding: op.valueEncoding,  // * (TODO: encodings on sublevel)\n        type:          op.type\n      }\n    })\n\n    nut.apply(ops, mergeOpts(opts), function (err) {\n      if(!err) { emitter.emit('batch', ops); cb(null) }\n      if(err) return cb(err)\n    })\n  }\n\n  emitter.get = function (key, opts, cb) {\n    if('function' === typeof opts)\n      cb = opts, opts = {}\n    nut.get(key, prefix, mergeOpts(opts), function (err, value) {\n      if(err) cb(new errors.NotFoundError('Key not found in database', err))\n      else cb(null, value)\n    })\n  }\n\n  emitter.clone = function(opts) {\n    return sublevel(nut, prefix, createStream, mergeOpts(opts))\n  }\n\n  emitter.sublevel = function (name, opts) {\n    return emitter.sublevels[name] =\n      emitter.sublevels[name] || sublevel(nut, prefix.concat(name), createStream, mergeOpts(opts))\n  }\n\n  emitter.pre = function (key, hook) {\n    if(isFunction(key)) return nut.pre([prefix], key)\n    if(isString(key)) return nut.pre([prefix, key], hook)\n    if(isObject(key)) return nut.pre(addpre(prefix, key), hook)\n\n    throw new Error('not implemented yet')\n  }\n\n  emitter.post = function (key, hook) {\n    if(isFunction(key)) return nut.post([prefix], key)\n    if(isString(key))   return nut.post([prefix, key], hook)\n    if(isObject(key))   return nut.post(addpre(prefix, key), hook)\n\n    //TODO: handle ranges, needed for level-live-stream, etc.\n    throw new Error('not implemented yet')\n  }\n\n  emitter.readStream =\n  emitter.createReadStream = function (opts) {\n    opts = mergeOpts(opts)\n    opts.prefix = prefix\n    var stream\n    var it = nut.iterator(opts, function (err, it) {\n      stream.setIterator(it)\n    })\n\n    stream = createStream(opts, nut.createDecoder(opts))\n    if(it) stream.setIterator(it)\n\n    return stream\n  }\n\n  emitter.valueStream =\n  emitter.createValueStream = function (opts) {\n    opts = opts || {}\n    opts.values = true\n    opts.keys = false\n    return emitter.createReadStream(opts)\n  }\n\n  emitter.keyStream =\n  emitter.createKeyStream = function (opts) {\n    opts = opts || {}\n    opts.values = false\n    opts.keys = true\n    return emitter.createReadStream(opts)\n  }\n\n  emitter.close = function (cb) {\n    //TODO: deregister all hooks\n    cb = cb || function () {}\n    if (!prefix.length) nut.close(cb)\n    else process.nextTick(cb)\n  }\n\n  emitter.isOpen = nut.isOpen\n  emitter.isClosed = nut.isClosed\n\n  return emitter\n}\n","var pull     = require('pull-stream')\nvar toPull   = require('stream-to-pull-stream')\nvar pushable = require('pull-pushable')\nvar cat      = require('pull-cat')\nvar pw       = require('pull-window')\nvar post     = require('level-post')\n\nfunction read(db, opts) {\n  return toPull.read1(db.createReadStream(opts))\n}\n\nvar live =\nexports.live =\nfunction (db, opts) {\n  opts = opts || {}\n\n  var l = pushable(function (err) {\n    if(opts.onAbort) opts.onAbort(err)\n    cleanup()\n  })\n\n  var cleanup = post(db, opts, function (ch) {\n    if(opts.keys === false)\n      l.push(ch.value)\n    else if(opts.values === false)\n      l.push(ch.key)\n    else\n      l.push(ch)\n  })\n\n  return l\n\n}\n\nexports.read =\nexports.readStream =\nexports.createReadStream = function (db, opts) {\n  opts = opts || {}\n  if(!(opts.tail || opts.live))\n    return read(db, opts)\n\n  //optionally notify when we switch from reading history to realtime\n  var sync = opts.onSync && function (abort, cb) {\n      opts.onSync(abort); cb(abort || true)\n    }\n\n  if(opts.onSync === true || opts.sync === true)\n    sync = pull.values([{sync: true}])\n\n  return cat([read(db, opts), sync, live(db, opts)])\n}\n\nexports.write =\nexports.writeStream =\nexports.createWriteStream = function (db, opts, done) {\n  if('function' === typeof opts)\n    done = opts, opts = null\n  opts = opts || {}\n  return pull(\n    pull.map(function (e) {\n      if(e.type) return e\n      return {\n        key   : e.key, \n        value : e.value,\n        type  : e.value == null ? 'del' : 'put'\n      }\n    }),\n    pw.recent(opts.windowSize, opts.windowTime),\n    pull.asyncMap(function (batch, cb) {\n      db.batch(batch, cb)\n    }),\n    pull.drain(null, done)\n  )\n}\n\n","var u      = require('pull-core')\nvar sources = require('./sources')\nvar sinks = require('./sinks')\n\nvar prop   = u.prop\nvar id     = u.id\nvar tester = u.tester\n\nvar map = exports.map = \nfunction (read, map) {\n  map = prop(map) || id\n  return function (end, cb) {\n    read(end, function (end, data) {\n      var data = !end ? map(data) : null\n      cb(end, data)\n    })\n  }\n}\n\nvar asyncMap = exports.asyncMap =\nfunction (read, map) {\n  if(!map) return read\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    read(null, function (end, data) {\n      if(end) return cb(end, data)\n      map(data, cb)\n    })\n  }\n}\n\nvar paraMap = exports.paraMap =\nfunction (read, map, width) {\n  if(!map) return read\n  var ended = false, queue = [], _cb\n\n  function drain () {\n    if(!_cb) return\n    var cb = _cb\n    _cb = null\n    if(queue.length)\n      return cb(null, queue.shift())\n    else if(ended && !n)\n      return cb(ended)\n    _cb = cb\n  }\n\n  function pull () {\n    read(null, function (end, data) {\n      if(end) {\n        ended = end\n        return drain()\n      }\n      n++\n      map(data, function (err, data) {\n        n--\n\n        queue.push(data)\n        drain()\n      })\n\n      if(n < width && !ended)\n        pull()\n    })\n  }\n\n  var n = 0\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    //continue to read while there are less than 3 maps in flight\n    _cb = cb\n    if(queue.length || ended)\n      pull(), drain()\n    else pull()\n  }\n  return highWaterMark(asyncMap(read, map), width)\n}\n\nvar filter = exports.filter =\nfunction (read, test) {\n  //regexp\n  test = tester(test)\n  return function next (end, cb) {\n    read(end, function (end, data) {\n      if(!end && !test(data))\n        return next(end, cb)\n      cb(end, data)\n    })\n  }\n}\n\nvar filterNot = exports.filterNot =\nfunction (read, test) {\n  test = tester(test)\n  return filter(read, function (e) {\n    return !test(e)\n  })\n}\n\nvar through = exports.through = \nfunction (read, op, onEnd) {\n  var a = false\n  function once (abort) {\n    if(a || !onEnd) return\n    a = true\n    onEnd(abort === true ? null : abort)\n  }\n\n  return function (end, cb) {\n    if(end) once(end)\n    return read(end, function (end, data) {\n      if(!end) op && op(data)\n      else once(end)\n      cb(end, data)\n    })\n  }\n}\n\nvar take = exports.take =\nfunction (read, test) {\n  var ended = false\n  if('number' === typeof test) {\n    var n = test; test = function () {\n      return n --\n    }\n  }\n\n  return function (end, cb) {\n    if(ended) return cb(ended)\n    if(ended = end) return read(ended, cb)\n\n    read(null, function (end, data) {\n      if(ended = ended || end) return cb(ended)\n      if(!test(data)) {\n        ended = true\n        read(true, function (end, data) {\n          cb(ended, data)\n        })\n      }\n      else\n        cb(null, data)\n    })\n  }\n}\n\nvar unique = exports.unique = function (read, field, invert) {\n  field = prop(field) || id\n  var seen = {}\n  return filter(read, function (data) {\n    var key = field(data)\n    if(seen[key]) return !!invert //false, by default\n    else seen[key] = true\n    return !invert //true by default\n  })\n}\n\nvar nonUnique = exports.nonUnique = function (read, field) {\n  return unique(read, field, true)\n}\n\nvar group = exports.group =\nfunction (read, size) {\n  var ended; size = size || 5\n  var queue = []\n\n  return function (end, cb) {\n    //this means that the upstream is sending an error.\n    if(end) return read(ended = end, cb)\n    //this means that we read an end before.\n    if(ended) return cb(ended)\n\n    read(null, function next(end, data) {\n      if(ended = ended || end) {\n        if(!queue.length)\n          return cb(ended)\n\n        var _queue = queue; queue = []\n        return cb(null, _queue)\n      }\n      queue.push(data)\n      if(queue.length < size)\n        return read(null, next)\n\n      var _queue = queue; queue = []\n      cb(null, _queue)\n    })\n  }\n}\n\nvar flatten = exports.flatten = function (read) {\n  var _read\n  return function (abort, cb) {\n    if(_read) nextChunk()\n    else      nextStream()\n\n    function nextChunk () {\n      _read(null, function (end, data) {\n        if(end) nextStream()\n        else    cb(null, data)\n      })\n    }\n    function nextStream () {\n      read(null, function (end, stream) {\n        if(end)\n          return cb(end)\n        if(Array.isArray(stream))\n          stream = sources.values(stream)\n        else if('function' != typeof stream)\n          throw new Error('expected stream of streams')\n        \n        _read = stream\n        nextChunk()\n      })\n    }\n  }\n}\n\nvar prepend =\nexports.prepend =\nfunction (read, head) {\n\n  return function (abort, cb) {\n    if(head !== null) {\n      if(abort)\n        return read(abort, cb)\n      var _head = head\n      head = null\n      cb(null, _head)\n    } else {\n      read(abort, cb)\n    }\n  }\n\n}\n\n//var drainIf = exports.drainIf = function (op, done) {\n//  sinks.drain(\n//}\n\nvar _reduce = exports._reduce = function (read, reduce, initial) {\n  return function (close, cb) {\n    if(close) return read(close, cb)\n    if(ended) return cb(ended)\n\n    sinks.drain(function (item) {\n      initial = reduce(initial, item)\n    }, function (err, data) {\n      ended = err || true\n      if(!err) cb(null, initial)\n      else     cb(ended)\n    })\n    (read)\n  }\n}\n\nvar nextTick = process.nextTick\n\nvar highWaterMark = exports.highWaterMark = \nfunction (read, highWaterMark) {\n  var buffer = [], waiting = [], ended, reading = false\n  highWaterMark = highWaterMark || 10\n\n  function readAhead () {\n    while(waiting.length && (buffer.length || ended))\n      waiting.shift()(ended, ended ? null : buffer.shift())\n  }\n\n  function next () {\n    if(ended || reading || buffer.length >= highWaterMark)\n      return\n    reading = true\n    return read(ended, function (end, data) {\n      reading = false\n      ended = ended || end\n      if(data != null) buffer.push(data)\n      \n      next(); readAhead()\n    })\n  }\n\n  nextTick(next)\n\n  return function (end, cb) {\n    ended = ended || end\n    waiting.push(cb)\n\n    next(); readAhead()\n  }\n}\n\n\n\n","\nvar keys = exports.keys =\nfunction (object) {\n  return values(Object.keys(object))\n}\n\nvar once = exports.once =\nfunction (value) {\n  return function (abort, cb) {\n    if(abort) return cb(abort)\n    if(value != null) {\n      var _value = value; value = null\n      cb(null, _value)\n    } else\n      cb(true)\n  }\n}\n\nvar values = exports.values = exports.readArray =\nfunction (array) {\n  if(!Array.isArray(array))\n    array = Object.keys(array).map(function (k) {\n      return array[k]\n    })\n  var i = 0\n  return function (end, cb) {\n    if(end)\n      return cb && cb(end)\n    cb(i >= array.length || null, array[i++])\n  }\n}\n\n\nvar count = exports.count =\nfunction (max) {\n  var i = 0; max = max || Infinity\n  return function (end, cb) {\n    if(end) return cb && cb(end)\n    if(i > max)\n      return cb(true)\n    cb(null, i++)\n  }\n}\n\nvar infinite = exports.infinite =\nfunction (generate) {\n  generate = generate || Math.random\n  return function (end, cb) {\n    if(end) return cb && cb(end)\n    return cb(null, generate())\n  }\n}\n\nvar defer = exports.defer = function () {\n  var _read, cbs = [], _end\n\n  var read = function (end, cb) {\n    if(!_read) {\n      _end = end\n      cbs.push(cb)\n    } \n    else _read(end, cb)\n  }\n  read.resolve = function (read) {\n    if(_read) throw new Error('already resolved')\n    _read = read\n    if(!_read) throw new Error('no read cannot resolve!' + _read)\n    while(cbs.length)\n      _read(_end, cbs.shift())\n  }\n  read.abort = function(err) {\n    read.resolve(function (_, cb) {\n      cb(err || true)\n    })\n  }\n  return read\n}\n\nvar empty = exports.empty = function () {\n  return function (abort, cb) {\n    cb(true)\n  }\n}\n\nvar depthFirst = exports.depthFirst =\nfunction (start, createStream) {\n  var reads = []\n\n  reads.unshift(once(start))\n\n  return function next (end, cb) {\n    if(!reads.length)\n      return cb(true)\n    reads[0](end, function (end, data) {\n      if(end) {\n        //if this stream has ended, go to the next queue\n        reads.shift()\n        return next(null, cb)\n      }\n      reads.unshift(createStream(data))\n      cb(end, data)\n    })\n  }\n}\n//width first is just like depth first,\n//but push each new stream onto the end of the queue\nvar widthFirst = exports.widthFirst =\nfunction (start, createStream) {\n  var reads = []\n\n  reads.push(once(start))\n\n  return function next (end, cb) {\n    if(!reads.length)\n      return cb(true)\n    reads[0](end, function (end, data) {\n      if(end) {\n        reads.shift()\n        return next(null, cb)\n      }\n      reads.push(createStream(data))\n      cb(end, data)\n    })\n  }\n}\n\n//this came out different to the first (strm)\n//attempt at leafFirst, but it's still a valid\n//topological sort.\nvar leafFirst = exports.leafFirst =\nfunction (start, createStream) {\n  var reads = []\n  var output = []\n  reads.push(once(start))\n\n  return function next (end, cb) {\n    reads[0](end, function (end, data) {\n      if(end) {\n        reads.shift()\n        if(!output.length)\n          return cb(true)\n        return cb(null, output.shift())\n      }\n      reads.unshift(createStream(data))\n      output.unshift(data)\n      next(null, cb)\n    })\n  }\n}\n\n","var u      = require('pull-core')\nvar sources = require('./sources')\nvar sinks = require('./sinks')\n\nvar prop   = u.prop\nvar id     = u.id\nvar tester = u.tester\n\nvar map = exports.map = \nfunction (read, map) {\n  map = prop(map) || id\n  return function (abort, cb) {\n    read(abort, function (end, data) {\n      try {\n      data = !end ? map(data) : null\n      } catch (err) {\n        return read(err, function () {\n          return cb(err)\n        })\n      }\n      cb(end, data)\n    })\n  }\n}\n\nvar asyncMap = exports.asyncMap =\nfunction (read, map) {\n  if(!map) return read\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    read(null, function (end, data) {\n      if(end) return cb(end, data)\n      map(data, cb)\n    })\n  }\n}\n\nvar paraMap = exports.paraMap =\nfunction (read, map, width) {\n  if(!map) return read\n  var ended = false, queue = [], _cb\n\n  function drain () {\n    if(!_cb) return\n    var cb = _cb\n    _cb = null\n    if(queue.length)\n      return cb(null, queue.shift())\n    else if(ended && !n)\n      return cb(ended)\n    _cb = cb\n  }\n\n  function pull () {\n    read(null, function (end, data) {\n      if(end) {\n        ended = end\n        return drain()\n      }\n      n++\n      map(data, function (err, data) {\n        n--\n\n        queue.push(data)\n        drain()\n      })\n\n      if(n < width && !ended)\n        pull()\n    })\n  }\n\n  var n = 0\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    //continue to read while there are less than 3 maps in flight\n    _cb = cb\n    if(queue.length || ended)\n      pull(), drain()\n    else pull()\n  }\n  return highWaterMark(asyncMap(read, map), width)\n}\n\nvar filter = exports.filter =\nfunction (read, test) {\n  //regexp\n  test = tester(test)\n  return function next (end, cb) {\n    var sync, loop = true\n    while(loop) {\n      loop = false\n      sync = true\n      read(end, function (end, data) {\n        if(!end && !test(data))\n          return sync ? loop = true : next(end, cb)\n        cb(end, data)\n      })\n      sync = false\n    }\n  }\n}\n\nvar filterNot = exports.filterNot =\nfunction (read, test) {\n  test = tester(test)\n  return filter(read, function (e) {\n    return !test(e)\n  })\n}\n\nvar through = exports.through = \nfunction (read, op, onEnd) {\n  var a = false\n  function once (abort) {\n    if(a || !onEnd) return\n    a = true\n    onEnd(abort === true ? null : abort)\n  }\n\n  return function (end, cb) {\n    if(end) once(end)\n    return read(end, function (end, data) {\n      if(!end) op && op(data)\n      else once(end)\n      cb(end, data)\n    })\n  }\n}\n\nvar take = exports.take =\nfunction (read, test) {\n  var ended = false\n  if('number' === typeof test) {\n    var n = test; test = function () {\n      return n --\n    }\n  }\n\n  return function (end, cb) {\n    if(ended) return cb(ended)\n    if(ended = end) return read(ended, cb)\n\n    read(null, function (end, data) {\n      if(ended = ended || end) return cb(ended)\n      if(!test(data)) {\n        ended = true\n        read(true, function (end, data) {\n          cb(ended, data)\n        })\n      }\n      else\n        cb(null, data)\n    })\n  }\n}\n\nvar unique = exports.unique = function (read, field, invert) {\n  field = prop(field) || id\n  var seen = {}\n  return filter(read, function (data) {\n    var key = field(data)\n    if(seen[key]) return !!invert //false, by default\n    else seen[key] = true\n    return !invert //true by default\n  })\n}\n\nvar nonUnique = exports.nonUnique = function (read, field) {\n  return unique(read, field, true)\n}\n\nvar group = exports.group =\nfunction (read, size) {\n  var ended; size = size || 5\n  var queue = []\n\n  return function (end, cb) {\n    //this means that the upstream is sending an error.\n    if(end) return read(ended = end, cb)\n    //this means that we read an end before.\n    if(ended) return cb(ended)\n\n    read(null, function next(end, data) {\n      if(ended = ended || end) {\n        if(!queue.length)\n          return cb(ended)\n\n        var _queue = queue; queue = []\n        return cb(null, _queue)\n      }\n      queue.push(data)\n      if(queue.length < size)\n        return read(null, next)\n\n      var _queue = queue; queue = []\n      cb(null, _queue)\n    })\n  }\n}\n\nvar flatten = exports.flatten = function (read) {\n  var _read\n  return function (abort, cb) {\n    if(_read) nextChunk()\n    else      nextStream()\n\n    function nextChunk () {\n      _read(null, function (end, data) {\n        if(end) nextStream()\n        else    cb(null, data)\n      })\n    }\n    function nextStream () {\n      read(null, function (end, stream) {\n        if(end)\n          return cb(end)\n        if(Array.isArray(stream))\n          stream = sources.values(stream)\n        else if('function' != typeof stream)\n          throw new Error('expected stream of streams')\n        \n        _read = stream\n        nextChunk()\n      })\n    }\n  }\n}\n\nvar prepend =\nexports.prepend =\nfunction (read, head) {\n\n  return function (abort, cb) {\n    if(head !== null) {\n      if(abort)\n        return read(abort, cb)\n      var _head = head\n      head = null\n      cb(null, _head)\n    } else {\n      read(abort, cb)\n    }\n  }\n\n}\n\n//var drainIf = exports.drainIf = function (op, done) {\n//  sinks.drain(\n//}\n\nvar _reduce = exports._reduce = function (read, reduce, initial) {\n  return function (close, cb) {\n    if(close) return read(close, cb)\n    if(ended) return cb(ended)\n\n    sinks.drain(function (item) {\n      initial = reduce(initial, item)\n    }, function (err, data) {\n      ended = err || true\n      if(!err) cb(null, initial)\n      else     cb(ended)\n    })\n    (read)\n  }\n}\n\nvar nextTick = process.nextTick\n\nvar highWaterMark = exports.highWaterMark =\nfunction (read, highWaterMark) {\n  var buffer = [], waiting = [], ended, ending, reading = false\n  highWaterMark = highWaterMark || 10\n\n  function readAhead () {\n    while(waiting.length && (buffer.length || ended))\n      waiting.shift()(ended, ended ? null : buffer.shift())\n\n    if (!buffer.length && ending) ended = ending;\n  }\n\n  function next () {\n    if(ended || ending || reading || buffer.length >= highWaterMark)\n      return\n    reading = true\n    return read(ended || ending, function (end, data) {\n      reading = false\n      ending = ending || end\n      if(data != null) buffer.push(data)\n\n      next(); readAhead()\n    })\n  }\n\n  process.nextTick(next)\n\n  return function (end, cb) {\n    ended = ended || end\n    waiting.push(cb)\n\n    next(); readAhead()\n  }\n}\n\nvar flatMap = exports.flatMap =\nfunction (read, mapper) {\n  mapper = mapper || id\n  var queue = [], ended\n\n  return function (abort, cb) {\n    if(queue.length) return cb(null, queue.shift())\n    else if(ended)   return cb(ended)\n\n    read(abort, function next (end, data) {\n      if(end) ended = end\n      else {\n        var add = mapper(data)\n        while(add && add.length)\n          queue.push(add.shift())\n      }\n\n      if(queue.length) cb(null, queue.shift())\n      else if(ended)   cb(ended)\n      else             read(null, next)\n    })\n  }\n}\n\n","module.exports={\n  \"_args\": [\n    [\n      \"secure-scuttlebutt@git+https://github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d\",\n      \"/Users/joran/Documents/development/patchdeck/node_modules/scuttlebot\"\n    ]\n  ],\n  \"_from\": \"git+https://github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d\",\n  \"_id\": \"secure-scuttlebutt@15.0.5\",\n  \"_inCache\": true,\n  \"_installable\": true,\n  \"_location\": \"/secure-scuttlebutt\",\n  \"_phantomChildren\": {\n    \"bytewise-core\": \"1.2.3\",\n    \"level-post\": \"1.0.4\",\n    \"levelup\": \"0.19.1\",\n    \"pull-cat\": \"1.1.9\",\n    \"pull-window\": \"2.1.3\",\n    \"stream-to-pull-stream\": \"1.6.8\",\n    \"typewise\": \"1.0.3\",\n    \"typewiselite\": \"1.0.0\"\n  },\n  \"_requested\": {\n    \"hosted\": {\n      \"directUrl\": \"https://raw.githubusercontent.com/ssbc/secure-scuttlebutt/b8de480bd262a69c357e80681dd60cf60c17681d/package.json\",\n      \"gitUrl\": \"git://github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d\",\n      \"httpsUrl\": \"git+https://github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d\",\n      \"shortcut\": \"github:ssbc/secure-scuttlebutt#b8de480bd262a69c357e80681dd60cf60c17681d\",\n      \"ssh\": \"git@github.com:ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d\",\n      \"sshUrl\": \"git+ssh://git@github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d\",\n      \"type\": \"github\"\n    },\n    \"name\": \"secure-scuttlebutt\",\n    \"raw\": \"secure-scuttlebutt@git+https://github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d\",\n    \"rawSpec\": \"git+https://github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d\",\n    \"scope\": null,\n    \"spec\": \"git+https://github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d\",\n    \"type\": \"hosted\"\n  },\n  \"_requiredBy\": [\n    \"/scuttlebot\"\n  ],\n  \"_resolved\": \"git+https://github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d\",\n  \"_shasum\": \"4c2fa68fd5ebd8d9ee0d4b27279cb9c156ed7868\",\n  \"_shrinkwrap\": null,\n  \"_spec\": \"secure-scuttlebutt@git+https://github.com/ssbc/secure-scuttlebutt.git#b8de480bd262a69c357e80681dd60cf60c17681d\",\n  \"_where\": \"/Users/joran/Documents/development/patchdeck/node_modules/scuttlebot\",\n  \"author\": {\n    \"email\": \"dominic.tarr@gmail.com\",\n    \"name\": \"Dominic Tarr\",\n    \"url\": \"http://dominictarr.com\"\n  },\n  \"bugs\": {\n    \"url\": \"https://github.com/ssbc/secure-scuttlebutt/issues\"\n  },\n  \"dependencies\": {\n    \"cont\": \"~1.0.0\",\n    \"deep-equal\": \"~0.2.1\",\n    \"explain-error\": \"~1.0.1\",\n    \"level\": \"^1.3.0\",\n    \"level-sublevel\": \"^6.5.2\",\n    \"ltgt\": \"~2.0.0\",\n    \"monotonic-timestamp\": \"~0.0.8\",\n    \"pull-cat\": \"~1.1.5\",\n    \"pull-level\": \"~1.4.0\",\n    \"pull-paramap\": \"~1.1.3\",\n    \"pull-stream\": \"~2.24.1\",\n    \"ssb-feed\": \"^2.0.0\",\n    \"ssb-keys\": \"^5.0.0\",\n    \"ssb-msgs\": \"^5.0.0\",\n    \"ssb-ref\": \"^2.0.0\"\n  },\n  \"description\": \"a secure, replicatable database\",\n  \"devDependencies\": {\n    \"deep-equal\": \"^0.2.1\",\n    \"hexpp\": \"~1.1.3\",\n    \"level-test\": \"^2.0.1\",\n    \"multicb\": \"~0.0.2\",\n    \"pull-abortable\": \"~4.1.0\",\n    \"pull-randomly-split\": \"~1.0.4\",\n    \"rimraf\": \"~2.2.8\",\n    \"tape\": \"^4.2.2\",\n    \"typewiselite\": \"~1.0.0\"\n  },\n  \"gitHead\": \"b8de480bd262a69c357e80681dd60cf60c17681d\",\n  \"homepage\": \"https://github.com/ssbc/secure-scuttlebutt\",\n  \"license\": \"MIT\",\n  \"name\": \"secure-scuttlebutt\",\n  \"optionalDependencies\": {},\n  \"readme\": \"# secure-scuttlebutt\\n\\nA database of unforgable append-only feeds, optimized for efficient replication for peer to peer protocols.\\n\\n## What does it do?\\n\\nSecure-scuttlebutt provides tools for dealing with unforgeable append-only message \\nfeeds. You can create a feed, post messages to that feed, verify a feed created by\\nsomeone else, stream messages to and from feeds, and more (see [API](#API)).\\n\\n\\\"Unforgeable\\\" means that only the owner of a feed can modify that feed, as\\nenforced by digital signing (see [Security properties](#security-properties)).\\nThis property makes secure-scuttlebutt useful for peer-to-peer applications.\\nSecure-scuttlebutt also makes it easy to encrypt messages.\\n\\n## Example\\n\\nIn this example, we create a feed, post a signed message to it, then create a stream \\nthat reads from the feed.\\n\\n``` js\\n/**\\n * create a secure scuttlebutt instance and add a message to it.\\n */\\n\\nvar pull = require('pull-stream')\\n\\n// paths:\\nvar pathToDB     = '/tmp/ssb1/'\\nvar pathToSecret = '/tmp/ssb1-secret'\\n\\n// ways to create keys:\\nvar keys = require('ssb-keys').generate()\\nvar keys = require('ssb-keys').loadSync(pathToSecret)\\nvar keys = require('ssb-keys').createSync(pathToSecret)\\nvar keys = require('ssb-keys').loadOrCreateSync(pathToSecret)\\n\\n// create the db instance.\\n//  - uses leveldb.\\n//  - can only open one instance at a time.\\n\\nvar ssb = require('secure-scuttlebutt/create')(pathToDB)\\n\\n// create a feed.\\n//  - this represents a write access / user.\\n//  - you must pass in keys.\\n//  (see options section)\\n\\nvar feed = ssb.createFeed(keys)\\n\\n// publish a message.\\n//  - feed.add appends a message to your key's chain.\\n//  - the `type` attribute is required.\\n\\nfeed.add({ type: 'post', text: 'My First Post!' }, function (err, msg, hash) {\\n  // the message as it appears in the database:\\n  console.log(msg)\\n\\n  // and its hash:\\n  console.log(hash)\\n})\\n\\n// stream all messages for all keypairs.\\npull(\\n  ssb.createFeedStream(),\\n  pull.collect(function (err, ary) {\\n    console.log(ary)\\n  })\\n)\\n\\n// stream all messages for a particular keypair.\\npull(\\n  ssb.createHistoryStream(feed.id),\\n  pull.collect(function (err, ary) {\\n    console.log(ary)\\n  })\\n)\\n```\\n\\n## Concepts\\n\\nBuilding upon secure-scuttlebutt requires understanding a few concepts\\nthat it uses to ensure the unforgeability of message feeds.\\n\\n### Identities\\n\\nAn identity is simply a public/private key pair.\\n\\nEven though there is no worldwide store of identities, it's infeasible\\nfor anyone to forge your identity. Identities are binary strings, so not\\nparticularly human-readable.\\n\\n### Feeds\\n\\nA feed is an append-only sequence of messages. Each feed is associated\\n1:1 with an identity. The feed is identified by its public key. This\\nworks because public keys are unique.\\n\\nSince feeds are append-only, replication is simple: request all messages\\nin the feed that are newer than the latest message you know about.\\n\\nNote that append-only really means append-only: you cannot delete an\\nexisting message. If you want to enable entities to be deleted or \\nmodified in your data model, that can be implemented in a layer on top \\nof secure-scuttlebutt using \\n[delta encoding](https://en.wikipedia.org/wiki/Delta_encoding). \\n\\n### Messages\\n\\nEach message contains:\\n\\n- A message object. This is the thing that the end user cares about. If\\n  there is no encryption, this is a `{}` object. If there is encryption,\\n  this is an encrypted string.\\n- A content-hash of the previous message. This prevents somebody with\\n  the private key from changing the feed history after publishing, as a\\n  newly-created message wouldn't match the \\\"prev-hash\\\" of later messages\\n  which were already replicated.\\n- The signing public key.\\n- A signature. This prevents malicious parties from writing fake \\n  messages to a stream.\\n- A sequence number. This prevents a malicious party from making a copy\\n  of the feed that omits or reorders messages.\\n  \\nSince each message contains a reference to the previous message, a feed \\nmust be replicated in order, starting with the first message. This is\\nthe only way that the feed can be verified. A feed can be *viewed* in\\nany order after it's been replicated.\\n\\n### Object ids\\n\\nThe text inside a message can refer to three types of secure-scuttlebutt\\nentities: messages, feeds, and blobs (i.e. attachments). Messages and \\nblobs are referred to by their hashes, but a feed is referred to by its\\nsigning public key. Thus, a message within a feed can refer to another\\nfeed, or to a particular point _within_ a feed.\\n\\nObject ids begin with a sigil `@` `%` and `&` for a `feedId`, `msgId`\\nand `blobId` respectively.\\n\\nNote that secure-scuttlebutt does not include facilities for retrieving\\na blob given the hash.\\n\\n### Replication\\n\\nIt is possible to easily replicate data between two SecureScuttlebutts.\\nFirst, they exchange maps of their newest data. Then, each one downloads\\nall data newer than its newest data.\\n\\n[Scuttlebot](https://github.com/ssbc/scuttlebot) is a tool that\\nmakes it easy to replicate multiple SecureScuttlebutts using a\\ndecentralized network.\\n\\n### Security properties\\nSecure-scuttlebutt maintains useful security properties even when it is\\nconnected to a malicious secure-scuttlebutt database. This makes it ideal\\nas a store for peer-to-peer applications.\\n\\nImagine that we want to read from a feed for which we know the identity,\\nbut we're connected to a malicious secure-scuttlebutt instance. As\\nlong as the malicious database does not have the private key:\\n\\n- The malicious database cannot create a new feed with the same identifier\\n- The malicious database cannot write new fake messages to the feed\\n- The malicious database cannot reorder the messages in the feed\\n- The malicious database cannot send us a new copy of the feed that omits\\n  messages from the middle\\n- The malicious database *can* refuse to send us the feed, or only send\\n  us the first *N* messages in the feed\\n- Messages may optionally be encrypted. See `test/end-to-end.js`.\\n\\n\\n## API\\n\\n### ssb = require('secure-scuttlebutt/create')(path)\\n\\nCreate a secure-scuttlebutt database at the given path,\\nreturns an instance.\\n\\n### require('secure-scuttlebutt')(db, opts)\\n\\nPass in a [levelup](https://github.com/rvagg/node-levelup) instance\\n(it must have [sublevel](https://github.com/dominictarr/level-sublevel) installed),\\nand an options object. The options object provides the crypto\\nand encoding functions, that are not directly tied into how\\nsecure-scuttlebutt works.\\n\\nThe following methods all apply to a `SecureScuttlebutt` instance\\n\\n### SecureScuttlebutt#createFeed (keys?)\\n\\nCreate a Feed object. A feed is a chain of messages signed\\nby a single key (the identity of the feed).\\nThis handles the state needed to append valid messages to a feed.\\nIf keys are not provided, then a new key pair will be generated.\\n\\nThe following methods apply to the Feed type.\\n\\n#### Feed#add (message, cb)\\n\\nAdds a message of a given type to a feed.\\nThis is the recommended way to append messages.\\nmessage is a javascript object. It must be a `{}` object with a `type`\\nproperty that is a string between 3 and 32 chars long.\\n\\n#### Feed#id\\n\\nthe id of the feed (which is the feed's public key)\\n\\n#### Feed#keys\\n\\nthe key pair for this feed.\\n\\n### SecureScuttlebutt#needsRebuild(cb)\\n\\nChecks the version stored in the database against the code version and\\ncalls back true/false accordingly. This keeps the database in sync with\\nmajor breaking changes to secure-scuttlebutt when they occur.\\n\\nShould be run at startup. If true, you should call `rebuildIndex` before\\nusing the database.\\n\\n```js\\nssb.needsRebuild(function (err, b) {\\n  if (b)\\n    ssb.rebuildIndex(next)\\n})\\n```\\n\\n### SecureScuttlebutt#rebuildIndex(cb)\\n\\nRebuilds the indexes by replaying history. See `needsRebuild`.\\n\\n### SecureScuttlebutt#createFeedStream (opts) -> PullSource\\n\\nCreate a [pull-stream](https://github.com/dominictarr/pull-stream)\\nof all the feeds in the database, ordered by timestamps.\\nAll [pull-level](https://github.com/dominictarr/pull-level) options\\nare allowed (start, end, reverse, tail)\\n\\n### SecureScuttlebutt#createLogStream({gt: ts, tail: boolean}) -> PullSource\\n\\ncreate a stream of the messages that have been written to this instance\\nin the order they arrived. This is mainly intended for building views.\\nThe objects in this stream will be of the form:\\n\\n``` js\\n{\\n  key: Hash, value: Message, timestamp: timestamp\\n}\\n```\\n`timestamp` is generated by\\n[monotonic-timestamp](https://github.com/dominictarr/monotonic-timestamp)\\n\\n### SecureScuttlebutt#createHistoryStream ({id: feedId, seq: int?, live: bool?}) -> PullSource\\n\\nCreate a stream of the history of `id`. If `seq > 0`, then\\nonly stream messages with sequence numbers greater than `seq`.\\nif `live` is true, the stream will be a\\n[live mode](https://github.com/dominictarr/pull-level#example---reading)\\n\\n### SecureScuttlebutt#messagesByType ({type: string, live: bool?}) -> PullSource\\n\\nretrive messages with a given type. All messages must have a type,\\nso this is a good way to select messages that an application might use.\\nReturns a source pull-stream. This function takes all the options from [pull-level#read](https://github.com/dominictarr/pull-level#example---reading)\\n(gt, lt, gte, lte, limit, reverse, live)\\n\\n\\n### SecureScuttlebutt#links ({source: feedId?, dest: feedId|msgId|blobId?, rel: string?, meta: true?, keys: true?, values: false?, live:false?, reverse: false?}) -> PullSource\\n\\nGet a stream of links from a feed to a blob/msg/feed id.\\n\\nThe objects in this stream will be of the form:\\n\\n```\\n{ source: feedId, rel: String, dest: Id, key: MsgId, value: Object? }\\n```\\n\\n - `source` (string, optional): feed id..\\n - `dest` (string, optional): An id or filter, specifying where the link should point to.\\n  To filter, just use the sigil of the type you want: `@` for feeds, `%` for messages, and `&` for blobs.\\n - `rel` (string, optional): Filters the links by the relation string.\\n\\nIf `opts.values` is set (default: false) `value` will be the message the link occurs in.\\nIf `opts.keys` is set (default: true) `key` will be the message id.\\nIf `opts.meta` is unset (default: true) `source, hash, rel` will be left off.\\n\\n> Note: if `source`, and `dest` is provided, but not `rel`, ssb will\\n> have to scan all the links from source, and then filter by dest.\\n> your query will be more efficient if you also provide `rel`.\\n\\n\\n### SecureScuttlebutt#relatedMessages ({id: msgId, rel: string?, count: false?, parent: false?}, cb)\\n\\nRetrieve the tree of messages related to `id`.\\nThis is ideal for collecting things like threaded replies.\\nIf `rel` is provided, only messages that link to the message with the given type are included.\\nThe output is a recursive structure like this:\\n\\n``` js\\n{\\n  key: <msgId>,\\n  value: <msg>,\\n  related: [\\n    <recursive>,...\\n  ],\\n  //number of messages below this point. (when opts.count = true)\\n  count: <int>,\\n  //the message this message links to. this will not appear on the bottom level.\\n  //(when opts.parent = true)\\n  parent: <parent_id>\\n}\\n```\\n\\nIf `count` option is true, then each message will contain a `count`\\nit's descendant messages. If `parent` is true then each level will have \\n`parent`, the `id/key` of it's parent message.\\n\\n## Stability\\n\\nStable: Expect patches, possible features additions.\\n\\n## License\\n\\nMIT\\n\\n\",\n  \"readmeFilename\": \"README.md\",\n  \"repository\": {\n    \"type\": \"git\",\n    \"url\": \"git://github.com/ssbc/secure-scuttlebutt.git\"\n  },\n  \"scripts\": {\n    \"prepublish\": \"npm ls && npm test\",\n    \"test\": \"set -e; for t in test/*.js; do node $t; done\"\n  },\n  \"testling\": {\n    \"browsers\": [\n      \"chrome/22..latest\",\n      \"chrome/canary\",\n      \"firefox/17..latest\",\n      \"firefox/nightly\",\n      \"ie/8..latest\",\n      \"ipad/6.0..latest\",\n      \"iphone/6.0..latest\",\n      \"opera/12..latest\",\n      \"opera/next\",\n      \"safari/5.1..latest\"\n    ],\n    \"files\": \"test/defaults.js\"\n  },\n  \"version\": \"15.0.5\"\n}\n","// prototype class for hash functions\nfunction Hash (blockSize, finalSize) {\n  this._block = new Buffer(blockSize)\n  this._finalSize = finalSize\n  this._blockSize = blockSize\n  this._len = 0\n  this._s = 0\n}\n\nHash.prototype.update = function (data, enc) {\n  if (typeof data === 'string') {\n    enc = enc || 'utf8'\n    data = new Buffer(data, enc)\n  }\n\n  var l = this._len += data.length\n  var s = this._s || 0\n  var f = 0\n  var buffer = this._block\n\n  while (s < l) {\n    var t = Math.min(data.length, f + this._blockSize - (s % this._blockSize))\n    var ch = (t - f)\n\n    for (var i = 0; i < ch; i++) {\n      buffer[(s % this._blockSize) + i] = data[i + f]\n    }\n\n    s += ch\n    f += ch\n\n    if ((s % this._blockSize) === 0) {\n      this._update(buffer)\n    }\n  }\n  this._s = s\n\n  return this\n}\n\nHash.prototype.digest = function (enc) {\n  // Suppose the length of the message M, in bits, is l\n  var l = this._len * 8\n\n  // Append the bit 1 to the end of the message\n  this._block[this._len % this._blockSize] = 0x80\n\n  // and then k zero bits, where k is the smallest non-negative solution to the equation (l + 1 + k) === finalSize mod blockSize\n  this._block.fill(0, this._len % this._blockSize + 1)\n\n  if (l % (this._blockSize * 8) >= this._finalSize * 8) {\n    this._update(this._block)\n    this._block.fill(0)\n  }\n\n  // to this append the block which is equal to the number l written in binary\n  // TODO: handle case where l is > Math.pow(2, 29)\n  this._block.writeInt32BE(l, this._blockSize - 4)\n\n  var hash = this._update(this._block) || this._hash()\n\n  return enc ? hash.toString(enc) : hash\n}\n\nHash.prototype._update = function () {\n  throw new Error('_update must be implemented by subclass')\n}\n\nmodule.exports = Hash\n","var exports = module.exports = function SHA (algorithm) {\n  algorithm = algorithm.toLowerCase()\n\n  var Algorithm = exports[algorithm]\n  if (!Algorithm) throw new Error(algorithm + ' is not supported (we accept pull requests)')\n\n  return new Algorithm()\n}\n\nexports.sha = require('./sha')\nexports.sha1 = require('./sha1')\nexports.sha224 = require('./sha224')\nexports.sha256 = require('./sha256')\nexports.sha384 = require('./sha384')\nexports.sha512 = require('./sha512')\n","/*\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-0, as defined\n * in FIPS PUB 180-1\n * This source code is derived from sha1.js of the same repository.\n * The difference between SHA-0 and SHA-1 is just a bitwise rotate left\n * operation was added.\n */\n\nvar inherits = require('inherits')\nvar Hash = require('./hash')\n\nvar K = [\n  0x5a827999, 0x6ed9eba1, 0x8f1bbcdc | 0, 0xca62c1d6 | 0\n]\n\nvar W = new Array(80)\n\nfunction Sha () {\n  this.init()\n  this._w = W\n\n  Hash.call(this, 64, 56)\n}\n\ninherits(Sha, Hash)\n\nSha.prototype.init = function () {\n  this._a = 0x67452301\n  this._b = 0xefcdab89\n  this._c = 0x98badcfe\n  this._d = 0x10325476\n  this._e = 0xc3d2e1f0\n\n  return this\n}\n\nfunction rotl5 (num) {\n  return (num << 5) | (num >>> 27)\n}\n\nfunction rotl30 (num) {\n  return (num << 30) | (num >>> 2)\n}\n\nfunction ft (s, b, c, d) {\n  if (s === 0) return (b & c) | ((~b) & d)\n  if (s === 2) return (b & c) | (b & d) | (c & d)\n  return b ^ c ^ d\n}\n\nSha.prototype._update = function (M) {\n  var W = this._w\n\n  var a = this._a | 0\n  var b = this._b | 0\n  var c = this._c | 0\n  var d = this._d | 0\n  var e = this._e | 0\n\n  for (var i = 0; i < 16; ++i) W[i] = M.readInt32BE(i * 4)\n  for (; i < 80; ++i) W[i] = W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16]\n\n  for (var j = 0; j < 80; ++j) {\n    var s = ~~(j / 20)\n    var t = (rotl5(a) + ft(s, b, c, d) + e + W[j] + K[s]) | 0\n\n    e = d\n    d = c\n    c = rotl30(b)\n    b = a\n    a = t\n  }\n\n  this._a = (a + this._a) | 0\n  this._b = (b + this._b) | 0\n  this._c = (c + this._c) | 0\n  this._d = (d + this._d) | 0\n  this._e = (e + this._e) | 0\n}\n\nSha.prototype._hash = function () {\n  var H = new Buffer(20)\n\n  H.writeInt32BE(this._a | 0, 0)\n  H.writeInt32BE(this._b | 0, 4)\n  H.writeInt32BE(this._c | 0, 8)\n  H.writeInt32BE(this._d | 0, 12)\n  H.writeInt32BE(this._e | 0, 16)\n\n  return H\n}\n\nmodule.exports = Sha\n","/*\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-1, as defined\n * in FIPS PUB 180-1\n * Version 2.1a Copyright Paul Johnston 2000 - 2002.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n * Distributed under the BSD License\n * See http://pajhome.org.uk/crypt/md5 for details.\n */\n\nvar inherits = require('inherits')\nvar Hash = require('./hash')\n\nvar K = [\n  0x5a827999, 0x6ed9eba1, 0x8f1bbcdc | 0, 0xca62c1d6 | 0\n]\n\nvar W = new Array(80)\n\nfunction Sha1 () {\n  this.init()\n  this._w = W\n\n  Hash.call(this, 64, 56)\n}\n\ninherits(Sha1, Hash)\n\nSha1.prototype.init = function () {\n  this._a = 0x67452301\n  this._b = 0xefcdab89\n  this._c = 0x98badcfe\n  this._d = 0x10325476\n  this._e = 0xc3d2e1f0\n\n  return this\n}\n\nfunction rotl1 (num) {\n  return (num << 1) | (num >>> 31)\n}\n\nfunction rotl5 (num) {\n  return (num << 5) | (num >>> 27)\n}\n\nfunction rotl30 (num) {\n  return (num << 30) | (num >>> 2)\n}\n\nfunction ft (s, b, c, d) {\n  if (s === 0) return (b & c) | ((~b) & d)\n  if (s === 2) return (b & c) | (b & d) | (c & d)\n  return b ^ c ^ d\n}\n\nSha1.prototype._update = function (M) {\n  var W = this._w\n\n  var a = this._a | 0\n  var b = this._b | 0\n  var c = this._c | 0\n  var d = this._d | 0\n  var e = this._e | 0\n\n  for (var i = 0; i < 16; ++i) W[i] = M.readInt32BE(i * 4)\n  for (; i < 80; ++i) W[i] = rotl1(W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16])\n\n  for (var j = 0; j < 80; ++j) {\n    var s = ~~(j / 20)\n    var t = (rotl5(a) + ft(s, b, c, d) + e + W[j] + K[s]) | 0\n\n    e = d\n    d = c\n    c = rotl30(b)\n    b = a\n    a = t\n  }\n\n  this._a = (a + this._a) | 0\n  this._b = (b + this._b) | 0\n  this._c = (c + this._c) | 0\n  this._d = (d + this._d) | 0\n  this._e = (e + this._e) | 0\n}\n\nSha1.prototype._hash = function () {\n  var H = new Buffer(20)\n\n  H.writeInt32BE(this._a | 0, 0)\n  H.writeInt32BE(this._b | 0, 4)\n  H.writeInt32BE(this._c | 0, 8)\n  H.writeInt32BE(this._d | 0, 12)\n  H.writeInt32BE(this._e | 0, 16)\n\n  return H\n}\n\nmodule.exports = Sha1\n","/**\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-256, as defined\n * in FIPS 180-2\n * Version 2.2-beta Copyright Angel Marin, Paul Johnston 2000 - 2009.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n *\n */\n\nvar inherits = require('inherits')\nvar Sha256 = require('./sha256')\nvar Hash = require('./hash')\n\nvar W = new Array(64)\n\nfunction Sha224 () {\n  this.init()\n\n  this._w = W // new Array(64)\n\n  Hash.call(this, 64, 56)\n}\n\ninherits(Sha224, Sha256)\n\nSha224.prototype.init = function () {\n  this._a = 0xc1059ed8\n  this._b = 0x367cd507\n  this._c = 0x3070dd17\n  this._d = 0xf70e5939\n  this._e = 0xffc00b31\n  this._f = 0x68581511\n  this._g = 0x64f98fa7\n  this._h = 0xbefa4fa4\n\n  return this\n}\n\nSha224.prototype._hash = function () {\n  var H = new Buffer(28)\n\n  H.writeInt32BE(this._a, 0)\n  H.writeInt32BE(this._b, 4)\n  H.writeInt32BE(this._c, 8)\n  H.writeInt32BE(this._d, 12)\n  H.writeInt32BE(this._e, 16)\n  H.writeInt32BE(this._f, 20)\n  H.writeInt32BE(this._g, 24)\n\n  return H\n}\n\nmodule.exports = Sha224\n","/**\n * A JavaScript implementation of the Secure Hash Algorithm, SHA-256, as defined\n * in FIPS 180-2\n * Version 2.2-beta Copyright Angel Marin, Paul Johnston 2000 - 2009.\n * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet\n *\n */\n\nvar inherits = require('inherits')\nvar Hash = require('./hash')\n\nvar K = [\n  0x428A2F98, 0x71374491, 0xB5C0FBCF, 0xE9B5DBA5,\n  0x3956C25B, 0x59F111F1, 0x923F82A4, 0xAB1C5ED5,\n  0xD807AA98, 0x12835B01, 0x243185BE, 0x550C7DC3,\n  0x72BE5D74, 0x80DEB1FE, 0x9BDC06A7, 0xC19BF174,\n  0xE49B69C1, 0xEFBE4786, 0x0FC19DC6, 0x240CA1CC,\n  0x2DE92C6F, 0x4A7484AA, 0x5CB0A9DC, 0x76F988DA,\n  0x983E5152, 0xA831C66D, 0xB00327C8, 0xBF597FC7,\n  0xC6E00BF3, 0xD5A79147, 0x06CA6351, 0x14292967,\n  0x27B70A85, 0x2E1B2138, 0x4D2C6DFC, 0x53380D13,\n  0x650A7354, 0x766A0ABB, 0x81C2C92E, 0x92722C85,\n  0xA2BFE8A1, 0xA81A664B, 0xC24B8B70, 0xC76C51A3,\n  0xD192E819, 0xD6990624, 0xF40E3585, 0x106AA070,\n  0x19A4C116, 0x1E376C08, 0x2748774C, 0x34B0BCB5,\n  0x391C0CB3, 0x4ED8AA4A, 0x5B9CCA4F, 0x682E6FF3,\n  0x748F82EE, 0x78A5636F, 0x84C87814, 0x8CC70208,\n  0x90BEFFFA, 0xA4506CEB, 0xBEF9A3F7, 0xC67178F2\n]\n\nvar W = new Array(64)\n\nfunction Sha256 () {\n  this.init()\n\n  this._w = W // new Array(64)\n\n  Hash.call(this, 64, 56)\n}\n\ninherits(Sha256, Hash)\n\nSha256.prototype.init = function () {\n  this._a = 0x6a09e667\n  this._b = 0xbb67ae85\n  this._c = 0x3c6ef372\n  this._d = 0xa54ff53a\n  this._e = 0x510e527f\n  this._f = 0x9b05688c\n  this._g = 0x1f83d9ab\n  this._h = 0x5be0cd19\n\n  return this\n}\n\nfunction ch (x, y, z) {\n  return z ^ (x & (y ^ z))\n}\n\nfunction maj (x, y, z) {\n  return (x & y) | (z & (x | y))\n}\n\nfunction sigma0 (x) {\n  return (x >>> 2 | x << 30) ^ (x >>> 13 | x << 19) ^ (x >>> 22 | x << 10)\n}\n\nfunction sigma1 (x) {\n  return (x >>> 6 | x << 26) ^ (x >>> 11 | x << 21) ^ (x >>> 25 | x << 7)\n}\n\nfunction gamma0 (x) {\n  return (x >>> 7 | x << 25) ^ (x >>> 18 | x << 14) ^ (x >>> 3)\n}\n\nfunction gamma1 (x) {\n  return (x >>> 17 | x << 15) ^ (x >>> 19 | x << 13) ^ (x >>> 10)\n}\n\nSha256.prototype._update = function (M) {\n  var W = this._w\n\n  var a = this._a | 0\n  var b = this._b | 0\n  var c = this._c | 0\n  var d = this._d | 0\n  var e = this._e | 0\n  var f = this._f | 0\n  var g = this._g | 0\n  var h = this._h | 0\n\n  for (var i = 0; i < 16; ++i) W[i] = M.readInt32BE(i * 4)\n  for (; i < 64; ++i) W[i] = (gamma1(W[i - 2]) + W[i - 7] + gamma0(W[i - 15]) + W[i - 16]) | 0\n\n  for (var j = 0; j < 64; ++j) {\n    var T1 = (h + sigma1(e) + ch(e, f, g) + K[j] + W[j]) | 0\n    var T2 = (sigma0(a) + maj(a, b, c)) | 0\n\n    h = g\n    g = f\n    f = e\n    e = (d + T1) | 0\n    d = c\n    c = b\n    b = a\n    a = (T1 + T2) | 0\n  }\n\n  this._a = (a + this._a) | 0\n  this._b = (b + this._b) | 0\n  this._c = (c + this._c) | 0\n  this._d = (d + this._d) | 0\n  this._e = (e + this._e) | 0\n  this._f = (f + this._f) | 0\n  this._g = (g + this._g) | 0\n  this._h = (h + this._h) | 0\n}\n\nSha256.prototype._hash = function () {\n  var H = new Buffer(32)\n\n  H.writeInt32BE(this._a, 0)\n  H.writeInt32BE(this._b, 4)\n  H.writeInt32BE(this._c, 8)\n  H.writeInt32BE(this._d, 12)\n  H.writeInt32BE(this._e, 16)\n  H.writeInt32BE(this._f, 20)\n  H.writeInt32BE(this._g, 24)\n  H.writeInt32BE(this._h, 28)\n\n  return H\n}\n\nmodule.exports = Sha256\n","var inherits = require('inherits')\nvar SHA512 = require('./sha512')\nvar Hash = require('./hash')\n\nvar W = new Array(160)\n\nfunction Sha384 () {\n  this.init()\n  this._w = W\n\n  Hash.call(this, 128, 112)\n}\n\ninherits(Sha384, SHA512)\n\nSha384.prototype.init = function () {\n  this._ah = 0xcbbb9d5d\n  this._bh = 0x629a292a\n  this._ch = 0x9159015a\n  this._dh = 0x152fecd8\n  this._eh = 0x67332667\n  this._fh = 0x8eb44a87\n  this._gh = 0xdb0c2e0d\n  this._hh = 0x47b5481d\n\n  this._al = 0xc1059ed8\n  this._bl = 0x367cd507\n  this._cl = 0x3070dd17\n  this._dl = 0xf70e5939\n  this._el = 0xffc00b31\n  this._fl = 0x68581511\n  this._gl = 0x64f98fa7\n  this._hl = 0xbefa4fa4\n\n  return this\n}\n\nSha384.prototype._hash = function () {\n  var H = new Buffer(48)\n\n  function writeInt64BE (h, l, offset) {\n    H.writeInt32BE(h, offset)\n    H.writeInt32BE(l, offset + 4)\n  }\n\n  writeInt64BE(this._ah, this._al, 0)\n  writeInt64BE(this._bh, this._bl, 8)\n  writeInt64BE(this._ch, this._cl, 16)\n  writeInt64BE(this._dh, this._dl, 24)\n  writeInt64BE(this._eh, this._el, 32)\n  writeInt64BE(this._fh, this._fl, 40)\n\n  return H\n}\n\nmodule.exports = Sha384\n","var inherits = require('inherits')\nvar Hash = require('./hash')\n\nvar K = [\n  0x428a2f98, 0xd728ae22, 0x71374491, 0x23ef65cd,\n  0xb5c0fbcf, 0xec4d3b2f, 0xe9b5dba5, 0x8189dbbc,\n  0x3956c25b, 0xf348b538, 0x59f111f1, 0xb605d019,\n  0x923f82a4, 0xaf194f9b, 0xab1c5ed5, 0xda6d8118,\n  0xd807aa98, 0xa3030242, 0x12835b01, 0x45706fbe,\n  0x243185be, 0x4ee4b28c, 0x550c7dc3, 0xd5ffb4e2,\n  0x72be5d74, 0xf27b896f, 0x80deb1fe, 0x3b1696b1,\n  0x9bdc06a7, 0x25c71235, 0xc19bf174, 0xcf692694,\n  0xe49b69c1, 0x9ef14ad2, 0xefbe4786, 0x384f25e3,\n  0x0fc19dc6, 0x8b8cd5b5, 0x240ca1cc, 0x77ac9c65,\n  0x2de92c6f, 0x592b0275, 0x4a7484aa, 0x6ea6e483,\n  0x5cb0a9dc, 0xbd41fbd4, 0x76f988da, 0x831153b5,\n  0x983e5152, 0xee66dfab, 0xa831c66d, 0x2db43210,\n  0xb00327c8, 0x98fb213f, 0xbf597fc7, 0xbeef0ee4,\n  0xc6e00bf3, 0x3da88fc2, 0xd5a79147, 0x930aa725,\n  0x06ca6351, 0xe003826f, 0x14292967, 0x0a0e6e70,\n  0x27b70a85, 0x46d22ffc, 0x2e1b2138, 0x5c26c926,\n  0x4d2c6dfc, 0x5ac42aed, 0x53380d13, 0x9d95b3df,\n  0x650a7354, 0x8baf63de, 0x766a0abb, 0x3c77b2a8,\n  0x81c2c92e, 0x47edaee6, 0x92722c85, 0x1482353b,\n  0xa2bfe8a1, 0x4cf10364, 0xa81a664b, 0xbc423001,\n  0xc24b8b70, 0xd0f89791, 0xc76c51a3, 0x0654be30,\n  0xd192e819, 0xd6ef5218, 0xd6990624, 0x5565a910,\n  0xf40e3585, 0x5771202a, 0x106aa070, 0x32bbd1b8,\n  0x19a4c116, 0xb8d2d0c8, 0x1e376c08, 0x5141ab53,\n  0x2748774c, 0xdf8eeb99, 0x34b0bcb5, 0xe19b48a8,\n  0x391c0cb3, 0xc5c95a63, 0x4ed8aa4a, 0xe3418acb,\n  0x5b9cca4f, 0x7763e373, 0x682e6ff3, 0xd6b2b8a3,\n  0x748f82ee, 0x5defb2fc, 0x78a5636f, 0x43172f60,\n  0x84c87814, 0xa1f0ab72, 0x8cc70208, 0x1a6439ec,\n  0x90befffa, 0x23631e28, 0xa4506ceb, 0xde82bde9,\n  0xbef9a3f7, 0xb2c67915, 0xc67178f2, 0xe372532b,\n  0xca273ece, 0xea26619c, 0xd186b8c7, 0x21c0c207,\n  0xeada7dd6, 0xcde0eb1e, 0xf57d4f7f, 0xee6ed178,\n  0x06f067aa, 0x72176fba, 0x0a637dc5, 0xa2c898a6,\n  0x113f9804, 0xbef90dae, 0x1b710b35, 0x131c471b,\n  0x28db77f5, 0x23047d84, 0x32caab7b, 0x40c72493,\n  0x3c9ebe0a, 0x15c9bebc, 0x431d67c4, 0x9c100d4c,\n  0x4cc5d4be, 0xcb3e42b6, 0x597f299c, 0xfc657e2a,\n  0x5fcb6fab, 0x3ad6faec, 0x6c44198c, 0x4a475817\n]\n\nvar W = new Array(160)\n\nfunction Sha512 () {\n  this.init()\n  this._w = W\n\n  Hash.call(this, 128, 112)\n}\n\ninherits(Sha512, Hash)\n\nSha512.prototype.init = function () {\n  this._ah = 0x6a09e667\n  this._bh = 0xbb67ae85\n  this._ch = 0x3c6ef372\n  this._dh = 0xa54ff53a\n  this._eh = 0x510e527f\n  this._fh = 0x9b05688c\n  this._gh = 0x1f83d9ab\n  this._hh = 0x5be0cd19\n\n  this._al = 0xf3bcc908\n  this._bl = 0x84caa73b\n  this._cl = 0xfe94f82b\n  this._dl = 0x5f1d36f1\n  this._el = 0xade682d1\n  this._fl = 0x2b3e6c1f\n  this._gl = 0xfb41bd6b\n  this._hl = 0x137e2179\n\n  return this\n}\n\nfunction Ch (x, y, z) {\n  return z ^ (x & (y ^ z))\n}\n\nfunction maj (x, y, z) {\n  return (x & y) | (z & (x | y))\n}\n\nfunction sigma0 (x, xl) {\n  return (x >>> 28 | xl << 4) ^ (xl >>> 2 | x << 30) ^ (xl >>> 7 | x << 25)\n}\n\nfunction sigma1 (x, xl) {\n  return (x >>> 14 | xl << 18) ^ (x >>> 18 | xl << 14) ^ (xl >>> 9 | x << 23)\n}\n\nfunction Gamma0 (x, xl) {\n  return (x >>> 1 | xl << 31) ^ (x >>> 8 | xl << 24) ^ (x >>> 7)\n}\n\nfunction Gamma0l (x, xl) {\n  return (x >>> 1 | xl << 31) ^ (x >>> 8 | xl << 24) ^ (x >>> 7 | xl << 25)\n}\n\nfunction Gamma1 (x, xl) {\n  return (x >>> 19 | xl << 13) ^ (xl >>> 29 | x << 3) ^ (x >>> 6)\n}\n\nfunction Gamma1l (x, xl) {\n  return (x >>> 19 | xl << 13) ^ (xl >>> 29 | x << 3) ^ (x >>> 6 | xl << 26)\n}\n\nfunction getCarry (a, b) {\n  return (a >>> 0) < (b >>> 0) ? 1 : 0\n}\n\nSha512.prototype._update = function (M) {\n  var W = this._w\n\n  var ah = this._ah | 0\n  var bh = this._bh | 0\n  var ch = this._ch | 0\n  var dh = this._dh | 0\n  var eh = this._eh | 0\n  var fh = this._fh | 0\n  var gh = this._gh | 0\n  var hh = this._hh | 0\n\n  var al = this._al | 0\n  var bl = this._bl | 0\n  var cl = this._cl | 0\n  var dl = this._dl | 0\n  var el = this._el | 0\n  var fl = this._fl | 0\n  var gl = this._gl | 0\n  var hl = this._hl | 0\n\n  for (var i = 0; i < 32; i += 2) {\n    W[i] = M.readInt32BE(i * 4)\n    W[i + 1] = M.readInt32BE(i * 4 + 4)\n  }\n  for (; i < 160; i += 2) {\n    var xh = W[i - 15 * 2]\n    var xl = W[i - 15 * 2 + 1]\n    var gamma0 = Gamma0(xh, xl)\n    var gamma0l = Gamma0l(xl, xh)\n\n    xh = W[i - 2 * 2]\n    xl = W[i - 2 * 2 + 1]\n    var gamma1 = Gamma1(xh, xl)\n    var gamma1l = Gamma1l(xl, xh)\n\n    // W[i] = gamma0 + W[i - 7] + gamma1 + W[i - 16]\n    var Wi7h = W[i - 7 * 2]\n    var Wi7l = W[i - 7 * 2 + 1]\n\n    var Wi16h = W[i - 16 * 2]\n    var Wi16l = W[i - 16 * 2 + 1]\n\n    var Wil = (gamma0l + Wi7l) | 0\n    var Wih = (gamma0 + Wi7h + getCarry(Wil, gamma0l)) | 0\n    Wil = (Wil + gamma1l) | 0\n    Wih = (Wih + gamma1 + getCarry(Wil, gamma1l)) | 0\n    Wil = (Wil + Wi16l) | 0\n    Wih = (Wih + Wi16h + getCarry(Wil, Wi16l)) | 0\n\n    W[i] = Wih\n    W[i + 1] = Wil\n  }\n\n  for (var j = 0; j < 160; j += 2) {\n    Wih = W[j]\n    Wil = W[j + 1]\n\n    var majh = maj(ah, bh, ch)\n    var majl = maj(al, bl, cl)\n\n    var sigma0h = sigma0(ah, al)\n    var sigma0l = sigma0(al, ah)\n    var sigma1h = sigma1(eh, el)\n    var sigma1l = sigma1(el, eh)\n\n    // t1 = h + sigma1 + ch + K[j] + W[j]\n    var Kih = K[j]\n    var Kil = K[j + 1]\n\n    var chh = Ch(eh, fh, gh)\n    var chl = Ch(el, fl, gl)\n\n    var t1l = (hl + sigma1l) | 0\n    var t1h = (hh + sigma1h + getCarry(t1l, hl)) | 0\n    t1l = (t1l + chl) | 0\n    t1h = (t1h + chh + getCarry(t1l, chl)) | 0\n    t1l = (t1l + Kil) | 0\n    t1h = (t1h + Kih + getCarry(t1l, Kil)) | 0\n    t1l = (t1l + Wil) | 0\n    t1h = (t1h + Wih + getCarry(t1l, Wil)) | 0\n\n    // t2 = sigma0 + maj\n    var t2l = (sigma0l + majl) | 0\n    var t2h = (sigma0h + majh + getCarry(t2l, sigma0l)) | 0\n\n    hh = gh\n    hl = gl\n    gh = fh\n    gl = fl\n    fh = eh\n    fl = el\n    el = (dl + t1l) | 0\n    eh = (dh + t1h + getCarry(el, dl)) | 0\n    dh = ch\n    dl = cl\n    ch = bh\n    cl = bl\n    bh = ah\n    bl = al\n    al = (t1l + t2l) | 0\n    ah = (t1h + t2h + getCarry(al, t1l)) | 0\n  }\n\n  this._al = (this._al + al) | 0\n  this._bl = (this._bl + bl) | 0\n  this._cl = (this._cl + cl) | 0\n  this._dl = (this._dl + dl) | 0\n  this._el = (this._el + el) | 0\n  this._fl = (this._fl + fl) | 0\n  this._gl = (this._gl + gl) | 0\n  this._hl = (this._hl + hl) | 0\n\n  this._ah = (this._ah + ah + getCarry(this._al, al)) | 0\n  this._bh = (this._bh + bh + getCarry(this._bl, bl)) | 0\n  this._ch = (this._ch + ch + getCarry(this._cl, cl)) | 0\n  this._dh = (this._dh + dh + getCarry(this._dl, dl)) | 0\n  this._eh = (this._eh + eh + getCarry(this._el, el)) | 0\n  this._fh = (this._fh + fh + getCarry(this._fl, fl)) | 0\n  this._gh = (this._gh + gh + getCarry(this._gl, gl)) | 0\n  this._hh = (this._hh + hh + getCarry(this._hl, hl)) | 0\n}\n\nSha512.prototype._hash = function () {\n  var H = new Buffer(64)\n\n  function writeInt64BE (h, l, offset) {\n    H.writeInt32BE(h, offset)\n    H.writeInt32BE(l, offset + 4)\n  }\n\n  writeInt64BE(this._ah, this._al, 0)\n  writeInt64BE(this._bh, this._bl, 8)\n  writeInt64BE(this._ch, this._cl, 16)\n  writeInt64BE(this._dh, this._dl, 24)\n  writeInt64BE(this._eh, this._el, 32)\n  writeInt64BE(this._fh, this._fl, 40)\n  writeInt64BE(this._gh, this._gl, 48)\n  writeInt64BE(this._hh, this._hl, 56)\n\n  return H\n}\n\nmodule.exports = Sha512\n","\nvar sodium = require('libsodium-wrappers')\n\nfunction I(b) {\n  return Buffer.isBuffer(b) ? new Uint8Array(b) : b\n}\n\nfunction B(b) {\n  return (b instanceof Uint8Array) ? new Buffer(b) : b\n}\n\nfunction bufferize(fn) {\n  if('function' !== typeof fn)\n    throw new Error('not a function')\n  return function () {\n    var args = [].map.call(arguments, I)\n    var r =  B(fn.apply(this, args))\n    return r\n  }\n}\n\nfunction keys (k) {\n  return {\n    publicKey: B(k.publicKey),\n    secretKey: B(k.secretKey || k.privateKey)\n  }\n}\n\nexports.crypto_sign_seed_keypair = function (seed) {\n  return keys(sodium.crypto_sign_seed_keypair(I(seed)))\n}\n\nexports.crypto_sign_keypair = function () {\n  return keys(sodium.crypto_sign_keypair())\n}\n\nexports.crypto_box_keypair = function () {\n  return keys(sodium.crypto_box_keypair())\n}\n\n;[\n  'sign_verify_detached',\n  'sign_detached',\n  'sign',\n  'sign_open',\n  'sign_ed25519_pk_to_curve25519',\n  'sign_ed25519_sk_to_curve25519',\n  'scalarmult',\n  'secretbox_easy',\n  'secretbox_open_easy',\n  'box_easy',\n  'box_open_easy',\n  'auth',\n  'auth_verify',\n  'hash'\n].forEach(function (name) {\n  if(name === 'auth_verify') {\n    //this is inconsistent with sign_verify!!\n    var fn = bufferize(sodium.crypto_auth_verify)\n    exports['crypto_'+name] = function (msg, tok, key) { return fn(msg, tok, key) ? 0 : 1 }\n  }\n  else\n    exports['crypto_'+name] = bufferize(sodium['crypto_'+name])\n})\n\nvar Sha256 = require('sha.js/sha256')\nexports.crypto_hash_sha256 = function (msg) {\n  return new Sha256().update(msg).digest()\n}\n\nfunction nullIfThrew (fn) {\n  return function () {\n    try { return fn.apply(this, [].slice.call(arguments)) }\n    catch (err) { return null }\n  }\n}\n\nexports.crypto_secretbox_open_easy = nullIfThrew(exports.crypto_secretbox_open_easy)\nexports.crypto_box_open_easy = nullIfThrew(exports.crypto_box_open_easy)\n\n","\n//only exports browser api. use chloride module\n//to get automatic fallbacks!\nmodule.exports = require('./browser')\n","\nmodule.exports = function split (data, max) {\n\n  if(max <= 0) throw new Error('cannot split into zero (or smaller) length buffers')\n\n  if(data.length <= max)\n    return [data]\n  var out = [], len = 0\n\n  while(len < data.length) {\n    out.push(data.slice(len, Math.min(len + max, data.length)))\n    len += max\n  }\n\n  return out\n}\n\n","var path = require('path')\nvar home = require('osenv').home\nvar nonPrivate = require('non-private-ip')\nvar merge = require('deep-extend')\n\nvar RC = require('rc')\n\nvar SEC = 1e3\nvar MIN = 60*SEC\n\nmodule.exports = function (name, override) {\n  name = name || 'ssb'\n  return RC(name || 'ssb', merge({\n    //just use an ipv4 address by default.\n    //there have been some reports of seemingly non-private\n    //ipv6 addresses being returned and not working.\n    //https://github.com/ssbc/scuttlebot/pull/102\n    party: true,\n    host: nonPrivate.v4 || '',\n    port: 8008,\n    timeout: 0,\n    pub: true,\n    local: true,\n    friends: {\n      dunbar: 150,\n      hops: 3\n    },\n    gossip: {\n      connections: 3\n    },\n    path: path.join(home(), '.' + name),\n    timers: {\n      connection: 0,\n      reconnect: 5*SEC,\n      ping: 5*MIN,\n      handshake: 5*SEC\n    },\n    path: path.join(home(), '.' + name),\n    master: [],\n    logging: { level: 'notice' },\n    party: true //disable quotas\n  }, override || {}))\n}\n\n\n\n\n","var cont = require('cont')\nvar util = require('./util')\n\nvar ssbKeys = require('ssb-keys')\n\nfunction isFunction (f) {\n  return 'function' === typeof f\n}\n\nfunction isObject (o) {\n  return (\n    o && 'object' === typeof o\n    && !Buffer.isBuffer(o)\n    && !Array.isArray(o)\n  )\n}\n\nmodule.exports = function (ssb, keys) {\n\n  if(!ssb.add)\n    throw new Error('*must* install feeds on this ssb instance')\n\n  function getPrev(next) {\n    ssb.getLatest(keys.id, next)\n  }\n  function noop (err) {\n    if (err) throw err\n  }\n\n  var queue = null\n  var prev = null\n  var writing = false\n  var publish =\n    cont(function (type, message, cb) {\n      // argument variations\n      if (isFunction(message))    { cb = message; message = type } // add(msgObj, cbFn)\n      else if (isObject(message)) { message.type = type } // add(typeStr, mgObj, cbFn)\n      else                        { message = { type: type, value: message } } // add(typeStr, msgStr, cbFn)\n\n      var err = util.isInvalidContent(message)\n      if(err) return cb(err)\n\n      return ssb.add.queue(keys.id, function (key, value) {\n        return util.create(keys, null, message, value, key)\n      }, cb)\n\n      return this\n    })\n\n  return {\n    id: keys.id,\n    keys: keys,\n    add: publish,\n    publish: publish\n  }\n}\n\n\n","var ssbKeys = require('ssb-keys')\nvar timestamp = require('monotonic-timestamp')\nvar isRef = require('ssb-ref')\nvar isHash = isRef.isHash\nvar isFeedId = isRef.isFeedId\n\nvar encode = exports.encode = function (obj) {\n  return JSON.stringify(obj, null, 2)\n}\n\nfunction isString (s) {\n  return 'string' === typeof s\n}\n\nfunction isInteger (n) {\n  return ~~n === n\n}\n\nfunction isObject (o) {\n  return o && 'object' === typeof o\n}\n\nfunction clone (obj) {\n  var o = {}\n  for(var k in obj) o[k] = obj[k];\n  return o\n}\n\nfunction isEncrypted (str) {\n  return isString(str) && /^[0-9A-Za-z\\/+]+={0,2}\\.box/.test(str)\n}\n\nexports.BatchQueue = function BatchQueue (db) {\n\n  var batch = [], writing = false\n\n  function drain () {\n    writing = true\n    var _batch = batch\n    batch = []\n\n    db.batch(_batch, function () {\n      writing = false\n      write.size = batch.length\n      if(batch.length) drain()\n      _batch.forEach(function (op) {\n        op.cb(null, {key:op.key, value: op.value})\n      })\n    })\n  }\n\n  function write (op) {\n    batch.push(op)\n    write.size = batch.length\n    if(!writing) drain()\n  }\n\n  write.size = 0\n\n  return write\n}\n\nexports.create = function (keys, type, content, prev, prev_key) {\n\n  //this noise is to handle things calling this with legacy api.\n  if(isString(type) && (Buffer.isBuffer(content) || isString(content)))\n    content = {type: type, value: content}\n  if(isObject(content))\n    content.type = content.type || type\n  //noise end\n\n  prev_key = !prev_key && prev ? ('%'+ssbKeys.hash(encode(prev))) : prev_key || null\n\n  return ssbKeys.signObj(keys, {\n    previous: prev_key,\n    author: keys.id,\n    sequence: prev ? prev.sequence + 1 : 1,\n    timestamp: timestamp(),\n    hash: 'sha256',\n    content: content,\n  })\n}\n\nvar isInvalidContent = exports.isInvalidContent = function (content) {\n  if(!isEncrypted(content)) {\n\n    type = content.type\n\n    if (!(isString(type) && type.length <= 52 && type.length >= 3)) {\n      return new Error('type must be a string' +\n        '3 <= type.length < 52, was:' + type\n      )\n    }\n  }\n  return false\n}\n\nexports.isInvalidShape = function (msg) {\n  if(\n    !isObject(msg) ||\n    !isInteger(msg.sequence) ||\n    !isFeedId(msg.author) ||\n    !(isObject(msg.content) || isEncrypted(msg.content))\n  )\n    return new Error('message has invalid properties')\n\n  //allow encrypted messages, where content is a base64 string.\n\n  var asJson = encode(msg)\n  if (asJson.length > 8192) // 8kb\n    return new Error( 'encoded message must not be larger than 8192 bytes')\n\n  return isInvalidContent(msg.content)\n}\n\nexports.isInvalid = function validateSync (pub, msg, previous) {\n  // :TODO: is there a faster way to measure the size of this message?\n\n  var key = previous.key\n  var prev = previous.value\n\n  if(prev) {\n    if(msg.previous !== key)\n      return new Error(\n          'expected previous: '\n        + key\n        + 'but found:' + msg.previous\n      )\n\n    if(msg.sequence !== prev.sequence + 1\n     || msg.timestamp <= prev.timestamp)\n        return new Error('out of order')\n  }\n  else {\n    if(!(msg.previous == null\n      && msg.sequence === 1 && msg.timestamp > 0))\n        return new Error('expected initial message')\n  }\n\n  if(msg.author !== pub) {\n\n    return new Error(\n        'expected different author:'\n      + hash(pub.public || pub).toString('base64')\n      + 'but found:' + msg.author.toString('base64')\n    )\n  }\n\n  if(!ssbKeys.verifyObj(pub, msg))\n    return new Error('signature was invalid')\n\n  return false\n}\n\n","'use strict';\n\nvar hash = require('ssb-keys').hash\n\n// make a validation stream?\n// read the latest record in the database\n// check it against the incoming data,\n// and then read through\n\nfunction isString (s) {\n  return 'string' === typeof s\n}\n\nfunction isInteger (n) {\n  return ~~n === n\n}\n\nfunction isObject (o) {\n  return o && 'object' === typeof o\n}\n\nvar util = require('./util')\nvar encode = util.encode\n\nmodule.exports = function (ssb) {\n\n  var write = util.BatchQueue(ssb)\n\n  function getLatest (id, cb) {\n    ssb.getLatest(id, function (err, data) {\n      if(err) return cb(null, {key: null, value: null, type: 'put', public: null, ready: true})\n      cb(null, {\n        key: data.key, value: data.value, type: 'put',\n        public: data.value && data.value.author, ready: true\n      })\n    })\n  }\n\n  var latest = {}\n\n  function setLatest(id) {\n    if(latest[id].ready)\n      throw new Error('setLatest should only be called once')\n    ssb.getLatest(id, function (err, data) {\n      latest[id].ready = true\n      if(data) {\n        latest[id].key = data.key\n        latest[id].value = data.value\n      }\n      validate(id)\n    })\n  }\n\n  function validate(id) {\n    var feed = latest[id]\n    if(!feed.queue.length) return\n    if(!feed.ready) return\n\n    while(feed.queue.length) {\n      var op = feed.queue.shift()\n\n\n      if('function' == typeof op.create) {\n        op.value = op.create(feed.key, feed.value)\n        op.key = '%'+hash(encode(op.value))\n      }\n\n      var err =\n        util.isInvalidShape(op.value) ||\n        util.isInvalid(id, op.value, feed)\n\n      if(err)\n        op.cb(err)\n      else {\n        feed.key = op.key\n        feed.value = op.value\n        feed.ts = Date.now()\n        write(op)\n      }\n    }\n  }\n\n  function queue (id, job) {\n    if(!latest[id]) {\n      latest[id] = {\n        key:null, value: null,\n        ready: false, queue: [],\n        ts: Date.now()\n      }\n      latest[id].queue.push(job)\n      setLatest(id)\n    }\n    else\n      latest[id].queue.push(job)\n\n    validate(id)\n  }\n\n  function add (msg, cb) {\n    var err = util.isInvalidShape(msg)\n    if(err) return cb(err)\n\n    queue(msg.author, {\n        key: '%'+hash(encode(msg)),\n        value: msg, cb: cb,\n        create: null\n      })\n  }\n\n  add.queue = function (id, create, cb) {\n    queue(id, {\n        key: null, value: null,\n        create: create, cb: cb\n      })\n\n  }\n\n  return add\n}\n","var pull   = require('pull-stream')\nvar toPull = require('stream-to-pull-stream')\nvar cat    = require('pull-cat')\nvar ident  = require('pull-identify-filetype')\nvar mime   = require('mime-types')\nvar URL    = require('url')\nvar fs     = require('fs')\nvar refs   = require('ssb-ref')\nvar Stack  = require('stack')\nvar ip     = require('ip')\n\nexports = module.exports = function (sbot, config) {\n  require('http').createServer(exports.BlobStack(sbot)).listen(7777)\n}\n\nfunction respond (res, status, message) {\n  res.writeHead(status)\n  res.end(message)\n}\n\nfunction respondSource (res, source, wrap) {\n  if(wrap) {\n    res.writeHead(200, {'Content-Type': 'text/html'})\n    pull(\n      cat([\n        pull.once('<html><body><script>'),\n        source,\n        pull.once('</script></body></html>')\n      ]),\n      toPull.sink(res)\n    )\n  }\n  else {\n    pull(\n      source,\n      ident(function (type) {\n        if (type) res.writeHead(200, {'Content-Type': mime.lookup(type)})\n      }),\n      toPull.sink(res)\n    )\n  }\n}\n\nvar Localhost = exports.Localhost = function () {\n  return function (req, res, next) {\n    if (!ip.isLoopback(req.socket.remoteAddress))\n      return respond(res, 403, 'Remote access forbidden')\n    next()\n  }\n}\n\nvar CSP = exports.CSP = function (origin) {\n  return function (req, res, next) {\n    res.setHeader('Content-Security-Policy', \n      \"default-src \"+origin+\" 'unsafe-inline' 'unsafe-eval' data:; \"+\n      \"object-src 'none'; \"+\n      \"frame-src 'none'; \"+\n      \"sandbox\"\n    )\n    next()\n  }\n}\n\nvar ServeBlobs = exports.ServeBlobs = function (sbot) {\n  return function (req, res, next) {\n    var parsed = URL.parse(req.url, true)\n    var hash = parsed.pathname.slice(1)\n    sbot.blobs.want(hash, function(err, has) {\n      if (!has) return respond(res, 404, 'File not found')\n\n      // optional name override\n      if (parsed.query.name)\n        res.setHeader('Content-Disposition', 'inline; filename='+encodeURIComponent(parsed.query.name))\n\n      // serve\n      respondSource(res, sbot.blobs.get(hash), false)\n    })\n  }\n}\n\nvar ServeFiles = exports.ServeFiles = function () {\n  return function (req, res, next) {\n    var parsed = URL.parse(req.url, true)\n    fs.stat(parsed.pathname, function (err, stat) {\n      if(err) return respond(res, 404, 'File not found')\n      if(!stat.isFile()) return respond(res, 403, 'May only load filess')\n      respondSource(\n        res,\n        toPull.source(fs.createReadStream(parsed.pathname)),\n        false\n      )\n    })\n  }\n}\n\nexports.BlobStack = function (sbot, opts) {\n  return Stack(\n    Localhost(),\n    CSP('http://localhost:7777'),\n    ServeBlobs(sbot)\n  )\n}\n\nexports.FileStack = function (opts) {\n  return Stack(\n    Localhost(),\n    CSP('http://localhost:7777'),\n    ServeFiles()\n  )\n}\n","'use strict';\n\nvar ip = exports;\nvar Buffer = require('buffer').Buffer;\nvar os = require('os');\n\nip.toBuffer = function(ip, buff, offset) {\n  offset = ~~offset;\n\n  var result;\n\n  if (this.isV4Format(ip)) {\n    result = buff || new Buffer(offset + 4);\n    ip.split(/\\./g).map(function(byte) {\n      result[offset++] = parseInt(byte, 10) & 0xff;\n    });\n  } else if (this.isV6Format(ip)) {\n    var sections = ip.split(':', 8);\n\n    var i;\n    for (i = 0; i < sections.length; i++) {\n      var isv4 = this.isV4Format(sections[i]);\n      var v4Buffer;\n\n      if (isv4) {\n        v4Buffer = this.toBuffer(sections[i]);\n        sections[i] = v4Buffer.slice(0, 2).toString('hex');\n      }\n\n      if (v4Buffer && ++i < 8) {\n        sections.splice(i, 0, v4Buffer.slice(2, 4).toString('hex'));\n      }\n    }\n\n    if (sections[0] === '') {\n      while (sections.length < 8) sections.unshift('0');\n    } else if (sections[sections.length - 1] === '') {\n      while (sections.length < 8) sections.push('0');\n    } else if (sections.length < 8) {\n      for (i = 0; i < sections.length && sections[i] !== ''; i++);\n      var argv = [ i, 1 ];\n      for (i = 9 - sections.length; i > 0; i--) {\n        argv.push('0');\n      }\n      sections.splice.apply(sections, argv);\n    }\n\n    result = buff || new Buffer(offset + 16);\n    for (i = 0; i < sections.length; i++) {\n      var word = parseInt(sections[i], 16);\n      result[offset++] = (word >> 8) & 0xff;\n      result[offset++] = word & 0xff;\n    }\n  }\n\n  if (!result) {\n    throw Error('Invalid ip address: ' + ip);\n  }\n\n  return result;\n};\n\nip.toString = function(buff, offset, length) {\n  offset = ~~offset;\n  length = length || (buff.length - offset);\n\n  var result = [];\n  if (length === 4) {\n    // IPv4\n    for (var i = 0; i < length; i++) {\n      result.push(buff[offset + i]);\n    }\n    result = result.join('.');\n  } else if (length === 16) {\n    // IPv6\n    for (var i = 0; i < length; i += 2) {\n      result.push(buff.readUInt16BE(offset + i).toString(16));\n    }\n    result = result.join(':');\n    result = result.replace(/(^|:)0(:0)*:0(:|$)/, '$1::$3');\n    result = result.replace(/:{3,4}/, '::');\n  }\n\n  return result;\n};\n\nvar ipv4Regex = /^(\\d{1,3}\\.){3,3}\\d{1,3}$/;\nvar ipv6Regex =\n    /^(::)?(((\\d{1,3}\\.){3}(\\d{1,3}){1})?([0-9a-f]){0,4}:{0,2}){1,8}(::)?$/i;\n\nip.isV4Format = function(ip) {\n  return ipv4Regex.test(ip);\n};\n\nip.isV6Format = function(ip) {\n  return ipv6Regex.test(ip);\n};\nfunction _normalizeFamily(family) {\n  return family ? family.toLowerCase() : 'ipv4';\n}\n\nip.fromPrefixLen = function(prefixlen, family) {\n  if (prefixlen > 32) {\n    family = 'ipv6';\n  } else {\n    family = _normalizeFamily(family);\n  }\n\n  var len = 4;\n  if (family === 'ipv6') {\n    len = 16;\n  }\n  var buff = new Buffer(len);\n\n  for (var i = 0, n = buff.length; i < n; ++i) {\n    var bits = 8;\n    if (prefixlen < 8) {\n      bits = prefixlen;\n    }\n    prefixlen -= bits;\n\n    buff[i] = ~(0xff >> bits);\n  }\n\n  return ip.toString(buff);\n};\n\nip.mask = function(addr, mask) {\n  addr = ip.toBuffer(addr);\n  mask = ip.toBuffer(mask);\n\n  var result = new Buffer(Math.max(addr.length, mask.length));\n\n  // Same protocol - do bitwise and\n  if (addr.length === mask.length) {\n    for (var i = 0; i < addr.length; i++) {\n      result[i] = addr[i] & mask[i];\n    }\n  } else if (mask.length === 4) {\n    // IPv6 address and IPv4 mask\n    // (Mask low bits)\n    for (var i = 0; i < mask.length; i++) {\n      result[i] = addr[addr.length - 4  + i] & mask[i];\n    }\n  } else {\n    // IPv6 mask and IPv4 addr\n    for (var i = 0; i < result.length - 6; i++) {\n      result[i] = 0;\n    }\n\n    // ::ffff:ipv4\n    result[10] = 0xff;\n    result[11] = 0xff;\n    for (var i = 0; i < addr.length; i++) {\n      result[i + 12] = addr[i] & mask[i + 12];\n    }\n  }\n\n  return ip.toString(result);\n};\n\nip.cidr = function(cidrString) {\n  var cidrParts = cidrString.split('/');\n\n  var addr = cidrParts[0];\n  if (cidrParts.length !== 2)\n    throw new Error('invalid CIDR subnet: ' + addr);\n\n  var mask = ip.fromPrefixLen(parseInt(cidrParts[1], 10));\n\n  return ip.mask(addr, mask);\n};\n\nip.subnet = function(addr, mask) {\n  var networkAddress = ip.toLong(ip.mask(addr, mask));\n\n  // Calculate the mask's length.\n  var maskBuffer = ip.toBuffer(mask);\n  var maskLength = 0;\n\n  for (var i = 0; i < maskBuffer.length; i++) {\n    if (maskBuffer[i] === 0xff) {\n      maskLength += 8;\n    } else {\n      var octet = maskBuffer[i] & 0xff;\n      while (octet) {\n        octet = (octet << 1) & 0xff;\n        maskLength++;\n      }\n    }\n  }\n\n  var numberOfAddresses = Math.pow(2, 32 - maskLength);\n\n  return {\n    networkAddress: ip.fromLong(networkAddress),\n    firstAddress: numberOfAddresses <= 2 ?\n                    ip.fromLong(networkAddress) :\n                    ip.fromLong(networkAddress + 1),\n    lastAddress: numberOfAddresses <= 2 ?\n                    ip.fromLong(networkAddress + numberOfAddresses - 1) :\n                    ip.fromLong(networkAddress + numberOfAddresses - 2),\n    broadcastAddress: ip.fromLong(networkAddress + numberOfAddresses - 1),\n    subnetMask: mask,\n    subnetMaskLength: maskLength,\n    numHosts: numberOfAddresses <= 2 ?\n                numberOfAddresses : numberOfAddresses - 2,\n    length: numberOfAddresses,\n    contains: function(other) {\n      return networkAddress === ip.toLong(ip.mask(other, mask));\n    }\n  };\n};\n\nip.cidrSubnet = function(cidrString) {\n  var cidrParts = cidrString.split('/');\n\n  var addr = cidrParts[0];\n  if (cidrParts.length !== 2)\n    throw new Error('invalid CIDR subnet: ' + addr);\n\n  var mask = ip.fromPrefixLen(parseInt(cidrParts[1], 10));\n\n  return ip.subnet(addr, mask);\n};\n\nip.not = function(addr) {\n  var buff = ip.toBuffer(addr);\n  for (var i = 0; i < buff.length; i++) {\n    buff[i] = 0xff ^ buff[i];\n  }\n  return ip.toString(buff);\n};\n\nip.or = function(a, b) {\n  a = ip.toBuffer(a);\n  b = ip.toBuffer(b);\n\n  // same protocol\n  if (a.length === b.length) {\n    for (var i = 0; i < a.length; ++i) {\n      a[i] |= b[i];\n    }\n    return ip.toString(a);\n\n  // mixed protocols\n  } else {\n    var buff = a;\n    var other = b;\n    if (b.length > a.length) {\n      buff = b;\n      other = a;\n    }\n\n    var offset = buff.length - other.length;\n    for (var i = offset; i < buff.length; ++i) {\n      buff[i] |= other[i - offset];\n    }\n\n    return ip.toString(buff);\n  }\n};\n\nip.isEqual = function(a, b) {\n  a = ip.toBuffer(a);\n  b = ip.toBuffer(b);\n\n  // Same protocol\n  if (a.length === b.length) {\n    for (var i = 0; i < a.length; i++) {\n      if (a[i] !== b[i]) return false;\n    }\n    return true;\n  }\n\n  // Swap\n  if (b.length === 4) {\n    var t = b;\n    b = a;\n    a = t;\n  }\n\n  // a - IPv4, b - IPv6\n  for (var i = 0; i < 10; i++) {\n    if (b[i] !== 0) return false;\n  }\n\n  var word = b.readUInt16BE(10);\n  if (word !== 0 && word !== 0xffff) return false;\n\n  for (var i = 0; i < 4; i++) {\n    if (a[i] !== b[i + 12]) return false;\n  }\n\n  return true;\n};\n\nip.isPrivate = function(addr) {\n  return /^(::f{4}:)?10\\.([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})$/i\n      .test(addr) ||\n    /^(::f{4}:)?192\\.168\\.([0-9]{1,3})\\.([0-9]{1,3})$/i.test(addr) ||\n    /^(::f{4}:)?172\\.(1[6-9]|2\\d|30|31)\\.([0-9]{1,3})\\.([0-9]{1,3})$/i\n      .test(addr) ||\n    /^(::f{4}:)?127\\.([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})$/i.test(addr) ||\n    /^(::f{4}:)?169\\.254\\.([0-9]{1,3})\\.([0-9]{1,3})$/i.test(addr) ||\n    /^f[cd][0-9a-f]{2}:/i.test(addr) ||\n    /^fe80:/i.test(addr) ||\n    /^::1$/.test(addr) ||\n    /^::$/.test(addr);\n};\n\nip.isPublic = function(addr) {\n  return !ip.isPrivate(addr);\n};\n\nip.isLoopback = function(addr) {\n  return /^(::f{4}:)?127\\.([0-9]{1,3})\\.([0-9]{1,3})\\.([0-9]{1,3})/\n      .test(addr) ||\n    /^fe80::1$/.test(addr) ||\n    /^::1$/.test(addr) ||\n    /^::$/.test(addr);\n};\n\nip.loopback = function(family) {\n  //\n  // Default to `ipv4`\n  //\n  family = _normalizeFamily(family);\n\n  if (family !== 'ipv4' && family !== 'ipv6') {\n    throw new Error('family must be ipv4 or ipv6');\n  }\n\n  return family === 'ipv4' ? '127.0.0.1' : 'fe80::1';\n};\n\n//\n// ### function address (name, family)\n// #### @name {string|'public'|'private'} **Optional** Name or security\n//      of the network interface.\n// #### @family {ipv4|ipv6} **Optional** IP family of the address (defaults\n//      to ipv4).\n//\n// Returns the address for the network interface on the current system with\n// the specified `name`:\n//   * String: First `family` address of the interface.\n//             If not found see `undefined`.\n//   * 'public': the first public ip address of family.\n//   * 'private': the first private ip address of family.\n//   * undefined: First address with `ipv4` or loopback address `127.0.0.1`.\n//\nip.address = function(name, family) {\n  var interfaces = os.networkInterfaces();\n  var all;\n\n  //\n  // Default to `ipv4`\n  //\n  family = _normalizeFamily(family);\n\n  //\n  // If a specific network interface has been named,\n  // return the address.\n  //\n  if (name && name !== 'private' && name !== 'public') {\n    var res = interfaces[name].filter(function(details) {\n      var itemFamily = details.family.toLowerCase();\n      return itemFamily === family;\n    });\n    if (res.length === 0)\n      return undefined;\n    return res[0].address;\n  }\n\n  var all = Object.keys(interfaces).map(function (nic) {\n    //\n    // Note: name will only be `public` or `private`\n    // when this is called.\n    //\n    var addresses = interfaces[nic].filter(function (details) {\n      details.family = details.family.toLowerCase();\n      if (details.family !== family || ip.isLoopback(details.address)) {\n        return false;\n      } else if (!name) {\n        return true;\n      }\n\n      return name === 'public' ? !ip.isPrivate(details.address) :\n          ip.isPrivate(details.address);\n    });\n\n    return addresses.length ? addresses[0].address : undefined;\n  }).filter(Boolean);\n\n  return !all.length ? ip.loopback(family) : all[0];\n};\n\nip.toLong = function(ip) {\n  var ipl = 0;\n  ip.split('.').forEach(function(octet) {\n    ipl <<= 8;\n    ipl += parseInt(octet);\n  });\n  return(ipl >>> 0);\n};\n\nip.fromLong = function(ipl) {\n  return ((ipl >>> 24) + '.' +\n      (ipl >> 16 & 255) + '.' +\n      (ipl >> 8 & 255) + '.' +\n      (ipl & 255) );\n};\n","\n\nvar ecc = require('eccjs')\nvar crypto = require('crypto')\nvar Blake2s = require('blake2s')\n\nvar curve = ecc.curves.k256\n\nfunction hash (message) {\n  return new Blake2s().update(message).digest()\n}\n\nmodule.exports = {\n\n  curves: ['k256'],\n\n  generate: function (seed) {\n    //we use eccjs.restore here, instead of eccjs.generate\n    //because we trust node's random generator much more than\n    //sjcl's (via crypto-browserify's polyfil this uses\n    //webcrypto's random generator in the browser)\n\n    var keys = ecc.restore(curve, seed || crypto.randomBytes(32))\n\n    return {\n      curve: 'k256',\n      public: keys.public,\n      private: keys.private\n    }\n  },\n\n  sign: function (private, message) {\n    return ecc.sign(curve, private, hash(message))\n  },\n\n  verify: function (public, sig, message) {\n    return ecc.verify(curve, public, sig, hash(message))\n  },\n\n  restore: function (seed) {\n    return ecc.restore(curve, seed)\n  }\n\n}\n","var fs         = require('fs')\nvar mkdirp     = require('mkdirp')\nvar path       = require('path')\nvar deepEqual  = require('deep-equal')\n\nvar crypto     = require('crypto')\nvar createHmac = require('hmac')\n\nvar sodium     = require('chloride')\nvar ssbref     = require('ssb-ref')\n\nvar pb         = require('private-box')\n\nvar isBuffer = Buffer.isBuffer\n\nfunction isString (s) {\n  return 'string' === typeof s\n}\n//UTILS\n\nfunction clone (obj) {\n  var _obj = {}\n  for(var k in obj) {\n    if(Object.hasOwnProperty.call(obj, k))\n      _obj[k] = obj[k]\n  }\n  return _obj\n}\n\nfunction hash (data, enc) {\n  data = (\n    'string' === typeof data && enc == null\n  ? new Buffer(data, 'binary')\n  : new Buffer(data, enc)\n  )\n  return crypto.createHash('sha256').update(data).digest('base64')+'.sha256'\n}\n\nvar isLink = ssbref.isLink\nvar isFeedId = ssbref.isFeedId\n\nexports.hash = hash\n\nfunction isObject (o) {\n  return 'object' === typeof o\n}\n\nfunction isFunction (f) {\n  return 'function' === typeof f\n}\n\nfunction isString(s) {\n  return 'string' === typeof s\n}\n\nfunction hasSigil (s) {\n  return /^(@|%|&)/.test(s)\n}\n\nfunction empty(v) { return !!v }\n\nfunction toBuffer(buf) {\n  if(buf == null) return buf\n  if(Buffer.isBuffer(buf)) throw new Error('already a buffer')\n  var i = buf.indexOf('.')\n  var start = (hasSigil(buf)) ? 1 : 0\n  return new Buffer(buf.substring(start, ~i ? i : buf.length), 'base64')\n}\n\nfunction toUint8(buf) {\n  return new Uint8Array(toBuffer(buf))\n}\n\nfunction getTag (string) {\n  var i = string.indexOf('.')\n  return string.substring(i+1)\n}\n\nexports.getTag = getTag\n\nfunction tag (key, tag) {\n  if(!tag) throw new Error('no tag for:' + key.toString('base64'))\n  return key.toString('base64')+'.' + tag.replace(/^\\./, '')\n}\n\nfunction keysToJSON(keys, curve) {\n  curve = (keys.curve || curve)\n\n  var pub = tag(keys.public.toString('base64'), curve)\n  return {\n    curve: curve,\n    public: pub,\n    private: keys.private ? tag(keys.private.toString('base64'), curve) : undefined,\n    id: '@'+(curve === 'ed25519' ? pub : hash(pub))\n  }\n}\n\n//(DE)SERIALIZE KEYS\n\nfunction constructKeys(keys, legacy) {\n  if(!keys) throw new Error('*must* pass in keys') \n\n  return [\n  '# this is your SECRET name.',\n  '# this name gives you magical powers.',\n  '# with it you can mark your messages so that your friends can verify',\n  '# that they really did come from you.',\n  '#',\n  '# if any one learns this name, they can use it to destroy your identity',\n  '# NEVER show this to anyone!!!',\n  '',\n  legacy ? keys.private : JSON.stringify(keys, null, 2),\n  '',\n  '# WARNING! It\\'s vital that you DO NOT edit OR share your secret name',\n  '# instead, share your public name',\n  '# your public name: ' + keys.id\n  ].join('\\n')\n}\n\nfunction reconstructKeys(keyfile) {\n  var private = keyfile\n    .replace(/\\s*\\#[^\\n]*/g, '')\n    .split('\\n').filter(empty).join('')\n\n  //if the key is in JSON format, we are good.\n  try {\n    var keys = JSON.parse(private)\n    if(!hasSigil(keys.id)) keys.id = '@' + keys.public\n    return keys\n  } catch (_) {}\n\n  //else, reconstruct legacy curve...\n\n  var curve = getTag(private)\n\n  if(curve !== 'k256')\n    throw new Error('expected legacy curve (k256) but found:' + curve)\n\n  var ecc = require('./eccjs')\n\n  return keysToJSON(ecc.restore(toBuffer(private)), 'k256')\n}\n\nvar toNameFile = exports.toNameFile = function (namefile) {\n  if(isObject(namefile))\n    return path.join(namefile.path, 'secret')\n  return namefile\n}\n\nexports.load = function(namefile, cb) {\n  namefile = toNameFile(namefile)\n  fs.readFile(namefile, 'ascii', function(err, privateKeyStr) {\n    if (err) return cb(err)\n    try { cb(null, reconstructKeys(privateKeyStr)) }\n    catch (e) { cb(err) }\n  })\n}\n\nexports.loadSync = function(namefile) {\n  namefile = toNameFile(namefile)\n  return reconstructKeys(fs.readFileSync(namefile, 'ascii'))\n}\n\nexports.create = function(namefile, curve, legacy, cb) {\n  if(isFunction(legacy))\n    cb = legacy, legacy = null\n  if(isFunction(curve))\n    cb = curve, curve = null\n\n  namefile = toNameFile(namefile)\n  var keys = exports.generate(curve)\n  var keyfile = constructKeys(keys, legacy)\n  mkdirp(path.dirname(namefile), function (err) {\n    if(err) return cb(err)\n    fs.writeFile(namefile, keyfile, function(err) {\n      if (err) return cb(err)\n      cb(null, keys)\n    })\n  })\n}\n\nexports.createSync = function(namefile, curve, legacy) {\n  namefile = toNameFile(namefile)\n  var keys = exports.generate(curve)\n  var keyfile = constructKeys(keys, legacy)\n  mkdirp.sync(path.dirname(namefile))\n  fs.writeFileSync(namefile, keyfile)\n  return keys\n}\n\nexports.loadOrCreate = function (namefile, cb) {\n  namefile = toNameFile(namefile)\n  exports.load(namefile, function (err, keys) {\n    if(!err) return cb(null, keys)\n    exports.create(namefile, cb)\n  })\n}\n\nexports.loadOrCreateSync = function (namefile) {\n  namefile = toNameFile(namefile)\n  try {\n    return exports.loadSync(namefile)\n  } catch (err) {\n    return exports.createSync(namefile)\n  }\n}\n\n\n// DIGITAL SIGNATURES\n\nvar curves = {}\ncurves.ed25519 = require('./sodium')\ntry { curves.k256 = require('./eccjs') }\ncatch (_) {}\n\nfunction getCurve(keys) {\n  var curve = keys.curve\n\n  if(!keys.curve && isString(keys.public))\n    keys = keys.public\n\n  if(!curve && isString(keys))\n    curve = getTag(keys)\n\n  if(!curves[curve]) {\n    throw new Error(\n      'unkown curve:' + curve +\n      ' expected: '+Object.keys(curves)\n    )\n  }\n\n  return curve\n}\n\n//this should return a key pair:\n// {curve: curve, public: Buffer, private: Buffer}\n\nexports.generate = function (curve, seed) {\n  curve = curve || 'ed25519'\n\n  if(!curves[curve])\n    throw new Error('unknown curve:'+curve)\n\n  return keysToJSON(curves[curve].generate(seed), curve)\n}\n\n//takes a public key and a hash and returns a signature.\n//(a signature must be a node buffer)\n\nexports.sign = function (keys, msg) {\n  if(isString(msg))\n    msg = new Buffer(msg)\n  if(!isBuffer(msg))\n    throw new Error('msg should be buffer')\n  var curve = getCurve(keys)\n\n  return curves[curve]\n    .sign(toBuffer(keys.private || keys), msg)\n    .toString('base64')+'.sig.'+curve\n\n}\n\n//takes a public key, signature, and a hash\n//and returns true if the signature was valid.\nexports.verify = function (keys, sig, msg) {\n  if(isObject(sig))\n    throw new Error('signature should be base64 string, did you mean verifyObj(public, signed_obj)')\n  return curves[getCurve(keys)].verify(\n    toBuffer(keys.public || keys),\n    toBuffer(sig),\n    isBuffer(msg) ? msg : new Buffer(msg)\n  )\n}\n\n// OTHER CRYTPO FUNCTIONS\n\nexports.hmac = function (data, key) {\n  return createHmac(createHash, 64, key)\n    .update(data).digest('base64')+'.sha256.hmac'\n}\n\nexports.signObj = function (keys, obj) {\n  var _obj = clone(obj)\n  var b = new Buffer(JSON.stringify(_obj, null, 2))\n  _obj.signature = exports.sign(keys, b)\n  return _obj\n}\n\nexports.verifyObj = function (keys, obj) {\n  obj = clone(obj)\n  var sig = obj.signature\n  delete obj.signature\n  var b = new Buffer(JSON.stringify(obj, null, 2))\n  return exports.verify(keys, sig, b)\n}\n\nexports.box = function (msg, recipients) {\n  msg = new Buffer(JSON.stringify(msg))\n\n  recipients = recipients.map(function (keys) {\n    var public = keys.public || keys\n    return sodium.crypto_sign_ed25519_pk_to_curve25519(toBuffer(public))\n  })\n\n  //it's since the nonce is 24 bytes (a multiple of 3)\n  //it's possible to concatenate the base64 strings\n  //and still have a valid base64 string.\n  return pb.multibox(msg, recipients).toString('base64')+'.box'\n}\n\nexports.unbox = function (boxed, keys) {\n  boxed = toBuffer(boxed)\n  var sk = sodium.crypto_sign_ed25519_sk_to_curve25519(toBuffer(keys.private || keys))\n\n  var msg = pb.multibox_open(boxed, sk)\n  if(msg) return JSON.parse(''+msg)\n}\n\n\n","var pSlice = Array.prototype.slice;\nvar objectKeys = require('./lib/keys.js');\nvar isArguments = require('./lib/is_arguments.js');\n\nvar deepEqual = module.exports = function (actual, expected, opts) {\n  if (!opts) opts = {};\n  // 7.1. All identical values are equivalent, as determined by ===.\n  if (actual === expected) {\n    return true;\n\n  } else if (actual instanceof Date && expected instanceof Date) {\n    return actual.getTime() === expected.getTime();\n\n  // 7.3. Other pairs that do not both pass typeof value == 'object',\n  // equivalence is determined by ==.\n  } else if (typeof actual != 'object' && typeof expected != 'object') {\n    return opts.strict ? actual === expected : actual == expected;\n\n  // 7.4. For all other Object pairs, including Array objects, equivalence is\n  // determined by having the same number of owned properties (as verified\n  // with Object.prototype.hasOwnProperty.call), the same set of keys\n  // (although not necessarily the same order), equivalent values for every\n  // corresponding key, and an identical 'prototype' property. Note: this\n  // accounts for both named and indexed properties on Arrays.\n  } else {\n    return objEquiv(actual, expected, opts);\n  }\n}\n\nfunction isUndefinedOrNull(value) {\n  return value === null || value === undefined;\n}\n\nfunction isBuffer (x) {\n  if (!x || typeof x !== 'object' || typeof x.length !== 'number') return false;\n  if (typeof x.copy !== 'function' || typeof x.slice !== 'function') {\n    return false;\n  }\n  if (x.length > 0 && typeof x[0] !== 'number') return false;\n  return true;\n}\n\nfunction objEquiv(a, b, opts) {\n  var i, key;\n  if (isUndefinedOrNull(a) || isUndefinedOrNull(b))\n    return false;\n  // an identical 'prototype' property.\n  if (a.prototype !== b.prototype) return false;\n  //~~~I've managed to break Object.keys through screwy arguments passing.\n  //   Converting to array solves the problem.\n  if (isArguments(a)) {\n    if (!isArguments(b)) {\n      return false;\n    }\n    a = pSlice.call(a);\n    b = pSlice.call(b);\n    return deepEqual(a, b, opts);\n  }\n  if (isBuffer(a)) {\n    if (!isBuffer(b)) {\n      return false;\n    }\n    if (a.length !== b.length) return false;\n    for (i = 0; i < a.length; i++) {\n      if (a[i] !== b[i]) return false;\n    }\n    return true;\n  }\n  try {\n    var ka = objectKeys(a),\n        kb = objectKeys(b);\n  } catch (e) {//happens when one is a string literal and the other isn't\n    return false;\n  }\n  // having the same number of owned properties (keys incorporates\n  // hasOwnProperty)\n  if (ka.length != kb.length)\n    return false;\n  //the same set of keys (although not necessarily the same order),\n  ka.sort();\n  kb.sort();\n  //~~~cheap key test\n  for (i = ka.length - 1; i >= 0; i--) {\n    if (ka[i] != kb[i])\n      return false;\n  }\n  //equivalent values for every corresponding key, and\n  //~~~possibly expensive deep test\n  for (i = ka.length - 1; i >= 0; i--) {\n    key = ka[i];\n    if (!deepEqual(a[key], b[key], opts)) return false;\n  }\n  return typeof a === typeof b;\n}\n","var supportsArgumentsClass = (function(){\n  return Object.prototype.toString.call(arguments)\n})() == '[object Arguments]';\n\nexports = module.exports = supportsArgumentsClass ? supported : unsupported;\n\nexports.supported = supported;\nfunction supported(object) {\n  return Object.prototype.toString.call(object) == '[object Arguments]';\n};\n\nexports.unsupported = unsupported;\nfunction unsupported(object){\n  return object &&\n    typeof object == 'object' &&\n    typeof object.length == 'number' &&\n    Object.prototype.hasOwnProperty.call(object, 'callee') &&\n    !Object.prototype.propertyIsEnumerable.call(object, 'callee') ||\n    false;\n};\n","exports = module.exports = typeof Object.keys === 'function'\n  ? Object.keys : shim;\n\nexports.shim = shim;\nfunction shim (obj) {\n  var keys = [];\n  for (var key in obj) keys.push(key);\n  return keys;\n}\n","\nvar sodium = require('chloride')\nvar crypto = require('crypto')\n\nmodule.exports = {\n\n  curves: ['ed25519'],\n\n  generate: function (seed) {\n    var keys = sodium.crypto_sign_seed_keypair(seed || crypto.randomBytes(32))\n    return {\n      curve: 'ed25519',\n      public: keys.publicKey,\n\n      //so that this works with either sodium\n      //or libsodium-wrappers (in browser)\n      private: keys.privateKey || keys.secretKey\n    }\n  },\n\n  sign: function (private, message) {\n    return sodium.crypto_sign_detached(message, private)\n  },\n\n  verify: function (public, sig, message) {\n    return sodium.crypto_sign_verify_detached(sig, message, public)\n  }\n\n}\n","var pull = require('pull-stream')\nvar Links = require('streamview-links')\nvar path = require('path')\n\nvar extractLinks = require('./links')\n\n//we could have up to six indexes for links,\n//but these are the three that we really need.\n//(queries are fast if the fields you already know\n//are left most, and the ranges are to the right of that.\n\nvar indexes = [\n  { key: 'SRD', value: ['source', 'rel', 'dest', 'ts'] },\n  { key: 'DRS', value: ['dest', 'rel', 'source', 'ts'] },\n  { key: 'RDS', value: ['rel', 'dest', 'source', 'ts'] }\n]\n\nexports.name = 'links2'\n\nexports.manifest = {\n  read: 'source',\n  dump: 'source'\n}\nexports.init = function (ssb, config) {\n\n  var dir = path.join(config.path, 'links')\n\n  var version = 5\n  //it's really nice to tweak a few things\n  //and then change the version number,\n  //restart the server and have it regenerate the indexes,\n  //all consistent again.\n  var links = Links(dir, indexes, extractLinks, version)\n\n  links.init(function (err, since) {\n    console.error('LOAD LINKS SINCE', err, since)\n    pull(\n      ssb.createLogStream({gt: since || 0, live: true, limit: -1}),\n      pull.through(function (e) {\n        process.stderr.write('.')\n      }),\n      links.write(function (err) {\n        if(err) throw err\n      })\n    )\n  })\n\n  return {\n    dump: function () {\n      return links.dump()\n    },\n    read: function (opts) {\n      if(opts && 'string' == typeof opts)\n        try { opts = {query: JSON.parse(opts) } } catch (err) {\n        return pull.error(err)\n      }\n      return links.read(opts)\n    }\n  }\n}\n\n\n","var msgs = require('ssb-msgs')\n\nmodule.exports = function (data, iter) {\n  if(data.sync) return\n  var content = data.value.content\n  var source = data.value.author\n\n  //TODO parse the links from markdown\n  //and index those also. most of these are http links,\n  //some ipfs.\n\n  //it would be easy to tag another message,\n  //and query that, once markdown links are ready\n  //[#hashtag](msgId) would tag msg with #hashtag\n\n  //TODO: what about a syntax for self-links?\n  //interpret a lone hashtag in a message as a selflink,\n  //and then that will work.\n\n  msgs.indexLinks(data.value, function (ln, rel) {\n    var dest = ln.link\n\n    //take all the already existing links and put\n    //the relavant aspects into the index,\n    //as part of the rel, so that we don't need to lookup\n    //the message to get them, and even better,\n    //we can query by these attributes! enabling search.\n\n    if(rel == 'vote')\n      rel = ['vote', ln.value]\n    else if(rel == 'flag')\n      rel = ['flag', ln.reason]\n    else if(rel == 'mentions') {\n      if(ln.link[0] === '@')\n        rel = ['mentions', '@'+(ln.name||'').toLowerCase()]\n      else  if(ln.link[0] == '&') {\n        rel = ['mentions', ln.filename || ln.name, ln.size]\n      }\n      else {\n        //TODO: check whether they included some text in the markdown link.\n        rel = ['mentions']\n      }\n    }\n    else if(rel == 'about') {\n      rel = ['about', content.name]\n    }\n    else if(rel == 'image')\n      rel = ['image', ln.type, ln.size]\n    else if(rel == 'contact')\n      rel = ['contact', content.following, content.blocking]\n    else\n      rel = [rel]\n\n    iter({\n      source: source, dest: dest,\n      rel: rel,\n      ts: data.timestamp\n    })\n  })\n}\n\n\n\n\n\n","var ref = require('ssb-ref')\n\nfunction isObject (o) { return o && 'object' === typeof o }\nfunction isBool (o) { return 'boolean' === typeof o }\nfunction isString (s) { return 'string' === typeof s }\n\nfunction toArray (v, force) {\n  if (Array.isArray(v))\n    return v\n\n  // maybe it's an array-like object? (object with ordered numeric keys)\n  var i=0, arr=[]\n  if (isObject(v)) {\n    while (v[i]) {\n      arr[i] = v[i]\n      i++\n    }\n    if (Object.keys(arr).length > 0)\n      return arr // it was!\n  }\n\n  // it wasnt...\n  if (force) {\n    // ...just put v in the arr\n    arr.push(v)\n    return arr\n  }\n  return v\n}\n\n// given any part of the message-obj hierarchy, pull out the content-object\n// - uses ducktyping to find the content\nfunction toMsgContent (obj) {\n  if (!obj)\n    return null\n  if (obj.value && obj.value.content && obj.value.content.type)\n    return obj.value.content\n  if (obj.content && obj.content.type)\n    return obj.content\n  return obj\n}\n\nfunction traverse (obj, each) {\n  for (var k in obj) {\n    if (!obj[k])\n      continue\n    var arr = toArray(obj[k], false)\n    if (Array.isArray(arr)) {\n      arr.forEach(function (v) {\n        each(v, k)\n      })\n    } else\n      each(obj[k], k)\n  }\n}\n\n// iterate links in the message\nexports.indexLinks = function (message, opts, each) {\n  if (typeof opts == 'function') {\n    each = opts\n    opts = null\n  }\n  if (typeof opts == 'string')\n    opts = { rel: opts }\n  if (!opts)\n    opts = {}\n  var msg  = opts.msg\n  var feed = opts.feed\n  var blob = opts.blob\n  var any  = !(msg || feed || blob)\n\n  traverse(toMsgContent(message), function (obj, rel) {\n    if (opts.rel && rel !== opts.rel) return\n\n    var r = (typeof obj == 'string') ? obj : obj.link\n    if (any) {\n      if (!ref.isLink(r)) return\n    } else {\n      if (msg) {\n        if (isBool(msg) && ref.type(r) != 'msg') return \n        if (!isBool(msg) && r != msg) return\n      }\n\n      if (feed) {\n        if (isBool(feed) && ref.type(r) != 'feed') return \n        if (!isBool(feed) && r != feed) return\n      }\n\n      if (blob) {\n        if (isBool(blob) && ref.type(r) != 'blob') return \n        if (!isBool(blob) && r != blob) return\n      }\n    }\n\n    each((typeof obj == 'string') ? { link: obj } : obj, rel)\n  })\n}\n\n// coerce to link object, optionally of a given type\n// null if coersion fails\nexports.link =\nexports.asLink = function (obj, type) {\n  if (!obj)\n    return null\n  if (isString(obj))\n    obj = { link: obj }\n  return isLink(obj, type) ? obj : null\n}\n\n// coerce to links array, optionally of a given type\n// filters out failed coersions\nexports.links =\nexports.asLinks = function (obj, type) {\n  if (!obj)\n    return []\n  var arr = toArray(obj, true)\n  return arr\n    .filter(function (l) { return isLink(l, type) })\n    .map(function (o) { return (typeof o == 'string') ? { link: o } : o })\n}\n\n// detects whether the given string/object is a link\n// - `type` optional\nvar isLink =\nexports.isLink = function (obj, type) {\n  if (!obj)\n    return false\n  var r = (isString(obj)) ? obj : obj.link\n  return (type) ? (ref.type(r) == type) : ref.isLink(r)\n}\n\nfunction indexLinksTo (msgA, msgB, each) {\n  if (!msgA || !msgB || !msgB.key)\n    return\n  exports.indexLinks(msgA, function (l, rel) {\n    if (l.link === msgB.key)\n      each(l, rel)\n  })\n}\n\n// iterate `msgA` and find all links to `msgB`, returning an array of the link objects\nexports.linksTo = function (msgA, msgB) {\n  var links = []\n  indexLinksTo(msgA, msgB, function (link, rel) {\n    links.push(link)\n  })\n  return links\n}\n\n// iterate `msgA` and find all links to `msgB`, returning an array of the link rels \nexports.relationsTo = function (msgA, msgB) {\n  var rels = []\n  indexLinksTo(msgA, msgB, function (link, rel) {\n    rels.push(rel)\n  })\n  return rels\n}","\nvar pull = require('pull-stream')\nvar path = require('path')\nvar Links = require('streamview-links')\nvar explain = require('explain-error')\n\nexports.name = 'query'\nexports.version = require('./package.json').version\nexports.manifest = {\n  read: 'source', dump: 'source'\n}\n\nvar indexes = [\n  {key: 'clk', value: [['value', 'author'], ['value', 'sequence'], 'timestamp'] },\n  {key: 'typ', value: [['value', 'content', 'type'], 'timestamp'] },\n  {key: 'hsh', value: ['key', 'timestamp']},\n//  {key: 'aty', value: [['value', 'author'], ['value', 'content', 'type'], 'ts']}\n]\n\n//createHistoryStream( id, seq )\n//[{$filter: {author: <id>, sequence: {$gt: <seq>}}}, {$map: true}]\n\n//messagesByType (type)\n\n//[{$filter: {content: {type: <type>}}}, {$map: true}]\n\nexports.init = function  (ssb, config) {\n\n  var dir = path.join(config.path, 'query')\n\n  var version = 12\n  //it's really nice to tweak a few things\n  //and then change the version number,\n  //restart the server and have it regenerate the indexes,\n  //all consistent again.\n  function id (e, emit) {\n    return emit(e)\n  }\n\n  var links = Links(dir, indexes, id, version)\n\n  links.init(function (err, since) {\n    pull(\n      ssb.createLogStream({gt: since || 0, live: true, limit: -1}),\n      pull.through(function () {\n        process.stdout.write('x')\n      }),\n      links.write(function (err) {\n        if(err) throw err\n      })\n    )\n  })\n\n  return {\n    dump: function () {\n      return links.dump()\n    },\n\n    read: function (opts) {\n      if(opts && 'string' == typeof opts)\n        try { opts = {query: JSON.parse(opts) } } catch (err) {\n        return pull.error(err)\n      }\n    console.log('query', JSON.stringify(opts.query, null, 2))\n      return links.read(opts, function (ts, cb) {\n        ssb.sublevel('log').get(ts, function (err, key) {\n          if(err) return cb(explain(err, 'missing timestamp:'+ts))\n          ssb.get(key, function (err, value) {\n            if(err) return cb(explain(err, 'missing key:'+key))\n            cb(null, {key: key, value: value, timestamp: ts})\n          })\n        })\n      })\n    }\n  }\n}\n\n\n","\nmodule.exports = {\n  $count:\n    function (a, b) {\n      if(b === undefined) return (a||0)\n      return (a||0)+1\n    },\n  $sum:\n    function (a, b) {\n      if(b === undefined) return (a||0)\n      return (a||0)+(b||0)\n    },\n  $max:\n    function (a, b) {\n      if(b === undefined) a\n      if(a === undefined) return b\n      return Math.max(a, b)\n    },\n  $min:\n    function (a, b) {\n      if(b === undefined) a\n      if(a === undefined) return b\n      return Math.min(a, b)\n    },\n  $collect:\n    function (a, b) {\n      if(!a) a = a || []\n      if(!Array.isArray(a)) a = [a]\n      a.push(b)\n      return a\n    }\n}\n\n","var pull = require('pull-stream')\n\nvar filter = require('./filter')\nvar map = require('./map')\nvar reduce = require('./reduce')\nvar SinkThrough = require('pull-sink-through')\n\nfunction first (q) {\n  for(var k in q) return k\n}\n\nfunction get (q) {\n  var k = first(q)\n  var s = k.substring(1)\n  if(k[0] == '$' && exports[s]) return exports[s](q[k])\n  throw new Error('unknown function:'+ k)\n}\n\nfunction last (l) {\n  return l[l.length - 1]\n}\n\nexports = module.exports = function (q, cb) {\n  q = q.filter(Boolean)\n  if(last(q).$reduce && cb) {\n    return pull.apply(null,\n      q.slice(0, q.length - 1).map(get)\n        .concat(exports.reduce(last(q).$reduce, cb))\n    )\n  }\n  else if(Array.isArray(q))\n    return pull.apply(null, q.map(get))\n  else\n  return get(q)\n}\n\nexports.filter = function (q) {\n  return pull.filter(filter(q))\n}\n\nexports.map = function (q) {\n  return pull(pull.map(map(q)),pull.filter())\n}\n\nexports.reduce = function (q, cb) {\n  if(cb)\n    return pull.reduce(reduce(q), null, cb)\n  return pull(SinkThrough(function (cb) {\n    return pull.reduce(reduce(q), null, cb)\n  }), pull.flatten())\n}\n\n","var u = require('./util')\nvar map = u.map\n\nfunction id (v, k) {\n  return k ? v[k] : v\n}\n\nfunction isNull (n) {\n  return n == null\n}\n\nfunction key(q) {\n  return function (v) {\n    if(isNull(v)) return undefined\n    return v[q]\n  }\n}\n\nfunction path (q) {\n  return q.reduce(function (map1, map2) {\n    return function (v) { return map2(map1(v)) }\n  })\n}\n\nfunction notEmpty (o) {\n  for(var k in o) return o\n  return undefined\n}\n\nfunction obj (q) {\n  return function (v) {\n    if(isNull(v)) return undefined\n    return notEmpty(map(q, function (fn, k, o) {\n      return fn(v, k)\n    }))\n  }\n}\n\nfunction make(q) {\n  if(true === q) return id\n  if(isNull(q)) return isNull\n  if(u.isString(q) || u.isNumber(q)) return key(q)\n  if(u.isArray(q)) return path(q.map(make))\n  if(u.isObject(q)) return obj(map(q, make))\n  throw new Error('no match - should never happen')\n}\n\nmodule.exports = make\n\n","var u = require('./util')\nvar Map = require('./map')\nvar simple = require('./basic')\nvar search = require('binary-search')\nvar compare = require('typewiselite')\n\nfunction isFunction (f) { return 'function' === typeof f }\n\nfunction isSimple(query) {\n  if(query.$reduce) return amake(query.$reduce)\n  for(var k in simple) if(u.has(query, k)) return lookup(simple[k], query[k])\n}\n\n//this should be a reduce and a map\nfunction lookup(reduce, path) {\n  if(path === true) return reduce\n  return function (a, b) {\n    return reduce(a, u.get(b, path))\n  }\n}\n\nfunction multi(query) {\n  if(u.isFunction(query)) return query\n\n  return function (a, b) {\n    return u.map(query, function traverse (reduce, k) {\n      //some reduce functions may be maps (which take one arg)\n      return reduce.length == 1 ? reduce(b) : reduce(a[k], b)\n    }, a = a || {})\n  }\n}\n\n//rawpaths, reducedpaths, reduce\nfunction arrayGroup (_g, g, reduce) {\n\n  //we can use a different lookup path on the right hand object\n  //is always the \"needle\"\n  //compare(haystay[j], needle)\n  function _compare (hay, needle) {\n    for(var i in _g) {\n      var x = u.get(hay, _g[i]), y = needle[i]\n    if(x !== y) return compare(x, y) // < y ? -1 : 1\n    }\n    return 0\n  }\n\n  return function (a, b) {\n    if(a && !Array.isArray(a)) a = reduce([], a)\n    var A = a = a || []\n    var i = search(A, g.map(function (fn) { return fn(b) }), _compare)\n\n    if(i >= 0) A[i] = reduce(A[i], b)\n    else       A.splice(~i, 0, reduce(undefined, b))\n\n    return a\n  }\n}\n\nfunction objectGroup (g, reduce) {\n  if('string' === typeof g) g = [g]\n  return function (a, b) {\n    var A = a = a || {}\n    u.each(g, function (k, i) {\n      var last = (i == (g.length - 1))\n      var v = u.get(b, k)\n      A[v] = last ? reduce(A[v], b) : A[v] || {}\n      A = A[v]\n    })\n    return a\n  }\n}\n\nfunction make2 (query) {\n  var r = isSimple(query)\n  if(r) return r\n  if(query.$group)\n    return objectGroup(query.$group, multi(make2(query.$reduce)))\n  if(query.$reduce)\n    return make2(query.$reduce)\n  if(u.isObject(query))\n    return u.map(query, make2)\n  return Map(query)\n}\n\nfunction make (query) {\n  var r = isSimple(query)\n  if(r) return r\n  else if(query.$group)\n    return objectGroup(query.$group, gmake(query.$reduce))\n  else if(u.isObject(query) && !u.isArray(query)) {\n    return multi(u.map(query, gmake))\n  }\n  else return function (a, b) {\n    return u.get(b, query)\n  }\n}\n\nfunction amake (query) {\n  var _query = make2(query)\n  if(query.$group)\n      return objectGroup(query.$group, make(query.$reduce))\n  var r = isSimple(query)\n  if(r) return r\n\n  //get the lookup paths, and the paths they will be saved to.\n  //these will both be passed to arrayGroup.\n  var paths = []\n  var _paths = u.paths(_query, function (value) {\n    if(u.isFunction(value) && value.length === 1) {\n      return paths.push(value), true\n    }\n  })\n\n  return paths.length ? arrayGroup(_paths, paths, make(query)) : make(query)\n}\n\nfunction gmake (query) {\n  if(query.$group && !query.$reduce) throw new Error('expected $reduce')\n  return query.$group ? objectGroup(query.$group, gmake(query.$reduce)) : make(query)\n}\n\nmodule.exports = amake\n\n\n\n\n","'use strict'\n\nfunction isString(s) { return 'string' === typeof s }\n\nfunction isNumber(n) { return !isNaN(+n) }\n\nfunction isBoolean (b) { return 'boolean' === typeof b }\n\nfunction isBasic (p) { return isString(p) || isNumber(p) || isBoolean(p) }\n\nfunction isFunction (f) { return 'function' === typeof f }\n\nvar isArray = Array.isArray\n\nfunction isObject (o) { return o && 'object' === typeof o && !isArray(o) }\n\nfunction has(o, k) {\n  return Object.hasOwnProperty.call(o, k)\n}\n\nfunction isExact (v) {\n  if(isBasic(v)) return true\n  if(isArray(v))\n    return v.every(isExact)\n  return isObject(v) && has(v, '$eq')\n}\n\nfunction isLtgt (v) {\n  return has(v, '$lt') || has(v, '$gt') || has(v, '$lte') || has(v, '$gte')\n}\n\nfunction isRange (v) {\n  if(!isObject(v)) return false\n  if(isString(v.$prefix)) return true\n  if(isArray(v)) return find(v, isRange)\n  return isLtgt(v)\n}\n\nfunction find (ary, test) {\n  for(var i = 0; i < ary.length; i++)\n    if(test(ary[i], i, ary)) return true\n  return false\n}\n\nfunction lower (v) {\n  if(isBasic(v)) return v\n  if(isObject(v)) {\n    if(isArray(v.$prefix)) return v.$prefix.concat(exports.HI)\n    if(isString(v.$prefix)) return v.$prefix\n    if(has(v, '$gt')) return v.$gt\n    if(has(v, '$gte')) return v.$gte\n  }\n  if(isArray(v)) return v.map(lower)\n}\n\nfunction upper (v) {\n  if(isBasic(v)) return v\n  if(isObject(v)) {\n    if(isArray(v.$prefix)) return v.$prefix.concat(exports.LO)\n    if(isString(v.$prefix)) return v.$prefix+'\\uffff'\n    if(has(v, '$le')) return v.$lt\n    if(has(v, '$lte')) return v.$lte\n  }\n  if(isArray(v)) return v.map(upper)\n}\n\nfunction get(obj, path) {\n  if(isString(path)) return obj[path]\n  if(isArray(path)) {\n    for(var i = 0; i < path.length; i++) {\n      if(obj == null) return undefined\n      obj = obj[path[i]]\n    }\n    return obj\n  }\n  if(path === true) return obj\n  return undefined\n}\n\nfunction map(obj, iter, o) {\n  if(Array.isArray(obj)) return obj.map(iter)\n  o = o || {}\n  for(var k in obj)\n    o[k] = iter(obj[k], k, obj)\n  return o\n}\n\n\nfunction mapa(obj, iter) {\n  if(Array.isArray(obj)) return obj.map(iter)\n  var a = []\n  for(var k in obj) {\n    var v = iter(obj[k], k, obj)\n    if(v !== undefined) a.push(v)\n  }\n  return a\n\n}\n\nfunction each(obj, iter) {\n  if(Array.isArray(obj)) return obj.forEach(iter)\n  else if(isObject(obj))\n    for(var k in obj) iter(obj[k], k, obj)\n  else\n    iter(obj)\n}\n\nfunction project (value, map, isObj) {\n  isObj = isObj || isObject\n  if(!isObj(value))\n    return map(value)\n  else {\n    var o\n    for(var k in value) {\n      var v = project(value[k], map, isObj)\n      if(v !== undefined)\n        (o = o || {})[k] = v\n    }\n    return o\n  }\n}\n\n//get all paths within an object\n//this can probably be optimized to create less arrays!\nfunction paths (object, test) {\n  var p = []\n  if(test(object)) return []\n  for(var key in object) {\n    var value = object[key]\n    if(test(value)) p.push(key)\n    else if(isObject(value))\n      p = p.concat(paths(value, test).map(function (path) {\n        return [key].concat(path)\n      }))\n  }\n  return p\n}\n\nexports.isString = isString\nexports.isNumber = isNumber\nexports.isBasic = isBasic\nexports.isArray = isArray\nexports.isObject = isObject\nexports.isRange = isRange\nexports.isExact = isExact\nexports.isLtgt = isLtgt\nexports.isFunction = isFunction\n\nexports.has     = has\nexports.get     = get\nexports.map     = map\nexports.mapa    = mapa\nexports.project = project\nexports.paths   = paths\nexports.each    = each\n\nexports.upper = upper\nexports.lower = lower\n\nexports.HI = undefined\nexports.LO = null\n\n\n\n\n\n\n","var u      = require('pull-core')\nvar sources = require('./sources')\nvar sinks = require('./sinks')\n\nvar prop   = u.prop\nvar id     = u.id\nvar tester = u.tester\n\nvar map = exports.map = \nfunction (read, map) {\n  map = prop(map) || id\n  return function (end, cb) {\n    read(end, function (end, data) {\n      var data = !end ? map(data) : null\n      cb(end, data)\n    })\n  }\n}\n\nvar asyncMap = exports.asyncMap =\nfunction (read, map) {\n  if(!map) return read\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    read(null, function (end, data) {\n      if(end) return cb(end, data)\n      map(data, cb)\n    })\n  }\n}\n\nvar paraMap = exports.paraMap =\nfunction (read, map, width) {\n  if(!map) return read\n  var ended = false, queue = [], _cb\n\n  function drain () {\n    if(!_cb) return\n    var cb = _cb\n    _cb = null\n    if(queue.length)\n      return cb(null, queue.shift())\n    else if(ended && !n)\n      return cb(ended)\n    _cb = cb\n  }\n\n  function pull () {\n    read(null, function (end, data) {\n      if(end) {\n        ended = end\n        return drain()\n      }\n      n++\n      map(data, function (err, data) {\n        n--\n\n        queue.push(data)\n        drain()\n      })\n\n      if(n < width && !ended)\n        pull()\n    })\n  }\n\n  var n = 0\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    //continue to read while there are less than 3 maps in flight\n    _cb = cb\n    if(queue.length || ended)\n      pull(), drain()\n    else pull()\n  }\n  return highWaterMark(asyncMap(read, map), width)\n}\n\nvar filter = exports.filter =\nfunction (read, test) {\n  //regexp\n  test = tester(test)\n  return function next (end, cb) {\n    read(end, function (end, data) {\n      if(!end && !test(data))\n        return next(end, cb)\n      cb(end, data)\n    })\n  }\n}\n\nvar filterNot = exports.filterNot =\nfunction (read, test) {\n  test = tester(test)\n  return filter(read, function (e) {\n    return !test(e)\n  })\n}\n\nvar through = exports.through = \nfunction (read, op, onEnd) {\n  var a = false\n  function once (abort) {\n    if(a || !onEnd) return\n    a = true\n    onEnd(abort === true ? null : abort)\n  }\n\n  return function (end, cb) {\n    if(end) once(end)\n    return read(end, function (end, data) {\n      if(!end) op && op(data)\n      else once(end)\n      cb(end, data)\n    })\n  }\n}\n\nvar take = exports.take =\nfunction (read, test) {\n  var ended = false\n  if('number' === typeof test) {\n    var n = test; test = function () {\n      return n --\n    }\n  }\n\n  return function (end, cb) {\n    if(ended) return cb(ended)\n    if(ended = end) return read(ended, cb)\n\n    read(null, function (end, data) {\n      if(ended = ended || end) return cb(ended)\n      if(!test(data)) {\n        ended = true\n        read(true, function (end, data) {\n          cb(ended, data)\n        })\n      }\n      else\n        cb(null, data)\n    })\n  }\n}\n\nvar unique = exports.unique = function (read, field, invert) {\n  field = prop(field) || id\n  var seen = {}\n  return filter(read, function (data) {\n    var key = field(data)\n    if(seen[key]) return !!invert //false, by default\n    else seen[key] = true\n    return !invert //true by default\n  })\n}\n\nvar nonUnique = exports.nonUnique = function (read, field) {\n  return unique(read, field, true)\n}\n\nvar group = exports.group =\nfunction (read, size) {\n  var ended; size = size || 5\n  var queue = []\n\n  return function (end, cb) {\n    //this means that the upstream is sending an error.\n    if(end) return read(ended = end, cb)\n    //this means that we read an end before.\n    if(ended) return cb(ended)\n\n    read(null, function next(end, data) {\n      if(ended = ended || end) {\n        if(!queue.length)\n          return cb(ended)\n\n        var _queue = queue; queue = []\n        return cb(null, _queue)\n      }\n      queue.push(data)\n      if(queue.length < size)\n        return read(null, next)\n\n      var _queue = queue; queue = []\n      cb(null, _queue)\n    })\n  }\n}\n\nvar flatten = exports.flatten = function (read) {\n  var _read\n  return function (abort, cb) {\n    if(_read) nextChunk()\n    else      nextStream()\n\n    function nextChunk () {\n      _read(null, function (end, data) {\n        if(end) nextStream()\n        else    cb(null, data)\n      })\n    }\n    function nextStream () {\n      read(null, function (end, stream) {\n        if(end)\n          return cb(end)\n        if(Array.isArray(stream))\n          stream = sources.values(stream)\n        else if('function' != typeof stream)\n          throw new Error('expected stream of streams')\n        \n        _read = stream\n        nextChunk()\n      })\n    }\n  }\n}\n\nvar prepend =\nexports.prepend =\nfunction (read, head) {\n\n  return function (abort, cb) {\n    if(head !== null) {\n      if(abort)\n        return read(abort, cb)\n      var _head = head\n      head = null\n      cb(null, _head)\n    } else {\n      read(abort, cb)\n    }\n  }\n\n}\n\n//var drainIf = exports.drainIf = function (op, done) {\n//  sinks.drain(\n//}\n\nvar _reduce = exports._reduce = function (read, reduce, initial) {\n  return function (close, cb) {\n    if(close) return read(close, cb)\n    if(ended) return cb(ended)\n\n    sinks.drain(function (item) {\n      initial = reduce(initial, item)\n    }, function (err, data) {\n      ended = err || true\n      if(!err) cb(null, initial)\n      else     cb(ended)\n    })\n    (read)\n  }\n}\n\nvar nextTick = process.nextTick\n\nvar highWaterMark = exports.highWaterMark = \nfunction (read, highWaterMark) {\n  var buffer = [], waiting = [], ended, reading = false\n  highWaterMark = highWaterMark || 10\n\n  function readAhead () {\n    while(waiting.length && (buffer.length || ended))\n      waiting.shift()(ended, ended ? null : buffer.shift())\n  }\n\n  function next () {\n    if(ended || reading || buffer.length >= highWaterMark)\n      return\n    reading = true\n    return read(ended, function (end, data) {\n      reading = false\n      ended = ended || end\n      if(data != null) buffer.push(data)\n      \n      next(); readAhead()\n    })\n  }\n\n  nextTick(next)\n\n  return function (end, cb) {\n    ended = ended || end\n    waiting.push(cb)\n\n    next(); readAhead()\n  }\n}\n\n\n\n","'use strict'\nvar level = require('level')\nvar pull = require('pull-stream')\nvar Write = require('pull-write')\nvar pl = require('pull-level')\nvar query = require('./query')\nvar select = require('./select')\nvar mfr = require('map-filter-reduce')\nvar keys = require('map-filter-reduce/keys')\nvar bytewise = require('bytewise')\nvar paramap = require('pull-paramap')\nvar explain = require('explain-error')\nvar u = require('./util')\n\nvar isArray = Array.isArray\n\n//sorted index.\n\n\nmodule.exports = function (path, indexes, links, version, codec) {\n  codec = codec || require('bytewise')\n  var db = level(path)\n\n  if('string' !== typeof path)\n    throw new Error('must provide path for leveldb instance')\n  if(!Array.isArray(indexes))\n    throw new Error('must provide an array of indexes')\n  if('number' !== typeof version)\n    throw new Error('must provide version number')\n\n  if(!links)\n    links = function (data, emit) { emit(data) }\n\n  //always write metada to the lowest key,\n  //so the indexes do not interfeer\n  //we don't want to encode this with the codec,\n  //because then we can't change the codec safely\n  //(prehaps the encoding of META is also some indexed value in another codec?)\n  var META = '\\x00'\n\n  return {\n    init: function (cb) {\n      db.get(META, function (err, value) {\n        console.log('RELOAD INDEX:', value)\n        if(value)\n          try { value = JSON.parse(value) }\n          catch (err) { return cb(null, 0) }\n\n        if(err) //first time this was run\n          cb(null, 0)\n        //if the view has changed, rebuild entire index.\n        //else, read current version.\n\n        else if(version && value.version !== version) {\n          db.close(function () {\n            level.destroy(path, function (err) {\n              if(err) return cb(err)\n              db = level(path)\n              cb(null, 0)\n            })\n          })\n        }\n        else\n          cb(null, value.since || 0)\n      })\n    },\n    write: function (cb) {\n      return pull(\n        Write(function (batch, cb) {\n          db.batch(batch, cb)\n        }, function (batch, data) {\n          if(data.sync) return batch\n          if(!batch)\n            batch = [{\n              key: META,\n              value: {version: version, since: data.ts},\n              valueEncoding: 'json',\n              type: 'put'\n            }]\n\n          function push(ary) {\n            batch.push({key: codec.encode(ary), value: ' ', type: 'put'})\n          }\n\n          links(data, function (link) {\n            indexes.forEach(function (index) {\n              var a = [index.key]\n              for(var i = 0; i < index.value.length; i++) {\n                var key = index.value[i]\n                if(!u.has(key, link)) return\n                a.push(u.get(key, link))\n              }\n              push(a)\n            })\n          })\n\n          var ts = data.ts || data.timestamp\n          if(ts) batch[0].value.since = ts\n          return batch\n        }, 100, cb)\n      )\n    },\n    close: function (cb) {\n      db.close(cb)\n    },\n    //get the raw indexes, for debugging.\n    dump: function () {\n      return pl.read(db, {keyEncoding: codec, gt: '\\x00'})\n    },\n    //read all the messages out, via matching ranges.\n    read: function (opts, get) {\n      var lookup\n      opts = opts || {}\n      var _opts = {}\n      var q, k\n\n      if(isArray(opts.query)) {\n        q = opts.query[0].$filter || {}\n        k = keys(opts.query)\n      }\n      else if(opts.query) {\n        q = opts.query\n      }\n      else\n        q = {}\n\n      var index = select(indexes, q)\n      var _opts = query(index, q)\n\n    console.log(_opts)\n\n      _opts.values = false\n      _opts.keys = true\n      _opts.keyEncoding = codec\n\n      _opts.reverse = !!opts.reverse\n      _opts.live = !!opts.live\n      _opts.limit = opts.limit || -1\n\n      // If a query uses a key not in the index\n      // then we need to get that somehow.\n      // if this is a key from the thing indexed,\n      // it makes sense to look up that record.\n      // how to do that might be different in a view.\n\n      // just disable this for now.\n\n      if(get)\n        lookup = paramap(function (link, cb) {\n          get(link.ts || link.timestamp, function (err, data) {\n            if(err) return cb(explain(err, 'could not find matching timestamp for index:'+JSON.stringify(link)))\n            link.key = data.key\n            link.value = data.value\n            cb(null, link)\n          })\n        })\n\n      return pull(\n        pl.read(db, _opts),\n        //rehydrate the index to resemble the original object.\n        pull.map(function (e) {\n          var o = {}\n          for(var i = 0; i < index.value.length; i++)\n            u.set(index.value[i], e[i+1], o)\n          return o\n        }),\n        lookup,\n        isArray(opts.query) ? mfr(opts.query) : pull.through()\n      )\n    }\n  }\n}\n\n\n\n\n","var Q = require('map-filter-reduce/util')\nvar select = require('./select')\nvar get = require('./util').get\n\nfunction id (e) { return e }\n\nmodule.exports = function (index, query) {\n\n  function bound (value, range, sentinel) {\n    return (\n      value == null    ? sentinel\n    : Q.isRange(value) ? range(value)\n    :                    value\n    )\n  }\n\n  function build (index, map) {\n    var a = [index.key]\n    for(var i = 0; i < index.value.length; i++)\n      a.push(map(get(index.value[i], query)))\n    return a\n  }\n\n  return {\n    gte: build(index, function (value) {\n      return bound(value, Q.lower, Q.LO)\n    }),\n    lte: build(index, function (value) {\n      return bound(value, Q.upper, Q.HI)\n    })\n    //reverse, limit, live?\n  }\n\n}\n\n\n","\n//of several indexes available,\n//select the one most suitable for a given query.\n\n// select the index that matches the most exact fields in the query\n// starting from the left, then moving on to range fields.\n\nvar Q = require('map-filter-reduce/util')\nvar u = require('./util')\nfunction max(array, compare) {\n  return array.reduce(function (max, e) {\n    return compare(e.value, max.value) > 0 ? e : max\n  }, array[0])\n}\n\nmodule.exports = function select (indexes, query) {\n\n  function score (k) {\n    var v = u.get(k, query)\n    return u.has(k, query) ? (\n        Q.isExact(v) ? 3\n      : Q.isRange(v) ? 2\n      :                1\n    ) : 0\n  }\n\n  function exact (k) {\n    return u.has(k, query) && Q.isExact(u.get(k, query))\n  }\n\n  function range (k) {\n    return u.has(k, query) && Q.isRange(u.get(k, query))\n  }\n\n  function compare(a, b) {\n    var l = Math.min(a.length, b.length)\n    for(var i = 0; i < l; i++) {\n      var k = a[i], j = b[i]\n\n      var v = score(k), x = score(j)\n      if(v != x) return v - x\n\n      // else, loop to next item.\n    }\n    return 0\n  }\n\n  return max(indexes, compare)\n\n}\n\n\n\n\n\n\n\n","exports.has = function has (key, obj) {\n  if('string' === typeof key)\n    return Object.hasOwnProperty.call(obj, key)\n  for(var i in key) {\n    if(Object.hasOwnProperty.call(obj, key[i]))\n      obj = obj[key[i]]\n    else\n      return false\n  }\n  return true\n}\n\nexports.get = function get (key, obj) {\n  if('string' === typeof key) return obj[key]\n  for(var i in key) {\n    obj = obj[key[i]]\n    if(!obj) return obj\n  }\n  return obj\n}\n\nexports.set = function set(key, value, obj) {\n  if('string' === typeof key)\n    obj[key] = value\n  else {\n    for(var i = 0 ; i < key.length - 1; i++) {\n      obj = (obj[key[i]] = obj[key[i]] || {})\n    }\n    obj[key[key.length -1]] = value\n  }\n}\n\n\n","module.exports={\n  \"_args\": [\n    [\n      \"ssb-query@0.0.2\",\n      \"/Users/joran/Documents/development/patchdeck\"\n    ]\n  ],\n  \"_from\": \"ssb-query@0.0.2\",\n  \"_id\": \"ssb-query@0.0.2\",\n  \"_inCache\": true,\n  \"_installable\": true,\n  \"_location\": \"/ssb-query\",\n  \"_nodeVersion\": \"5.6.0\",\n  \"_npmOperationalInternal\": {\n    \"host\": \"packages-16-east.internal.npmjs.com\",\n    \"tmp\": \"tmp/ssb-query-0.0.2.tgz_1460607908133_0.18419223045930266\"\n  },\n  \"_npmUser\": {\n    \"email\": \"dominic.tarr@gmail.com\",\n    \"name\": \"dominictarr\"\n  },\n  \"_npmVersion\": \"3.6.0\",\n  \"_phantomChildren\": {\n    \"binary-search\": \"1.2.0\",\n    \"bytewise-core\": \"1.2.3\",\n    \"explain-error\": \"1.0.1\",\n    \"level\": \"1.4.0\",\n    \"level-post\": \"1.0.4\",\n    \"pull-cat\": \"1.1.9\",\n    \"pull-paramap\": \"1.1.4\",\n    \"pull-sink-through\": \"0.0.0\",\n    \"pull-window\": \"2.1.3\",\n    \"pull-write\": \"1.0.2\",\n    \"stream-to-pull-stream\": \"1.6.8\",\n    \"typewise\": \"1.0.3\",\n    \"typewiselite\": \"1.0.0\"\n  },\n  \"_requested\": {\n    \"name\": \"ssb-query\",\n    \"raw\": \"ssb-query@0.0.2\",\n    \"rawSpec\": \"0.0.2\",\n    \"scope\": null,\n    \"spec\": \"0.0.2\",\n    \"type\": \"version\"\n  },\n  \"_requiredBy\": [\n    \"/\"\n  ],\n  \"_resolved\": \"https://registry.npmjs.org/ssb-query/-/ssb-query-0.0.2.tgz\",\n  \"_shasum\": \"9af20e734ffda21724873fad375d7d160e831eb3\",\n  \"_shrinkwrap\": null,\n  \"_spec\": \"ssb-query@0.0.2\",\n  \"_where\": \"/Users/joran/Documents/development/patchdeck\",\n  \"author\": {\n    \"email\": \"dominic.tarr@gmail.com\",\n    \"name\": \"Dominic Tarr\",\n    \"url\": \"http://dominictarr.com\"\n  },\n  \"bugs\": {\n    \"url\": \"https://github.com/dominictarr/ssb-query/issues\"\n  },\n  \"dependencies\": {\n    \"explain-error\": \"^1.0.1\",\n    \"streamview-links\": \"^2.0.0\"\n  },\n  \"description\": \"\",\n  \"devDependencies\": {},\n  \"directories\": {},\n  \"dist\": {\n    \"shasum\": \"9af20e734ffda21724873fad375d7d160e831eb3\",\n    \"tarball\": \"https://registry.npmjs.org/ssb-query/-/ssb-query-0.0.2.tgz\"\n  },\n  \"gitHead\": \"901b36afd5fb25815ecf077e71a0a8825e847907\",\n  \"homepage\": \"https://github.com/dominictarr/ssb-query\",\n  \"license\": \"MIT\",\n  \"maintainers\": [\n    {\n      \"name\": \"dominictarr\",\n      \"email\": \"dominic.tarr@gmail.com\"\n    }\n  ],\n  \"name\": \"ssb-query\",\n  \"optionalDependencies\": {},\n  \"readme\": \"ERROR: No README data found!\",\n  \"repository\": {\n    \"type\": \"git\",\n    \"url\": \"git://github.com/dominictarr/ssb-query.git\"\n  },\n  \"scripts\": {\n    \"test\": \"set -e; for t in test/*.js; do node $t; done\"\n  },\n  \"version\": \"0.0.2\"\n}\n","var isDomain = require('is-valid-domain')\nvar rx = require('ip-regex')({exact: true})\nvar isIP = rx.test.bind(rx)\n\nvar isInteger = Number.isInteger\n\nfunction isString(s) {\n  return 'string' === typeof s\n}\n\nvar isLink = exports.isLink =\n  function (data) {\n    return isString(data) && /^(@|%|&)[A-Za-z0-9\\/+]{43}=\\.[\\w\\d]+$/.test(data)\n  }\n\nvar isFeedId = exports.isFeed = exports.isFeedId =\n  function (data) {\n    return isString(data) && /^@[A-Za-z0-9\\/+]{43}=\\.(?:sha256|ed25519)$/.test(data)\n  }\n\nvar isMsgId = exports.isMsg = exports.isMsgId =\n  function (data) {\n    return isString(data) && /^%[A-Za-z0-9\\/+]{43}=\\.sha256$/.test(data)\n  }\n\nvar isBlobId = exports.isBlob = exports.isBlobId =\n  function (data) {\n    return isString(data) && /^&[A-Za-z0-9\\/+]{43}=\\.sha256$/.test(data)\n  }\n\nvar isAddress = exports.isAddress =\n  function (data) {\n    if(!isString(data)) return false\n  var parts = data.split(':')\n  var id = parts.pop(), port = parts.pop(), addr = parts.join(':')\n  return (\n    isFeedId(id) && isInteger(+port)\n    && (isIP(addr) || isDomain(addr) || addr === 'localhost')\n  )\n}\n\nvar isInvite = exports.isInvite =\n  function (data) {\n    if(!isString(data)) return false\n    var parts = data.split('~')\n    //console.log(parts, isAddress(parts[0]), /^[A-Za-z0-9\\/+]{43}=$/.test(parts[1]))\n    return parts.length == 2 && isAddress(parts[0]) && /^[A-Za-z0-9\\/+]{43}=$/.test(parts[1])\n  }\n\nexports.type =\n  function (id) {\n    if(!isString(id)) return false\n    var c = id.charAt(0)\n    if (c == '@' && isFeedId(id))\n      return 'feed'\n    else if (c == '%' && isMsgId(id))\n      return 'msg'\n    else if (c == '&' && isBlobId(id))\n      return 'blob'\n    else if(isAddress(id)) return 'address'\n    else if(isInvite(id)) return 'invite'\n    else\n    return false\n  }\n\nexports.extract =\n  function (data) {\n    if (!isString(data))\n      return false\n\n    var _data = data\n    try { _data = decodeURIComponent(data) }\n    catch (e) {} // this may fail if it's not encoded, so don't worry if it does\n    _data = _data.replace(/&amp;/g, '&')\n\n    var res = /([@%&][A-Za-z0-9\\/+]{43}=\\.[\\w\\d]+)/.exec(_data)\n    return res && res[0]\n  }","module.exports = Stack;\nvar Url = require('url');\n\nfunction Stack(/*layers*/) {\n  var error = Stack.errorHandler,\n      handle = error;\n  Array.prototype.slice.call(arguments).reverse().forEach(function (layer) {\n    var child = handle;\n    handle = function (req, res) {\n      try {\n        layer(req, res, function (err) {\n          if (err) { return error(req, res, err); }\n          child(req, res);\n        });\n      } catch (err) {\n        error(req, res, err);\n      }\n    };\n  });\n  return handle;\n}\nStack.errorHandler = function error(req, res, err) {\n  if (err) {\n    console.error(err.stack);\n    res.writeHead(500, {\"Content-Type\": \"text/plain\"});\n    res.end(err.stack + \"\\n\");\n    return;\n  }\n  res.writeHead(404, {\"Content-Type\": \"text/plain\"});\n  res.end(\"Not Found\\n\");\n};\n\nfunction core(req, res, next) { next(); }\n\n// Build a composite stack made of several layers\nStack.compose = function compose(/*layers*/) {\n  // Don't bother composing singletons\n  if (arguments.length == 1) { return arguments[0]; }\n\n  var stack = core;\n  Array.prototype.slice.call(arguments).reverse().forEach(function (layer) {\n\n    var child = stack;\n    stack = function (req, res, next) {\n      try {\n        layer(req, res, function (err) {\n          if (err) { return next(err); }\n          child(req, res, next);\n        });\n      } catch (err) {\n        next(err);\n      }\n    };\n\n  });\n\n  return stack;\n}\n\n// Mounts a substack app at a url subtree\nStack.mount = function mount(mountpoint/*, stack*/) {\n\n  var stack = Stack.compose.apply(null, Array.prototype.slice.call(arguments, 1));\n\n  if (mountpoint.substr(mountpoint.length - 1) == \"/\") {\n    mountpoint = mountpoint.substr(0, mountpoint.length - 1);\n  }\n\n  var matchpoint = mountpoint + \"/\";\n\n  return function (req, res, next) {\n    var url = req.url;\n    var uri = req.uri;\n\n    if (url.substr(0, matchpoint.length) !== matchpoint) { return next(); }\n\n    // Modify the url\n    if (!req.realUrl) { req.realUrl = url; }\n\n    req.url = url.substr(mountpoint.length);\n    if (req.uri) { req.uri = Url.parse(req.url); }\n\n    stack(req, res, function (err) {\n      req.url = url;\n      req.uri = uri;\n      next(err)\n    });\n\n  };\n\n};\n","\n//\n// caluclate simple statistics\n//\n\nmodule.exports = Stats\n\nfunction Stats () {\n  if (!(this instanceof Stats)) return new Stats()\n  this.sum = 0\n  this.sqsum = 0\n  this.mean = 0\n  this.count = 0\n  this.max = null\n  this.min = null\n}\n\nStats.prototype = {\n  value: function (val) {\n    this.sum += val\n    this.sqsum += val*val\n    this.count ++\n    this.mean = this.sum / this.count\n    this.max = \n        this.max === null ? val \n      : val > this.max ? val\n      : this.max \n    this.min = \n        this.min === null ? val \n      : val < this.min ? val\n      : this.min \n    return this\n  },\n  get variance () {\n    return this.sqsum / this.count - (this.mean * this.mean)\n  },\n  get stdev() {\n    return Math.sqrt(this.variance)\n  },\n  toJSON: function () {\n    return {mean: this.mean, count: this.count, stdev: this.stdev}\n  }\n}\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nmodule.exports = Stream;\n\nvar EE = require('events').EventEmitter;\nvar inherits = require('inherits');\n\ninherits(Stream, EE);\nStream.Readable = require('readable-stream/readable.js');\nStream.Writable = require('readable-stream/writable.js');\nStream.Duplex = require('readable-stream/duplex.js');\nStream.Transform = require('readable-stream/transform.js');\nStream.PassThrough = require('readable-stream/passthrough.js');\n\n// Backwards-compat with node 0.4.x\nStream.Stream = Stream;\n\n\n\n// old-style streams.  Note that the pipe method (the only relevant\n// part of this class) is overridden in the Readable class.\n\nfunction Stream() {\n  EE.call(this);\n}\n\nStream.prototype.pipe = function(dest, options) {\n  var source = this;\n\n  function ondata(chunk) {\n    if (dest.writable) {\n      if (false === dest.write(chunk) && source.pause) {\n        source.pause();\n      }\n    }\n  }\n\n  source.on('data', ondata);\n\n  function ondrain() {\n    if (source.readable && source.resume) {\n      source.resume();\n    }\n  }\n\n  dest.on('drain', ondrain);\n\n  // If the 'end' option is not supplied, dest.end() will be called when\n  // source gets the 'end' or 'close' events.  Only dest.end() once.\n  if (!dest._isStdio && (!options || options.end !== false)) {\n    source.on('end', onend);\n    source.on('close', onclose);\n  }\n\n  var didOnEnd = false;\n  function onend() {\n    if (didOnEnd) return;\n    didOnEnd = true;\n\n    dest.end();\n  }\n\n\n  function onclose() {\n    if (didOnEnd) return;\n    didOnEnd = true;\n\n    if (typeof dest.destroy === 'function') dest.destroy();\n  }\n\n  // don't leave dangling pipes when there are errors.\n  function onerror(er) {\n    cleanup();\n    if (EE.listenerCount(this, 'error') === 0) {\n      throw er; // Unhandled stream error in pipe.\n    }\n  }\n\n  source.on('error', onerror);\n  dest.on('error', onerror);\n\n  // remove all the event listeners that were added.\n  function cleanup() {\n    source.removeListener('data', ondata);\n    dest.removeListener('drain', ondrain);\n\n    source.removeListener('end', onend);\n    source.removeListener('close', onclose);\n\n    source.removeListener('error', onerror);\n    dest.removeListener('error', onerror);\n\n    source.removeListener('end', cleanup);\n    source.removeListener('close', cleanup);\n\n    dest.removeListener('close', cleanup);\n  }\n\n  source.on('end', cleanup);\n  source.on('close', cleanup);\n\n  dest.on('close', cleanup);\n\n  dest.emit('pipe', source);\n\n  // Allow for unix-like usage: A.pipe(B).pipe(C)\n  return dest;\n};\n","// a passthrough stream.\n// basically just the most minimal sort of Transform stream.\n// Every written chunk gets output as-is.\n\n'use strict';\n\nmodule.exports = PassThrough;\n\nvar Transform = require('./_stream_transform');\n\n/*<replacement>*/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/*</replacement>*/\n\nutil.inherits(PassThrough, Transform);\n\nfunction PassThrough(options) {\n  if (!(this instanceof PassThrough)) return new PassThrough(options);\n\n  Transform.call(this, options);\n}\n\nPassThrough.prototype._transform = function (chunk, encoding, cb) {\n  cb(null, chunk);\n};","'use strict';\n\nmodule.exports = Readable;\n\n/*<replacement>*/\nvar processNextTick = require('process-nextick-args');\n/*</replacement>*/\n\n/*<replacement>*/\nvar isArray = require('isarray');\n/*</replacement>*/\n\n/*<replacement>*/\nvar Buffer = require('buffer').Buffer;\n/*</replacement>*/\n\nReadable.ReadableState = ReadableState;\n\nvar EE = require('events');\n\n/*<replacement>*/\nvar EElistenerCount = function (emitter, type) {\n  return emitter.listeners(type).length;\n};\n/*</replacement>*/\n\n/*<replacement>*/\nvar Stream;\n(function () {\n  try {\n    Stream = require('st' + 'ream');\n  } catch (_) {} finally {\n    if (!Stream) Stream = require('events').EventEmitter;\n  }\n})();\n/*</replacement>*/\n\nvar Buffer = require('buffer').Buffer;\n\n/*<replacement>*/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/*</replacement>*/\n\n/*<replacement>*/\nvar debugUtil = require('util');\nvar debug = undefined;\nif (debugUtil && debugUtil.debuglog) {\n  debug = debugUtil.debuglog('stream');\n} else {\n  debug = function () {};\n}\n/*</replacement>*/\n\nvar StringDecoder;\n\nutil.inherits(Readable, Stream);\n\nvar Duplex;\nfunction ReadableState(options, stream) {\n  Duplex = Duplex || require('./_stream_duplex');\n\n  options = options || {};\n\n  // object stream flag. Used to make read(n) ignore n and to\n  // make all the buffer merging and length checks go away\n  this.objectMode = !!options.objectMode;\n\n  if (stream instanceof Duplex) this.objectMode = this.objectMode || !!options.readableObjectMode;\n\n  // the point at which it stops calling _read() to fill the buffer\n  // Note: 0 is a valid value, means \"don't call _read preemptively ever\"\n  var hwm = options.highWaterMark;\n  var defaultHwm = this.objectMode ? 16 : 16 * 1024;\n  this.highWaterMark = hwm || hwm === 0 ? hwm : defaultHwm;\n\n  // cast to ints.\n  this.highWaterMark = ~ ~this.highWaterMark;\n\n  this.buffer = [];\n  this.length = 0;\n  this.pipes = null;\n  this.pipesCount = 0;\n  this.flowing = null;\n  this.ended = false;\n  this.endEmitted = false;\n  this.reading = false;\n\n  // a flag to be able to tell if the onwrite cb is called immediately,\n  // or on a later tick.  We set this to true at first, because any\n  // actions that shouldn't happen until \"later\" should generally also\n  // not happen before the first write call.\n  this.sync = true;\n\n  // whenever we return null, then we set a flag to say\n  // that we're awaiting a 'readable' event emission.\n  this.needReadable = false;\n  this.emittedReadable = false;\n  this.readableListening = false;\n  this.resumeScheduled = false;\n\n  // Crypto is kind of old and crusty.  Historically, its default string\n  // encoding is 'binary' so we have to make this configurable.\n  // Everything else in the universe uses 'utf8', though.\n  this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n  // when piping, we only care about 'readable' events that happen\n  // after read()ing all the bytes and not getting any pushback.\n  this.ranOut = false;\n\n  // the number of writers that are awaiting a drain event in .pipe()s\n  this.awaitDrain = 0;\n\n  // if true, a maybeReadMore has been scheduled\n  this.readingMore = false;\n\n  this.decoder = null;\n  this.encoding = null;\n  if (options.encoding) {\n    if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n    this.decoder = new StringDecoder(options.encoding);\n    this.encoding = options.encoding;\n  }\n}\n\nvar Duplex;\nfunction Readable(options) {\n  Duplex = Duplex || require('./_stream_duplex');\n\n  if (!(this instanceof Readable)) return new Readable(options);\n\n  this._readableState = new ReadableState(options, this);\n\n  // legacy\n  this.readable = true;\n\n  if (options && typeof options.read === 'function') this._read = options.read;\n\n  Stream.call(this);\n}\n\n// Manually shove something into the read() buffer.\n// This returns true if the highWaterMark has not been hit yet,\n// similar to how Writable.write() returns true if you should\n// write() some more.\nReadable.prototype.push = function (chunk, encoding) {\n  var state = this._readableState;\n\n  if (!state.objectMode && typeof chunk === 'string') {\n    encoding = encoding || state.defaultEncoding;\n    if (encoding !== state.encoding) {\n      chunk = new Buffer(chunk, encoding);\n      encoding = '';\n    }\n  }\n\n  return readableAddChunk(this, state, chunk, encoding, false);\n};\n\n// Unshift should *always* be something directly out of read()\nReadable.prototype.unshift = function (chunk) {\n  var state = this._readableState;\n  return readableAddChunk(this, state, chunk, '', true);\n};\n\nReadable.prototype.isPaused = function () {\n  return this._readableState.flowing === false;\n};\n\nfunction readableAddChunk(stream, state, chunk, encoding, addToFront) {\n  var er = chunkInvalid(state, chunk);\n  if (er) {\n    stream.emit('error', er);\n  } else if (chunk === null) {\n    state.reading = false;\n    onEofChunk(stream, state);\n  } else if (state.objectMode || chunk && chunk.length > 0) {\n    if (state.ended && !addToFront) {\n      var e = new Error('stream.push() after EOF');\n      stream.emit('error', e);\n    } else if (state.endEmitted && addToFront) {\n      var e = new Error('stream.unshift() after end event');\n      stream.emit('error', e);\n    } else {\n      var skipAdd;\n      if (state.decoder && !addToFront && !encoding) {\n        chunk = state.decoder.write(chunk);\n        skipAdd = !state.objectMode && chunk.length === 0;\n      }\n\n      if (!addToFront) state.reading = false;\n\n      // Don't add to the buffer if we've decoded to an empty string chunk and\n      // we're not in object mode\n      if (!skipAdd) {\n        // if we want the data now, just emit it.\n        if (state.flowing && state.length === 0 && !state.sync) {\n          stream.emit('data', chunk);\n          stream.read(0);\n        } else {\n          // update the buffer info.\n          state.length += state.objectMode ? 1 : chunk.length;\n          if (addToFront) state.buffer.unshift(chunk);else state.buffer.push(chunk);\n\n          if (state.needReadable) emitReadable(stream);\n        }\n      }\n\n      maybeReadMore(stream, state);\n    }\n  } else if (!addToFront) {\n    state.reading = false;\n  }\n\n  return needMoreData(state);\n}\n\n// if it's past the high water mark, we can push in some more.\n// Also, if we have no data yet, we can stand some\n// more bytes.  This is to work around cases where hwm=0,\n// such as the repl.  Also, if the push() triggered a\n// readable event, and the user called read(largeNumber) such that\n// needReadable was set, then we ought to push more, so that another\n// 'readable' event will be triggered.\nfunction needMoreData(state) {\n  return !state.ended && (state.needReadable || state.length < state.highWaterMark || state.length === 0);\n}\n\n// backwards compatibility.\nReadable.prototype.setEncoding = function (enc) {\n  if (!StringDecoder) StringDecoder = require('string_decoder/').StringDecoder;\n  this._readableState.decoder = new StringDecoder(enc);\n  this._readableState.encoding = enc;\n  return this;\n};\n\n// Don't raise the hwm > 8MB\nvar MAX_HWM = 0x800000;\nfunction computeNewHighWaterMark(n) {\n  if (n >= MAX_HWM) {\n    n = MAX_HWM;\n  } else {\n    // Get the next highest power of 2\n    n--;\n    n |= n >>> 1;\n    n |= n >>> 2;\n    n |= n >>> 4;\n    n |= n >>> 8;\n    n |= n >>> 16;\n    n++;\n  }\n  return n;\n}\n\nfunction howMuchToRead(n, state) {\n  if (state.length === 0 && state.ended) return 0;\n\n  if (state.objectMode) return n === 0 ? 0 : 1;\n\n  if (n === null || isNaN(n)) {\n    // only flow one buffer at a time\n    if (state.flowing && state.buffer.length) return state.buffer[0].length;else return state.length;\n  }\n\n  if (n <= 0) return 0;\n\n  // If we're asking for more than the target buffer level,\n  // then raise the water mark.  Bump up to the next highest\n  // power of 2, to prevent increasing it excessively in tiny\n  // amounts.\n  if (n > state.highWaterMark) state.highWaterMark = computeNewHighWaterMark(n);\n\n  // don't have that much.  return null, unless we've ended.\n  if (n > state.length) {\n    if (!state.ended) {\n      state.needReadable = true;\n      return 0;\n    } else {\n      return state.length;\n    }\n  }\n\n  return n;\n}\n\n// you can override either this method, or the async _read(n) below.\nReadable.prototype.read = function (n) {\n  debug('read', n);\n  var state = this._readableState;\n  var nOrig = n;\n\n  if (typeof n !== 'number' || n > 0) state.emittedReadable = false;\n\n  // if we're doing read(0) to trigger a readable event, but we\n  // already have a bunch of data in the buffer, then just trigger\n  // the 'readable' event and move on.\n  if (n === 0 && state.needReadable && (state.length >= state.highWaterMark || state.ended)) {\n    debug('read: emitReadable', state.length, state.ended);\n    if (state.length === 0 && state.ended) endReadable(this);else emitReadable(this);\n    return null;\n  }\n\n  n = howMuchToRead(n, state);\n\n  // if we've ended, and we're now clear, then finish it up.\n  if (n === 0 && state.ended) {\n    if (state.length === 0) endReadable(this);\n    return null;\n  }\n\n  // All the actual chunk generation logic needs to be\n  // *below* the call to _read.  The reason is that in certain\n  // synthetic stream cases, such as passthrough streams, _read\n  // may be a completely synchronous operation which may change\n  // the state of the read buffer, providing enough data when\n  // before there was *not* enough.\n  //\n  // So, the steps are:\n  // 1. Figure out what the state of things will be after we do\n  // a read from the buffer.\n  //\n  // 2. If that resulting state will trigger a _read, then call _read.\n  // Note that this may be asynchronous, or synchronous.  Yes, it is\n  // deeply ugly to write APIs this way, but that still doesn't mean\n  // that the Readable class should behave improperly, as streams are\n  // designed to be sync/async agnostic.\n  // Take note if the _read call is sync or async (ie, if the read call\n  // has returned yet), so that we know whether or not it's safe to emit\n  // 'readable' etc.\n  //\n  // 3. Actually pull the requested chunks out of the buffer and return.\n\n  // if we need a readable event, then we need to do some reading.\n  var doRead = state.needReadable;\n  debug('need readable', doRead);\n\n  // if we currently have less than the highWaterMark, then also read some\n  if (state.length === 0 || state.length - n < state.highWaterMark) {\n    doRead = true;\n    debug('length less than watermark', doRead);\n  }\n\n  // however, if we've ended, then there's no point, and if we're already\n  // reading, then it's unnecessary.\n  if (state.ended || state.reading) {\n    doRead = false;\n    debug('reading or ended', doRead);\n  }\n\n  if (doRead) {\n    debug('do read');\n    state.reading = true;\n    state.sync = true;\n    // if the length is currently zero, then we *need* a readable event.\n    if (state.length === 0) state.needReadable = true;\n    // call internal read method\n    this._read(state.highWaterMark);\n    state.sync = false;\n  }\n\n  // If _read pushed data synchronously, then `reading` will be false,\n  // and we need to re-evaluate how much data we can return to the user.\n  if (doRead && !state.reading) n = howMuchToRead(nOrig, state);\n\n  var ret;\n  if (n > 0) ret = fromList(n, state);else ret = null;\n\n  if (ret === null) {\n    state.needReadable = true;\n    n = 0;\n  }\n\n  state.length -= n;\n\n  // If we have nothing in the buffer, then we want to know\n  // as soon as we *do* get something into the buffer.\n  if (state.length === 0 && !state.ended) state.needReadable = true;\n\n  // If we tried to read() past the EOF, then emit end on the next tick.\n  if (nOrig !== n && state.ended && state.length === 0) endReadable(this);\n\n  if (ret !== null) this.emit('data', ret);\n\n  return ret;\n};\n\nfunction chunkInvalid(state, chunk) {\n  var er = null;\n  if (!Buffer.isBuffer(chunk) && typeof chunk !== 'string' && chunk !== null && chunk !== undefined && !state.objectMode) {\n    er = new TypeError('Invalid non-string/buffer chunk');\n  }\n  return er;\n}\n\nfunction onEofChunk(stream, state) {\n  if (state.ended) return;\n  if (state.decoder) {\n    var chunk = state.decoder.end();\n    if (chunk && chunk.length) {\n      state.buffer.push(chunk);\n      state.length += state.objectMode ? 1 : chunk.length;\n    }\n  }\n  state.ended = true;\n\n  // emit 'readable' now to make sure it gets picked up.\n  emitReadable(stream);\n}\n\n// Don't emit readable right away in sync mode, because this can trigger\n// another read() call => stack overflow.  This way, it might trigger\n// a nextTick recursion warning, but that's not so bad.\nfunction emitReadable(stream) {\n  var state = stream._readableState;\n  state.needReadable = false;\n  if (!state.emittedReadable) {\n    debug('emitReadable', state.flowing);\n    state.emittedReadable = true;\n    if (state.sync) processNextTick(emitReadable_, stream);else emitReadable_(stream);\n  }\n}\n\nfunction emitReadable_(stream) {\n  debug('emit readable');\n  stream.emit('readable');\n  flow(stream);\n}\n\n// at this point, the user has presumably seen the 'readable' event,\n// and called read() to consume some data.  that may have triggered\n// in turn another _read(n) call, in which case reading = true if\n// it's in progress.\n// However, if we're not ended, or reading, and the length < hwm,\n// then go ahead and try to read some more preemptively.\nfunction maybeReadMore(stream, state) {\n  if (!state.readingMore) {\n    state.readingMore = true;\n    processNextTick(maybeReadMore_, stream, state);\n  }\n}\n\nfunction maybeReadMore_(stream, state) {\n  var len = state.length;\n  while (!state.reading && !state.flowing && !state.ended && state.length < state.highWaterMark) {\n    debug('maybeReadMore read 0');\n    stream.read(0);\n    if (len === state.length)\n      // didn't get any data, stop spinning.\n      break;else len = state.length;\n  }\n  state.readingMore = false;\n}\n\n// abstract method.  to be overridden in specific implementation classes.\n// call cb(er, data) where data is <= n in length.\n// for virtual (non-string, non-buffer) streams, \"length\" is somewhat\n// arbitrary, and perhaps not very meaningful.\nReadable.prototype._read = function (n) {\n  this.emit('error', new Error('not implemented'));\n};\n\nReadable.prototype.pipe = function (dest, pipeOpts) {\n  var src = this;\n  var state = this._readableState;\n\n  switch (state.pipesCount) {\n    case 0:\n      state.pipes = dest;\n      break;\n    case 1:\n      state.pipes = [state.pipes, dest];\n      break;\n    default:\n      state.pipes.push(dest);\n      break;\n  }\n  state.pipesCount += 1;\n  debug('pipe count=%d opts=%j', state.pipesCount, pipeOpts);\n\n  var doEnd = (!pipeOpts || pipeOpts.end !== false) && dest !== process.stdout && dest !== process.stderr;\n\n  var endFn = doEnd ? onend : cleanup;\n  if (state.endEmitted) processNextTick(endFn);else src.once('end', endFn);\n\n  dest.on('unpipe', onunpipe);\n  function onunpipe(readable) {\n    debug('onunpipe');\n    if (readable === src) {\n      cleanup();\n    }\n  }\n\n  function onend() {\n    debug('onend');\n    dest.end();\n  }\n\n  // when the dest drains, it reduces the awaitDrain counter\n  // on the source.  This would be more elegant with a .once()\n  // handler in flow(), but adding and removing repeatedly is\n  // too slow.\n  var ondrain = pipeOnDrain(src);\n  dest.on('drain', ondrain);\n\n  var cleanedUp = false;\n  function cleanup() {\n    debug('cleanup');\n    // cleanup event handlers once the pipe is broken\n    dest.removeListener('close', onclose);\n    dest.removeListener('finish', onfinish);\n    dest.removeListener('drain', ondrain);\n    dest.removeListener('error', onerror);\n    dest.removeListener('unpipe', onunpipe);\n    src.removeListener('end', onend);\n    src.removeListener('end', cleanup);\n    src.removeListener('data', ondata);\n\n    cleanedUp = true;\n\n    // if the reader is waiting for a drain event from this\n    // specific writer, then it would cause it to never start\n    // flowing again.\n    // So, if this is awaiting a drain, then we just call it now.\n    // If we don't know, then assume that we are waiting for one.\n    if (state.awaitDrain && (!dest._writableState || dest._writableState.needDrain)) ondrain();\n  }\n\n  src.on('data', ondata);\n  function ondata(chunk) {\n    debug('ondata');\n    var ret = dest.write(chunk);\n    if (false === ret) {\n      // If the user unpiped during `dest.write()`, it is possible\n      // to get stuck in a permanently paused state if that write\n      // also returned false.\n      if (state.pipesCount === 1 && state.pipes[0] === dest && src.listenerCount('data') === 1 && !cleanedUp) {\n        debug('false write response, pause', src._readableState.awaitDrain);\n        src._readableState.awaitDrain++;\n      }\n      src.pause();\n    }\n  }\n\n  // if the dest has an error, then stop piping into it.\n  // however, don't suppress the throwing behavior for this.\n  function onerror(er) {\n    debug('onerror', er);\n    unpipe();\n    dest.removeListener('error', onerror);\n    if (EElistenerCount(dest, 'error') === 0) dest.emit('error', er);\n  }\n  // This is a brutally ugly hack to make sure that our error handler\n  // is attached before any userland ones.  NEVER DO THIS.\n  if (!dest._events || !dest._events.error) dest.on('error', onerror);else if (isArray(dest._events.error)) dest._events.error.unshift(onerror);else dest._events.error = [onerror, dest._events.error];\n\n  // Both close and finish should trigger unpipe, but only once.\n  function onclose() {\n    dest.removeListener('finish', onfinish);\n    unpipe();\n  }\n  dest.once('close', onclose);\n  function onfinish() {\n    debug('onfinish');\n    dest.removeListener('close', onclose);\n    unpipe();\n  }\n  dest.once('finish', onfinish);\n\n  function unpipe() {\n    debug('unpipe');\n    src.unpipe(dest);\n  }\n\n  // tell the dest that it's being piped to\n  dest.emit('pipe', src);\n\n  // start the flow if it hasn't been started already.\n  if (!state.flowing) {\n    debug('pipe resume');\n    src.resume();\n  }\n\n  return dest;\n};\n\nfunction pipeOnDrain(src) {\n  return function () {\n    var state = src._readableState;\n    debug('pipeOnDrain', state.awaitDrain);\n    if (state.awaitDrain) state.awaitDrain--;\n    if (state.awaitDrain === 0 && EElistenerCount(src, 'data')) {\n      state.flowing = true;\n      flow(src);\n    }\n  };\n}\n\nReadable.prototype.unpipe = function (dest) {\n  var state = this._readableState;\n\n  // if we're not piping anywhere, then do nothing.\n  if (state.pipesCount === 0) return this;\n\n  // just one destination.  most common case.\n  if (state.pipesCount === 1) {\n    // passed in one, but it's not the right one.\n    if (dest && dest !== state.pipes) return this;\n\n    if (!dest) dest = state.pipes;\n\n    // got a match.\n    state.pipes = null;\n    state.pipesCount = 0;\n    state.flowing = false;\n    if (dest) dest.emit('unpipe', this);\n    return this;\n  }\n\n  // slow case. multiple pipe destinations.\n\n  if (!dest) {\n    // remove all.\n    var dests = state.pipes;\n    var len = state.pipesCount;\n    state.pipes = null;\n    state.pipesCount = 0;\n    state.flowing = false;\n\n    for (var _i = 0; _i < len; _i++) {\n      dests[_i].emit('unpipe', this);\n    }return this;\n  }\n\n  // try to find the right one.\n  var i = indexOf(state.pipes, dest);\n  if (i === -1) return this;\n\n  state.pipes.splice(i, 1);\n  state.pipesCount -= 1;\n  if (state.pipesCount === 1) state.pipes = state.pipes[0];\n\n  dest.emit('unpipe', this);\n\n  return this;\n};\n\n// set up data events if they are asked for\n// Ensure readable listeners eventually get something\nReadable.prototype.on = function (ev, fn) {\n  var res = Stream.prototype.on.call(this, ev, fn);\n\n  // If listening to data, and it has not explicitly been paused,\n  // then call resume to start the flow of data on the next tick.\n  if (ev === 'data' && false !== this._readableState.flowing) {\n    this.resume();\n  }\n\n  if (ev === 'readable' && !this._readableState.endEmitted) {\n    var state = this._readableState;\n    if (!state.readableListening) {\n      state.readableListening = true;\n      state.emittedReadable = false;\n      state.needReadable = true;\n      if (!state.reading) {\n        processNextTick(nReadingNextTick, this);\n      } else if (state.length) {\n        emitReadable(this, state);\n      }\n    }\n  }\n\n  return res;\n};\nReadable.prototype.addListener = Readable.prototype.on;\n\nfunction nReadingNextTick(self) {\n  debug('readable nexttick read 0');\n  self.read(0);\n}\n\n// pause() and resume() are remnants of the legacy readable stream API\n// If the user uses them, then switch into old mode.\nReadable.prototype.resume = function () {\n  var state = this._readableState;\n  if (!state.flowing) {\n    debug('resume');\n    state.flowing = true;\n    resume(this, state);\n  }\n  return this;\n};\n\nfunction resume(stream, state) {\n  if (!state.resumeScheduled) {\n    state.resumeScheduled = true;\n    processNextTick(resume_, stream, state);\n  }\n}\n\nfunction resume_(stream, state) {\n  if (!state.reading) {\n    debug('resume read 0');\n    stream.read(0);\n  }\n\n  state.resumeScheduled = false;\n  stream.emit('resume');\n  flow(stream);\n  if (state.flowing && !state.reading) stream.read(0);\n}\n\nReadable.prototype.pause = function () {\n  debug('call pause flowing=%j', this._readableState.flowing);\n  if (false !== this._readableState.flowing) {\n    debug('pause');\n    this._readableState.flowing = false;\n    this.emit('pause');\n  }\n  return this;\n};\n\nfunction flow(stream) {\n  var state = stream._readableState;\n  debug('flow', state.flowing);\n  if (state.flowing) {\n    do {\n      var chunk = stream.read();\n    } while (null !== chunk && state.flowing);\n  }\n}\n\n// wrap an old-style stream as the async data source.\n// This is *not* part of the readable stream interface.\n// It is an ugly unfortunate mess of history.\nReadable.prototype.wrap = function (stream) {\n  var state = this._readableState;\n  var paused = false;\n\n  var self = this;\n  stream.on('end', function () {\n    debug('wrapped end');\n    if (state.decoder && !state.ended) {\n      var chunk = state.decoder.end();\n      if (chunk && chunk.length) self.push(chunk);\n    }\n\n    self.push(null);\n  });\n\n  stream.on('data', function (chunk) {\n    debug('wrapped data');\n    if (state.decoder) chunk = state.decoder.write(chunk);\n\n    // don't skip over falsy values in objectMode\n    if (state.objectMode && (chunk === null || chunk === undefined)) return;else if (!state.objectMode && (!chunk || !chunk.length)) return;\n\n    var ret = self.push(chunk);\n    if (!ret) {\n      paused = true;\n      stream.pause();\n    }\n  });\n\n  // proxy all the other methods.\n  // important when wrapping filters and duplexes.\n  for (var i in stream) {\n    if (this[i] === undefined && typeof stream[i] === 'function') {\n      this[i] = function (method) {\n        return function () {\n          return stream[method].apply(stream, arguments);\n        };\n      }(i);\n    }\n  }\n\n  // proxy certain important events.\n  var events = ['error', 'close', 'destroy', 'pause', 'resume'];\n  forEach(events, function (ev) {\n    stream.on(ev, self.emit.bind(self, ev));\n  });\n\n  // when we try to consume some more bytes, simply unpause the\n  // underlying stream.\n  self._read = function (n) {\n    debug('wrapped _read', n);\n    if (paused) {\n      paused = false;\n      stream.resume();\n    }\n  };\n\n  return self;\n};\n\n// exposed for testing purposes only.\nReadable._fromList = fromList;\n\n// Pluck off n bytes from an array of buffers.\n// Length is the combined lengths of all the buffers in the list.\nfunction fromList(n, state) {\n  var list = state.buffer;\n  var length = state.length;\n  var stringMode = !!state.decoder;\n  var objectMode = !!state.objectMode;\n  var ret;\n\n  // nothing in the list, definitely empty.\n  if (list.length === 0) return null;\n\n  if (length === 0) ret = null;else if (objectMode) ret = list.shift();else if (!n || n >= length) {\n    // read it all, truncate the array.\n    if (stringMode) ret = list.join('');else if (list.length === 1) ret = list[0];else ret = Buffer.concat(list, length);\n    list.length = 0;\n  } else {\n    // read just some of it.\n    if (n < list[0].length) {\n      // just take a part of the first list item.\n      // slice is the same for buffers and strings.\n      var buf = list[0];\n      ret = buf.slice(0, n);\n      list[0] = buf.slice(n);\n    } else if (n === list[0].length) {\n      // first list is a perfect match\n      ret = list.shift();\n    } else {\n      // complex case.\n      // we have enough to cover it, but it spans past the first buffer.\n      if (stringMode) ret = '';else ret = new Buffer(n);\n\n      var c = 0;\n      for (var i = 0, l = list.length; i < l && c < n; i++) {\n        var buf = list[0];\n        var cpy = Math.min(n - c, buf.length);\n\n        if (stringMode) ret += buf.slice(0, cpy);else buf.copy(ret, c, 0, cpy);\n\n        if (cpy < buf.length) list[0] = buf.slice(cpy);else list.shift();\n\n        c += cpy;\n      }\n    }\n  }\n\n  return ret;\n}\n\nfunction endReadable(stream) {\n  var state = stream._readableState;\n\n  // If we get here before consuming all the bytes, then that is a\n  // bug in node.  Should never happen.\n  if (state.length > 0) throw new Error('endReadable called on non-empty stream');\n\n  if (!state.endEmitted) {\n    state.ended = true;\n    processNextTick(endReadableNT, state, stream);\n  }\n}\n\nfunction endReadableNT(state, stream) {\n  // Check that we didn't get one last unshift.\n  if (!state.endEmitted && state.length === 0) {\n    state.endEmitted = true;\n    stream.readable = false;\n    stream.emit('end');\n  }\n}\n\nfunction forEach(xs, f) {\n  for (var i = 0, l = xs.length; i < l; i++) {\n    f(xs[i], i);\n  }\n}\n\nfunction indexOf(xs, x) {\n  for (var i = 0, l = xs.length; i < l; i++) {\n    if (xs[i] === x) return i;\n  }\n  return -1;\n}","// a transform stream is a readable/writable stream where you do\n// something with the data.  Sometimes it's called a \"filter\",\n// but that's not a great name for it, since that implies a thing where\n// some bits pass through, and others are simply ignored.  (That would\n// be a valid example of a transform, of course.)\n//\n// While the output is causally related to the input, it's not a\n// necessarily symmetric or synchronous transformation.  For example,\n// a zlib stream might take multiple plain-text writes(), and then\n// emit a single compressed chunk some time in the future.\n//\n// Here's how this works:\n//\n// The Transform stream has all the aspects of the readable and writable\n// stream classes.  When you write(chunk), that calls _write(chunk,cb)\n// internally, and returns false if there's a lot of pending writes\n// buffered up.  When you call read(), that calls _read(n) until\n// there's enough pending readable data buffered up.\n//\n// In a transform stream, the written data is placed in a buffer.  When\n// _read(n) is called, it transforms the queued up data, calling the\n// buffered _write cb's as it consumes chunks.  If consuming a single\n// written chunk would result in multiple output chunks, then the first\n// outputted bit calls the readcb, and subsequent chunks just go into\n// the read buffer, and will cause it to emit 'readable' if necessary.\n//\n// This way, back-pressure is actually determined by the reading side,\n// since _read has to be called to start processing a new chunk.  However,\n// a pathological inflate type of transform can cause excessive buffering\n// here.  For example, imagine a stream where every byte of input is\n// interpreted as an integer from 0-255, and then results in that many\n// bytes of output.  Writing the 4 bytes {ff,ff,ff,ff} would result in\n// 1kb of data being output.  In this case, you could write a very small\n// amount of input, and end up with a very large amount of output.  In\n// such a pathological inflating mechanism, there'd be no way to tell\n// the system to stop doing the transform.  A single 4MB write could\n// cause the system to run out of memory.\n//\n// However, even in such a pathological case, only a single written chunk\n// would be consumed, and then the rest would wait (un-transformed) until\n// the results of the previous transformed chunk were consumed.\n\n'use strict';\n\nmodule.exports = Transform;\n\nvar Duplex = require('./_stream_duplex');\n\n/*<replacement>*/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/*</replacement>*/\n\nutil.inherits(Transform, Duplex);\n\nfunction TransformState(stream) {\n  this.afterTransform = function (er, data) {\n    return afterTransform(stream, er, data);\n  };\n\n  this.needTransform = false;\n  this.transforming = false;\n  this.writecb = null;\n  this.writechunk = null;\n  this.writeencoding = null;\n}\n\nfunction afterTransform(stream, er, data) {\n  var ts = stream._transformState;\n  ts.transforming = false;\n\n  var cb = ts.writecb;\n\n  if (!cb) return stream.emit('error', new Error('no writecb in Transform class'));\n\n  ts.writechunk = null;\n  ts.writecb = null;\n\n  if (data !== null && data !== undefined) stream.push(data);\n\n  cb(er);\n\n  var rs = stream._readableState;\n  rs.reading = false;\n  if (rs.needReadable || rs.length < rs.highWaterMark) {\n    stream._read(rs.highWaterMark);\n  }\n}\n\nfunction Transform(options) {\n  if (!(this instanceof Transform)) return new Transform(options);\n\n  Duplex.call(this, options);\n\n  this._transformState = new TransformState(this);\n\n  // when the writable side finishes, then flush out anything remaining.\n  var stream = this;\n\n  // start out asking for a readable event once data is transformed.\n  this._readableState.needReadable = true;\n\n  // we have implemented the _read method, and done the other things\n  // that Readable wants before the first _read call, so unset the\n  // sync guard flag.\n  this._readableState.sync = false;\n\n  if (options) {\n    if (typeof options.transform === 'function') this._transform = options.transform;\n\n    if (typeof options.flush === 'function') this._flush = options.flush;\n  }\n\n  this.once('prefinish', function () {\n    if (typeof this._flush === 'function') this._flush(function (er) {\n      done(stream, er);\n    });else done(stream);\n  });\n}\n\nTransform.prototype.push = function (chunk, encoding) {\n  this._transformState.needTransform = false;\n  return Duplex.prototype.push.call(this, chunk, encoding);\n};\n\n// This is the part where you do stuff!\n// override this function in implementation classes.\n// 'chunk' is an input chunk.\n//\n// Call `push(newChunk)` to pass along transformed output\n// to the readable side.  You may call 'push' zero or more times.\n//\n// Call `cb(err)` when you are done with this chunk.  If you pass\n// an error, then that'll put the hurt on the whole operation.  If you\n// never call cb(), then you'll never get another chunk.\nTransform.prototype._transform = function (chunk, encoding, cb) {\n  throw new Error('not implemented');\n};\n\nTransform.prototype._write = function (chunk, encoding, cb) {\n  var ts = this._transformState;\n  ts.writecb = cb;\n  ts.writechunk = chunk;\n  ts.writeencoding = encoding;\n  if (!ts.transforming) {\n    var rs = this._readableState;\n    if (ts.needTransform || rs.needReadable || rs.length < rs.highWaterMark) this._read(rs.highWaterMark);\n  }\n};\n\n// Doesn't matter what the args are here.\n// _transform does all the work.\n// That we got here means that the readable side wants more data.\nTransform.prototype._read = function (n) {\n  var ts = this._transformState;\n\n  if (ts.writechunk !== null && ts.writecb && !ts.transforming) {\n    ts.transforming = true;\n    this._transform(ts.writechunk, ts.writeencoding, ts.afterTransform);\n  } else {\n    // mark that we need a transform, so that any data that comes in\n    // will get processed, now that we've asked for it.\n    ts.needTransform = true;\n  }\n};\n\nfunction done(stream, er) {\n  if (er) return stream.emit('error', er);\n\n  // if there's nothing in the write buffer, then that means\n  // that nothing more will ever be provided\n  var ws = stream._writableState;\n  var ts = stream._transformState;\n\n  if (ws.length) throw new Error('calling transform done when ws.length != 0');\n\n  if (ts.transforming) throw new Error('calling transform done when still transforming');\n\n  return stream.push(null);\n}","// A bit simpler than readable streams.\n// Implement an async ._write(chunk, encoding, cb), and it'll handle all\n// the drain event emission and buffering.\n\n'use strict';\n\nmodule.exports = Writable;\n\n/*<replacement>*/\nvar processNextTick = require('process-nextick-args');\n/*</replacement>*/\n\n/*<replacement>*/\nvar asyncWrite = !true ? setImmediate : processNextTick;\n/*</replacement>*/\n\n/*<replacement>*/\nvar Buffer = require('buffer').Buffer;\n/*</replacement>*/\n\nWritable.WritableState = WritableState;\n\n/*<replacement>*/\nvar util = require('core-util-is');\nutil.inherits = require('inherits');\n/*</replacement>*/\n\n/*<replacement>*/\nvar internalUtil = {\n  deprecate: require('util-deprecate')\n};\n/*</replacement>*/\n\n/*<replacement>*/\nvar Stream;\n(function () {\n  try {\n    Stream = require('st' + 'ream');\n  } catch (_) {} finally {\n    if (!Stream) Stream = require('events').EventEmitter;\n  }\n})();\n/*</replacement>*/\n\nvar Buffer = require('buffer').Buffer;\n\nutil.inherits(Writable, Stream);\n\nfunction nop() {}\n\nfunction WriteReq(chunk, encoding, cb) {\n  this.chunk = chunk;\n  this.encoding = encoding;\n  this.callback = cb;\n  this.next = null;\n}\n\nvar Duplex;\nfunction WritableState(options, stream) {\n  Duplex = Duplex || require('./_stream_duplex');\n\n  options = options || {};\n\n  // object stream flag to indicate whether or not this stream\n  // contains buffers or objects.\n  this.objectMode = !!options.objectMode;\n\n  if (stream instanceof Duplex) this.objectMode = this.objectMode || !!options.writableObjectMode;\n\n  // the point at which write() starts returning false\n  // Note: 0 is a valid value, means that we always return false if\n  // the entire buffer is not flushed immediately on write()\n  var hwm = options.highWaterMark;\n  var defaultHwm = this.objectMode ? 16 : 16 * 1024;\n  this.highWaterMark = hwm || hwm === 0 ? hwm : defaultHwm;\n\n  // cast to ints.\n  this.highWaterMark = ~ ~this.highWaterMark;\n\n  this.needDrain = false;\n  // at the start of calling end()\n  this.ending = false;\n  // when end() has been called, and returned\n  this.ended = false;\n  // when 'finish' is emitted\n  this.finished = false;\n\n  // should we decode strings into buffers before passing to _write?\n  // this is here so that some node-core streams can optimize string\n  // handling at a lower level.\n  var noDecode = options.decodeStrings === false;\n  this.decodeStrings = !noDecode;\n\n  // Crypto is kind of old and crusty.  Historically, its default string\n  // encoding is 'binary' so we have to make this configurable.\n  // Everything else in the universe uses 'utf8', though.\n  this.defaultEncoding = options.defaultEncoding || 'utf8';\n\n  // not an actual buffer we keep track of, but a measurement\n  // of how much we're waiting to get pushed to some underlying\n  // socket or file.\n  this.length = 0;\n\n  // a flag to see when we're in the middle of a write.\n  this.writing = false;\n\n  // when true all writes will be buffered until .uncork() call\n  this.corked = 0;\n\n  // a flag to be able to tell if the onwrite cb is called immediately,\n  // or on a later tick.  We set this to true at first, because any\n  // actions that shouldn't happen until \"later\" should generally also\n  // not happen before the first write call.\n  this.sync = true;\n\n  // a flag to know if we're processing previously buffered items, which\n  // may call the _write() callback in the same tick, so that we don't\n  // end up in an overlapped onwrite situation.\n  this.bufferProcessing = false;\n\n  // the callback that's passed to _write(chunk,cb)\n  this.onwrite = function (er) {\n    onwrite(stream, er);\n  };\n\n  // the callback that the user supplies to write(chunk,encoding,cb)\n  this.writecb = null;\n\n  // the amount that is being written when _write is called.\n  this.writelen = 0;\n\n  this.bufferedRequest = null;\n  this.lastBufferedRequest = null;\n\n  // number of pending user-supplied write callbacks\n  // this must be 0 before 'finish' can be emitted\n  this.pendingcb = 0;\n\n  // emit prefinish if the only thing we're waiting for is _write cbs\n  // This is relevant for synchronous Transform streams\n  this.prefinished = false;\n\n  // True if the error was already emitted and should not be thrown again\n  this.errorEmitted = false;\n\n  // count buffered requests\n  this.bufferedRequestCount = 0;\n\n  // create the two objects needed to store the corked requests\n  // they are not a linked list, as no new elements are inserted in there\n  this.corkedRequestsFree = new CorkedRequest(this);\n  this.corkedRequestsFree.next = new CorkedRequest(this);\n}\n\nWritableState.prototype.getBuffer = function writableStateGetBuffer() {\n  var current = this.bufferedRequest;\n  var out = [];\n  while (current) {\n    out.push(current);\n    current = current.next;\n  }\n  return out;\n};\n\n(function () {\n  try {\n    Object.defineProperty(WritableState.prototype, 'buffer', {\n      get: internalUtil.deprecate(function () {\n        return this.getBuffer();\n      }, '_writableState.buffer is deprecated. Use _writableState.getBuffer ' + 'instead.')\n    });\n  } catch (_) {}\n})();\n\nvar Duplex;\nfunction Writable(options) {\n  Duplex = Duplex || require('./_stream_duplex');\n\n  // Writable ctor is applied to Duplexes, though they're not\n  // instanceof Writable, they're instanceof Readable.\n  if (!(this instanceof Writable) && !(this instanceof Duplex)) return new Writable(options);\n\n  this._writableState = new WritableState(options, this);\n\n  // legacy.\n  this.writable = true;\n\n  if (options) {\n    if (typeof options.write === 'function') this._write = options.write;\n\n    if (typeof options.writev === 'function') this._writev = options.writev;\n  }\n\n  Stream.call(this);\n}\n\n// Otherwise people can pipe Writable streams, which is just wrong.\nWritable.prototype.pipe = function () {\n  this.emit('error', new Error('Cannot pipe. Not readable.'));\n};\n\nfunction writeAfterEnd(stream, cb) {\n  var er = new Error('write after end');\n  // TODO: defer error events consistently everywhere, not just the cb\n  stream.emit('error', er);\n  processNextTick(cb, er);\n}\n\n// If we get something that is not a buffer, string, null, or undefined,\n// and we're not in objectMode, then that's an error.\n// Otherwise stream chunks are all considered to be of length=1, and the\n// watermarks determine how many objects to keep in the buffer, rather than\n// how many bytes or characters.\nfunction validChunk(stream, state, chunk, cb) {\n  var valid = true;\n\n  if (!Buffer.isBuffer(chunk) && typeof chunk !== 'string' && chunk !== null && chunk !== undefined && !state.objectMode) {\n    var er = new TypeError('Invalid non-string/buffer chunk');\n    stream.emit('error', er);\n    processNextTick(cb, er);\n    valid = false;\n  }\n  return valid;\n}\n\nWritable.prototype.write = function (chunk, encoding, cb) {\n  var state = this._writableState;\n  var ret = false;\n\n  if (typeof encoding === 'function') {\n    cb = encoding;\n    encoding = null;\n  }\n\n  if (Buffer.isBuffer(chunk)) encoding = 'buffer';else if (!encoding) encoding = state.defaultEncoding;\n\n  if (typeof cb !== 'function') cb = nop;\n\n  if (state.ended) writeAfterEnd(this, cb);else if (validChunk(this, state, chunk, cb)) {\n    state.pendingcb++;\n    ret = writeOrBuffer(this, state, chunk, encoding, cb);\n  }\n\n  return ret;\n};\n\nWritable.prototype.cork = function () {\n  var state = this._writableState;\n\n  state.corked++;\n};\n\nWritable.prototype.uncork = function () {\n  var state = this._writableState;\n\n  if (state.corked) {\n    state.corked--;\n\n    if (!state.writing && !state.corked && !state.finished && !state.bufferProcessing && state.bufferedRequest) clearBuffer(this, state);\n  }\n};\n\nWritable.prototype.setDefaultEncoding = function setDefaultEncoding(encoding) {\n  // node::ParseEncoding() requires lower case.\n  if (typeof encoding === 'string') encoding = encoding.toLowerCase();\n  if (!(['hex', 'utf8', 'utf-8', 'ascii', 'binary', 'base64', 'ucs2', 'ucs-2', 'utf16le', 'utf-16le', 'raw'].indexOf((encoding + '').toLowerCase()) > -1)) throw new TypeError('Unknown encoding: ' + encoding);\n  this._writableState.defaultEncoding = encoding;\n};\n\nfunction decodeChunk(state, chunk, encoding) {\n  if (!state.objectMode && state.decodeStrings !== false && typeof chunk === 'string') {\n    chunk = new Buffer(chunk, encoding);\n  }\n  return chunk;\n}\n\n// if we're already writing something, then just put this\n// in the queue, and wait our turn.  Otherwise, call _write\n// If we return false, then we need a drain event, so set that flag.\nfunction writeOrBuffer(stream, state, chunk, encoding, cb) {\n  chunk = decodeChunk(state, chunk, encoding);\n\n  if (Buffer.isBuffer(chunk)) encoding = 'buffer';\n  var len = state.objectMode ? 1 : chunk.length;\n\n  state.length += len;\n\n  var ret = state.length < state.highWaterMark;\n  // we must ensure that previous needDrain will not be reset to false.\n  if (!ret) state.needDrain = true;\n\n  if (state.writing || state.corked) {\n    var last = state.lastBufferedRequest;\n    state.lastBufferedRequest = new WriteReq(chunk, encoding, cb);\n    if (last) {\n      last.next = state.lastBufferedRequest;\n    } else {\n      state.bufferedRequest = state.lastBufferedRequest;\n    }\n    state.bufferedRequestCount += 1;\n  } else {\n    doWrite(stream, state, false, len, chunk, encoding, cb);\n  }\n\n  return ret;\n}\n\nfunction doWrite(stream, state, writev, len, chunk, encoding, cb) {\n  state.writelen = len;\n  state.writecb = cb;\n  state.writing = true;\n  state.sync = true;\n  if (writev) stream._writev(chunk, state.onwrite);else stream._write(chunk, encoding, state.onwrite);\n  state.sync = false;\n}\n\nfunction onwriteError(stream, state, sync, er, cb) {\n  --state.pendingcb;\n  if (sync) processNextTick(cb, er);else cb(er);\n\n  stream._writableState.errorEmitted = true;\n  stream.emit('error', er);\n}\n\nfunction onwriteStateUpdate(state) {\n  state.writing = false;\n  state.writecb = null;\n  state.length -= state.writelen;\n  state.writelen = 0;\n}\n\nfunction onwrite(stream, er) {\n  var state = stream._writableState;\n  var sync = state.sync;\n  var cb = state.writecb;\n\n  onwriteStateUpdate(state);\n\n  if (er) onwriteError(stream, state, sync, er, cb);else {\n    // Check if we're actually ready to finish, but don't emit yet\n    var finished = needFinish(state);\n\n    if (!finished && !state.corked && !state.bufferProcessing && state.bufferedRequest) {\n      clearBuffer(stream, state);\n    }\n\n    if (sync) {\n      /*<replacement>*/\n      asyncWrite(afterWrite, stream, state, finished, cb);\n      /*</replacement>*/\n    } else {\n        afterWrite(stream, state, finished, cb);\n      }\n  }\n}\n\nfunction afterWrite(stream, state, finished, cb) {\n  if (!finished) onwriteDrain(stream, state);\n  state.pendingcb--;\n  cb();\n  finishMaybe(stream, state);\n}\n\n// Must force callback to be called on nextTick, so that we don't\n// emit 'drain' before the write() consumer gets the 'false' return\n// value, and has a chance to attach a 'drain' listener.\nfunction onwriteDrain(stream, state) {\n  if (state.length === 0 && state.needDrain) {\n    state.needDrain = false;\n    stream.emit('drain');\n  }\n}\n\n// if there's something in the buffer waiting, then process it\nfunction clearBuffer(stream, state) {\n  state.bufferProcessing = true;\n  var entry = state.bufferedRequest;\n\n  if (stream._writev && entry && entry.next) {\n    // Fast case, write everything using _writev()\n    var l = state.bufferedRequestCount;\n    var buffer = new Array(l);\n    var holder = state.corkedRequestsFree;\n    holder.entry = entry;\n\n    var count = 0;\n    while (entry) {\n      buffer[count] = entry;\n      entry = entry.next;\n      count += 1;\n    }\n\n    doWrite(stream, state, true, state.length, buffer, '', holder.finish);\n\n    // doWrite is always async, defer these to save a bit of time\n    // as the hot path ends with doWrite\n    state.pendingcb++;\n    state.lastBufferedRequest = null;\n    state.corkedRequestsFree = holder.next;\n    holder.next = null;\n  } else {\n    // Slow case, write chunks one-by-one\n    while (entry) {\n      var chunk = entry.chunk;\n      var encoding = entry.encoding;\n      var cb = entry.callback;\n      var len = state.objectMode ? 1 : chunk.length;\n\n      doWrite(stream, state, false, len, chunk, encoding, cb);\n      entry = entry.next;\n      // if we didn't call the onwrite immediately, then\n      // it means that we need to wait until it does.\n      // also, that means that the chunk and cb are currently\n      // being processed, so move the buffer counter past them.\n      if (state.writing) {\n        break;\n      }\n    }\n\n    if (entry === null) state.lastBufferedRequest = null;\n  }\n\n  state.bufferedRequestCount = 0;\n  state.bufferedRequest = entry;\n  state.bufferProcessing = false;\n}\n\nWritable.prototype._write = function (chunk, encoding, cb) {\n  cb(new Error('not implemented'));\n};\n\nWritable.prototype._writev = null;\n\nWritable.prototype.end = function (chunk, encoding, cb) {\n  var state = this._writableState;\n\n  if (typeof chunk === 'function') {\n    cb = chunk;\n    chunk = null;\n    encoding = null;\n  } else if (typeof encoding === 'function') {\n    cb = encoding;\n    encoding = null;\n  }\n\n  if (chunk !== null && chunk !== undefined) this.write(chunk, encoding);\n\n  // .end() fully uncorks\n  if (state.corked) {\n    state.corked = 1;\n    this.uncork();\n  }\n\n  // ignore unnecessary end() calls.\n  if (!state.ending && !state.finished) endWritable(this, state, cb);\n};\n\nfunction needFinish(state) {\n  return state.ending && state.length === 0 && state.bufferedRequest === null && !state.finished && !state.writing;\n}\n\nfunction prefinish(stream, state) {\n  if (!state.prefinished) {\n    state.prefinished = true;\n    stream.emit('prefinish');\n  }\n}\n\nfunction finishMaybe(stream, state) {\n  var need = needFinish(state);\n  if (need) {\n    if (state.pendingcb === 0) {\n      prefinish(stream, state);\n      state.finished = true;\n      stream.emit('finish');\n    } else {\n      prefinish(stream, state);\n    }\n  }\n  return need;\n}\n\nfunction endWritable(stream, state, cb) {\n  state.ending = true;\n  finishMaybe(stream, state);\n  if (cb) {\n    if (state.finished) processNextTick(cb);else stream.once('finish', cb);\n  }\n  state.ended = true;\n  stream.writable = false;\n}\n\n// It seems a linked list but it is not\n// there will be only 2 of these for each stream\nfunction CorkedRequest(state) {\n  var _this = this;\n\n  this.next = null;\n  this.entry = null;\n\n  this.finish = function (err) {\n    var entry = _this.entry;\n    _this.entry = null;\n    while (entry) {\n      var cb = entry.callback;\n      state.pendingcb--;\n      cb(err);\n      entry = entry.next;\n    }\n    if (state.corkedRequestsFree) {\n      state.corkedRequestsFree.next = _this;\n    } else {\n      state.corkedRequestsFree = _this;\n    }\n  };\n}","module.exports = require(\"./lib/_stream_passthrough.js\")\n","var Stream = (function (){\n  try {\n    return require('st' + 'ream'); // hack to fix a circular dependency issue when used with browserify\n  } catch(_){}\n}());\nexports = module.exports = require('./lib/_stream_readable.js');\nexports.Stream = Stream || exports;\nexports.Readable = exports;\nexports.Writable = require('./lib/_stream_writable.js');\nexports.Duplex = require('./lib/_stream_duplex.js');\nexports.Transform = require('./lib/_stream_transform.js');\nexports.PassThrough = require('./lib/_stream_passthrough.js');\n\n// inline-process-browser and unreachable-branch-transform make sure this is\n// removed in browserify builds\nif (!true) {\n  module.exports = require('stream');\n}\n","module.exports = require(\"./lib/_stream_transform.js\")\n","module.exports = require(\"./lib/_stream_writable.js\")\n","var ClientRequest = require('./lib/request')\nvar extend = require('xtend')\nvar statusCodes = require('builtin-status-codes')\nvar url = require('url')\n\nvar http = exports\n\nhttp.request = function (opts, cb) {\n\tif (typeof opts === 'string')\n\t\topts = url.parse(opts)\n\telse\n\t\topts = extend(opts)\n\n\t// Normally, the page is loaded from http or https, so not specifying a protocol\n\t// will result in a (valid) protocol-relative url. However, this won't work if\n\t// the protocol is something else, like 'file:'\n\tvar defaultProtocol = global.location.protocol.search(/^https?:$/) === -1 ? 'http:' : ''\n\n\tvar protocol = opts.protocol || defaultProtocol\n\tvar host = opts.hostname || opts.host\n\tvar port = opts.port\n\tvar path = opts.path || '/'\n\n\t// Necessary for IPv6 addresses\n\tif (host && host.indexOf(':') !== -1)\n\t\thost = '[' + host + ']'\n\n\t// This may be a relative url. The browser should always be able to interpret it correctly.\n\topts.url = (host ? (protocol + '//' + host) : '') + (port ? ':' + port : '') + path\n\topts.method = (opts.method || 'GET').toUpperCase()\n\topts.headers = opts.headers || {}\n\n\t// Also valid opts.auth, opts.mode\n\n\tvar req = new ClientRequest(opts)\n\tif (cb)\n\t\treq.on('response', cb)\n\treturn req\n}\n\nhttp.get = function get (opts, cb) {\n\tvar req = http.request(opts, cb)\n\treq.end()\n\treturn req\n}\n\nhttp.Agent = function () {}\nhttp.Agent.defaultMaxSockets = 4\n\nhttp.STATUS_CODES = statusCodes\n\nhttp.METHODS = [\n\t'CHECKOUT',\n\t'CONNECT',\n\t'COPY',\n\t'DELETE',\n\t'GET',\n\t'HEAD',\n\t'LOCK',\n\t'M-SEARCH',\n\t'MERGE',\n\t'MKACTIVITY',\n\t'MKCOL',\n\t'MOVE',\n\t'NOTIFY',\n\t'OPTIONS',\n\t'PATCH',\n\t'POST',\n\t'PROPFIND',\n\t'PROPPATCH',\n\t'PURGE',\n\t'PUT',\n\t'REPORT',\n\t'SEARCH',\n\t'SUBSCRIBE',\n\t'TRACE',\n\t'UNLOCK',\n\t'UNSUBSCRIBE'\n]","exports.fetch = isFunction(global.fetch) && isFunction(global.ReadableByteStream)\n\nexports.blobConstructor = false\ntry {\n\tnew Blob([new ArrayBuffer(1)])\n\texports.blobConstructor = true\n} catch (e) {}\n\nvar xhr = new global.XMLHttpRequest()\n// If location.host is empty, e.g. if this page/worker was loaded\n// from a Blob, then use example.com to avoid an error\nxhr.open('GET', global.location.host ? '/' : 'https://example.com')\n\nfunction checkTypeSupport (type) {\n\ttry {\n\t\txhr.responseType = type\n\t\treturn xhr.responseType === type\n\t} catch (e) {}\n\treturn false\n}\n\n// For some strange reason, Safari 7.0 reports typeof global.ArrayBuffer === 'object'.\n// Safari 7.1 appears to have fixed this bug.\nvar haveArrayBuffer = typeof global.ArrayBuffer !== 'undefined'\nvar haveSlice = haveArrayBuffer && isFunction(global.ArrayBuffer.prototype.slice)\n\nexports.arraybuffer = haveArrayBuffer && checkTypeSupport('arraybuffer')\n// These next two tests unavoidably show warnings in Chrome. Since fetch will always\n// be used if it's available, just return false for these to avoid the warnings.\nexports.msstream = !exports.fetch && haveSlice && checkTypeSupport('ms-stream')\nexports.mozchunkedarraybuffer = !exports.fetch && haveArrayBuffer &&\n\tcheckTypeSupport('moz-chunked-arraybuffer')\nexports.overrideMimeType = isFunction(xhr.overrideMimeType)\nexports.vbArray = isFunction(global.VBArray)\n\nfunction isFunction (value) {\n  return typeof value === 'function'\n}\n\nxhr = null // Help gc\n","// var Base64 = require('Base64')\nvar capability = require('./capability')\nvar inherits = require('inherits')\nvar response = require('./response')\nvar stream = require('stream')\nvar toArrayBuffer = require('to-arraybuffer')\n\nvar IncomingMessage = response.IncomingMessage\nvar rStates = response.readyStates\n\nfunction decideMode (preferBinary) {\n\tif (capability.fetch) {\n\t\treturn 'fetch'\n\t} else if (capability.mozchunkedarraybuffer) {\n\t\treturn 'moz-chunked-arraybuffer'\n\t} else if (capability.msstream) {\n\t\treturn 'ms-stream'\n\t} else if (capability.arraybuffer && preferBinary) {\n\t\treturn 'arraybuffer'\n\t} else if (capability.vbArray && preferBinary) {\n\t\treturn 'text:vbarray'\n\t} else {\n\t\treturn 'text'\n\t}\n}\n\nvar ClientRequest = module.exports = function (opts) {\n\tvar self = this\n\tstream.Writable.call(self)\n\n\tself._opts = opts\n\tself._body = []\n\tself._headers = {}\n\tif (opts.auth)\n\t\tself.setHeader('Authorization', 'Basic ' + new Buffer(opts.auth).toString('base64'))\n\tObject.keys(opts.headers).forEach(function (name) {\n\t\tself.setHeader(name, opts.headers[name])\n\t})\n\n\tvar preferBinary\n\tif (opts.mode === 'prefer-streaming') {\n\t\t// If streaming is a high priority but binary compatibility and\n\t\t// the accuracy of the 'content-type' header aren't\n\t\tpreferBinary = false\n\t} else if (opts.mode === 'allow-wrong-content-type') {\n\t\t// If streaming is more important than preserving the 'content-type' header\n\t\tpreferBinary = !capability.overrideMimeType\n\t} else if (!opts.mode || opts.mode === 'default' || opts.mode === 'prefer-fast') {\n\t\t// Use binary if text streaming may corrupt data or the content-type header, or for speed\n\t\tpreferBinary = true\n\t} else {\n\t\tthrow new Error('Invalid value for opts.mode')\n\t}\n\tself._mode = decideMode(preferBinary)\n\n\tself.on('finish', function () {\n\t\tself._onFinish()\n\t})\n}\n\ninherits(ClientRequest, stream.Writable)\n\nClientRequest.prototype.setHeader = function (name, value) {\n\tvar self = this\n\tvar lowerName = name.toLowerCase()\n\t// This check is not necessary, but it prevents warnings from browsers about setting unsafe\n\t// headers. To be honest I'm not entirely sure hiding these warnings is a good thing, but\n\t// http-browserify did it, so I will too.\n\tif (unsafeHeaders.indexOf(lowerName) !== -1)\n\t\treturn\n\n\tself._headers[lowerName] = {\n\t\tname: name,\n\t\tvalue: value\n\t}\n}\n\nClientRequest.prototype.getHeader = function (name) {\n\tvar self = this\n\treturn self._headers[name.toLowerCase()].value\n}\n\nClientRequest.prototype.removeHeader = function (name) {\n\tvar self = this\n\tdelete self._headers[name.toLowerCase()]\n}\n\nClientRequest.prototype._onFinish = function () {\n\tvar self = this\n\n\tif (self._destroyed)\n\t\treturn\n\tvar opts = self._opts\n\n\tvar headersObj = self._headers\n\tvar body\n\tif (opts.method === 'POST' || opts.method === 'PUT' || opts.method === 'PATCH') {\n\t\tif (capability.blobConstructor) {\n\t\t\tbody = new global.Blob(self._body.map(function (buffer) {\n\t\t\t\treturn toArrayBuffer(buffer)\n\t\t\t}), {\n\t\t\t\ttype: (headersObj['content-type'] || {}).value || ''\n\t\t\t})\n\t\t} else {\n\t\t\t// get utf8 string\n\t\t\tbody = Buffer.concat(self._body).toString()\n\t\t}\n\t}\n\n\tif (self._mode === 'fetch') {\n\t\tvar headers = Object.keys(headersObj).map(function (name) {\n\t\t\treturn [headersObj[name].name, headersObj[name].value]\n\t\t})\n\n\t\tglobal.fetch(self._opts.url, {\n\t\t\tmethod: self._opts.method,\n\t\t\theaders: headers,\n\t\t\tbody: body,\n\t\t\tmode: 'cors',\n\t\t\tcredentials: opts.withCredentials ? 'include' : 'same-origin'\n\t\t}).then(function (response) {\n\t\t\tself._fetchResponse = response\n\t\t\tself._connect()\n\t\t}, function (reason) {\n\t\t\tself.emit('error', reason)\n\t\t})\n\t} else {\n\t\tvar xhr = self._xhr = new global.XMLHttpRequest()\n\t\ttry {\n\t\t\txhr.open(self._opts.method, self._opts.url, true)\n\t\t} catch (err) {\n\t\t\tprocess.nextTick(function () {\n\t\t\t\tself.emit('error', err)\n\t\t\t})\n\t\t\treturn\n\t\t}\n\n\t\t// Can't set responseType on really old browsers\n\t\tif ('responseType' in xhr)\n\t\t\txhr.responseType = self._mode.split(':')[0]\n\n\t\tif ('withCredentials' in xhr)\n\t\t\txhr.withCredentials = !!opts.withCredentials\n\n\t\tif (self._mode === 'text' && 'overrideMimeType' in xhr)\n\t\t\txhr.overrideMimeType('text/plain; charset=x-user-defined')\n\n\t\tObject.keys(headersObj).forEach(function (name) {\n\t\t\txhr.setRequestHeader(headersObj[name].name, headersObj[name].value)\n\t\t})\n\n\t\tself._response = null\n\t\txhr.onreadystatechange = function () {\n\t\t\tswitch (xhr.readyState) {\n\t\t\t\tcase rStates.LOADING:\n\t\t\t\tcase rStates.DONE:\n\t\t\t\t\tself._onXHRProgress()\n\t\t\t\t\tbreak\n\t\t\t}\n\t\t}\n\t\t// Necessary for streaming in Firefox, since xhr.response is ONLY defined\n\t\t// in onprogress, not in onreadystatechange with xhr.readyState = 3\n\t\tif (self._mode === 'moz-chunked-arraybuffer') {\n\t\t\txhr.onprogress = function () {\n\t\t\t\tself._onXHRProgress()\n\t\t\t}\n\t\t}\n\n\t\txhr.onerror = function () {\n\t\t\tif (self._destroyed)\n\t\t\t\treturn\n\t\t\tself.emit('error', new Error('XHR error'))\n\t\t}\n\n\t\ttry {\n\t\t\txhr.send(body)\n\t\t} catch (err) {\n\t\t\tprocess.nextTick(function () {\n\t\t\t\tself.emit('error', err)\n\t\t\t})\n\t\t\treturn\n\t\t}\n\t}\n}\n\n/**\n * Checks if xhr.status is readable and non-zero, indicating no error.\n * Even though the spec says it should be available in readyState 3,\n * accessing it throws an exception in IE8\n */\nfunction statusValid (xhr) {\n\ttry {\n\t\tvar status = xhr.status\n\t\treturn (status !== null && status !== 0)\n\t} catch (e) {\n\t\treturn false\n\t}\n}\n\nClientRequest.prototype._onXHRProgress = function () {\n\tvar self = this\n\n\tif (!statusValid(self._xhr) || self._destroyed)\n\t\treturn\n\n\tif (!self._response)\n\t\tself._connect()\n\n\tself._response._onXHRProgress()\n}\n\nClientRequest.prototype._connect = function () {\n\tvar self = this\n\n\tif (self._destroyed)\n\t\treturn\n\n\tself._response = new IncomingMessage(self._xhr, self._fetchResponse, self._mode)\n\tself.emit('response', self._response)\n}\n\nClientRequest.prototype._write = function (chunk, encoding, cb) {\n\tvar self = this\n\n\tself._body.push(chunk)\n\tcb()\n}\n\nClientRequest.prototype.abort = ClientRequest.prototype.destroy = function () {\n\tvar self = this\n\tself._destroyed = true\n\tif (self._response)\n\t\tself._response._destroyed = true\n\tif (self._xhr)\n\t\tself._xhr.abort()\n\t// Currently, there isn't a way to truly abort a fetch.\n\t// If you like bikeshedding, see https://github.com/whatwg/fetch/issues/27\n}\n\nClientRequest.prototype.end = function (data, encoding, cb) {\n\tvar self = this\n\tif (typeof data === 'function') {\n\t\tcb = data\n\t\tdata = undefined\n\t}\n\n\tstream.Writable.prototype.end.call(self, data, encoding, cb)\n}\n\nClientRequest.prototype.flushHeaders = function () {}\nClientRequest.prototype.setTimeout = function () {}\nClientRequest.prototype.setNoDelay = function () {}\nClientRequest.prototype.setSocketKeepAlive = function () {}\n\n// Taken from http://www.w3.org/TR/XMLHttpRequest/#the-setrequestheader%28%29-method\nvar unsafeHeaders = [\n\t'accept-charset',\n\t'accept-encoding',\n\t'access-control-request-headers',\n\t'access-control-request-method',\n\t'connection',\n\t'content-length',\n\t'cookie',\n\t'cookie2',\n\t'date',\n\t'dnt',\n\t'expect',\n\t'host',\n\t'keep-alive',\n\t'origin',\n\t'referer',\n\t'te',\n\t'trailer',\n\t'transfer-encoding',\n\t'upgrade',\n\t'user-agent',\n\t'via'\n]\n","var capability = require('./capability')\nvar inherits = require('inherits')\nvar stream = require('stream')\n\nvar rStates = exports.readyStates = {\n\tUNSENT: 0,\n\tOPENED: 1,\n\tHEADERS_RECEIVED: 2,\n\tLOADING: 3,\n\tDONE: 4\n}\n\nvar IncomingMessage = exports.IncomingMessage = function (xhr, response, mode) {\n\tvar self = this\n\tstream.Readable.call(self)\n\n\tself._mode = mode\n\tself.headers = {}\n\tself.rawHeaders = []\n\tself.trailers = {}\n\tself.rawTrailers = []\n\n\t// Fake the 'close' event, but only once 'end' fires\n\tself.on('end', function () {\n\t\t// The nextTick is necessary to prevent the 'request' module from causing an infinite loop\n\t\tprocess.nextTick(function () {\n\t\t\tself.emit('close')\n\t\t})\n\t})\n\n\tif (mode === 'fetch') {\n\t\tself._fetchResponse = response\n\n\t\tself.statusCode = response.status\n\t\tself.statusMessage = response.statusText\n\t\t// backwards compatible version of for (<item> of <iterable>):\n\t\t// for (var <item>,_i,_it = <iterable>[Symbol.iterator](); <item> = (_i = _it.next()).value,!_i.done;)\n\t\tfor (var header, _i, _it = response.headers[Symbol.iterator](); header = (_i = _it.next()).value, !_i.done;) {\n\t\t\tself.headers[header[0].toLowerCase()] = header[1]\n\t\t\tself.rawHeaders.push(header[0], header[1])\n\t\t}\n\n\t\t// TODO: this doesn't respect backpressure. Once WritableStream is available, this can be fixed\n\t\tvar reader = response.body.getReader()\n\t\tfunction read () {\n\t\t\treader.read().then(function (result) {\n\t\t\t\tif (self._destroyed)\n\t\t\t\t\treturn\n\t\t\t\tif (result.done) {\n\t\t\t\t\tself.push(null)\n\t\t\t\t\treturn\n\t\t\t\t}\n\t\t\t\tself.push(new Buffer(result.value))\n\t\t\t\tread()\n\t\t\t})\n\t\t}\n\t\tread()\n\n\t} else {\n\t\tself._xhr = xhr\n\t\tself._pos = 0\n\n\t\tself.statusCode = xhr.status\n\t\tself.statusMessage = xhr.statusText\n\t\tvar headers = xhr.getAllResponseHeaders().split(/\\r?\\n/)\n\t\theaders.forEach(function (header) {\n\t\t\tvar matches = header.match(/^([^:]+):\\s*(.*)/)\n\t\t\tif (matches) {\n\t\t\t\tvar key = matches[1].toLowerCase()\n\t\t\t\tif (key === 'set-cookie') {\n\t\t\t\t\tif (self.headers[key] === undefined) {\n\t\t\t\t\t\tself.headers[key] = []\n\t\t\t\t\t}\n\t\t\t\t\tself.headers[key].push(matches[2])\n\t\t\t\t} else if (self.headers[key] !== undefined) {\n\t\t\t\t\tself.headers[key] += ', ' + matches[2]\n\t\t\t\t} else {\n\t\t\t\t\tself.headers[key] = matches[2]\n\t\t\t\t}\n\t\t\t\tself.rawHeaders.push(matches[1], matches[2])\n\t\t\t}\n\t\t})\n\n\t\tself._charset = 'x-user-defined'\n\t\tif (!capability.overrideMimeType) {\n\t\t\tvar mimeType = self.rawHeaders['mime-type']\n\t\t\tif (mimeType) {\n\t\t\t\tvar charsetMatch = mimeType.match(/;\\s*charset=([^;])(;|$)/)\n\t\t\t\tif (charsetMatch) {\n\t\t\t\t\tself._charset = charsetMatch[1].toLowerCase()\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (!self._charset)\n\t\t\t\tself._charset = 'utf-8' // best guess\n\t\t}\n\t}\n}\n\ninherits(IncomingMessage, stream.Readable)\n\nIncomingMessage.prototype._read = function () {}\n\nIncomingMessage.prototype._onXHRProgress = function () {\n\tvar self = this\n\n\tvar xhr = self._xhr\n\n\tvar response = null\n\tswitch (self._mode) {\n\t\tcase 'text:vbarray': // For IE9\n\t\t\tif (xhr.readyState !== rStates.DONE)\n\t\t\t\tbreak\n\t\t\ttry {\n\t\t\t\t// This fails in IE8\n\t\t\t\tresponse = new global.VBArray(xhr.responseBody).toArray()\n\t\t\t} catch (e) {}\n\t\t\tif (response !== null) {\n\t\t\t\tself.push(new Buffer(response))\n\t\t\t\tbreak\n\t\t\t}\n\t\t\t// Falls through in IE8\t\n\t\tcase 'text':\n\t\t\ttry { // This will fail when readyState = 3 in IE9. Switch mode and wait for readyState = 4\n\t\t\t\tresponse = xhr.responseText\n\t\t\t} catch (e) {\n\t\t\t\tself._mode = 'text:vbarray'\n\t\t\t\tbreak\n\t\t\t}\n\t\t\tif (response.length > self._pos) {\n\t\t\t\tvar newData = response.substr(self._pos)\n\t\t\t\tif (self._charset === 'x-user-defined') {\n\t\t\t\t\tvar buffer = new Buffer(newData.length)\n\t\t\t\t\tfor (var i = 0; i < newData.length; i++)\n\t\t\t\t\t\tbuffer[i] = newData.charCodeAt(i) & 0xff\n\n\t\t\t\t\tself.push(buffer)\n\t\t\t\t} else {\n\t\t\t\t\tself.push(newData, self._charset)\n\t\t\t\t}\n\t\t\t\tself._pos = response.length\n\t\t\t}\n\t\t\tbreak\n\t\tcase 'arraybuffer':\n\t\t\tif (xhr.readyState !== rStates.DONE)\n\t\t\t\tbreak\n\t\t\tresponse = xhr.response\n\t\t\tself.push(new Buffer(new Uint8Array(response)))\n\t\t\tbreak\n\t\tcase 'moz-chunked-arraybuffer': // take whole\n\t\t\tresponse = xhr.response\n\t\t\tif (xhr.readyState !== rStates.LOADING || !response)\n\t\t\t\tbreak\n\t\t\tself.push(new Buffer(new Uint8Array(response)))\n\t\t\tbreak\n\t\tcase 'ms-stream':\n\t\t\tresponse = xhr.response\n\t\t\tif (xhr.readyState !== rStates.LOADING)\n\t\t\t\tbreak\n\t\t\tvar reader = new global.MSStreamReader()\n\t\t\treader.onprogress = function () {\n\t\t\t\tif (reader.result.byteLength > self._pos) {\n\t\t\t\t\tself.push(new Buffer(new Uint8Array(reader.result.slice(self._pos))))\n\t\t\t\t\tself._pos = reader.result.byteLength\n\t\t\t\t}\n\t\t\t}\n\t\t\treader.onload = function () {\n\t\t\t\tself.push(null)\n\t\t\t}\n\t\t\t// reader.onerror = ??? // TODO: this\n\t\t\treader.readAsArrayBuffer(response)\n\t\t\tbreak\n\t}\n\n\t// The ms-stream case handles end separately in reader.onload()\n\tif (self._xhr.readyState === rStates.DONE && self._mode !== 'ms-stream') {\n\t\tself.push(null)\n\t}\n}\n","var pull = require('pull-stream/pull')\n\nfunction destroy(stream, cb) {\n  function onClose () {\n    cleanup(); cb()\n  }\n  function onError (err) {\n    cleanup(); cb(err)\n  }\n  function cleanup() {\n    stream.removeListener('close', onClose)\n    stream.removeListener('error', onError)\n  }\n  stream.on('close', onClose)\n  stream.on('error', onError)\n}\n\nfunction write(read, stream, cb) {\n  var ended, closed = false, did\n  function done () {\n    if(did) return\n    did = true\n    cb && cb(ended === true ? null : ended)\n  }\n\n  function onClose () {\n    if(closed) return\n    closed = true\n    cleanup()\n    if(!ended) read(ended = true, done)\n    else       done()\n  }\n  function onError (err) {\n    cleanup()\n    if(!ended) read(ended = err, done)\n  }\n  function cleanup() {\n    stream.on('finish', onClose)\n    stream.removeListener('close', onClose)\n    stream.removeListener('error', onError)\n  }\n  stream.on('close', onClose)\n  stream.on('finish', onClose)\n  stream.on('error', onError)\n  process.nextTick(function next() {\n    read(null, function (end, data) {\n      ended = ended || end\n      //you can't \"end\" a stdout stream, so this needs to be handled specially.\n      if(end === true)\n        return stream._isStdio ? done() : stream.end()\n\n      if(ended = ended || end) {\n        stream.destroy && stream.destroy()\n        return done(ended)\n      }\n\n      //I noticed a problem streaming to the terminal:\n      //sometimes the end got cut off, creating invalid output.\n      //it seems that stdout always emits \"drain\" when it ends.\n      //so this seems to work, but i have been unable to reproduce this test\n      //automatically, so you need to run ./test/stdout.js a few times and the end is valid json.\n      if(stream._isStdio)\n        stream.write(data, function () { next() })\n      else {\n        var pause = stream.write(data)\n        if(pause === false)\n          stream.once('drain', next)\n        else next()\n      }\n    })\n  })\n}\n\nfunction first (emitter, events, handler) {\n  function listener (val) {\n    events.forEach(function (e) {\n      emitter.removeListener(e, listener)\n    })\n    handler(val)\n  }\n  events.forEach(function (e) {\n    emitter.on(e, listener)\n  })\n  return emitter\n}\n\nfunction read2(stream) {\n  var ended = false, waiting = false\n  var _cb\n\n  function read () {\n    var data = stream.read()\n    if(data !== null && _cb) {\n      var cb = _cb; _cb = null\n      cb(null, data)\n    }\n  }\n\n  stream.on('readable', function () {\n    waiting = true\n    _cb && read()\n  })\n  .on('end', function () {\n    ended = true\n    _cb && _cb(ended)\n  })\n  .on('error', function (err) {\n    ended = err\n    _cb && _cb(ended)\n  })\n\n  return function (end, cb) {\n    _cb = cb\n    if(ended)\n      cb(ended)\n    else if(waiting)\n      read()\n  }\n}\n\nfunction read1(stream) {\n  var buffer = [], cbs = [], ended, paused = false\n\n  var draining\n  function drain() {\n    while((buffer.length || ended) && cbs.length)\n      cbs.shift()(buffer.length ? null : ended, buffer.shift())\n    if(!buffer.length && (paused)) {\n      paused = false\n      stream.resume()\n    }\n  }\n\n  stream.on('data', function (data) {\n    buffer.push(data)\n    drain()\n    if(buffer.length && stream.pause) {\n      paused = true\n      stream.pause()\n    }\n  })\n  stream.on('end', function () {\n    ended = true\n    drain()\n  })\n  stream.on('error', function (err) {\n    ended = err\n    drain()\n  })\n  return function (abort, cb) {\n    if(!cb) throw new Error('*must* provide cb')\n    if(abort) {\n      stream.once('close', function () {\n        cb(abort)\n      })\n      stream.destroy()\n    }\n    cbs.push(cb)\n    drain()\n  }\n}\n\nvar read = read1\n\nvar sink = function (stream, cb) {\n  return function (read) {\n    return write(read, stream, cb)\n  }\n}\n\nvar source = function (stream) {\n  return read1(stream)\n}\n\nexports = module.exports = function (stream, cb) {\n  return (\n    (stream.writable && stream.write)\n    ? stream.readable\n      ? function(_read) {\n          write(_read, stream, cb);\n          return read1(stream)\n        }\n      : sink(stream, cb)\n    : source(stream)\n  )\n}\n\nexports.sink = sink\nexports.source = source\nexports.read = read\nexports.read1 = read1\nexports.read2 = read2\nexports.duplex = function (stream, cb) {\n  return {\n    source: source(stream),\n    sink: sink(stream, cb)\n  }\n}\n\n\n\n\n","'use strict'\nvar level = require('level')\nvar pull = require('pull-stream')\nvar Write = require('pull-write')\nvar pl = require('pull-level')\nvar query = require('./query')\nvar select = require('./select')\nvar mfr = require('map-filter-reduce')\nvar keys = require('map-filter-reduce/keys')\nvar bytewise = require('bytewise')\nvar paramap = require('pull-paramap')\nvar u = require('./util')\n\nvar isArray = Array.isArray\n\n//sorted index.\n\n\nmodule.exports = function (path, indexes, links, version, codec) {\n  codec = codec || require('bytewise')\n  var db = level(path)\n\n  if('string' !== typeof path)\n    throw new Error('must provide path for leveldb instance')\n  if(!Array.isArray(indexes))\n    throw new Error('must provide an array of indexes')\n  if('number' !== typeof version)\n    throw new Error('must provide version number')\n\n  if(!links)\n    links = function (data, emit) { emit(data) }\n\n  //always write metada to the lowest key,\n  //so the indexes do not interfeer\n  //we don't want to encode this with the codec,\n  //because then we can't change the codec safely\n  //(prehaps the encoding of META is also some indexed value in another codec?)\n  var META = '\\x00'\n\n  return {\n    init: function (cb) {\n      db.get(META, function (err, value) {\n        console.log('RELOAD INDEX:', value)\n        if(value)\n          try { value = JSON.parse(value) }\n          catch (err) { return cb(null, 0) }\n\n        if(err) //first time this was run\n          cb(null, 0)\n        //if the view has changed, rebuild entire index.\n        //else, read current version.\n\n        else if(version && value.version !== version) {\n          db.close(function () {\n            level.destroy(path, function (err) {\n              if(err) return cb(err)\n              db = level(path)\n              cb(null, 0)\n            })\n          })\n        }\n        else\n          cb(null, value.since || 0)\n      })\n    },\n    write: function (cb) {\n      return pull(\n        Write(function (batch, cb) {\n          db.batch(batch, cb)\n        }, function (batch, data) {\n          if(data.sync) return batch\n          if(!batch)\n            batch = [{\n              key: META,\n              value: {version: version, since: data.ts},\n              valueEncoding: 'json',\n              type: 'put'\n            }]\n\n          function push(ary) {\n            batch.push({key: codec.encode(ary), value: ' ', type: 'put'})\n          }\n\n          links(data, function (link) {\n            indexes.forEach(function (index) {\n              var a = [index.key]\n              for(var i = 0; i < index.value.length; i++) {\n                var key = index.value[i]\n                if(!u.has(key, link)) return\n                a.push(u.get(key, link))\n              }\n              push(a)\n            })\n          })\n\n          var ts = data.ts || data.timestamp\n          if(ts) batch[0].value.since = ts\n          return batch\n        }, 100, cb)\n      )\n    },\n    close: function (cb) {\n      db.close(cb)\n    },\n    //get the raw indexes, for debugging.\n    dump: function () {\n      return pl.read(db, {keyEncoding: codec, gt: '\\x00'})\n    },\n    //read all the messages out, via matching ranges.\n    read: function (opts, get) {\n      var lookup\n      opts = opts || {}\n      var _opts = {}\n      var q, k\n\n      if(isArray(opts.query)) {\n        q = opts.query[0].$filter || {}\n        k = keys(opts.query)\n      }\n      else if(opts.query) {\n        q = opts.query\n      }\n      else\n        q = {}\n\n      var index = select(indexes, q)\n      var _opts = query(index, q)\n\n      _opts.values = false\n      _opts.keys = true\n      _opts.keyEncoding = codec\n\n      _opts.reverse = opts.reverse\n      _opts.live = opts.live\n      _opts.limit = opts.limit\n\n      // If a query uses a key not in the index\n      // then we need to get that somehow.\n      // if this is a key from the thing indexed,\n      // it makes sense to look up that record.\n      // how to do that might be different in a view.\n\n      // just disable this for now.\n\n      if(get)\n        lookup = paramap(function (link, cb) {\n          get(link.ts || link.timestamp, function (err, data) {\n            if(err) return cb(err)\n            link.key = data.key\n            link.value = data.value\n            cb(null, link)\n          })\n        })\n//      else\n//        lookup = pull.through()\n\n\n      return pull(\n        pl.read(db, _opts),\n        //rehydrate the index to resemble the original object.\n        pull.map(function (e) {\n          var o = {}\n          for(var i = 0; i < index.value.length; i++)\n            u.set(index.value[i], e[i+1], o)\n          return o\n        }),\n        lookup,\n        isArray(opts.query) ? mfr(opts.query) : pull.through()\n      )\n    }\n  }\n}\n\n\n\n\n\n\n\n","var u      = require('pull-core')\nvar sources = require('./sources')\nvar sinks = require('./sinks')\n\nvar prop   = u.prop\nvar id     = u.id\nvar tester = u.tester\n\nvar map = exports.map = \nfunction (read, map) {\n  map = prop(map) || id\n  return function (end, cb) {\n    read(end, function (end, data) {\n      var data = !end ? map(data) : null\n      cb(end, data)\n    })\n  }\n}\n\nvar asyncMap = exports.asyncMap =\nfunction (read, map) {\n  if(!map) return read\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    read(null, function (end, data) {\n      if(end) return cb(end, data)\n      map(data, cb)\n    })\n  }\n}\n\nvar paraMap = exports.paraMap =\nfunction (read, map, width) {\n  if(!map) return read\n  var ended = false, queue = [], _cb\n\n  function drain () {\n    if(!_cb) return\n    var cb = _cb\n    _cb = null\n    if(queue.length)\n      return cb(null, queue.shift())\n    else if(ended && !n)\n      return cb(ended)\n    _cb = cb\n  }\n\n  function pull () {\n    read(null, function (end, data) {\n      if(end) {\n        ended = end\n        return drain()\n      }\n      n++\n      map(data, function (err, data) {\n        n--\n\n        queue.push(data)\n        drain()\n      })\n\n      if(n < width && !ended)\n        pull()\n    })\n  }\n\n  var n = 0\n  return function (end, cb) {\n    if(end) return read(end, cb) //abort\n    //continue to read while there are less than 3 maps in flight\n    _cb = cb\n    if(queue.length || ended)\n      pull(), drain()\n    else pull()\n  }\n  return highWaterMark(asyncMap(read, map), width)\n}\n\nvar filter = exports.filter =\nfunction (read, test) {\n  //regexp\n  test = tester(test)\n  return function next (end, cb) {\n    read(end, function (end, data) {\n      if(!end && !test(data))\n        return next(end, cb)\n      cb(end, data)\n    })\n  }\n}\n\nvar filterNot = exports.filterNot =\nfunction (read, test) {\n  test = tester(test)\n  return filter(read, function (e) {\n    return !test(e)\n  })\n}\n\nvar through = exports.through = \nfunction (read, op, onEnd) {\n  var a = false\n  function once (abort) {\n    if(a || !onEnd) return\n    a = true\n    onEnd(abort === true ? null : abort)\n  }\n\n  return function (end, cb) {\n    if(end) once(end)\n    return read(end, function (end, data) {\n      if(!end) op && op(data)\n      else once(end)\n      cb(end, data)\n    })\n  }\n}\n\nvar take = exports.take =\nfunction (read, test) {\n  var ended = false\n  if('number' === typeof test) {\n    var n = test; test = function () {\n      return n --\n    }\n  }\n\n  return function (end, cb) {\n    if(ended) return cb(ended)\n    if(ended = end) return read(ended, cb)\n\n    read(null, function (end, data) {\n      if(ended = ended || end) return cb(ended)\n      if(!test(data)) {\n        ended = true\n        read(true, function (end, data) {\n          cb(ended, data)\n        })\n      }\n      else\n        cb(null, data)\n    })\n  }\n}\n\nvar unique = exports.unique = function (read, field, invert) {\n  field = prop(field) || id\n  var seen = {}\n  return filter(read, function (data) {\n    var key = field(data)\n    if(seen[key]) return !!invert //false, by default\n    else seen[key] = true\n    return !invert //true by default\n  })\n}\n\nvar nonUnique = exports.nonUnique = function (read, field) {\n  return unique(read, field, true)\n}\n\nvar group = exports.group =\nfunction (read, size) {\n  var ended; size = size || 5\n  var queue = []\n\n  return function (end, cb) {\n    //this means that the upstream is sending an error.\n    if(end) return read(ended = end, cb)\n    //this means that we read an end before.\n    if(ended) return cb(ended)\n\n    read(null, function next(end, data) {\n      if(ended = ended || end) {\n        if(!queue.length)\n          return cb(ended)\n\n        var _queue = queue; queue = []\n        return cb(null, _queue)\n      }\n      queue.push(data)\n      if(queue.length < size)\n        return read(null, next)\n\n      var _queue = queue; queue = []\n      cb(null, _queue)\n    })\n  }\n}\n\nvar flatten = exports.flatten = function (read) {\n  var _read\n  return function (abort, cb) {\n    if(_read) nextChunk()\n    else      nextStream()\n\n    function nextChunk () {\n      _read(null, function (end, data) {\n        if(end) nextStream()\n        else    cb(null, data)\n      })\n    }\n    function nextStream () {\n      read(null, function (end, stream) {\n        if(end)\n          return cb(end)\n        if(Array.isArray(stream))\n          stream = sources.values(stream)\n        else if('function' != typeof stream)\n          throw new Error('expected stream of streams')\n        \n        _read = stream\n        nextChunk()\n      })\n    }\n  }\n}\n\nvar prepend =\nexports.prepend =\nfunction (read, head) {\n\n  return function (abort, cb) {\n    if(head !== null) {\n      if(abort)\n        return read(abort, cb)\n      var _head = head\n      head = null\n      cb(null, _head)\n    } else {\n      read(abort, cb)\n    }\n  }\n\n}\n\n//var drainIf = exports.drainIf = function (op, done) {\n//  sinks.drain(\n//}\n\nvar _reduce = exports._reduce = function (read, reduce, initial) {\n  return function (close, cb) {\n    if(close) return read(close, cb)\n    if(ended) return cb(ended)\n\n    sinks.drain(function (item) {\n      initial = reduce(initial, item)\n    }, function (err, data) {\n      ended = err || true\n      if(!err) cb(null, initial)\n      else     cb(ended)\n    })\n    (read)\n  }\n}\n\nvar nextTick = process.nextTick\n\nvar highWaterMark = exports.highWaterMark = \nfunction (read, highWaterMark) {\n  var buffer = [], waiting = [], ended, reading = false\n  highWaterMark = highWaterMark || 10\n\n  function readAhead () {\n    while(waiting.length && (buffer.length || ended))\n      waiting.shift()(ended, ended ? null : buffer.shift())\n  }\n\n  function next () {\n    if(ended || reading || buffer.length >= highWaterMark)\n      return\n    reading = true\n    return read(ended, function (end, data) {\n      reading = false\n      ended = ended || end\n      if(data != null) buffer.push(data)\n      \n      next(); readAhead()\n    })\n  }\n\n  nextTick(next)\n\n  return function (end, cb) {\n    ended = ended || end\n    waiting.push(cb)\n\n    next(); readAhead()\n  }\n}\n\n\n\n","\n//force to a valid range\nvar range = exports.range = function (obj) {\n  return null == obj ? {} : 'string' === typeof range ? {\n      min: range, max: range + '\\xff'\n    } :  obj\n}\n\n//turn into a sub range.\nvar prefix = exports.prefix = function (range, within, term) {\n  range = exports.range(range)\n  var _range = {}\n  term = term || '\\xff'\n  if(range instanceof RegExp || 'function' == typeof range) {\n    _range.min = within\n    _range.max   = within + term,\n    _range.inner = function (k) {\n      var j = k.substring(within.length)\n      if(range.test)\n        return range.test(j)\n      return range(j)\n    }\n  }\n  else if('object' === typeof range) {\n    _range.min = within + (range.min || range.start || '')\n    _range.max = within + (range.max || range.end   || (term || '~'))\n    _range.reverse = !!range.reverse\n  }\n  return _range\n}\n\n//return a function that checks a range\nvar checker = exports.checker = function (range) {\n  if(!range) range = {}\n\n  if ('string' === typeof range)\n    return function (key) {\n      return key.indexOf(range) == 0\n    }\n  else if(range instanceof RegExp)\n    return function (key) {\n      return range.test(key)\n    }\n  else if('object' === typeof range)\n    return function (key) {\n      var min = range.min || range.start\n      var max = range.max || range.end\n\n      // fixes keys passed as ints from sublevels\n      key = String(key)\n\n      return (\n        !min || key >= min\n      ) && (\n        !max || key <= max\n      ) && (\n        !range.inner || (\n          range.inner.test \n            ? range.inner.test(key)\n            : range.inner(key)\n        )\n      )\n    }\n  else if('function' === typeof range)\n    return range\n}\n//check if a key is within a range.\nvar satifies = exports.satisfies = function (key, range) {\n  return checker(range)(key)\n}\n\n\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nvar Buffer = require('buffer').Buffer;\n\nvar isBufferEncoding = Buffer.isEncoding\n  || function(encoding) {\n       switch (encoding && encoding.toLowerCase()) {\n         case 'hex': case 'utf8': case 'utf-8': case 'ascii': case 'binary': case 'base64': case 'ucs2': case 'ucs-2': case 'utf16le': case 'utf-16le': case 'raw': return true;\n         default: return false;\n       }\n     }\n\n\nfunction assertEncoding(encoding) {\n  if (encoding && !isBufferEncoding(encoding)) {\n    throw new Error('Unknown encoding: ' + encoding);\n  }\n}\n\n// StringDecoder provides an interface for efficiently splitting a series of\n// buffers into a series of JS strings without breaking apart multi-byte\n// characters. CESU-8 is handled as part of the UTF-8 encoding.\n//\n// @TODO Handling all encodings inside a single object makes it very difficult\n// to reason about this code, so it should be split up in the future.\n// @TODO There should be a utf8-strict encoding that rejects invalid UTF-8 code\n// points as used by CESU-8.\nvar StringDecoder = exports.StringDecoder = function(encoding) {\n  this.encoding = (encoding || 'utf8').toLowerCase().replace(/[-_]/, '');\n  assertEncoding(encoding);\n  switch (this.encoding) {\n    case 'utf8':\n      // CESU-8 represents each of Surrogate Pair by 3-bytes\n      this.surrogateSize = 3;\n      break;\n    case 'ucs2':\n    case 'utf16le':\n      // UTF-16 represents each of Surrogate Pair by 2-bytes\n      this.surrogateSize = 2;\n      this.detectIncompleteChar = utf16DetectIncompleteChar;\n      break;\n    case 'base64':\n      // Base-64 stores 3 bytes in 4 chars, and pads the remainder.\n      this.surrogateSize = 3;\n      this.detectIncompleteChar = base64DetectIncompleteChar;\n      break;\n    default:\n      this.write = passThroughWrite;\n      return;\n  }\n\n  // Enough space to store all bytes of a single character. UTF-8 needs 4\n  // bytes, but CESU-8 may require up to 6 (3 bytes per surrogate).\n  this.charBuffer = new Buffer(6);\n  // Number of bytes received for the current incomplete multi-byte character.\n  this.charReceived = 0;\n  // Number of bytes expected for the current incomplete multi-byte character.\n  this.charLength = 0;\n};\n\n\n// write decodes the given buffer and returns it as JS string that is\n// guaranteed to not contain any partial multi-byte characters. Any partial\n// character found at the end of the buffer is buffered up, and will be\n// returned when calling write again with the remaining bytes.\n//\n// Note: Converting a Buffer containing an orphan surrogate to a String\n// currently works, but converting a String to a Buffer (via `new Buffer`, or\n// Buffer#write) will replace incomplete surrogates with the unicode\n// replacement character. See https://codereview.chromium.org/121173009/ .\nStringDecoder.prototype.write = function(buffer) {\n  var charStr = '';\n  // if our last write ended with an incomplete multibyte character\n  while (this.charLength) {\n    // determine how many remaining bytes this buffer has to offer for this char\n    var available = (buffer.length >= this.charLength - this.charReceived) ?\n        this.charLength - this.charReceived :\n        buffer.length;\n\n    // add the new bytes to the char buffer\n    buffer.copy(this.charBuffer, this.charReceived, 0, available);\n    this.charReceived += available;\n\n    if (this.charReceived < this.charLength) {\n      // still not enough chars in this buffer? wait for more ...\n      return '';\n    }\n\n    // remove bytes belonging to the current character from the buffer\n    buffer = buffer.slice(available, buffer.length);\n\n    // get the character that was split\n    charStr = this.charBuffer.slice(0, this.charLength).toString(this.encoding);\n\n    // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character\n    var charCode = charStr.charCodeAt(charStr.length - 1);\n    if (charCode >= 0xD800 && charCode <= 0xDBFF) {\n      this.charLength += this.surrogateSize;\n      charStr = '';\n      continue;\n    }\n    this.charReceived = this.charLength = 0;\n\n    // if there are no more bytes in this buffer, just emit our char\n    if (buffer.length === 0) {\n      return charStr;\n    }\n    break;\n  }\n\n  // determine and set charLength / charReceived\n  this.detectIncompleteChar(buffer);\n\n  var end = buffer.length;\n  if (this.charLength) {\n    // buffer the incomplete character bytes we got\n    buffer.copy(this.charBuffer, 0, buffer.length - this.charReceived, end);\n    end -= this.charReceived;\n  }\n\n  charStr += buffer.toString(this.encoding, 0, end);\n\n  var end = charStr.length - 1;\n  var charCode = charStr.charCodeAt(end);\n  // CESU-8: lead surrogate (D800-DBFF) is also the incomplete character\n  if (charCode >= 0xD800 && charCode <= 0xDBFF) {\n    var size = this.surrogateSize;\n    this.charLength += size;\n    this.charReceived += size;\n    this.charBuffer.copy(this.charBuffer, size, 0, size);\n    buffer.copy(this.charBuffer, 0, 0, size);\n    return charStr.substring(0, end);\n  }\n\n  // or just emit the charStr\n  return charStr;\n};\n\n// detectIncompleteChar determines if there is an incomplete UTF-8 character at\n// the end of the given buffer. If so, it sets this.charLength to the byte\n// length that character, and sets this.charReceived to the number of bytes\n// that are available for this character.\nStringDecoder.prototype.detectIncompleteChar = function(buffer) {\n  // determine how many bytes we have to check at the end of this buffer\n  var i = (buffer.length >= 3) ? 3 : buffer.length;\n\n  // Figure out if one of the last i bytes of our buffer announces an\n  // incomplete char.\n  for (; i > 0; i--) {\n    var c = buffer[buffer.length - i];\n\n    // See http://en.wikipedia.org/wiki/UTF-8#Description\n\n    // 110XXXXX\n    if (i == 1 && c >> 5 == 0x06) {\n      this.charLength = 2;\n      break;\n    }\n\n    // 1110XXXX\n    if (i <= 2 && c >> 4 == 0x0E) {\n      this.charLength = 3;\n      break;\n    }\n\n    // 11110XXX\n    if (i <= 3 && c >> 3 == 0x1E) {\n      this.charLength = 4;\n      break;\n    }\n  }\n  this.charReceived = i;\n};\n\nStringDecoder.prototype.end = function(buffer) {\n  var res = '';\n  if (buffer && buffer.length)\n    res = this.write(buffer);\n\n  if (this.charReceived) {\n    var cr = this.charReceived;\n    var buf = this.charBuffer;\n    var enc = this.encoding;\n    res += buf.slice(0, cr).toString(enc);\n  }\n\n  return res;\n};\n\nfunction passThroughWrite(buffer) {\n  return buffer.toString(this.encoding);\n}\n\nfunction utf16DetectIncompleteChar(buffer) {\n  this.charReceived = buffer.length % 2;\n  this.charLength = this.charReceived ? 2 : 0;\n}\n\nfunction base64DetectIncompleteChar(buffer) {\n  this.charReceived = buffer.length % 3;\n  this.charLength = this.charReceived ? 3 : 0;\n}\n","/**\n * @author Titus Wormer\n * @copyright 2015 Titus Wormer\n * @license MIT\n * @module stringify-entities\n * @fileoverview Encode HTML character references and character entities.\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\n/*\n * Dependencies.\n */\n\nvar entities = require('character-entities-html4');\nvar EXPRESSION_NAMED = require('./lib/expression.js');\n\n/*\n * Methods.\n */\n\nvar has = {}.hasOwnProperty;\n\n/*\n * List of enforced escapes.\n */\n\nvar escapes = ['\"', '\\'', '<', '>', '&', '`'];\n\n/*\n * Map of characters to names.\n */\n\nvar characters = {};\n\n(function () {\n    var name;\n\n    for (name in entities) {\n        characters[entities[name]] = name;\n    }\n})();\n\n/*\n * Regular expressions.\n */\n\nvar EXPRESSION_ESCAPE = new RegExp('[' + escapes.join('') + ']', 'g');\nvar EXPRESSION_SURROGATE_PAIR = /[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]/g;\nvar EXPRESSION_BMP = /[\\x01-\\t\\x0B\\f\\x0E-\\x1F\\x7F\\x81\\x8D\\x8F\\x90\\x9D\\xA0-\\uFFFF]/g;\n\n/**\n * Transform `code` into a hexadecimal character reference.\n *\n * @param {number} code - Number to encode.\n * @return {string} - `code` encoded as hexadecimal.\n */\nfunction characterCodeToHexadecimalReference(code) {\n    return '&#x' + code.toString(16).toUpperCase() + ';';\n}\n\n/**\n * Transform `character` into a hexadecimal character\n * reference.\n *\n * @param {string} character - Character to encode.\n * @return {string} - `character` encoded as hexadecimal.\n */\nfunction characterToHexadecimalReference(character) {\n    return characterCodeToHexadecimalReference(character.charCodeAt(0));\n}\n\n/**\n * Transform `code` into an entity.\n *\n * @param {string} name - Name to wrap.\n * @return {string} - `name` encoded as hexadecimal.\n */\nfunction toNamedEntity(name) {\n    return '&' + name + ';';\n}\n\n/**\n * Transform `code` into an entity.\n *\n * @param {string} character - Character to encode.\n * @return {string} - `name` encoded as hexadecimal.\n */\nfunction characterToNamedEntity(character) {\n    return toNamedEntity(characters[character]);\n}\n\n/**\n * Encode special characters in `value`.\n *\n * @param {string} value - Value to encode.\n * @param {Object?} [options] - Configuration.\n * @param {boolean?} [options.escapeOnly=false]\n *   - Whether to only escape required characters.\n * @param {boolean?} [options.useNamedReferences=false]\n *   - Whether to use entities where possible.\n * @return {string} - Encoded `value`.\n */\nfunction encode(value, options) {\n    var settings = options || {};\n    var escapeOnly = settings.escapeOnly;\n    var named = settings.useNamedReferences;\n    var map = named ? characters : null;\n\n    value = value.replace(EXPRESSION_ESCAPE, function (character) {\n        return map && has.call(map, character) ?\n            toNamedEntity(map[character]) :\n            characterToHexadecimalReference(character);\n    });\n\n    if (escapeOnly) {\n        return value;\n    }\n\n    if (named) {\n        value = value.replace(EXPRESSION_NAMED, characterToNamedEntity);\n    }\n\n    return value\n        .replace(EXPRESSION_SURROGATE_PAIR, function (pair) {\n            return characterCodeToHexadecimalReference(\n                (pair.charCodeAt(0) - 0xD800) * 0x400 +\n                pair.charCodeAt(1) - 0xDC00 + 0x10000\n            );\n        })\n        .replace(EXPRESSION_BMP, characterToHexadecimalReference);\n}\n\n/**\n * Shortcut to escape special characters in HTML.\n *\n * @param {string} value - Value to encode.\n * @return {string} - Encoded `value`.\n */\nfunction escape(value) {\n    return encode(value, {\n        'escapeOnly': true,\n        'useNamedReferences': true\n    });\n}\n\nencode.escape = escape;\n\n/*\n * Expose.\n */\n\nmodule.exports = encode;\n","/* This script was generated by `script/generate-expression.js` */\n\n'use strict';\n\n/* eslint-env commonjs */\n/* eslint-disable no-irregular-whitespace */\n\nmodule.exports = /[ ¡¢£¤¥¦§¨©ª«¬­®¯°±²³´µ¶·¸¹º»¼½¾¿ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖ×ØÙÚÛÜÝÞßàáâãäåæçèéêëìíîïðñòóôõö÷øùúûüýþÿƒΑΒΓΔΕΖΗΘΙΚΛΜΝΞΟΠΡΣΤΥΦΧΨΩαβγδεζηθικλμνξοπρςστυφχψωϑϒϖ•…′″‾⁄℘ℑℜ™ℵ←↑→↓↔↵⇐⇑⇒⇓⇔∀∂∃∅∇∈∉∋∏∑−∗√∝∞∠∧∨∩∪∫∴∼≅≈≠≡≤≥⊂⊃⊄⊆⊇⊕⊗⊥⋅⌈⌉⌊⌋〈〉◊♠♣♥♦ŒœŠšŸˆ˜   ‌‍‎‏–—‘’‚“”„†‡‰‹›€]/g;\n","var Buffer = require('buffer').Buffer\n\nmodule.exports = function (buf) {\n\t// If the buffer is backed by a Uint8Array, a faster version will work\n\tif (buf instanceof Uint8Array) {\n\t\t// If the buffer isn't a subarray, return the underlying ArrayBuffer\n\t\tif (buf.byteOffset === 0 && buf.byteLength === buf.buffer.byteLength) {\n\t\t\treturn buf.buffer\n\t\t} else if (typeof buf.buffer.slice === 'function') {\n\t\t\t// Otherwise we need to get a proper copy\n\t\t\treturn buf.buffer.slice(buf.byteOffset, buf.byteOffset + buf.byteLength)\n\t\t}\n\t}\n\n\tif (Buffer.isBuffer(buf)) {\n\t\t// This is the slow version that will work with any Buffer\n\t\t// implementation (even in old browsers)\n\t\tvar arrayCopy = new Uint8Array(buf.length)\n\t\tvar len = buf.length\n\t\tfor (var i = 0; i < len; i++) {\n\t\t\tarrayCopy[i] = buf[i]\n\t\t}\n\t\treturn arrayCopy.buffer\n\t} else {\n\t\tthrow new Error('Argument must be a Buffer')\n\t}\n}\n","'use strict';\n\n/*\n * Constants.\n */\n\nvar WHITE_SPACE_COLLAPSABLE_LINE = /[ \\t]*\\n+[ \\t]*/g;\nvar LINE = '\\n';\n\n/**\n * Remove initial and final spaces and tabs at the\n * line breaks in `value`. Does not trim initial and\n * final spaces and tabs of the value itself.\n *\n * @example\n *   trimLines(' foo\\t\\n\\n bar \\n\\tbaz '); // ' foo\\nbar\\nbaz '\n *\n * @param {string} value - Value with untrimmed line breaks,\n *   coerced to string.\n * @return {string} - Value with trimmed line breaks.\n */\nfunction trimLines(value) {\n    return String(value).replace(WHITE_SPACE_COLLAPSABLE_LINE, LINE);\n}\n\n/*\n * Expose.\n */\n\nmodule.exports = trimLines;\n","'use strict';\n\n/*\n * Constants.\n */\n\nvar LINE = '\\n';\n\n/**\n * Remove final newline characters from `value`.\n *\n * @example\n *   trimTrailingLines('foo\\nbar'); // 'foo\\nbar'\n *   trimTrailingLines('foo\\nbar\\n'); // 'foo\\nbar'\n *   trimTrailingLines('foo\\nbar\\n\\n'); // 'foo\\nbar'\n *\n * @param {string} value - Value with trailing newlines,\n *   coerced to string.\n * @return {string} - Value without trailing newlines.\n */\nfunction trimTrailingLines(value) {\n    var index;\n\n    value = String(value);\n    index = value.length;\n\n    while (value.charAt(--index) === LINE) { /* empty */ }\n\n    return value.slice(0, index + 1);\n}\n\n/*\n * Expose.\n */\n\nmodule.exports = trimTrailingLines;\n","\nexports = module.exports = trim;\n\nfunction trim(str){\n  return str.replace(/^\\s*|\\s*$/g, '');\n}\n\nexports.left = function(str){\n  return str.replace(/^\\s*/, '');\n};\n\nexports.right = function(str){\n  return str.replace(/\\s*$/, '');\n};\n","var collation = require('./collation')\n\n//\n// base type system\n//\nvar base = {}\n\n//\n// helper utilities\n//\n\nfunction _valueOf(instance) {\n  return instance == null ? instance : instance.valueOf()\n}\n\nvar _toString = Object.prototype.toString\n\nfunction _isObject(instance) {\n  return instance && _toString.call(instance) === '[object Object]'\n}\n\n//\n// base typewise compare implementation\n//\nbase.compare = function (a, b) {\n  //\n  // test for invalid values\n  //\n  if (base.invalid(a, b))\n    return NaN\n\n  //\n  // short circuit for identical objects\n  //\n  if (a === b)\n    return 0\n\n  //\n  // short circuit for base bound types\n  //\n  var result = base.bound.compare(a, b)\n  if (result !== undefined)\n    return result\n\n  //\n  // cache typeof and valueOf for both values\n  //\n  var aTypeOf = typeof a\n  var bTypeOf = typeof b\n  var aValueOf = _valueOf(a)\n  var bValueOf = _valueOf(b)\n\n  //\n  // loop over type tags and attempt compare\n  //\n  var order = base.order\n  var sorts = base.sorts\n  var sort\n  for (var i = 0, length = order.length; i < length; ++i) {\n    sort = sorts[order[i]]\n\n    //\n    // if first arg is a member of this sort we have an answer\n    //\n    if (sort.is(a, aTypeOf))\n      //\n      // if b is the same as a then defer to sort's comparator, else a comes first\n      //\n      return sort.is(b, bTypeOf) ? sort.compare(aValueOf, bValueOf) : -1\n\n    //\n    // if b is this type but not a then b comes first\n    //\n    if (sort.is(b, bTypeOf))\n      return 1\n  }\n\n  //\n  // values are incomparable as they didn't match against any registered types\n  //\n  return NaN\n}\n\n//\n// sort equality test\n//\nbase.equal = function(a, b) {\n  return base.compare(a, b) === 0\n}\n\n//\n// test for top-level incomparability using invalid sort definitions\n//\nbase.invalid = function (a, b) {\n  var types = base.invalid\n  for (var key in types) {\n    var type = types[key]\n    if (type && type.is && (type.is(a) || type.is(b)))\n      return true\n  }\n  return false\n}\n\n//\n// definitions for explicitly invalid/incomparable types\n//\n\nbase.invalid.NAN = {\n  is: function (instance) {\n    var valueOf = _valueOf(instance)\n    return valueOf !== valueOf\n  }\n}\n\nbase.invalid.ERROR = {\n  is: function (instance) {\n    return instance && instance instanceof Error\n  }\n}\n\n//\n// definitions for boundary types, unserializable as values\n//\n\nfunction BoundedKey(bound, upper, prefix) {\n  this.bound = bound\n  this.upper = !!upper\n  this.prefix = prefix\n}\n\nfunction Boundary(sort) {\n  this.sort = sort\n}\n\nBoundary.prototype.lower = function (prefix) {\n  return new BoundedKey(this, false, prefix)\n}\n\nBoundary.prototype.upper = function (prefix) {\n  return new BoundedKey(this, true, prefix)\n}\n\nBoundary.prototype.is = function (source) {\n  return source instanceof BoundedKey && source.sort === this.sort\n}\n\nBoundary.add = function (sort) {\n  sort.bound = new Boundary(sort)\n}\n\nBoundary.add(base)\n\nbase.bound.getBoundary = function (source) {\n  return source instanceof BoundedKey && source.bound\n}\n\n//\n// compare a values against top level bounds (assumes first arg is an instance)\n//\nbase.bound.compare = function (a, b) {\n  var aBound = base.bound.is(a)\n  var bBound = base.bound.is(b)\n  if (aBound) {\n    if (bBound && !a.upper === !b.upper)\n      return 0\n    return a.upper ? 1 : -1\n  }\n\n  if (bBound)\n    return -base.bound.compare(b, a)\n}\n\n//\n// helper to register fixed (nullary) types\n//\nfunction fixed(value) {\n  return {\n    is: function (instance) {\n      return instance === value\n    },\n    value: value\n  }\n}\n\n//\n// value types defined as ordered map of \"sorts\"\n//\nvar sorts = base.sorts = {}\n\nsorts.void = fixed(void 0)\nsorts.void.compare = collation.inequality\n\nsorts.null = fixed(null)\nsorts.null.compare = collation.inequality\n\nvar BOOLEAN = sorts.boolean = {}\nBOOLEAN.compare = collation.inequality\nBOOLEAN.is = function (instance, typeOf) {\n  return (typeOf || typeof instance) === 'boolean'\n}\n\nBOOLEAN.sorts = {}\nBOOLEAN.sorts.true = fixed(true)\nBOOLEAN.sorts.false = fixed(false)\n\nBoundary.add(BOOLEAN)\n\n\nvar NUMBER = sorts.number = {}\nNUMBER.compare = collation.difference\nNUMBER.is = function (instance, typeOf) {\n  return (typeOf || typeof instance) === 'number'\n}\n\nNUMBER.sorts = {}\nNUMBER.sorts.max = fixed(Number.POSITIVE_INFINITY)\nNUMBER.sorts.min = fixed(Number.NEGATIVE_INFINITY)\n\nNUMBER.sorts.positive = {}\nNUMBER.sorts.positive.is = function (instance) {\n  return instance >= 0\n}\n\nNUMBER.sorts.negative = {}\nNUMBER.sorts.negative.is = function (instance) {\n  return instance < 0\n}\n\nBoundary.add(NUMBER)\n\n\nvar DATE = sorts.date = {}\nDATE.compare = collation.difference\nDATE.is = function (instance) {\n  return instance instanceof Date && instance.valueOf() === instance.valueOf()\n}\n\nDATE.sorts = {}\nDATE.sorts.positive = {}\nDATE.sorts.positive.is = function (instance) {\n  return instance.valueOf() >= 0\n}\n\nDATE.sorts.negative = {}\nDATE.sorts.negative.is = function (instance) {\n  return instance.valueOf() < 0\n}\n\nBoundary.add(DATE)\n\n\nvar BINARY = sorts.binary = {}\nBINARY.empty = new Buffer([])\nBINARY.compare = collation.bitwise\nBINARY.is = Buffer.isBuffer\n\nBoundary.add(BINARY)\n\n\nvar STRING = sorts.string = {}\nSTRING.empty = ''\nSTRING.compare = collation.inequality\nSTRING.is = function (instance, typeOf) {\n  return (typeOf || typeof instance) === 'string'\n}\n\nBoundary.add(STRING)\n\n\nvar ARRAY = sorts.array = {}\nARRAY.empty = []\nARRAY.compare = collation.recursive.elementwise(base.compare)\nARRAY.is = Array.isArray\n\nBoundary.add(ARRAY)\n\n\n// var OBJECT = sorts.object = {}\n// OBJECT.empty = {}\n// OBJECT.compare = collation.recursive.fieldwise(base.compare)\n// OBJECT.is = _isObject\n\n// Boundary.add(OBJECT)\n\n//\n// default order for instance checking in compare operations\n//\nbase.order = []\nfor (var key in sorts) {\n  base.order.push(key)\n}\n\nmodule.exports = base\n","//\n// generic comparator implementations our types can use\n//\nvar collation = exports\n\n//\n// scalar comparisons\n//\ncollation.inequality = function (a, b) {\n  return a < b ? -1 : ( a > b ? 1 : 0 )\n}\n\ncollation.difference = function (a, b) {\n  return a - b\n}\n\n//\n// recursive collations have to be provided a collation function to delegate to\n//\ncollation.recursive = {}\n\n//\n// element by element (comparison for list-like structures\n//\ncollation.recursive.elementwise = function (compare, shortlex) {\n  return function (a, b) {\n    var aLength = a.length\n    var bLength = b.length\n    var difference\n\n    //\n    // short-circuit on length difference for shortlex semantics\n    //\n    if (shortlex && aLength !== bLength)\n        return aLength - bLength\n\n    for (var i = 0, length = Math.min(aLength, bLength); i < length; ++i) {\n      if (difference = compare(a[i], b[i]))\n        return difference\n    }\n\n    return aLength - bLength\n  }\n}\n\n//\n// field by field comparison of record-like structures\n//\ncollation.recursive.fieldwise = function (compare, shortlex) {\n  return function (a, b) {\n    var aKeys = Object.keys(a)\n    var bKeys = Object.keys(b)\n    var aLength = aKeys.length\n    var bLength = bKeys.length\n    var difference\n\n    //\n    // short-circuit on length difference for shortlex semantics\n    //\n    if (shortlex && aLength !== bLength)\n        return aLength - bLength\n\n    for (var i = 0, length = Math.min(aLength, bLength); i < length; ++i) {\n      //\n      // first compare keys\n      //\n      if (difference = compare(aKeys[i], bKeys[i]))\n        return difference\n\n      //\n      // then compare values\n      //\n      if (difference = compare(a[aKeys[i]], b[bKeys[i]]))\n        return difference\n    }\n\n    return aLength - bLength\n  }\n}\n\n//\n// elementwise compare with inequality can be used for binary equality\n//\ncollation.bitwise = collation.recursive.elementwise(exports.inequality)\n\n","//\n// extend core typewise\n//\nrequire('./collation')\n\nmodule.exports = require('typewise-core/base')\n","//\n// extend core typewise collations\n//\nvar collation = require('typewise-core/collation')\n\n// TODO: set, map\n\nmodule.exports = collation\n","module.exports = require('./base')\n","function inequality (a, b) {\n  return a === b ? 0 : a < b ? -1 : 1\n}\n\nfunction buffercmp (a, b) {\n  var l = Math.min(a.length, b.length)\n  for(var i = 0; i < l; i++)\n    if(a[i] !== b[i]) return inequality(a[i], b[i])\n  return a.length - b.length\n}\n\nfunction arraycmp (a, b) {\n  var l = Math.min(a.length, b.length)\n  for(var i = 0; i < l; i++) {\n    var c = compare(a[i], b[i])\n    if(c) return c\n  }\n\n  return inequality(a.length, b.length)\n\n}\n\nvar comparators = [\n  inequality, // null\n  inequality, // boolean\n  inequality, // number\n  buffercmp,  // buffer\n  inequality, // string\n  ,           // object\n  arraycmp,   // array\n  inequality  // undefined\n]\n\nfunction getType (v) {\n  if(v === null)         return 0\n  var t = typeof v\n  if(t === 'boolean')    return 1\n  if(t === 'number')     return 2\n  if(Buffer.isBuffer(v)) return 3\n  if(Array.isArray(v))   return 6\n  if(t === 'string')     return 4\n  if(t === 'undefined')  return 7\n\n  throw new Error('comparing objects or functions is not supported')\n  //                     return 5\n}\n\nfunction compare (a, b) {\n  var t = getType(a)\n  return inequality(t, getType(b)) || comparators[t](a, b)\n}\n\nmodule.exports = compare\n\nmodule.exports.equal = function (a, b) {\n  return compare(a, b) === 0\n}\n","/**\n * @author Titus Wormer\n * @copyright 2015 Titus Wormer\n * @license MIT\n * @module unherit\n * @fileoverview Create a custom constructor which can be modified\n *   without affecting the original class.\n * @example\n *   var EventEmitter = require('events').EventEmitter;\n *   var Emitter = unherit(EventEmitter);\n *   // Create a private class which acts just like\n *   // `EventEmitter`.\n *\n *   Emitter.prototype.defaultMaxListeners = 0;\n *   // Now, all instances of `Emitter` have no maximum\n *   // listeners, without affecting other `EventEmitter`s.\n */\n\n'use strict';\n\n/*\n * Dependencies.\n */\n\nvar clone = require('clone');\nvar inherits = require('inherits');\n\n/**\n * Create a custom constructor which can be modified\n * without affecting the original class.\n *\n * @param {Function} Super - Super-class.\n * @return {Function} - Constructor acting like `Super`,\n *   which can be modified without affecting the original\n *   class.\n */\nfunction unherit(Super) {\n    var base = clone(Super.prototype);\n    var result;\n    var key;\n\n    /**\n     * Constructor accepting a single argument,\n     * which itself is an `arguments` object.\n     */\n    function From(parameters) {\n        return Super.apply(this, parameters);\n    }\n\n    /**\n     * Constructor accepting variadic arguments.\n     */\n    function Of() {\n        if (!(this instanceof Of)) {\n            return new From(arguments);\n        }\n\n        return Super.apply(this, arguments);\n    }\n\n    inherits(Of, Super);\n    inherits(From, Of);\n\n    /*\n     * Both do duplicate work. However, cloning the\n     * prototype ensures clonable things are cloned\n     * and thus used. The `inherits` call ensures\n     * `instanceof` still thinks an instance subclasses\n     * `Super`.\n     */\n\n    result = Of.prototype;\n\n    for (key in base) {\n        result[key] = base[key];\n    }\n\n    return Of;\n}\n\n/*\n * Expose.\n */\n\nmodule.exports = unherit;\n","/**\n * @author Titus Wormer\n * @copyright 2015 Titus Wormer\n * @license MIT\n * @module unified\n * @fileoverview Parse / Transform / Compile / Repeat.\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\n/*\n * Dependencies.\n */\n\nvar bail = require('bail');\nvar ware = require('ware');\nvar AttachWare = require('attach-ware')(ware);\nvar VFile = require('vfile');\nvar unherit = require('unherit');\nvar extend;\n\ntry {\n    extend = require('node-extend');\n} catch (e) {\n    extend = require('extend');\n}\n\n/*\n * Processing pipeline.\n */\n\nvar pipeline = ware()\n    .use(function (ctx) {\n        ctx.tree = ctx.context.parse(ctx.file, ctx.settings);\n    })\n    .use(function (ctx, next) {\n        ctx.context.run(ctx.tree, ctx.file, next);\n    })\n    .use(function (ctx) {\n        ctx.result = ctx.context.stringify(ctx.tree, ctx.file, ctx.settings);\n    });\n\n/**\n * Construct a new Processor class based on the\n * given options.\n *\n * @param {Object} options - Configuration.\n * @param {string} options.name - Private storage.\n * @param {Function} options.Parser - Class to turn a\n *   virtual file into a syntax tree.\n * @param {Function} options.Compiler - Class to turn a\n *   syntax tree into a string.\n * @return {Processor} - A new constructor.\n */\nfunction unified(options) {\n    var name = options.name;\n    var Parser = options.Parser;\n    var Compiler = options.Compiler;\n    var data = options.data;\n\n    /**\n     * Construct a Processor instance.\n     *\n     * @constructor\n     * @class {Processor}\n     */\n    function Processor(processor) {\n        var self = this;\n\n        if (!(self instanceof Processor)) {\n            return new Processor(processor);\n        }\n\n        self.ware = new AttachWare(processor && processor.ware);\n        self.ware.context = self;\n\n        self.Parser = unherit(Parser);\n        self.Compiler = unherit(Compiler);\n\n        if (self.data) {\n            self.data = extend(true, {}, self.data);\n        }\n    }\n\n    /**\n     * Either return `context` if its an instance\n     * of `Processor` or construct a new `Processor`\n     * instance.\n     *\n     * @private\n     * @param {Processor?} [context] - Context object.\n     * @return {Processor} - Either `context` or a new\n     *   Processor instance.\n     */\n    function instance(context) {\n        return context instanceof Processor ? context : new Processor();\n    }\n\n    /**\n     * Attach a plugin.\n     *\n     * @this {Processor?} - Either a Processor instance or\n     *   the Processor constructor.\n     * @return {Processor} - Either `context` or a new\n     *   Processor instance.\n     */\n    function use() {\n        var self = instance(this);\n\n        self.ware.use.apply(self.ware, arguments);\n\n        return self;\n    }\n\n    /**\n     * Transform.\n     *\n     * @this {Processor?} - Either a Processor instance or\n     *   the Processor constructor.\n     * @param {Node} [node] - Syntax tree.\n     * @param {VFile?} [file] - Virtual file.\n     * @param {Function?} [done] - Callback.\n     * @return {Node} - `node`.\n     */\n    function run(node, file, done) {\n        var self = this;\n        var space;\n\n        if (typeof file === 'function') {\n            done = file;\n            file = null;\n        }\n\n        if (!file && node && !node.type) {\n            file = node;\n            node = null;\n        }\n\n        file = new VFile(file);\n        space = file.namespace(name);\n\n        if (!node) {\n            node = space.tree || node;\n        } else if (!space.tree) {\n            space.tree = node;\n        }\n\n        if (!node) {\n            throw new Error('Expected node, got ' + node);\n        }\n\n        done = typeof done === 'function' ? done : bail;\n\n        /*\n         * Only run when this is an instance of Processor,\n         * and when there are transformers.\n         */\n\n        if (self.ware && self.ware.fns) {\n            self.ware.run(node, file, done);\n        } else {\n            done(null, node, file);\n        }\n\n        return node;\n    }\n\n    /**\n     * Parse a file.\n     *\n     * Patches the parsed node onto the `name`\n     * namespace on the `type` property.\n     *\n     * @this {Processor?} - Either a Processor instance or\n     *   the Processor constructor.\n     * @param {string|VFile} value - Input to parse.\n     * @param {Object?} [settings] - Configuration.\n     * @return {Node} - `node`.\n     */\n    function parse(value, settings) {\n        var file = new VFile(value);\n        var CustomParser = (this && this.Parser) || Parser;\n        var node = new CustomParser(file, settings, instance(this)).parse();\n\n        file.namespace(name).tree = node;\n\n        return node;\n    }\n\n    /**\n     * Compile a file.\n     *\n     * Used the parsed node at the `name`\n     * namespace at `'tree'` when no node was given.\n     *\n     * @this {Processor?} - Either a Processor instance or\n     *   the Processor constructor.\n     * @param {Object} [node] - Syntax tree.\n     * @param {VFile} [file] - File with syntax tree.\n     * @param {Object?} [settings] - Configuration.\n     * @return {string} - Compiled `file`.\n     */\n    function stringify(node, file, settings) {\n        var CustomCompiler = (this && this.Compiler) || Compiler;\n        var space;\n\n        if (settings === null || settings === undefined) {\n            settings = file;\n            file = null;\n        }\n\n        if (!file && node && !node.type) {\n            file = node;\n            node = null;\n        }\n\n        file = new VFile(file);\n        space = file.namespace(name);\n\n        if (!node) {\n            node = space.tree || node;\n        } else if (!space.tree) {\n            space.tree = node;\n        }\n\n        if (!node) {\n            throw new Error('Expected node, got ' + node);\n        }\n\n        return new CustomCompiler(file, settings, instance(this)).compile();\n    }\n\n    /**\n     * Parse / Transform / Compile.\n     *\n     * @this {Processor?} - Either a Processor instance or\n     *   the Processor constructor.\n     * @param {string|VFile} value - Input to process.\n     * @param {Object?} [settings] - Configuration.\n     * @param {Function?} [done] - Callback.\n     * @return {string?} - Parsed document, when\n     *   transformation was async.\n     */\n    function process(value, settings, done) {\n        var self = instance(this);\n        var file = new VFile(value);\n        var result = null;\n\n        if (typeof settings === 'function') {\n            done = settings;\n            settings = null;\n        }\n\n        pipeline.run({\n            'context': self,\n            'file': file,\n            'settings': settings || {}\n        }, function (err, res) {\n            result = res && res.result;\n\n            if (done) {\n                done(err, file, result);\n            } else if (err) {\n                bail(err);\n            }\n        });\n\n        return result;\n    }\n\n    /*\n     * Methods / functions.\n     */\n\n    var proto = Processor.prototype;\n\n    Processor.use = proto.use = use;\n    Processor.parse = proto.parse = parse;\n    Processor.run = proto.run = run;\n    Processor.stringify = proto.stringify = stringify;\n    Processor.process = proto.process = process;\n    Processor.data = proto.data = data || null;\n\n    return Processor;\n}\n\n/*\n * Expose.\n */\n\nmodule.exports = unified;\n","/**\n * @author Titus Wormer\n * @copyright 2015 Titus Wormer\n * @license MIT\n * @module unist:util:visit\n * @fileoverview Recursively walk over unist nodes.\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\n/**\n * Visit.\n *\n * @param {Node} tree - Root node\n * @param {string} [type] - Node type.\n * @param {function(node): boolean?} visitor - Invoked\n *   with each found node.  Can return `false` to stop.\n * @param {boolean} [reverse] - By default, `visit` will\n *   walk forwards, when `reverse` is `true`, `visit`\n *   walks backwards.\n */\nfunction visit(tree, type, visitor, reverse) {\n    if (typeof type === 'function') {\n        reverse = visitor;\n        visitor = type;\n        type = null;\n    }\n\n    /**\n     * Visit children in `parent`.\n     *\n     * @param {Array.<Node>} children - Children of `node`.\n     * @param {Node?} parent - Parent of `node`.\n     * @return {boolean?} - `false` if the visiting stopped.\n     */\n    function all(children, parent) {\n        var step = reverse ? -1 : 1;\n        var max = children.length;\n        var min = -1;\n        var index = (reverse ? max : min) + step;\n        var child;\n\n        while (index > min && index < max) {\n            child = children[index];\n\n            if (child && one(child, index, parent) === false) {\n                return false;\n            }\n\n            index += step;\n        }\n\n        return true;\n    }\n\n    /**\n     * Visit a single node.\n     *\n     * @param {Node} node - Node to visit.\n     * @param {number?} [index] - Position of `node` in `parent`.\n     * @param {Node?} [parent] - Parent of `node`.\n     * @return {boolean?} - A result of invoking `visitor`.\n     */\n    function one(node, index, parent) {\n        var result;\n\n        index = index || (parent ? 0 : null);\n\n        if (!type || node.type === type) {\n            result = visitor(node, index, parent || null);\n        }\n\n        if (node.children && result !== false) {\n            return all(node.children, node);\n        }\n\n        return result;\n    }\n\n    one(tree);\n}\n\n/*\n * Expose.\n */\n\nmodule.exports = visit;\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar punycode = require('punycode');\nvar util = require('./util');\n\nexports.parse = urlParse;\nexports.resolve = urlResolve;\nexports.resolveObject = urlResolveObject;\nexports.format = urlFormat;\n\nexports.Url = Url;\n\nfunction Url() {\n  this.protocol = null;\n  this.slashes = null;\n  this.auth = null;\n  this.host = null;\n  this.port = null;\n  this.hostname = null;\n  this.hash = null;\n  this.search = null;\n  this.query = null;\n  this.pathname = null;\n  this.path = null;\n  this.href = null;\n}\n\n// Reference: RFC 3986, RFC 1808, RFC 2396\n\n// define these here so at least they only have to be\n// compiled once on the first module load.\nvar protocolPattern = /^([a-z0-9.+-]+:)/i,\n    portPattern = /:[0-9]*$/,\n\n    // Special case for a simple path URL\n    simplePathPattern = /^(\\/\\/?(?!\\/)[^\\?\\s]*)(\\?[^\\s]*)?$/,\n\n    // RFC 2396: characters reserved for delimiting URLs.\n    // We actually just auto-escape these.\n    delims = ['<', '>', '\"', '`', ' ', '\\r', '\\n', '\\t'],\n\n    // RFC 2396: characters not allowed for various reasons.\n    unwise = ['{', '}', '|', '\\\\', '^', '`'].concat(delims),\n\n    // Allowed by RFCs, but cause of XSS attacks.  Always escape these.\n    autoEscape = ['\\''].concat(unwise),\n    // Characters that are never ever allowed in a hostname.\n    // Note that any invalid chars are also handled, but these\n    // are the ones that are *expected* to be seen, so we fast-path\n    // them.\n    nonHostChars = ['%', '/', '?', ';', '#'].concat(autoEscape),\n    hostEndingChars = ['/', '?', '#'],\n    hostnameMaxLen = 255,\n    hostnamePartPattern = /^[+a-z0-9A-Z_-]{0,63}$/,\n    hostnamePartStart = /^([+a-z0-9A-Z_-]{0,63})(.*)$/,\n    // protocols that can allow \"unsafe\" and \"unwise\" chars.\n    unsafeProtocol = {\n      'javascript': true,\n      'javascript:': true\n    },\n    // protocols that never have a hostname.\n    hostlessProtocol = {\n      'javascript': true,\n      'javascript:': true\n    },\n    // protocols that always contain a // bit.\n    slashedProtocol = {\n      'http': true,\n      'https': true,\n      'ftp': true,\n      'gopher': true,\n      'file': true,\n      'http:': true,\n      'https:': true,\n      'ftp:': true,\n      'gopher:': true,\n      'file:': true\n    },\n    querystring = require('querystring');\n\nfunction urlParse(url, parseQueryString, slashesDenoteHost) {\n  if (url && util.isObject(url) && url instanceof Url) return url;\n\n  var u = new Url;\n  u.parse(url, parseQueryString, slashesDenoteHost);\n  return u;\n}\n\nUrl.prototype.parse = function(url, parseQueryString, slashesDenoteHost) {\n  if (!util.isString(url)) {\n    throw new TypeError(\"Parameter 'url' must be a string, not \" + typeof url);\n  }\n\n  // Copy chrome, IE, opera backslash-handling behavior.\n  // Back slashes before the query string get converted to forward slashes\n  // See: https://code.google.com/p/chromium/issues/detail?id=25916\n  var queryIndex = url.indexOf('?'),\n      splitter =\n          (queryIndex !== -1 && queryIndex < url.indexOf('#')) ? '?' : '#',\n      uSplit = url.split(splitter),\n      slashRegex = /\\\\/g;\n  uSplit[0] = uSplit[0].replace(slashRegex, '/');\n  url = uSplit.join(splitter);\n\n  var rest = url;\n\n  // trim before proceeding.\n  // This is to support parse stuff like \"  http://foo.com  \\n\"\n  rest = rest.trim();\n\n  if (!slashesDenoteHost && url.split('#').length === 1) {\n    // Try fast path regexp\n    var simplePath = simplePathPattern.exec(rest);\n    if (simplePath) {\n      this.path = rest;\n      this.href = rest;\n      this.pathname = simplePath[1];\n      if (simplePath[2]) {\n        this.search = simplePath[2];\n        if (parseQueryString) {\n          this.query = querystring.parse(this.search.substr(1));\n        } else {\n          this.query = this.search.substr(1);\n        }\n      } else if (parseQueryString) {\n        this.search = '';\n        this.query = {};\n      }\n      return this;\n    }\n  }\n\n  var proto = protocolPattern.exec(rest);\n  if (proto) {\n    proto = proto[0];\n    var lowerProto = proto.toLowerCase();\n    this.protocol = lowerProto;\n    rest = rest.substr(proto.length);\n  }\n\n  // figure out if it's got a host\n  // user@server is *always* interpreted as a hostname, and url\n  // resolution will treat //foo/bar as host=foo,path=bar because that's\n  // how the browser resolves relative URLs.\n  if (slashesDenoteHost || proto || rest.match(/^\\/\\/[^@\\/]+@[^@\\/]+/)) {\n    var slashes = rest.substr(0, 2) === '//';\n    if (slashes && !(proto && hostlessProtocol[proto])) {\n      rest = rest.substr(2);\n      this.slashes = true;\n    }\n  }\n\n  if (!hostlessProtocol[proto] &&\n      (slashes || (proto && !slashedProtocol[proto]))) {\n\n    // there's a hostname.\n    // the first instance of /, ?, ;, or # ends the host.\n    //\n    // If there is an @ in the hostname, then non-host chars *are* allowed\n    // to the left of the last @ sign, unless some host-ending character\n    // comes *before* the @-sign.\n    // URLs are obnoxious.\n    //\n    // ex:\n    // http://a@b@c/ => user:a@b host:c\n    // http://a@b?@c => user:a host:c path:/?@c\n\n    // v0.12 TODO(isaacs): This is not quite how Chrome does things.\n    // Review our test case against browsers more comprehensively.\n\n    // find the first instance of any hostEndingChars\n    var hostEnd = -1;\n    for (var i = 0; i < hostEndingChars.length; i++) {\n      var hec = rest.indexOf(hostEndingChars[i]);\n      if (hec !== -1 && (hostEnd === -1 || hec < hostEnd))\n        hostEnd = hec;\n    }\n\n    // at this point, either we have an explicit point where the\n    // auth portion cannot go past, or the last @ char is the decider.\n    var auth, atSign;\n    if (hostEnd === -1) {\n      // atSign can be anywhere.\n      atSign = rest.lastIndexOf('@');\n    } else {\n      // atSign must be in auth portion.\n      // http://a@b/c@d => host:b auth:a path:/c@d\n      atSign = rest.lastIndexOf('@', hostEnd);\n    }\n\n    // Now we have a portion which is definitely the auth.\n    // Pull that off.\n    if (atSign !== -1) {\n      auth = rest.slice(0, atSign);\n      rest = rest.slice(atSign + 1);\n      this.auth = decodeURIComponent(auth);\n    }\n\n    // the host is the remaining to the left of the first non-host char\n    hostEnd = -1;\n    for (var i = 0; i < nonHostChars.length; i++) {\n      var hec = rest.indexOf(nonHostChars[i]);\n      if (hec !== -1 && (hostEnd === -1 || hec < hostEnd))\n        hostEnd = hec;\n    }\n    // if we still have not hit it, then the entire thing is a host.\n    if (hostEnd === -1)\n      hostEnd = rest.length;\n\n    this.host = rest.slice(0, hostEnd);\n    rest = rest.slice(hostEnd);\n\n    // pull out port.\n    this.parseHost();\n\n    // we've indicated that there is a hostname,\n    // so even if it's empty, it has to be present.\n    this.hostname = this.hostname || '';\n\n    // if hostname begins with [ and ends with ]\n    // assume that it's an IPv6 address.\n    var ipv6Hostname = this.hostname[0] === '[' &&\n        this.hostname[this.hostname.length - 1] === ']';\n\n    // validate a little.\n    if (!ipv6Hostname) {\n      var hostparts = this.hostname.split(/\\./);\n      for (var i = 0, l = hostparts.length; i < l; i++) {\n        var part = hostparts[i];\n        if (!part) continue;\n        if (!part.match(hostnamePartPattern)) {\n          var newpart = '';\n          for (var j = 0, k = part.length; j < k; j++) {\n            if (part.charCodeAt(j) > 127) {\n              // we replace non-ASCII char with a temporary placeholder\n              // we need this to make sure size of hostname is not\n              // broken by replacing non-ASCII by nothing\n              newpart += 'x';\n            } else {\n              newpart += part[j];\n            }\n          }\n          // we test again with ASCII char only\n          if (!newpart.match(hostnamePartPattern)) {\n            var validParts = hostparts.slice(0, i);\n            var notHost = hostparts.slice(i + 1);\n            var bit = part.match(hostnamePartStart);\n            if (bit) {\n              validParts.push(bit[1]);\n              notHost.unshift(bit[2]);\n            }\n            if (notHost.length) {\n              rest = '/' + notHost.join('.') + rest;\n            }\n            this.hostname = validParts.join('.');\n            break;\n          }\n        }\n      }\n    }\n\n    if (this.hostname.length > hostnameMaxLen) {\n      this.hostname = '';\n    } else {\n      // hostnames are always lower case.\n      this.hostname = this.hostname.toLowerCase();\n    }\n\n    if (!ipv6Hostname) {\n      // IDNA Support: Returns a punycoded representation of \"domain\".\n      // It only converts parts of the domain name that\n      // have non-ASCII characters, i.e. it doesn't matter if\n      // you call it with a domain that already is ASCII-only.\n      this.hostname = punycode.toASCII(this.hostname);\n    }\n\n    var p = this.port ? ':' + this.port : '';\n    var h = this.hostname || '';\n    this.host = h + p;\n    this.href += this.host;\n\n    // strip [ and ] from the hostname\n    // the host field still retains them, though\n    if (ipv6Hostname) {\n      this.hostname = this.hostname.substr(1, this.hostname.length - 2);\n      if (rest[0] !== '/') {\n        rest = '/' + rest;\n      }\n    }\n  }\n\n  // now rest is set to the post-host stuff.\n  // chop off any delim chars.\n  if (!unsafeProtocol[lowerProto]) {\n\n    // First, make 100% sure that any \"autoEscape\" chars get\n    // escaped, even if encodeURIComponent doesn't think they\n    // need to be.\n    for (var i = 0, l = autoEscape.length; i < l; i++) {\n      var ae = autoEscape[i];\n      if (rest.indexOf(ae) === -1)\n        continue;\n      var esc = encodeURIComponent(ae);\n      if (esc === ae) {\n        esc = escape(ae);\n      }\n      rest = rest.split(ae).join(esc);\n    }\n  }\n\n\n  // chop off from the tail first.\n  var hash = rest.indexOf('#');\n  if (hash !== -1) {\n    // got a fragment string.\n    this.hash = rest.substr(hash);\n    rest = rest.slice(0, hash);\n  }\n  var qm = rest.indexOf('?');\n  if (qm !== -1) {\n    this.search = rest.substr(qm);\n    this.query = rest.substr(qm + 1);\n    if (parseQueryString) {\n      this.query = querystring.parse(this.query);\n    }\n    rest = rest.slice(0, qm);\n  } else if (parseQueryString) {\n    // no query string, but parseQueryString still requested\n    this.search = '';\n    this.query = {};\n  }\n  if (rest) this.pathname = rest;\n  if (slashedProtocol[lowerProto] &&\n      this.hostname && !this.pathname) {\n    this.pathname = '/';\n  }\n\n  //to support http.request\n  if (this.pathname || this.search) {\n    var p = this.pathname || '';\n    var s = this.search || '';\n    this.path = p + s;\n  }\n\n  // finally, reconstruct the href based on what has been validated.\n  this.href = this.format();\n  return this;\n};\n\n// format a parsed object into a url string\nfunction urlFormat(obj) {\n  // ensure it's an object, and not a string url.\n  // If it's an obj, this is a no-op.\n  // this way, you can call url_format() on strings\n  // to clean up potentially wonky urls.\n  if (util.isString(obj)) obj = urlParse(obj);\n  if (!(obj instanceof Url)) return Url.prototype.format.call(obj);\n  return obj.format();\n}\n\nUrl.prototype.format = function() {\n  var auth = this.auth || '';\n  if (auth) {\n    auth = encodeURIComponent(auth);\n    auth = auth.replace(/%3A/i, ':');\n    auth += '@';\n  }\n\n  var protocol = this.protocol || '',\n      pathname = this.pathname || '',\n      hash = this.hash || '',\n      host = false,\n      query = '';\n\n  if (this.host) {\n    host = auth + this.host;\n  } else if (this.hostname) {\n    host = auth + (this.hostname.indexOf(':') === -1 ?\n        this.hostname :\n        '[' + this.hostname + ']');\n    if (this.port) {\n      host += ':' + this.port;\n    }\n  }\n\n  if (this.query &&\n      util.isObject(this.query) &&\n      Object.keys(this.query).length) {\n    query = querystring.stringify(this.query);\n  }\n\n  var search = this.search || (query && ('?' + query)) || '';\n\n  if (protocol && protocol.substr(-1) !== ':') protocol += ':';\n\n  // only the slashedProtocols get the //.  Not mailto:, xmpp:, etc.\n  // unless they had them to begin with.\n  if (this.slashes ||\n      (!protocol || slashedProtocol[protocol]) && host !== false) {\n    host = '//' + (host || '');\n    if (pathname && pathname.charAt(0) !== '/') pathname = '/' + pathname;\n  } else if (!host) {\n    host = '';\n  }\n\n  if (hash && hash.charAt(0) !== '#') hash = '#' + hash;\n  if (search && search.charAt(0) !== '?') search = '?' + search;\n\n  pathname = pathname.replace(/[?#]/g, function(match) {\n    return encodeURIComponent(match);\n  });\n  search = search.replace('#', '%23');\n\n  return protocol + host + pathname + search + hash;\n};\n\nfunction urlResolve(source, relative) {\n  return urlParse(source, false, true).resolve(relative);\n}\n\nUrl.prototype.resolve = function(relative) {\n  return this.resolveObject(urlParse(relative, false, true)).format();\n};\n\nfunction urlResolveObject(source, relative) {\n  if (!source) return relative;\n  return urlParse(source, false, true).resolveObject(relative);\n}\n\nUrl.prototype.resolveObject = function(relative) {\n  if (util.isString(relative)) {\n    var rel = new Url();\n    rel.parse(relative, false, true);\n    relative = rel;\n  }\n\n  var result = new Url();\n  var tkeys = Object.keys(this);\n  for (var tk = 0; tk < tkeys.length; tk++) {\n    var tkey = tkeys[tk];\n    result[tkey] = this[tkey];\n  }\n\n  // hash is always overridden, no matter what.\n  // even href=\"\" will remove it.\n  result.hash = relative.hash;\n\n  // if the relative url is empty, then there's nothing left to do here.\n  if (relative.href === '') {\n    result.href = result.format();\n    return result;\n  }\n\n  // hrefs like //foo/bar always cut to the protocol.\n  if (relative.slashes && !relative.protocol) {\n    // take everything except the protocol from relative\n    var rkeys = Object.keys(relative);\n    for (var rk = 0; rk < rkeys.length; rk++) {\n      var rkey = rkeys[rk];\n      if (rkey !== 'protocol')\n        result[rkey] = relative[rkey];\n    }\n\n    //urlParse appends trailing / to urls like http://www.example.com\n    if (slashedProtocol[result.protocol] &&\n        result.hostname && !result.pathname) {\n      result.path = result.pathname = '/';\n    }\n\n    result.href = result.format();\n    return result;\n  }\n\n  if (relative.protocol && relative.protocol !== result.protocol) {\n    // if it's a known url protocol, then changing\n    // the protocol does weird things\n    // first, if it's not file:, then we MUST have a host,\n    // and if there was a path\n    // to begin with, then we MUST have a path.\n    // if it is file:, then the host is dropped,\n    // because that's known to be hostless.\n    // anything else is assumed to be absolute.\n    if (!slashedProtocol[relative.protocol]) {\n      var keys = Object.keys(relative);\n      for (var v = 0; v < keys.length; v++) {\n        var k = keys[v];\n        result[k] = relative[k];\n      }\n      result.href = result.format();\n      return result;\n    }\n\n    result.protocol = relative.protocol;\n    if (!relative.host && !hostlessProtocol[relative.protocol]) {\n      var relPath = (relative.pathname || '').split('/');\n      while (relPath.length && !(relative.host = relPath.shift()));\n      if (!relative.host) relative.host = '';\n      if (!relative.hostname) relative.hostname = '';\n      if (relPath[0] !== '') relPath.unshift('');\n      if (relPath.length < 2) relPath.unshift('');\n      result.pathname = relPath.join('/');\n    } else {\n      result.pathname = relative.pathname;\n    }\n    result.search = relative.search;\n    result.query = relative.query;\n    result.host = relative.host || '';\n    result.auth = relative.auth;\n    result.hostname = relative.hostname || relative.host;\n    result.port = relative.port;\n    // to support http.request\n    if (result.pathname || result.search) {\n      var p = result.pathname || '';\n      var s = result.search || '';\n      result.path = p + s;\n    }\n    result.slashes = result.slashes || relative.slashes;\n    result.href = result.format();\n    return result;\n  }\n\n  var isSourceAbs = (result.pathname && result.pathname.charAt(0) === '/'),\n      isRelAbs = (\n          relative.host ||\n          relative.pathname && relative.pathname.charAt(0) === '/'\n      ),\n      mustEndAbs = (isRelAbs || isSourceAbs ||\n                    (result.host && relative.pathname)),\n      removeAllDots = mustEndAbs,\n      srcPath = result.pathname && result.pathname.split('/') || [],\n      relPath = relative.pathname && relative.pathname.split('/') || [],\n      psychotic = result.protocol && !slashedProtocol[result.protocol];\n\n  // if the url is a non-slashed url, then relative\n  // links like ../.. should be able\n  // to crawl up to the hostname, as well.  This is strange.\n  // result.protocol has already been set by now.\n  // Later on, put the first path part into the host field.\n  if (psychotic) {\n    result.hostname = '';\n    result.port = null;\n    if (result.host) {\n      if (srcPath[0] === '') srcPath[0] = result.host;\n      else srcPath.unshift(result.host);\n    }\n    result.host = '';\n    if (relative.protocol) {\n      relative.hostname = null;\n      relative.port = null;\n      if (relative.host) {\n        if (relPath[0] === '') relPath[0] = relative.host;\n        else relPath.unshift(relative.host);\n      }\n      relative.host = null;\n    }\n    mustEndAbs = mustEndAbs && (relPath[0] === '' || srcPath[0] === '');\n  }\n\n  if (isRelAbs) {\n    // it's absolute.\n    result.host = (relative.host || relative.host === '') ?\n                  relative.host : result.host;\n    result.hostname = (relative.hostname || relative.hostname === '') ?\n                      relative.hostname : result.hostname;\n    result.search = relative.search;\n    result.query = relative.query;\n    srcPath = relPath;\n    // fall through to the dot-handling below.\n  } else if (relPath.length) {\n    // it's relative\n    // throw away the existing file, and take the new path instead.\n    if (!srcPath) srcPath = [];\n    srcPath.pop();\n    srcPath = srcPath.concat(relPath);\n    result.search = relative.search;\n    result.query = relative.query;\n  } else if (!util.isNullOrUndefined(relative.search)) {\n    // just pull out the search.\n    // like href='?foo'.\n    // Put this after the other two cases because it simplifies the booleans\n    if (psychotic) {\n      result.hostname = result.host = srcPath.shift();\n      //occationaly the auth can get stuck only in host\n      //this especially happens in cases like\n      //url.resolveObject('mailto:local1@domain1', 'local2@domain2')\n      var authInHost = result.host && result.host.indexOf('@') > 0 ?\n                       result.host.split('@') : false;\n      if (authInHost) {\n        result.auth = authInHost.shift();\n        result.host = result.hostname = authInHost.shift();\n      }\n    }\n    result.search = relative.search;\n    result.query = relative.query;\n    //to support http.request\n    if (!util.isNull(result.pathname) || !util.isNull(result.search)) {\n      result.path = (result.pathname ? result.pathname : '') +\n                    (result.search ? result.search : '');\n    }\n    result.href = result.format();\n    return result;\n  }\n\n  if (!srcPath.length) {\n    // no path at all.  easy.\n    // we've already handled the other stuff above.\n    result.pathname = null;\n    //to support http.request\n    if (result.search) {\n      result.path = '/' + result.search;\n    } else {\n      result.path = null;\n    }\n    result.href = result.format();\n    return result;\n  }\n\n  // if a url ENDs in . or .., then it must get a trailing slash.\n  // however, if it ends in anything else non-slashy,\n  // then it must NOT get a trailing slash.\n  var last = srcPath.slice(-1)[0];\n  var hasTrailingSlash = (\n      (result.host || relative.host || srcPath.length > 1) &&\n      (last === '.' || last === '..') || last === '');\n\n  // strip single dots, resolve double dots to parent dir\n  // if the path tries to go above the root, `up` ends up > 0\n  var up = 0;\n  for (var i = srcPath.length; i >= 0; i--) {\n    last = srcPath[i];\n    if (last === '.') {\n      srcPath.splice(i, 1);\n    } else if (last === '..') {\n      srcPath.splice(i, 1);\n      up++;\n    } else if (up) {\n      srcPath.splice(i, 1);\n      up--;\n    }\n  }\n\n  // if the path is allowed to go above the root, restore leading ..s\n  if (!mustEndAbs && !removeAllDots) {\n    for (; up--; up) {\n      srcPath.unshift('..');\n    }\n  }\n\n  if (mustEndAbs && srcPath[0] !== '' &&\n      (!srcPath[0] || srcPath[0].charAt(0) !== '/')) {\n    srcPath.unshift('');\n  }\n\n  if (hasTrailingSlash && (srcPath.join('/').substr(-1) !== '/')) {\n    srcPath.push('');\n  }\n\n  var isAbsolute = srcPath[0] === '' ||\n      (srcPath[0] && srcPath[0].charAt(0) === '/');\n\n  // put the host back\n  if (psychotic) {\n    result.hostname = result.host = isAbsolute ? '' :\n                                    srcPath.length ? srcPath.shift() : '';\n    //occationaly the auth can get stuck only in host\n    //this especially happens in cases like\n    //url.resolveObject('mailto:local1@domain1', 'local2@domain2')\n    var authInHost = result.host && result.host.indexOf('@') > 0 ?\n                     result.host.split('@') : false;\n    if (authInHost) {\n      result.auth = authInHost.shift();\n      result.host = result.hostname = authInHost.shift();\n    }\n  }\n\n  mustEndAbs = mustEndAbs || (result.host && srcPath.length);\n\n  if (mustEndAbs && !isAbsolute) {\n    srcPath.unshift('');\n  }\n\n  if (!srcPath.length) {\n    result.pathname = null;\n    result.path = null;\n  } else {\n    result.pathname = srcPath.join('/');\n  }\n\n  //to support request.http\n  if (!util.isNull(result.pathname) || !util.isNull(result.search)) {\n    result.path = (result.pathname ? result.pathname : '') +\n                  (result.search ? result.search : '');\n  }\n  result.auth = relative.auth || result.auth;\n  result.slashes = result.slashes || relative.slashes;\n  result.href = result.format();\n  return result;\n};\n\nUrl.prototype.parseHost = function() {\n  var host = this.host;\n  var port = portPattern.exec(host);\n  if (port) {\n    port = port[0];\n    if (port !== ':') {\n      this.port = port.substr(1);\n    }\n    host = host.substr(0, host.length - port.length);\n  }\n  if (host) this.hostname = host;\n};\n","'use strict';\n\nmodule.exports = {\n  isString: function(arg) {\n    return typeof(arg) === 'string';\n  },\n  isObject: function(arg) {\n    return typeof(arg) === 'object' && arg !== null;\n  },\n  isNull: function(arg) {\n    return arg === null;\n  },\n  isNullOrUndefined: function(arg) {\n    return arg == null;\n  }\n};\n","\n/**\n * Module exports.\n */\n\nmodule.exports = deprecate;\n\n/**\n * Mark that a method should not be used.\n * Returns a modified function which warns once by default.\n *\n * If `localStorage.noDeprecation = true` is set, then it is a no-op.\n *\n * If `localStorage.throwDeprecation = true` is set, then deprecated functions\n * will throw an Error when invoked.\n *\n * If `localStorage.traceDeprecation = true` is set, then deprecated functions\n * will invoke `console.trace()` instead of `console.error()`.\n *\n * @param {Function} fn - the function to deprecate\n * @param {String} msg - the string to print to the console when `fn` is invoked\n * @returns {Function} a new \"deprecated\" version of `fn`\n * @api public\n */\n\nfunction deprecate (fn, msg) {\n  if (config('noDeprecation')) {\n    return fn;\n  }\n\n  var warned = false;\n  function deprecated() {\n    if (!warned) {\n      if (config('throwDeprecation')) {\n        throw new Error(msg);\n      } else if (config('traceDeprecation')) {\n        console.trace(msg);\n      } else {\n        console.warn(msg);\n      }\n      warned = true;\n    }\n    return fn.apply(this, arguments);\n  }\n\n  return deprecated;\n}\n\n/**\n * Checks `localStorage` for boolean values for the given `name`.\n *\n * @param {String} name\n * @returns {Boolean}\n * @api private\n */\n\nfunction config (name) {\n  // accessing global.localStorage can trigger a DOMException in sandboxed iframes\n  try {\n    if (!global.localStorage) return false;\n  } catch (_) {\n    return false;\n  }\n  var val = global.localStorage[name];\n  if (null == val) return false;\n  return String(val).toLowerCase() === 'true';\n}\n","module.exports = function isBuffer(arg) {\n  return arg && typeof arg === 'object'\n    && typeof arg.copy === 'function'\n    && typeof arg.fill === 'function'\n    && typeof arg.readUInt8 === 'function';\n}","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nvar formatRegExp = /%[sdj%]/g;\nexports.format = function(f) {\n  if (!isString(f)) {\n    var objects = [];\n    for (var i = 0; i < arguments.length; i++) {\n      objects.push(inspect(arguments[i]));\n    }\n    return objects.join(' ');\n  }\n\n  var i = 1;\n  var args = arguments;\n  var len = args.length;\n  var str = String(f).replace(formatRegExp, function(x) {\n    if (x === '%%') return '%';\n    if (i >= len) return x;\n    switch (x) {\n      case '%s': return String(args[i++]);\n      case '%d': return Number(args[i++]);\n      case '%j':\n        try {\n          return JSON.stringify(args[i++]);\n        } catch (_) {\n          return '[Circular]';\n        }\n      default:\n        return x;\n    }\n  });\n  for (var x = args[i]; i < len; x = args[++i]) {\n    if (isNull(x) || !isObject(x)) {\n      str += ' ' + x;\n    } else {\n      str += ' ' + inspect(x);\n    }\n  }\n  return str;\n};\n\n\n// Mark that a method should not be used.\n// Returns a modified function which warns once by default.\n// If --no-deprecation is set, then it is a no-op.\nexports.deprecate = function(fn, msg) {\n  // Allow for deprecating things in the process of starting up.\n  if (isUndefined(global.process)) {\n    return function() {\n      return exports.deprecate(fn, msg).apply(this, arguments);\n    };\n  }\n\n  if (process.noDeprecation === true) {\n    return fn;\n  }\n\n  var warned = false;\n  function deprecated() {\n    if (!warned) {\n      if (process.throwDeprecation) {\n        throw new Error(msg);\n      } else if (process.traceDeprecation) {\n        console.trace(msg);\n      } else {\n        console.error(msg);\n      }\n      warned = true;\n    }\n    return fn.apply(this, arguments);\n  }\n\n  return deprecated;\n};\n\n\nvar debugs = {};\nvar debugEnviron;\nexports.debuglog = function(set) {\n  if (isUndefined(debugEnviron))\n    debugEnviron = process.env.NODE_DEBUG || '';\n  set = set.toUpperCase();\n  if (!debugs[set]) {\n    if (new RegExp('\\\\b' + set + '\\\\b', 'i').test(debugEnviron)) {\n      var pid = process.pid;\n      debugs[set] = function() {\n        var msg = exports.format.apply(exports, arguments);\n        console.error('%s %d: %s', set, pid, msg);\n      };\n    } else {\n      debugs[set] = function() {};\n    }\n  }\n  return debugs[set];\n};\n\n\n/**\n * Echos the value of a value. Trys to print the value out\n * in the best way possible given the different types.\n *\n * @param {Object} obj The object to print out.\n * @param {Object} opts Optional options object that alters the output.\n */\n/* legacy: obj, showHidden, depth, colors*/\nfunction inspect(obj, opts) {\n  // default options\n  var ctx = {\n    seen: [],\n    stylize: stylizeNoColor\n  };\n  // legacy...\n  if (arguments.length >= 3) ctx.depth = arguments[2];\n  if (arguments.length >= 4) ctx.colors = arguments[3];\n  if (isBoolean(opts)) {\n    // legacy...\n    ctx.showHidden = opts;\n  } else if (opts) {\n    // got an \"options\" object\n    exports._extend(ctx, opts);\n  }\n  // set default options\n  if (isUndefined(ctx.showHidden)) ctx.showHidden = false;\n  if (isUndefined(ctx.depth)) ctx.depth = 2;\n  if (isUndefined(ctx.colors)) ctx.colors = false;\n  if (isUndefined(ctx.customInspect)) ctx.customInspect = true;\n  if (ctx.colors) ctx.stylize = stylizeWithColor;\n  return formatValue(ctx, obj, ctx.depth);\n}\nexports.inspect = inspect;\n\n\n// http://en.wikipedia.org/wiki/ANSI_escape_code#graphics\ninspect.colors = {\n  'bold' : [1, 22],\n  'italic' : [3, 23],\n  'underline' : [4, 24],\n  'inverse' : [7, 27],\n  'white' : [37, 39],\n  'grey' : [90, 39],\n  'black' : [30, 39],\n  'blue' : [34, 39],\n  'cyan' : [36, 39],\n  'green' : [32, 39],\n  'magenta' : [35, 39],\n  'red' : [31, 39],\n  'yellow' : [33, 39]\n};\n\n// Don't use 'blue' not visible on cmd.exe\ninspect.styles = {\n  'special': 'cyan',\n  'number': 'yellow',\n  'boolean': 'yellow',\n  'undefined': 'grey',\n  'null': 'bold',\n  'string': 'green',\n  'date': 'magenta',\n  // \"name\": intentionally not styling\n  'regexp': 'red'\n};\n\n\nfunction stylizeWithColor(str, styleType) {\n  var style = inspect.styles[styleType];\n\n  if (style) {\n    return '\\u001b[' + inspect.colors[style][0] + 'm' + str +\n           '\\u001b[' + inspect.colors[style][1] + 'm';\n  } else {\n    return str;\n  }\n}\n\n\nfunction stylizeNoColor(str, styleType) {\n  return str;\n}\n\n\nfunction arrayToHash(array) {\n  var hash = {};\n\n  array.forEach(function(val, idx) {\n    hash[val] = true;\n  });\n\n  return hash;\n}\n\n\nfunction formatValue(ctx, value, recurseTimes) {\n  // Provide a hook for user-specified inspect functions.\n  // Check that value is an object with an inspect function on it\n  if (ctx.customInspect &&\n      value &&\n      isFunction(value.inspect) &&\n      // Filter out the util module, it's inspect function is special\n      value.inspect !== exports.inspect &&\n      // Also filter out any prototype objects using the circular check.\n      !(value.constructor && value.constructor.prototype === value)) {\n    var ret = value.inspect(recurseTimes, ctx);\n    if (!isString(ret)) {\n      ret = formatValue(ctx, ret, recurseTimes);\n    }\n    return ret;\n  }\n\n  // Primitive types cannot have properties\n  var primitive = formatPrimitive(ctx, value);\n  if (primitive) {\n    return primitive;\n  }\n\n  // Look up the keys of the object.\n  var keys = Object.keys(value);\n  var visibleKeys = arrayToHash(keys);\n\n  if (ctx.showHidden) {\n    keys = Object.getOwnPropertyNames(value);\n  }\n\n  // IE doesn't make error fields non-enumerable\n  // http://msdn.microsoft.com/en-us/library/ie/dww52sbt(v=vs.94).aspx\n  if (isError(value)\n      && (keys.indexOf('message') >= 0 || keys.indexOf('description') >= 0)) {\n    return formatError(value);\n  }\n\n  // Some type of object without properties can be shortcutted.\n  if (keys.length === 0) {\n    if (isFunction(value)) {\n      var name = value.name ? ': ' + value.name : '';\n      return ctx.stylize('[Function' + name + ']', 'special');\n    }\n    if (isRegExp(value)) {\n      return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n    }\n    if (isDate(value)) {\n      return ctx.stylize(Date.prototype.toString.call(value), 'date');\n    }\n    if (isError(value)) {\n      return formatError(value);\n    }\n  }\n\n  var base = '', array = false, braces = ['{', '}'];\n\n  // Make Array say that they are Array\n  if (isArray(value)) {\n    array = true;\n    braces = ['[', ']'];\n  }\n\n  // Make functions say that they are functions\n  if (isFunction(value)) {\n    var n = value.name ? ': ' + value.name : '';\n    base = ' [Function' + n + ']';\n  }\n\n  // Make RegExps say that they are RegExps\n  if (isRegExp(value)) {\n    base = ' ' + RegExp.prototype.toString.call(value);\n  }\n\n  // Make dates with properties first say the date\n  if (isDate(value)) {\n    base = ' ' + Date.prototype.toUTCString.call(value);\n  }\n\n  // Make error with message first say the error\n  if (isError(value)) {\n    base = ' ' + formatError(value);\n  }\n\n  if (keys.length === 0 && (!array || value.length == 0)) {\n    return braces[0] + base + braces[1];\n  }\n\n  if (recurseTimes < 0) {\n    if (isRegExp(value)) {\n      return ctx.stylize(RegExp.prototype.toString.call(value), 'regexp');\n    } else {\n      return ctx.stylize('[Object]', 'special');\n    }\n  }\n\n  ctx.seen.push(value);\n\n  var output;\n  if (array) {\n    output = formatArray(ctx, value, recurseTimes, visibleKeys, keys);\n  } else {\n    output = keys.map(function(key) {\n      return formatProperty(ctx, value, recurseTimes, visibleKeys, key, array);\n    });\n  }\n\n  ctx.seen.pop();\n\n  return reduceToSingleString(output, base, braces);\n}\n\n\nfunction formatPrimitive(ctx, value) {\n  if (isUndefined(value))\n    return ctx.stylize('undefined', 'undefined');\n  if (isString(value)) {\n    var simple = '\\'' + JSON.stringify(value).replace(/^\"|\"$/g, '')\n                                             .replace(/'/g, \"\\\\'\")\n                                             .replace(/\\\\\"/g, '\"') + '\\'';\n    return ctx.stylize(simple, 'string');\n  }\n  if (isNumber(value))\n    return ctx.stylize('' + value, 'number');\n  if (isBoolean(value))\n    return ctx.stylize('' + value, 'boolean');\n  // For some reason typeof null is \"object\", so special case here.\n  if (isNull(value))\n    return ctx.stylize('null', 'null');\n}\n\n\nfunction formatError(value) {\n  return '[' + Error.prototype.toString.call(value) + ']';\n}\n\n\nfunction formatArray(ctx, value, recurseTimes, visibleKeys, keys) {\n  var output = [];\n  for (var i = 0, l = value.length; i < l; ++i) {\n    if (hasOwnProperty(value, String(i))) {\n      output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n          String(i), true));\n    } else {\n      output.push('');\n    }\n  }\n  keys.forEach(function(key) {\n    if (!key.match(/^\\d+$/)) {\n      output.push(formatProperty(ctx, value, recurseTimes, visibleKeys,\n          key, true));\n    }\n  });\n  return output;\n}\n\n\nfunction formatProperty(ctx, value, recurseTimes, visibleKeys, key, array) {\n  var name, str, desc;\n  desc = Object.getOwnPropertyDescriptor(value, key) || { value: value[key] };\n  if (desc.get) {\n    if (desc.set) {\n      str = ctx.stylize('[Getter/Setter]', 'special');\n    } else {\n      str = ctx.stylize('[Getter]', 'special');\n    }\n  } else {\n    if (desc.set) {\n      str = ctx.stylize('[Setter]', 'special');\n    }\n  }\n  if (!hasOwnProperty(visibleKeys, key)) {\n    name = '[' + key + ']';\n  }\n  if (!str) {\n    if (ctx.seen.indexOf(desc.value) < 0) {\n      if (isNull(recurseTimes)) {\n        str = formatValue(ctx, desc.value, null);\n      } else {\n        str = formatValue(ctx, desc.value, recurseTimes - 1);\n      }\n      if (str.indexOf('\\n') > -1) {\n        if (array) {\n          str = str.split('\\n').map(function(line) {\n            return '  ' + line;\n          }).join('\\n').substr(2);\n        } else {\n          str = '\\n' + str.split('\\n').map(function(line) {\n            return '   ' + line;\n          }).join('\\n');\n        }\n      }\n    } else {\n      str = ctx.stylize('[Circular]', 'special');\n    }\n  }\n  if (isUndefined(name)) {\n    if (array && key.match(/^\\d+$/)) {\n      return str;\n    }\n    name = JSON.stringify('' + key);\n    if (name.match(/^\"([a-zA-Z_][a-zA-Z_0-9]*)\"$/)) {\n      name = name.substr(1, name.length - 2);\n      name = ctx.stylize(name, 'name');\n    } else {\n      name = name.replace(/'/g, \"\\\\'\")\n                 .replace(/\\\\\"/g, '\"')\n                 .replace(/(^\"|\"$)/g, \"'\");\n      name = ctx.stylize(name, 'string');\n    }\n  }\n\n  return name + ': ' + str;\n}\n\n\nfunction reduceToSingleString(output, base, braces) {\n  var numLinesEst = 0;\n  var length = output.reduce(function(prev, cur) {\n    numLinesEst++;\n    if (cur.indexOf('\\n') >= 0) numLinesEst++;\n    return prev + cur.replace(/\\u001b\\[\\d\\d?m/g, '').length + 1;\n  }, 0);\n\n  if (length > 60) {\n    return braces[0] +\n           (base === '' ? '' : base + '\\n ') +\n           ' ' +\n           output.join(',\\n  ') +\n           ' ' +\n           braces[1];\n  }\n\n  return braces[0] + base + ' ' + output.join(', ') + ' ' + braces[1];\n}\n\n\n// NOTE: These type checking functions intentionally don't use `instanceof`\n// because it is fragile and can be easily faked with `Object.create()`.\nfunction isArray(ar) {\n  return Array.isArray(ar);\n}\nexports.isArray = isArray;\n\nfunction isBoolean(arg) {\n  return typeof arg === 'boolean';\n}\nexports.isBoolean = isBoolean;\n\nfunction isNull(arg) {\n  return arg === null;\n}\nexports.isNull = isNull;\n\nfunction isNullOrUndefined(arg) {\n  return arg == null;\n}\nexports.isNullOrUndefined = isNullOrUndefined;\n\nfunction isNumber(arg) {\n  return typeof arg === 'number';\n}\nexports.isNumber = isNumber;\n\nfunction isString(arg) {\n  return typeof arg === 'string';\n}\nexports.isString = isString;\n\nfunction isSymbol(arg) {\n  return typeof arg === 'symbol';\n}\nexports.isSymbol = isSymbol;\n\nfunction isUndefined(arg) {\n  return arg === void 0;\n}\nexports.isUndefined = isUndefined;\n\nfunction isRegExp(re) {\n  return isObject(re) && objectToString(re) === '[object RegExp]';\n}\nexports.isRegExp = isRegExp;\n\nfunction isObject(arg) {\n  return typeof arg === 'object' && arg !== null;\n}\nexports.isObject = isObject;\n\nfunction isDate(d) {\n  return isObject(d) && objectToString(d) === '[object Date]';\n}\nexports.isDate = isDate;\n\nfunction isError(e) {\n  return isObject(e) &&\n      (objectToString(e) === '[object Error]' || e instanceof Error);\n}\nexports.isError = isError;\n\nfunction isFunction(arg) {\n  return typeof arg === 'function';\n}\nexports.isFunction = isFunction;\n\nfunction isPrimitive(arg) {\n  return arg === null ||\n         typeof arg === 'boolean' ||\n         typeof arg === 'number' ||\n         typeof arg === 'string' ||\n         typeof arg === 'symbol' ||  // ES6 symbol\n         typeof arg === 'undefined';\n}\nexports.isPrimitive = isPrimitive;\n\nexports.isBuffer = require('./support/isBuffer');\n\nfunction objectToString(o) {\n  return Object.prototype.toString.call(o);\n}\n\n\nfunction pad(n) {\n  return n < 10 ? '0' + n.toString(10) : n.toString(10);\n}\n\n\nvar months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep',\n              'Oct', 'Nov', 'Dec'];\n\n// 26 Feb 16:19:34\nfunction timestamp() {\n  var d = new Date();\n  var time = [pad(d.getHours()),\n              pad(d.getMinutes()),\n              pad(d.getSeconds())].join(':');\n  return [d.getDate(), months[d.getMonth()], time].join(' ');\n}\n\n\n// log is just a thin wrapper to console.log that prepends a timestamp\nexports.log = function() {\n  console.log('%s - %s', timestamp(), exports.format.apply(exports, arguments));\n};\n\n\n/**\n * Inherit the prototype methods from one constructor into another.\n *\n * The Function.prototype.inherits from lang.js rewritten as a standalone\n * function (not on Function.prototype). NOTE: If this file is to be loaded\n * during bootstrapping this function needs to be rewritten using some native\n * functions as prototype setup using normal JavaScript does not work as\n * expected during bootstrapping (see mirror.js in r114903).\n *\n * @param {function} ctor Constructor function which needs to inherit the\n *     prototype.\n * @param {function} superCtor Constructor function to inherit prototype from.\n */\nexports.inherits = require('inherits');\n\nexports._extend = function(origin, add) {\n  // Don't do anything if add isn't an object\n  if (!add || !isObject(add)) return origin;\n\n  var keys = Object.keys(add);\n  var i = keys.length;\n  while (i--) {\n    origin[keys[i]] = add[keys[i]];\n  }\n  return origin;\n};\n\nfunction hasOwnProperty(obj, prop) {\n  return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n","/**\n * @author Titus Wormer\n * @copyright 2015 Titus Wormer\n * @license MIT\n * @module vfile\n * @fileoverview Virtual file format to attach additional\n *   information related to processed input.  Similar to\n *   `wearefractal/vinyl`.  Additionally, `VFile` can be\n *   passed directly to ESLint formatters to visualise\n *   warnings and errors relating to a file.\n * @example\n *   var VFile = require('vfile');\n *\n *   var file = new VFile({\n *     'directory': '~',\n *     'filename': 'example',\n *     'extension': 'txt',\n *     'contents': 'Foo *bar* baz'\n *   });\n *\n *   file.toString(); // 'Foo *bar* baz'\n *   file.filePath(); // '~/example.txt'\n *\n *   file.move({'extension': 'md'});\n *   file.filePath(); // '~/example.md'\n *\n *   file.warn('Something went wrong', {'line': 2, 'column': 3});\n *   // { [~/example.md:2:3: Something went wrong]\n *   //   name: '~/example.md:2:3',\n *   //   file: '~/example.md',\n *   //   reason: 'Something went wrong',\n *   //   line: 2,\n *   //   column: 3,\n *   //   fatal: false }\n */\n\n'use strict';\n\n/* eslint-env commonjs */\n\nvar SEPARATOR = '/';\n\ntry {\n    SEPARATOR = require('pa' + 'th').sep;\n} catch (e) { /* empty */ }\n\n/**\n * Construct a new file message.\n *\n * Note: We cannot invoke `Error` on the created context,\n * as that adds readonly `line` and `column` attributes on\n * Safari 9, thus throwing and failing the data.\n *\n * @example\n *   var message = new VFileMessage('Whoops!');\n *\n *   message instanceof Error // true\n *\n * @constructor\n * @class {VFileMessage}\n * @param {string} reason - Reason for messaging.\n * @property {boolean} [fatal=null] - Whether the message\n *   is fatal.\n * @property {string} [name=''] - File-name and positional\n *   information.\n * @property {string} [file=''] - File-path.\n * @property {string} [reason=''] - Reason for messaging.\n * @property {number} [line=null] - Start of message.\n * @property {number} [column=null] - Start of message.\n * @property {Position|Location} [location=null] - Place of\n *   message.\n * @property {string} [stack] - Stack-trace of warning.\n */\nfunction VFileMessage(reason) {\n    this.message = reason;\n}\n\n/**\n * Inherit from `Error#`.\n */\nfunction VFileMessagePrototype() {}\n\nVFileMessagePrototype.prototype = Error.prototype;\n\nvar proto = new VFileMessagePrototype();\n\nVFileMessage.prototype = proto;\n\n/*\n * Expose defaults.\n */\n\nproto.file = proto.name = proto.reason = proto.message = proto.stack = '';\nproto.fatal = proto.column = proto.line = null;\n\n/**\n * File-related message with location information.\n *\n * @typedef {Error} VFileMessage\n * @property {string} name - (Starting) location of the\n *   message, preceded by its file-path when available,\n *   and joined by `:`. Used internally by the native\n *   `Error#toString()`.\n * @property {string} file - File-path.\n * @property {string} reason - Reason for message.\n * @property {number?} line - Line of message, when\n *   available.\n * @property {number?} column - Column of message, when\n *   available.\n * @property {string?} stack - Stack of message, when\n *   available.\n * @property {boolean?} fatal - Whether the associated file\n *   is still processable.\n */\n\n/**\n * Stringify a position.\n *\n * @example\n *   stringify({'line': 1, 'column': 3}) // '1:3'\n *   stringify({'line': 1}) // '1:1'\n *   stringify({'column': 3}) // '1:3'\n *   stringify() // '1:1'\n *\n * @private\n * @param {Object?} [position] - Single position, like\n *   those available at `node.position.start`.\n * @return {string} - Compiled location.\n */\nfunction stringify(position) {\n    if (!position) {\n        position = {};\n    }\n\n    return (position.line || 1) + ':' + (position.column || 1);\n}\n\n/**\n * ESLint's formatter API expects `filePath` to be a\n * string.  This hack supports invocation as well as\n * implicit coercion.\n *\n * @example\n *   var file = new VFile({\n *     'filename': 'example',\n *     'extension': 'txt'\n *   });\n *\n *   filePath = filePathFactory(file);\n *\n *   String(filePath); // 'example.txt'\n *   filePath(); // 'example.txt'\n *\n * @private\n * @param {VFile} file - Virtual file.\n * @return {Function} - `filePath` getter.\n */\nfunction filePathFactory(file) {\n    /**\n     * Get the filename, with extension and directory, if applicable.\n     *\n     * @example\n     *   var file = new VFile({\n     *     'directory': '~',\n     *     'filename': 'example',\n     *     'extension': 'txt'\n     *   });\n     *\n     *   String(file.filePath); // ~/example.txt\n     *   file.filePath() // ~/example.txt\n     *\n     * @memberof {VFile}\n     * @property {Function} toString - Itself. ESLint's\n     *   formatter API expects `filePath` to be `string`.\n     *   This hack supports invocation as well as implicit\n     *   coercion.\n     * @return {string} - If the `vFile` has a `filename`,\n     *   it will be prefixed with the directory (slashed),\n     *   if applicable, and suffixed with the (dotted)\n     *   extension (if applicable).  Otherwise, an empty\n     *   string is returned.\n     */\n    function filePath() {\n        var directory = file.directory;\n        var separator;\n\n        if (file.filename || file.extension) {\n            separator = directory.charAt(directory.length - 1);\n\n            if (separator === '/' || separator === '\\\\') {\n                directory = directory.slice(0, -1);\n            }\n\n            if (directory === '.') {\n                directory = '';\n            }\n\n            return (directory ? directory + SEPARATOR : '') +\n                file.filename +\n                (file.extension ? '.' + file.extension : '');\n        }\n\n        return '';\n    }\n\n    filePath.toString = filePath;\n\n    return filePath;\n}\n\n/**\n* Get the filename with extantion.\n*\n* @example\n*   var file = new VFile({\n*     'directory': '~/foo/bar'\n*     'filename': 'example',\n*     'extension': 'txt'\n*   });\n*\n*   file.basename() // example.txt\n*\n* @memberof {VFile}\n* @return {string} - name of file with extantion.\n*/\nfunction basename() {\n    var self = this;\n    var extension = self.extension;\n\n    if (self.filename || extension) {\n        return self.filename + (extension ? '.' + extension : '');\n    }\n\n    return '';\n}\n\n/**\n * Construct a new file.\n *\n * @example\n *   var file = new VFile({\n *     'directory': '~',\n *     'filename': 'example',\n *     'extension': 'txt',\n *     'contents': 'Foo *bar* baz'\n *   });\n *\n *   file === VFile(file) // true\n *   file === new VFile(file) // true\n *   VFile('foo') instanceof VFile // true\n *\n * @constructor\n * @class {VFile}\n * @param {Object|VFile|string} [options] - either an\n *   options object, or the value of `contents` (both\n *   optional).  When a `file` is passed in, it's\n *   immediately returned.\n * @property {string} [contents=''] - Content of file.\n * @property {string} [directory=''] - Path to parent\n *   directory.\n * @property {string} [filename=''] - Filename.\n *   A file-path can still be generated when no filename\n *   exists.\n * @property {string} [extension=''] - Extension.\n *   A file-path can still be generated when no extension\n *   exists.\n * @property {boolean?} quiet - Whether an error created by\n *   `VFile#fail()` is returned (when truthy) or thrown\n *   (when falsey). Ensure all `messages` associated with\n *   a file are handled properly when setting this to\n *   `true`.\n * @property {Array.<VFileMessage>} messages - List of associated\n *   messages.\n */\nfunction VFile(options) {\n    var self = this;\n\n    /*\n     * No `new` operator.\n     */\n\n    if (!(self instanceof VFile)) {\n        return new VFile(options);\n    }\n\n    /*\n     * Given file.\n     */\n\n    if (\n        options &&\n        typeof options.message === 'function' &&\n        typeof options.hasFailed === 'function'\n    ) {\n        return options;\n    }\n\n    if (!options) {\n        options = {};\n    } else if (typeof options === 'string') {\n        options = {\n            'contents': options\n        };\n    }\n\n    self.contents = options.contents || '';\n\n    self.messages = [];\n\n    /*\n     * Make sure eslint’s formatters stringify `filePath`\n     * properly.\n     */\n\n    self.filePath = filePathFactory(self);\n\n    self.history = [];\n\n    self.move({\n        'filename': options.filename,\n        'directory': options.directory,\n        'extension': options.extension\n    });\n}\n\n/**\n * Get the value of the file.\n *\n * @example\n *   var vFile = new VFile('Foo');\n *   String(vFile); // 'Foo'\n *\n * @this {VFile}\n * @memberof {VFile}\n * @return {string} - value at the `contents` property\n *   in context.\n */\nfunction toString() {\n    return this.contents;\n}\n\n/**\n * Move a file by passing a new directory, filename,\n * and extension.  When these are not given, the default\n * values are kept.\n *\n * @example\n *   var file = new VFile({\n *     'directory': '~',\n *     'filename': 'example',\n *     'extension': 'txt',\n *     'contents': 'Foo *bar* baz'\n *   });\n *\n *   file.move({'directory': '/var/www'});\n *   file.filePath(); // '/var/www/example.txt'\n *\n *   file.move({'extension': 'md'});\n *   file.filePath(); // '/var/www/example.md'\n *\n * @this {VFile}\n * @memberof {VFile}\n * @param {Object?} [options] - Configuration.\n * @return {VFile} - Context object.\n */\nfunction move(options) {\n    var self = this;\n    var before = self.filePath();\n    var after;\n\n    if (!options) {\n        options = {};\n    }\n\n    self.directory = options.directory || self.directory || '';\n    self.filename = options.filename || self.filename || '';\n    self.extension = options.extension || self.extension || '';\n\n    after = self.filePath();\n\n    if (after && before !== after) {\n        self.history.push(after);\n    }\n\n    return self;\n}\n\n/**\n * Create a message with `reason` at `position`.\n * When an error is passed in as `reason`, copies the\n * stack.  This does not add a message to `messages`.\n *\n * @example\n *   var file = new VFile();\n *\n *   file.message('Something went wrong');\n *   // { [1:1: Something went wrong]\n *   //   name: '1:1',\n *   //   file: '',\n *   //   reason: 'Something went wrong',\n *   //   line: null,\n *   //   column: null }\n *\n * @this {VFile}\n * @memberof {VFile}\n * @param {string|Error} reason - Reason for message.\n * @param {Node|Location|Position} [position] - Location\n *   of message in file.\n * @return {VFileMessage} - File-related message with\n *   location information.\n */\nfunction message(reason, position) {\n    var filePath = this.filePath();\n    var range;\n    var err;\n    var location = {\n        'start': {\n            'line': null,\n            'column': null\n        },\n        'end': {\n            'line': null,\n            'column': null\n        }\n    };\n\n    /*\n     * Node / location / position.\n     */\n\n    if (position && position.position) {\n        position = position.position;\n    }\n\n    if (position && position.start) {\n        range = stringify(position.start) + '-' + stringify(position.end);\n        location = position;\n        position = position.start;\n    } else {\n        range = stringify(position);\n\n        if (position) {\n            location.start = position;\n            location.end.line = null;\n            location.end.column = null;\n        }\n    }\n\n    err = new VFileMessage(reason.message || reason);\n\n    err.name = (filePath ? filePath + ':' : '') + range;\n    err.file = filePath;\n    err.reason = reason.message || reason;\n    err.line = position ? position.line : null;\n    err.column = position ? position.column : null;\n    err.location = location;\n\n    if (reason.stack) {\n        err.stack = reason.stack;\n    }\n\n    return err;\n}\n\n/**\n * Warn. Creates a non-fatal message (see `VFile#message()`),\n * and adds it to the file's `messages` list.\n *\n * @example\n *   var file = new VFile();\n *\n *   file.warn('Something went wrong');\n *   // { [1:1: Something went wrong]\n *   //   name: '1:1',\n *   //   file: '',\n *   //   reason: 'Something went wrong',\n *   //   line: null,\n *   //   column: null,\n *   //   fatal: false }\n *\n * @see VFile#message\n * @this {VFile}\n * @memberof {VFile}\n */\nfunction warn() {\n    var err = this.message.apply(this, arguments);\n\n    err.fatal = false;\n\n    this.messages.push(err);\n\n    return err;\n}\n\n/**\n * Fail. Creates a fatal message (see `VFile#message()`),\n * sets `fatal: true`, adds it to the file's\n * `messages` list.\n *\n * If `quiet` is not `true`, throws the error.\n *\n * @example\n *   var file = new VFile();\n *\n *   file.fail('Something went wrong');\n *   // 1:1: Something went wrong\n *   //     at VFile.exception (vfile/index.js:296:11)\n *   //     at VFile.fail (vfile/index.js:360:20)\n *   //     at repl:1:6\n *\n *   file.quiet = true;\n *   file.fail('Something went wrong');\n *   // { [1:1: Something went wrong]\n *   //   name: '1:1',\n *   //   file: '',\n *   //   reason: 'Something went wrong',\n *   //   line: null,\n *   //   column: null,\n *   //   fatal: true }\n *\n * @this {VFile}\n * @memberof {VFile}\n * @throws {VFileMessage} - When not `quiet: true`.\n * @param {string|Error} reason - Reason for failure.\n * @param {Node|Location|Position} [position] - Place\n *   of failure in file.\n * @return {VFileMessage} - Unless thrown, of course.\n */\nfunction fail(reason, position) {\n    var err = this.message(reason, position);\n\n    err.fatal = true;\n\n    this.messages.push(err);\n\n    if (!this.quiet) {\n        throw err;\n    }\n\n    return err;\n}\n\n/**\n * Check if a fatal message occurred making the file no\n * longer processable.\n *\n * @example\n *   var file = new VFile();\n *   file.quiet = true;\n *\n *   file.hasFailed(); // false\n *\n *   file.fail('Something went wrong');\n *   file.hasFailed(); // true\n *\n * @this {VFile}\n * @memberof {VFile}\n * @return {boolean} - `true` if at least one of file's\n *   `messages` has a `fatal` property set to `true`\n */\nfunction hasFailed() {\n    var messages = this.messages;\n    var index = -1;\n    var length = messages.length;\n\n    while (++index < length) {\n        if (messages[index].fatal) {\n            return true;\n        }\n    }\n\n    return false;\n}\n\n/**\n * Access metadata.\n *\n * @example\n *   var file = new VFile('Foo');\n *\n *   file.namespace('foo').bar = 'baz';\n *\n *   console.log(file.namespace('foo').bar) // 'baz';\n *\n * @this {VFile}\n * @memberof {VFile}\n * @param {string} key - Namespace key.\n * @return {Object} - Private space.\n */\nfunction namespace(key) {\n    var self = this;\n    var space = self.data;\n\n    if (!space) {\n        space = self.data = {};\n    }\n\n    if (!space[key]) {\n        space[key] = {};\n    }\n\n    return space[key];\n}\n\n/*\n * Methods.\n */\n\nvar vFilePrototype = VFile.prototype;\n\nvFilePrototype.basename = basename;\nvFilePrototype.move = move;\nvFilePrototype.toString = toString;\nvFilePrototype.message = message;\nvFilePrototype.warn = warn;\nvFilePrototype.fail = fail;\nvFilePrototype.hasFailed = hasFailed;\nvFilePrototype.namespace = namespace;\n\n/*\n * Expose.\n */\n\nmodule.exports = VFile;\n","var indexOf = require('indexof');\n\nvar Object_keys = function (obj) {\n    if (Object.keys) return Object.keys(obj)\n    else {\n        var res = [];\n        for (var key in obj) res.push(key)\n        return res;\n    }\n};\n\nvar forEach = function (xs, fn) {\n    if (xs.forEach) return xs.forEach(fn)\n    else for (var i = 0; i < xs.length; i++) {\n        fn(xs[i], i, xs);\n    }\n};\n\nvar defineProp = (function() {\n    try {\n        Object.defineProperty({}, '_', {});\n        return function(obj, name, value) {\n            Object.defineProperty(obj, name, {\n                writable: true,\n                enumerable: false,\n                configurable: true,\n                value: value\n            })\n        };\n    } catch(e) {\n        return function(obj, name, value) {\n            obj[name] = value;\n        };\n    }\n}());\n\nvar globals = ['Array', 'Boolean', 'Date', 'Error', 'EvalError', 'Function',\n'Infinity', 'JSON', 'Math', 'NaN', 'Number', 'Object', 'RangeError',\n'ReferenceError', 'RegExp', 'String', 'SyntaxError', 'TypeError', 'URIError',\n'decodeURI', 'decodeURIComponent', 'encodeURI', 'encodeURIComponent', 'escape',\n'eval', 'isFinite', 'isNaN', 'parseFloat', 'parseInt', 'undefined', 'unescape'];\n\nfunction Context() {}\nContext.prototype = {};\n\nvar Script = exports.Script = function NodeScript (code) {\n    if (!(this instanceof Script)) return new Script(code);\n    this.code = code;\n};\n\nScript.prototype.runInContext = function (context) {\n    if (!(context instanceof Context)) {\n        throw new TypeError(\"needs a 'context' argument.\");\n    }\n    \n    var iframe = document.createElement('iframe');\n    if (!iframe.style) iframe.style = {};\n    iframe.style.display = 'none';\n    \n    document.body.appendChild(iframe);\n    \n    var win = iframe.contentWindow;\n    var wEval = win.eval, wExecScript = win.execScript;\n\n    if (!wEval && wExecScript) {\n        // win.eval() magically appears when this is called in IE:\n        wExecScript.call(win, 'null');\n        wEval = win.eval;\n    }\n    \n    forEach(Object_keys(context), function (key) {\n        win[key] = context[key];\n    });\n    forEach(globals, function (key) {\n        if (context[key]) {\n            win[key] = context[key];\n        }\n    });\n    \n    var winKeys = Object_keys(win);\n\n    var res = wEval.call(win, this.code);\n    \n    forEach(Object_keys(win), function (key) {\n        // Avoid copying circular objects like `top` and `window` by only\n        // updating existing context properties or new properties in the `win`\n        // that was only introduced after the eval.\n        if (key in context || indexOf(winKeys, key) === -1) {\n            context[key] = win[key];\n        }\n    });\n\n    forEach(globals, function (key) {\n        if (!(key in context)) {\n            defineProp(context, key, win[key]);\n        }\n    });\n    \n    document.body.removeChild(iframe);\n    \n    return res;\n};\n\nScript.prototype.runInThisContext = function () {\n    return eval(this.code); // maybe...\n};\n\nScript.prototype.runInNewContext = function (context) {\n    var ctx = Script.createContext(context);\n    var res = this.runInContext(ctx);\n\n    forEach(Object_keys(ctx), function (key) {\n        context[key] = ctx[key];\n    });\n\n    return res;\n};\n\nforEach(Object_keys(Script.prototype), function (name) {\n    exports[name] = Script[name] = function (code) {\n        var s = Script(code);\n        return s[name].apply(s, [].slice.call(arguments, 1));\n    };\n});\n\nexports.createScript = function (code) {\n    return exports.Script(code);\n};\n\nexports.createContext = Script.createContext = function (context) {\n    var copy = new Context();\n    if(typeof context === 'object') {\n        forEach(Object_keys(context), function (key) {\n            copy[key] = context[key];\n        });\n    }\n    return copy;\n};\n","/**\n * Module Dependencies\n */\n\nvar slice = [].slice;\nvar wrap = require('wrap-fn');\n\n/**\n * Expose `Ware`.\n */\n\nmodule.exports = Ware;\n\n/**\n * Throw an error.\n *\n * @param {Error} error\n */\n\nfunction fail (err) {\n  throw err;\n}\n\n/**\n * Initialize a new `Ware` manager, with optional `fns`.\n *\n * @param {Function or Array or Ware} fn (optional)\n */\n\nfunction Ware (fn) {\n  if (!(this instanceof Ware)) return new Ware(fn);\n  this.fns = [];\n  if (fn) this.use(fn);\n}\n\n/**\n * Use a middleware `fn`.\n *\n * @param {Function or Array or Ware} fn\n * @return {Ware}\n */\n\nWare.prototype.use = function (fn) {\n  if (fn instanceof Ware) {\n    return this.use(fn.fns);\n  }\n\n  if (fn instanceof Array) {\n    for (var i = 0, f; f = fn[i++];) this.use(f);\n    return this;\n  }\n\n  this.fns.push(fn);\n  return this;\n};\n\n/**\n * Run through the middleware with the given `args` and optional `callback`.\n *\n * @param {Mixed} args...\n * @param {Function} callback (optional)\n * @return {Ware}\n */\n\nWare.prototype.run = function () {\n  var fns = this.fns;\n  var ctx = this;\n  var i = 0;\n  var last = arguments[arguments.length - 1];\n  var done = 'function' == typeof last && last;\n  var args = done\n    ? slice.call(arguments, 0, arguments.length - 1)\n    : slice.call(arguments);\n\n  // next step\n  function next (err) {\n    if (err) return (done || fail)(err);\n    var fn = fns[i++];\n    var arr = slice.call(args);\n\n    if (!fn) {\n      return done && done.apply(null, [null].concat(args));\n    }\n\n    wrap(fn, next).apply(ctx, arr);\n  }\n\n  next();\n\n  return this;\n};\n","/**\n * Module Dependencies\n */\n\nvar noop = function(){};\nvar co = require('co');\n\n/**\n * Export `wrap-fn`\n */\n\nmodule.exports = wrap;\n\n/**\n * Wrap a function to support\n * sync, async, and gen functions.\n *\n * @param {Function} fn\n * @param {Function} done\n * @return {Function}\n * @api public\n */\n\nfunction wrap(fn, done) {\n  done = once(done || noop);\n\n  return function() {\n    // prevents arguments leakage\n    // see https://github.com/petkaantonov/bluebird/wiki/Optimization-killers#3-managing-arguments\n    var i = arguments.length;\n    var args = new Array(i);\n    while (i--) args[i] = arguments[i];\n\n    var ctx = this;\n\n    // done\n    if (!fn) {\n      return done.apply(ctx, [null].concat(args));\n    }\n\n    // async\n    if (fn.length > args.length) {\n      // NOTE: this only handles uncaught synchronous errors\n      try {\n        return fn.apply(ctx, args.concat(done));\n      } catch (e) {\n        return done(e);\n      }\n    }\n\n    // generator\n    if (generator(fn)) {\n      return co(fn).apply(ctx, args.concat(done));\n    }\n\n    // sync\n    return sync(fn, done).apply(ctx, args);\n  }\n}\n\n/**\n * Wrap a synchronous function execution.\n *\n * @param {Function} fn\n * @param {Function} done\n * @return {Function}\n * @api private\n */\n\nfunction sync(fn, done) {\n  return function () {\n    var ret;\n\n    try {\n      ret = fn.apply(this, arguments);\n    } catch (err) {\n      return done(err);\n    }\n\n    if (promise(ret)) {\n      ret.then(function (value) { done(null, value); }, done);\n    } else {\n      ret instanceof Error ? done(ret) : done(null, ret);\n    }\n  }\n}\n\n/**\n * Is `value` a generator?\n *\n * @param {Mixed} value\n * @return {Boolean}\n * @api private\n */\n\nfunction generator(value) {\n  return value\n    && value.constructor\n    && 'GeneratorFunction' == value.constructor.name;\n}\n\n\n/**\n * Is `value` a promise?\n *\n * @param {Mixed} value\n * @return {Boolean}\n * @api private\n */\n\nfunction promise(value) {\n  return value && 'function' == typeof value.then;\n}\n\n/**\n * Once\n */\n\nfunction once(fn) {\n  return function() {\n    var ret = fn.apply(this, arguments);\n    fn = noop;\n    return ret;\n  };\n}\n","// Returns a wrapper function that returns a wrapped callback\n// The wrapper function should do some stuff, and return a\n// presumably different callback function.\n// This makes sure that own properties are retained, so that\n// decorations and such are not lost along the way.\nmodule.exports = wrappy\nfunction wrappy (fn, cb) {\n  if (fn && cb) return wrappy(fn)(cb)\n\n  if (typeof fn !== 'function')\n    throw new TypeError('need wrapper function')\n\n  Object.keys(fn).forEach(function (k) {\n    wrapper[k] = fn[k]\n  })\n\n  return wrapper\n\n  function wrapper() {\n    var args = new Array(arguments.length)\n    for (var i = 0; i < args.length; i++) {\n      args[i] = arguments[i]\n    }\n    var ret = fn.apply(this, args)\n    var cb = args[args.length-1]\n    if (typeof ret === 'function' && ret !== cb) {\n      Object.keys(cb).forEach(function (k) {\n        ret[k] = cb[k]\n      })\n    }\n    return ret\n  }\n}\n","\n/**\n * Module dependencies.\n */\n\nvar global = (function() { return this; })();\n\n/**\n * WebSocket constructor.\n */\n\nvar WebSocket = global.WebSocket || global.MozWebSocket;\n\n/**\n * Module exports.\n */\n\nmodule.exports = WebSocket ? ws : null;\n\n/**\n * WebSocket constructor.\n *\n * The third `opts` options object gets ignored in web browsers, since it's\n * non-standard, and throws a TypeError if passed to the constructor.\n * See: https://github.com/einaros/ws/issues/227\n *\n * @param {String} uri\n * @param {Array} protocols (optional)\n * @param {Object) opts (optional)\n * @api public\n */\n\nfunction ws(uri, protocols, opts) {\n  var instance;\n  if (protocols) {\n    instance = new WebSocket(uri, protocols);\n  } else {\n    instance = new WebSocket(uri);\n  }\n  return instance;\n}\n\nif (WebSocket) ws.prototype = WebSocket.prototype;\n","\nmodule.exports = function zerr (name, msgTemplate) {\n  // make sure the name ends with the word Error\n  if (name.slice(-5) != 'Error')\n    name += 'Error'\n\n  function ZError () {\n    // call as a class constructor if called as a function\n    if (!(this instanceof ZError)) {\n      // a bit tricker than usual, because we have to combine `apply()` with the `new` form...\n      function ZE (args) { return ZError.apply(this, args) }\n      ZE.prototype = ZError.prototype;\n      return new ZE(arguments)\n    }\n\n    Error.call(this)\n    Error.captureStackTrace(this, arguments.callee)\n    this.name = name\n\n    // if an error was passed, shift it out of the args\n    var parentErr\n    var args = Array.prototype.slice.call(arguments)\n    if (args[0] instanceof Error)\n      parentErr = args.shift()\n\n    // create message\n    if (msgTemplate)\n      this.message = interp(msgTemplate, args)\n    else if (typeof args[0] == 'string')\n      this.message = args[0]\n\n    // modify stack to show parent error\n    if (parentErr) {\n      var stack = removePrefix(getStack(this), getStack(parentErr)).join('\\n')\n      this.stack =\n        this.name + ': ' + this.message + '\\n' +\n        stack + '\\n  ' + parentErr.stack\n    }\n  }\n  ZError.prototype = Object.create(Error.prototype)\n  return ZError\n}\n\n// interpolate function\n// - takes a template string and a list of strings to insert\n// - replaces '%' token in tmpl using values in `args`\n// eg interp('hello %, how are you % today?', ['bob', 'doing']) => 'hello bob, how are you doing today?'\n// eg interp('hello %, how are you % today?', ['bob']) => 'hello bob, how are you  today?'\nvar re = /%/g\nfunction interp (tmpl, args) {\n  var n = 0\n  return tmpl.replace(re, function () { return args[n++] || '' })\n}\n\n\nfunction getStack(err) {\n  return err.stack.substring(err.name.length + 3 + err.message.length)\n    .split('\\n')\n}\n\nfunction removePrefix (a, b) {\n  return a.filter(function (e) {\n    return !~b.indexOf(e)\n  })\n}","var ssbKeys      = require('ssb-keys')\nvar config       = require('ssb-config/inject')(process.env.ssb_appname)\nvar fs           = require('fs')\nvar path         = require('path')\nvar manifestFile = path.join(__dirname, 'manifest.json')\nvar pull = require('pull-stream')\nvar Serializer = require('pull-serializer')\n\nvar keys = ssbKeys.loadOrCreateSync(path.join(config.path, 'secret'))\n\nvar createSbot = require('scuttlebot')\n  .use(require('scuttlebot/plugins/master'))\n  .use(require('scuttlebot/plugins/gossip'))\n  .use(require('scuttlebot/plugins/friends'))\n  .use(require('scuttlebot/plugins/replicate'))\n  .use(require('scuttlebot/plugins/blobs'))\n  .use(require('scuttlebot/plugins/invite'))\n  .use(require('scuttlebot/plugins/block'))\n  .use(require('scuttlebot/plugins/local'))\n  .use(require('scuttlebot/plugins/logging'))\n  .use(require('scuttlebot/plugins/private'))\n  .use(require('ssb-links'))\n  .use(require('ssb-query'))\n  .use(require('ssb-http'))\n\nconfig.keys = keys\nvar sbot = createSbot(config)\nfs.writeFileSync(manifestFile, JSON.stringify(sbot.getManifest(), null, 2))\n\n\nvar http = require('http')\nvar WS = require('pull-ws-server')\nvar MuxRpc = require('muxrpc')\nvar server = http.createServer(function (req, res) {\n    fs.createReadStream(path.join(__dirname, 'static', 'index.html')).pipe(res)\n  }).listen(8000)\n\nWS.createServer({server: server}, function (ws) {\n  console.log('RPC connection')\n  var rpc = MuxRpc(sbot.getManifest(), sbot.getManifest(), Serializer)\n    (sbot)\n\n  pull(ws, pull.through(console.log), rpc.createStream(), pull.through(console.log), ws)\n})\n\n"]}